The beginning of 0.9.5

- Remove unused stuff
- Start Moving from c stuff to c++ stuff Like mkdir to filesystem
- Remove usless stuff from config
- Begin with Project Li7
This commit is contained in:
tobid7 2023-08-28 16:33:16 +02:00
parent 5695110739
commit 5cca34ede4
47 changed files with 88 additions and 37949 deletions

View File

@ -32,10 +32,27 @@ Example-App
└── src
└── main.cpp
```
# Back to Old Usage aka Submodule (0.9.5+)
If you want to use RenderD7 as Submodule run
`git submodule add https://github.com/NPI-D7/RenderD7`
And to Use Add this to make file
```
# Make Sure to Change this paths if your Submodule
# is located somewhere else
RENDERD7_SRC := RenderD7/source RenderD7/external
RENDERD7_INC := RenderD7/include
```
Now you need to add it to your sources and includes
```
SOURCES := source $(RENDERD7_SRC)
INCLUDES := source $(RENDERD7_INC)
```
Example from rd7tf
# Credits
- NPI-D7
- Tobi-D7 Main Dev
Some Icons are From
https://icons8.de/
See Subfolder Readmes
See Subfolder Readmes

View File

@ -23,9 +23,6 @@ do
../../tools/bin/file2array "${file}" "${name}"
done
echo "Convert Npi-Intro to C++ Code"
../../tools/bin/file2array ../splash/npi_intro.nvid npi_intro
echo "Fix The Output of file2array"
for file in ./*.cpp
do

View File

@ -1,2 +0,0 @@
# Source
https://icons8.de/

Binary file not shown.

Before

Width:  |  Height:  |  Size: 900 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 739 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 388 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 394 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 437 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 445 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 440 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 447 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 638 B

View File

@ -1,11 +0,0 @@
--atlas -f rgba -z auto
battery/battery_full.png
battery/battery_nearfull.png
battery/battery_half.png
battery/battery_low.png
battery/battery_verylow.png
battery/battery_warning.png
battery/battery_charging.png
battery/battery_empty.png
battery/battery_dead.png

View File

@ -1,19 +0,0 @@
--atlas -f rgba -z auto
ui_elements/high_volume.png
ui_elements/mid_volume.png
ui_elements/low_volume.png
ui_elements/speaker_v1.png
ui_elements/no_sound.png
ui_elements/speaker.png
ui_elements/wifi_connected.png
ui_elements/wifi_disconnected.png
ui_elements/wifi_off.png
ui_elements/good_connection.png
ui_elements/mid_connection.png
ui_elements/bad_connection.png
ui_elements/no_connection.png
ui_elements/headphones.png

View File

@ -1,2 +0,0 @@
# Source
https://icons8.de/

Binary file not shown.

Before

Width:  |  Height:  |  Size: 392 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 418 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.3 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.4 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 964 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 400 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.1 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 380 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.6 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.4 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 681 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.6 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.7 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.3 KiB

Binary file not shown.

Binary file not shown.

3185
external/source/jpgd.cpp vendored

File diff suppressed because it is too large Load Diff

1246
external/source/jpge.cpp vendored

File diff suppressed because it is too large Load Diff

View File

@ -1,5 +0,0 @@
#pragma once
#include <cstddef>
extern unsigned char battery_icons[];
extern size_t battery_icons_size;

View File

@ -1,422 +0,0 @@
// jpgd.h - C++ class for JPEG decompression.
// Richard Geldreich <richgel99@gmail.com>
// See jpgd.cpp for license (Public Domain or Apache 2.0).
#ifndef JPEG_DECODER_H
#define JPEG_DECODER_H
#include <assert.h>
#include <cinttypes>
#include <setjmp.h>
#include <stdint.h>
#include <stdio.h>
#include <stdlib.h>
#ifdef _MSC_VER
#define JPGD_NORETURN __declspec(noreturn)
#elif defined(__GNUC__)
#define JPGD_NORETURN __attribute__((noreturn))
#else
#define JPGD_NORETURN
#endif
#define JPGD_HUFF_TREE_MAX_LENGTH 512
#define JPGD_HUFF_CODE_SIZE_MAX_LENGTH 256
namespace jpgd {
typedef unsigned char uint8;
typedef signed short int16;
typedef unsigned short uint16;
typedef unsigned int uint;
typedef signed int int32;
// Loads a JPEG image from a memory buffer or a file.
// req_comps can be 1 (grayscale), 3 (RGB), or 4 (RGBA).
// On return, width/height will be set to the image's dimensions, and
// actual_comps will be set to the either 1 (grayscale) or 3 (RGB). Notes: For
// more control over where and how the source data is read, see the
// decompress_jpeg_image_from_stream() function below, or call the jpeg_decoder
// class directly. Requesting a 8 or 32bpp image is currently a little faster
// than 24bpp because the jpeg_decoder class itself currently always unpacks to
// either 8 or 32bpp.
unsigned char *decompress_jpeg_image_from_memory(const unsigned char *pSrc_data,
int src_data_size, int *width,
int *height, int *actual_comps,
int req_comps,
uint32_t flags = 0);
unsigned char *decompress_jpeg_image_from_file(const char *pSrc_filename,
int *width, int *height,
int *actual_comps, int req_comps,
uint32_t flags = 0);
// Success/failure error codes.
enum jpgd_status {
JPGD_SUCCESS = 0,
JPGD_FAILED = -1,
JPGD_DONE = 1,
JPGD_BAD_DHT_COUNTS = -256,
JPGD_BAD_DHT_INDEX,
JPGD_BAD_DHT_MARKER,
JPGD_BAD_DQT_MARKER,
JPGD_BAD_DQT_TABLE,
JPGD_BAD_PRECISION,
JPGD_BAD_HEIGHT,
JPGD_BAD_WIDTH,
JPGD_TOO_MANY_COMPONENTS,
JPGD_BAD_SOF_LENGTH,
JPGD_BAD_VARIABLE_MARKER,
JPGD_BAD_DRI_LENGTH,
JPGD_BAD_SOS_LENGTH,
JPGD_BAD_SOS_COMP_ID,
JPGD_W_EXTRA_BYTES_BEFORE_MARKER,
JPGD_NO_ARITHMITIC_SUPPORT,
JPGD_UNEXPECTED_MARKER,
JPGD_NOT_JPEG,
JPGD_UNSUPPORTED_MARKER,
JPGD_BAD_DQT_LENGTH,
JPGD_TOO_MANY_BLOCKS,
JPGD_UNDEFINED_QUANT_TABLE,
JPGD_UNDEFINED_HUFF_TABLE,
JPGD_NOT_SINGLE_SCAN,
JPGD_UNSUPPORTED_COLORSPACE,
JPGD_UNSUPPORTED_SAMP_FACTORS,
JPGD_DECODE_ERROR,
JPGD_BAD_RESTART_MARKER,
JPGD_BAD_SOS_SPECTRAL,
JPGD_BAD_SOS_SUCCESSIVE,
JPGD_STREAM_READ,
JPGD_NOTENOUGHMEM,
JPGD_TOO_MANY_SCANS
};
// Input stream interface.
// Derive from this class to read input data from sources other than files or
// memory. Set m_eof_flag to true when no more data is available. The decoder is
// rather greedy: it will keep on calling this method until its internal input
// buffer is full, or until the EOF flag is set. It the input stream contains
// data after the JPEG stream's EOI (end of image) marker it will probably be
// pulled into the internal buffer. Call the get_total_bytes_read() method to
// determine the actual size of the JPEG stream after successful decoding.
class jpeg_decoder_stream {
public:
jpeg_decoder_stream() {}
virtual ~jpeg_decoder_stream() {}
// The read() method is called when the internal input buffer is empty.
// Parameters:
// pBuf - input buffer
// max_bytes_to_read - maximum bytes that can be written to pBuf
// pEOF_flag - set this to true if at end of stream (no more bytes remaining)
// Returns -1 on error, otherwise return the number of bytes actually written
// to the buffer (which may be 0). Notes: This method will be called in a loop
// until you set *pEOF_flag to true or the internal buffer is full.
virtual int read(uint8 *pBuf, int max_bytes_to_read, bool *pEOF_flag) = 0;
};
// stdio FILE stream class.
class jpeg_decoder_file_stream : public jpeg_decoder_stream {
jpeg_decoder_file_stream(const jpeg_decoder_file_stream &);
jpeg_decoder_file_stream &operator=(const jpeg_decoder_file_stream &);
FILE *m_pFile;
bool m_eof_flag, m_error_flag;
public:
jpeg_decoder_file_stream();
virtual ~jpeg_decoder_file_stream();
bool open(const char *Pfilename);
void close();
virtual int read(uint8 *pBuf, int max_bytes_to_read, bool *pEOF_flag);
};
// Memory stream class.
class jpeg_decoder_mem_stream : public jpeg_decoder_stream {
const uint8 *m_pSrc_data;
uint m_ofs, m_size;
public:
jpeg_decoder_mem_stream() : m_pSrc_data(NULL), m_ofs(0), m_size(0) {}
jpeg_decoder_mem_stream(const uint8 *pSrc_data, uint size)
: m_pSrc_data(pSrc_data), m_ofs(0), m_size(size) {}
virtual ~jpeg_decoder_mem_stream() {}
bool open(const uint8 *pSrc_data, uint size);
void close() {
m_pSrc_data = NULL;
m_ofs = 0;
m_size = 0;
}
virtual int read(uint8 *pBuf, int max_bytes_to_read, bool *pEOF_flag);
};
// Loads JPEG file from a jpeg_decoder_stream.
unsigned char *decompress_jpeg_image_from_stream(jpeg_decoder_stream *pStream,
int *width, int *height,
int *actual_comps,
int req_comps,
uint32_t flags = 0);
enum {
JPGD_IN_BUF_SIZE = 8192,
JPGD_MAX_BLOCKS_PER_MCU = 10,
JPGD_MAX_HUFF_TABLES = 8,
JPGD_MAX_QUANT_TABLES = 4,
JPGD_MAX_COMPONENTS = 4,
JPGD_MAX_COMPS_IN_SCAN = 4,
JPGD_MAX_BLOCKS_PER_ROW = 16384,
JPGD_MAX_HEIGHT = 32768,
JPGD_MAX_WIDTH = 32768
};
typedef int16 jpgd_quant_t;
typedef int16 jpgd_block_coeff_t;
class jpeg_decoder {
public:
enum { cFlagBoxChromaFiltering = 1, cFlagDisableSIMD = 2 };
// Call get_error_code() after constructing to determine if the stream is
// valid or not. You may call the get_width(), get_height(), etc. methods
// after the constructor is called. You may then either destruct the object,
// or begin decoding the image by calling begin_decoding(), then decode() on
// each scanline.
jpeg_decoder(jpeg_decoder_stream *pStream, uint32_t flags = 0);
~jpeg_decoder();
// Call this method after constructing the object to begin decompression.
// If JPGD_SUCCESS is returned you may then call decode() on each scanline.
int begin_decoding();
// Returns the next scan line.
// For grayscale images, pScan_line will point to a buffer containing 8-bit
// pixels (get_bytes_per_pixel() will return 1). Otherwise, it will always
// point to a buffer containing 32-bit RGBA pixels (A will always be 255, and
// get_bytes_per_pixel() will return 4). Returns JPGD_SUCCESS if a scan line
// has been returned. Returns JPGD_DONE if all scan lines have been returned.
// Returns JPGD_FAILED if an error occurred. Call get_error_code() for a more
// info.
int decode(const void **pScan_line, uint *pScan_line_len);
inline jpgd_status get_error_code() const { return m_error_code; }
inline int get_width() const { return m_image_x_size; }
inline int get_height() const { return m_image_y_size; }
inline int get_num_components() const { return m_comps_in_frame; }
inline int get_bytes_per_pixel() const { return m_dest_bytes_per_pixel; }
inline int get_bytes_per_scan_line() const {
return m_image_x_size * get_bytes_per_pixel();
}
// Returns the total number of bytes actually consumed by the decoder (which
// should equal the actual size of the JPEG file).
inline int get_total_bytes_read() const { return m_total_bytes_read; }
private:
jpeg_decoder(const jpeg_decoder &);
jpeg_decoder &operator=(const jpeg_decoder &);
typedef void (*pDecode_block_func)(jpeg_decoder *, int, int, int);
struct huff_tables {
bool ac_table;
uint look_up[256];
uint look_up2[256];
uint8 code_size[JPGD_HUFF_CODE_SIZE_MAX_LENGTH];
uint tree[JPGD_HUFF_TREE_MAX_LENGTH];
};
struct coeff_buf {
uint8 *pData;
int block_num_x, block_num_y;
int block_len_x, block_len_y;
int block_size;
};
struct mem_block {
mem_block *m_pNext;
size_t m_used_count;
size_t m_size;
char m_data[1];
};
jmp_buf m_jmp_state;
uint32_t m_flags;
mem_block *m_pMem_blocks;
int m_image_x_size;
int m_image_y_size;
jpeg_decoder_stream *m_pStream;
int m_progressive_flag;
uint8 m_huff_ac[JPGD_MAX_HUFF_TABLES];
uint8 *m_huff_num[JPGD_MAX_HUFF_TABLES]; // pointer to number of Huffman codes
// per bit size
uint8 *
m_huff_val[JPGD_MAX_HUFF_TABLES]; // pointer to Huffman codes per bit size
jpgd_quant_t
*m_quant[JPGD_MAX_QUANT_TABLES]; // pointer to quantization tables
int m_scan_type; // Gray, Yh1v1, Yh1v2, Yh2v1, Yh2v2 (CMYK111, CMYK4114 no
// longer supported)
int m_comps_in_frame; // # of components in frame
int m_comp_h_samp[JPGD_MAX_COMPONENTS]; // component's horizontal sampling
// factor
int m_comp_v_samp[JPGD_MAX_COMPONENTS]; // component's vertical sampling
// factor
int m_comp_quant[JPGD_MAX_COMPONENTS]; // component's quantization table
// selector
int m_comp_ident[JPGD_MAX_COMPONENTS]; // component's ID
int m_comp_h_blocks[JPGD_MAX_COMPONENTS];
int m_comp_v_blocks[JPGD_MAX_COMPONENTS];
int m_comps_in_scan; // # of components in scan
int m_comp_list[JPGD_MAX_COMPS_IN_SCAN]; // components in this scan
int m_comp_dc_tab[JPGD_MAX_COMPONENTS]; // component's DC Huffman coding table
// selector
int m_comp_ac_tab[JPGD_MAX_COMPONENTS]; // component's AC Huffman coding table
// selector
int m_spectral_start; // spectral selection start
int m_spectral_end; // spectral selection end
int m_successive_low; // successive approximation low
int m_successive_high; // successive approximation high
int m_max_mcu_x_size; // MCU's max. X size in pixels
int m_max_mcu_y_size; // MCU's max. Y size in pixels
int m_blocks_per_mcu;
int m_max_blocks_per_row;
int m_mcus_per_row, m_mcus_per_col;
int m_mcu_org[JPGD_MAX_BLOCKS_PER_MCU];
int m_total_lines_left; // total # lines left in image
int m_mcu_lines_left; // total # lines left in this MCU
int m_num_buffered_scanlines;
int m_real_dest_bytes_per_scan_line;
int m_dest_bytes_per_scan_line; // rounded up
int m_dest_bytes_per_pixel; // 4 (RGB) or 1 (Y)
huff_tables *m_pHuff_tabs[JPGD_MAX_HUFF_TABLES];
coeff_buf *m_dc_coeffs[JPGD_MAX_COMPONENTS];
coeff_buf *m_ac_coeffs[JPGD_MAX_COMPONENTS];
int m_eob_run;
int m_block_y_mcu[JPGD_MAX_COMPONENTS];
uint8 *m_pIn_buf_ofs;
int m_in_buf_left;
int m_tem_flag;
uint8 m_in_buf_pad_start[64];
uint8 m_in_buf[JPGD_IN_BUF_SIZE + 128];
uint8 m_in_buf_pad_end[64];
int m_bits_left;
uint m_bit_buf;
int m_restart_interval;
int m_restarts_left;
int m_next_restart_num;
int m_max_mcus_per_row;
int m_max_blocks_per_mcu;
int m_max_mcus_per_col;
uint m_last_dc_val[JPGD_MAX_COMPONENTS];
jpgd_block_coeff_t *m_pMCU_coefficients;
int m_mcu_block_max_zag[JPGD_MAX_BLOCKS_PER_MCU];
uint8 *m_pSample_buf;
uint8 *m_pSample_buf_prev;
int m_crr[256];
int m_cbb[256];
int m_crg[256];
int m_cbg[256];
uint8 *m_pScan_line_0;
uint8 *m_pScan_line_1;
jpgd_status m_error_code;
int m_total_bytes_read;
bool m_ready_flag;
bool m_eof_flag;
bool m_sample_buf_prev_valid;
bool m_has_sse2;
inline int check_sample_buf_ofs(int ofs) const {
assert(ofs >= 0);
assert(ofs < m_max_blocks_per_row * 64);
return ofs;
}
void free_all_blocks();
JPGD_NORETURN void stop_decoding(jpgd_status status);
void *alloc(size_t n, bool zero = false);
void *alloc_aligned(size_t nSize, uint32_t align = 16, bool zero = false);
void word_clear(void *p, uint16 c, uint n);
void prep_in_buffer();
void read_dht_marker();
void read_dqt_marker();
void read_sof_marker();
void skip_variable_marker();
void read_dri_marker();
void read_sos_marker();
int next_marker();
int process_markers();
void locate_soi_marker();
void locate_sof_marker();
int locate_sos_marker();
void init(jpeg_decoder_stream *pStream, uint32_t flags);
void create_look_ups();
void fix_in_buffer();
void transform_mcu(int mcu_row);
coeff_buf *coeff_buf_open(int block_num_x, int block_num_y, int block_len_x,
int block_len_y);
inline jpgd_block_coeff_t *coeff_buf_getp(coeff_buf *cb, int block_x,
int block_y);
void load_next_row();
void decode_next_row();
void make_huff_table(int index, huff_tables *pH);
void check_quant_tables();
void check_huff_tables();
bool calc_mcu_block_order();
int init_scan();
void init_frame();
void process_restart();
void decode_scan(pDecode_block_func decode_block_func);
void init_progressive();
void init_sequential();
void decode_start();
void decode_init(jpeg_decoder_stream *pStream, uint32_t flags);
void H2V2Convert();
uint32_t H2V2ConvertFiltered();
void H2V1Convert();
void H2V1ConvertFiltered();
void H1V2Convert();
void H1V2ConvertFiltered();
void H1V1Convert();
void gray_convert();
void find_eoi();
inline uint get_char();
inline uint get_char(bool *pPadding_flag);
inline void stuff_char(uint8 q);
inline uint8 get_octet();
inline uint get_bits(int num_bits);
inline uint get_bits_no_markers(int numbits);
inline int huff_decode(huff_tables *pH);
inline int huff_decode(huff_tables *pH, int &extrabits);
// Clamps a value between 0-255.
static inline uint8 clamp(int i) {
if (static_cast<uint>(i) > 255)
i = (((~i) >> 31) & 0xFF);
return static_cast<uint8>(i);
}
int decode_next_mcu_row();
static void decode_block_dc_first(jpeg_decoder *pD, int component_id,
int block_x, int block_y);
static void decode_block_dc_refine(jpeg_decoder *pD, int component_id,
int block_x, int block_y);
static void decode_block_ac_first(jpeg_decoder *pD, int component_id,
int block_x, int block_y);
static void decode_block_ac_refine(jpeg_decoder *pD, int component_id,
int block_x, int block_y);
};
} // namespace jpgd
#endif // JPEG_DECODER_H

View File

@ -1,478 +0,0 @@
// Copyright 2009 Intel Corporation
// All Rights Reserved
//
// Permission is granted to use, copy, distribute and prepare derivative works
// of this software for any purpose and without fee, provided, that the above
// copyright notice and this statement appear in all copies. Intel makes no
// representations about the suitability of this software for any purpose. THIS
// SOFTWARE IS PROVIDED "AS IS." INTEL SPECIFICALLY DISCLAIMS ALL WARRANTIES,
// EXPRESS OR IMPLIED, AND ALL LIABILITY, INCLUDING CONSEQUENTIAL AND OTHER
// INDIRECT DAMAGES, FOR THE USE OF THIS SOFTWARE, INCLUDING LIABILITY FOR
// INFRINGEMENT OF ANY PROPRIETARY RIGHTS, AND INCLUDING THE WARRANTIES OF
// MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. Intel does not assume
// any responsibility for any errors which may appear in this software nor any
// responsibility to update it.
//
// From:
// https://software.intel.com/sites/default/files/m/d/4/1/d/8/UsingIntelAVXToImplementIDCT-r1_5.pdf
// https://software.intel.com/file/29048
//
// Requires SSE
//
#ifdef _MSC_VER
#include <intrin.h>
#endif
#include <immintrin.h>
#ifdef _MSC_VER
#define JPGD_SIMD_ALIGN(type, name) __declspec(align(16)) type name
#else
#define JPGD_SIMD_ALIGN(type, name) type name __attribute__((aligned(16)))
#endif
#include <cinttypes>
#define BITS_INV_ACC 4
#define SHIFT_INV_ROW 16 - BITS_INV_ACC
#define SHIFT_INV_COL 1 + BITS_INV_ACC
const short IRND_INV_ROW = 1024 * (6 - BITS_INV_ACC); // 1 << (SHIFT_INV_ROW-1)
const short IRND_INV_COL = 16 * (BITS_INV_ACC - 3); // 1 << (SHIFT_INV_COL-1)
const short IRND_INV_CORR = IRND_INV_COL - 1; // correction -1.0 and round
JPGD_SIMD_ALIGN(short, shortM128_one_corr[8]) = {1, 1, 1, 1, 1, 1, 1, 1};
JPGD_SIMD_ALIGN(short, shortM128_round_inv_row[8]) = {
IRND_INV_ROW, 0, IRND_INV_ROW, 0, IRND_INV_ROW, 0, IRND_INV_ROW, 0};
JPGD_SIMD_ALIGN(short, shortM128_round_inv_col[8]) = {
IRND_INV_COL, IRND_INV_COL, IRND_INV_COL, IRND_INV_COL,
IRND_INV_COL, IRND_INV_COL, IRND_INV_COL, IRND_INV_COL};
JPGD_SIMD_ALIGN(short, shortM128_round_inv_corr[8]) = {
IRND_INV_CORR, IRND_INV_CORR, IRND_INV_CORR, IRND_INV_CORR,
IRND_INV_CORR, IRND_INV_CORR, IRND_INV_CORR, IRND_INV_CORR};
JPGD_SIMD_ALIGN(short, shortM128_tg_1_16[8]) = {
13036, 13036, 13036, 13036,
13036, 13036, 13036, 13036}; // tg * (2<<16) + 0.5
JPGD_SIMD_ALIGN(short, shortM128_tg_2_16[8]) = {
27146, 27146, 27146, 27146,
27146, 27146, 27146, 27146}; // tg * (2<<16) + 0.5
JPGD_SIMD_ALIGN(short, shortM128_tg_3_16[8]) = {
-21746, -21746, -21746, -21746,
-21746, -21746, -21746, -21746}; // tg * (2<<16) + 0.5
JPGD_SIMD_ALIGN(short, shortM128_cos_4_16[8]) = {
-19195, -19195, -19195, -19195,
-19195, -19195, -19195, -19195}; // cos * (2<<16) + 0.5
//-----------------------------------------------------------------------------
// Table for rows 0,4 - constants are multiplied on cos_4_16
// w15 w14 w11 w10 w07 w06 w03 w02
// w29 w28 w25 w24 w21 w20 w17 w16
// w31 w30 w27 w26 w23 w22 w19 w18
// movq -> w05 w04 w01 w00
JPGD_SIMD_ALIGN(short, shortM128_tab_i_04[]) = {
16384, 21407, 16384, 8867,
16384, -8867, 16384, -21407, // w13 w12 w09 w08
16384, 8867, -16384, -21407, // w07 w06 w03 w02
-16384, 21407, 16384, -8867, // w15 w14 w11 w10
22725, 19266, 19266, -4520, // w21 w20 w17 w16
12873, -22725, 4520, -12873, // w29 w28 w25 w24
12873, 4520, -22725, -12873, // w23 w22 w19 w18
4520, 19266, 19266, -22725}; // w31 w30 w27 w26
// Table for rows 1,7 - constants are multiplied on cos_1_16
// movq -> w05 w04 w01 w00
JPGD_SIMD_ALIGN(short, shortM128_tab_i_17[]) = {
22725, 29692, 22725, 12299,
22725, -12299, 22725, -29692, // w13 w12 w09 w08
22725, 12299, -22725, -29692, // w07 w06 w03 w02
-22725, 29692, 22725, -12299, // w15 w14 w11 w10
31521, 26722, 26722, -6270, // w21 w20 w17 w16
17855, -31521, 6270, -17855, // w29 w28 w25 w24
17855, 6270, -31521, -17855, // w23 w22 w19 w18
6270, 26722, 26722, -31521}; // w31 w30 w27 w26
// Table for rows 2,6 - constants are multiplied on cos_2_16
// movq -> w05 w04 w01 w00
JPGD_SIMD_ALIGN(short, shortM128_tab_i_26[]) = {
21407, 27969, 21407, 11585,
21407, -11585, 21407, -27969, // w13 w12 w09 w08
21407, 11585, -21407, -27969, // w07 w06 w03 w02
-21407, 27969, 21407, -11585, // w15 w14 w11 w10
29692, 25172, 25172, -5906, // w21 w20 w17 w16
16819, -29692, 5906, -16819, // w29 w28 w25 w24
16819, 5906, -29692, -16819, // w23 w22 w19 w18
5906, 25172, 25172, -29692}; // w31 w30 w27 w26
// Table for rows 3,5 - constants are multiplied on cos_3_16
// movq -> w05 w04 w01 w00
JPGD_SIMD_ALIGN(short, shortM128_tab_i_35[]) = {
19266, 25172, 19266, 10426,
19266, -10426, 19266, -25172, // w13 w12 w09 w08
19266, 10426, -19266, -25172, // w07 w06 w03 w02
-19266, 25172, 19266, -10426, // w15 w14 w11 w10
26722, 22654, 22654, -5315, // w21 w20 w17 w16
15137, -26722, 5315, -15137, // w29 w28 w25 w24
15137, 5315, -26722, -15137, // w23 w22 w19 w18
5315, 22654, 22654, -26722}; // w31 w30 w27 w26
JPGD_SIMD_ALIGN(short, shortM128_128[8]) = {128, 128, 128, 128,
128, 128, 128, 128};
void idctSSEShortU8(const short *pInput, uint8_t *pOutputUB) {
__m128i r_xmm0, r_xmm4;
__m128i r_xmm1, r_xmm2, r_xmm3, r_xmm5, r_xmm6, r_xmm7;
__m128i row0, row1, row2, row3, row4, row5, row6, row7;
short *pTab_i_04 = shortM128_tab_i_04;
short *pTab_i_26 = shortM128_tab_i_26;
// Get pointers for this input and output
pTab_i_04 = shortM128_tab_i_04;
pTab_i_26 = shortM128_tab_i_26;
// Row 1 and Row 3
r_xmm0 = _mm_load_si128((__m128i *)pInput);
r_xmm4 = _mm_load_si128((__m128i *)(&pInput[2 * 8]));
// *** Work on the data in xmm0
// low shuffle mask = 0xd8 = 11 01 10 00
// get short 2 and short 0 into ls 32-bits
r_xmm0 = _mm_shufflelo_epi16(r_xmm0, 0xd8);
// copy short 2 and short 0 to all locations
r_xmm1 = _mm_shuffle_epi32(r_xmm0, 0);
// add to those copies
r_xmm1 = _mm_madd_epi16(r_xmm1, *((__m128i *)pTab_i_04));
// shuffle mask = 0x55 = 01 01 01 01
// copy short 3 and short 1 to all locations
r_xmm3 = _mm_shuffle_epi32(r_xmm0, 0x55);
// high shuffle mask = 0xd8 = 11 01 10 00
// get short 6 and short 4 into bit positions 64-95
// get short 7 and short 5 into bit positions 96-127
r_xmm0 = _mm_shufflehi_epi16(r_xmm0, 0xd8);
// add to short 3 and short 1
r_xmm3 = _mm_madd_epi16(r_xmm3, *((__m128i *)&pTab_i_04[16]));
// shuffle mask = 0xaa = 10 10 10 10
// copy short 6 and short 4 to all locations
r_xmm2 = _mm_shuffle_epi32(r_xmm0, 0xaa);
// shuffle mask = 0xaa = 11 11 11 11
// copy short 7 and short 5 to all locations
r_xmm0 = _mm_shuffle_epi32(r_xmm0, 0xff);
// add to short 6 and short 4
r_xmm2 = _mm_madd_epi16(r_xmm2, *((__m128i *)&pTab_i_04[8]));
// *** Work on the data in xmm4
// high shuffle mask = 0xd8 11 01 10 00
// get short 6 and short 4 into bit positions 64-95
// get short 7 and short 5 into bit positions 96-127
r_xmm4 = _mm_shufflehi_epi16(r_xmm4, 0xd8);
// (xmm0 short 2 and short 0 plus pSi) + some constants
r_xmm1 = _mm_add_epi32(r_xmm1, *((__m128i *)shortM128_round_inv_row));
r_xmm4 = _mm_shufflelo_epi16(r_xmm4, 0xd8);
r_xmm0 = _mm_madd_epi16(r_xmm0, *((__m128i *)&pTab_i_04[24]));
r_xmm5 = _mm_shuffle_epi32(r_xmm4, 0);
r_xmm6 = _mm_shuffle_epi32(r_xmm4, 0xaa);
r_xmm5 = _mm_madd_epi16(r_xmm5, *((__m128i *)&shortM128_tab_i_26[0]));
r_xmm1 = _mm_add_epi32(r_xmm1, r_xmm2);
r_xmm2 = r_xmm1;
r_xmm7 = _mm_shuffle_epi32(r_xmm4, 0x55);
r_xmm6 = _mm_madd_epi16(r_xmm6, *((__m128i *)&shortM128_tab_i_26[8]));
r_xmm0 = _mm_add_epi32(r_xmm0, r_xmm3);
r_xmm4 = _mm_shuffle_epi32(r_xmm4, 0xff);
r_xmm2 = _mm_sub_epi32(r_xmm2, r_xmm0);
r_xmm7 = _mm_madd_epi16(r_xmm7, *((__m128i *)&shortM128_tab_i_26[16]));
r_xmm0 = _mm_add_epi32(r_xmm0, r_xmm1);
r_xmm2 = _mm_srai_epi32(r_xmm2, 12);
r_xmm5 = _mm_add_epi32(r_xmm5, *((__m128i *)shortM128_round_inv_row));
r_xmm4 = _mm_madd_epi16(r_xmm4, *((__m128i *)&shortM128_tab_i_26[24]));
r_xmm5 = _mm_add_epi32(r_xmm5, r_xmm6);
r_xmm6 = r_xmm5;
r_xmm0 = _mm_srai_epi32(r_xmm0, 12);
r_xmm2 = _mm_shuffle_epi32(r_xmm2, 0x1b);
row0 = _mm_packs_epi32(r_xmm0, r_xmm2);
r_xmm4 = _mm_add_epi32(r_xmm4, r_xmm7);
r_xmm6 = _mm_sub_epi32(r_xmm6, r_xmm4);
r_xmm4 = _mm_add_epi32(r_xmm4, r_xmm5);
r_xmm6 = _mm_srai_epi32(r_xmm6, 12);
r_xmm4 = _mm_srai_epi32(r_xmm4, 12);
r_xmm6 = _mm_shuffle_epi32(r_xmm6, 0x1b);
row2 = _mm_packs_epi32(r_xmm4, r_xmm6);
// Row 5 and row 7
r_xmm0 = _mm_load_si128((__m128i *)(&pInput[4 * 8]));
r_xmm4 = _mm_load_si128((__m128i *)(&pInput[6 * 8]));
r_xmm0 = _mm_shufflelo_epi16(r_xmm0, 0xd8);
r_xmm1 = _mm_shuffle_epi32(r_xmm0, 0);
r_xmm1 = _mm_madd_epi16(r_xmm1, *((__m128i *)pTab_i_04));
r_xmm3 = _mm_shuffle_epi32(r_xmm0, 0x55);
r_xmm0 = _mm_shufflehi_epi16(r_xmm0, 0xd8);
r_xmm3 = _mm_madd_epi16(r_xmm3, *((__m128i *)&pTab_i_04[16]));
r_xmm2 = _mm_shuffle_epi32(r_xmm0, 0xaa);
r_xmm0 = _mm_shuffle_epi32(r_xmm0, 0xff);
r_xmm2 = _mm_madd_epi16(r_xmm2, *((__m128i *)&pTab_i_04[8]));
r_xmm4 = _mm_shufflehi_epi16(r_xmm4, 0xd8);
r_xmm1 = _mm_add_epi32(r_xmm1, *((__m128i *)shortM128_round_inv_row));
r_xmm4 = _mm_shufflelo_epi16(r_xmm4, 0xd8);
r_xmm0 = _mm_madd_epi16(r_xmm0, *((__m128i *)&pTab_i_04[24]));
r_xmm5 = _mm_shuffle_epi32(r_xmm4, 0);
r_xmm6 = _mm_shuffle_epi32(r_xmm4, 0xaa);
r_xmm5 = _mm_madd_epi16(r_xmm5, *((__m128i *)&shortM128_tab_i_26[0]));
r_xmm1 = _mm_add_epi32(r_xmm1, r_xmm2);
r_xmm2 = r_xmm1;
r_xmm7 = _mm_shuffle_epi32(r_xmm4, 0x55);
r_xmm6 = _mm_madd_epi16(r_xmm6, *((__m128i *)&shortM128_tab_i_26[8]));
r_xmm0 = _mm_add_epi32(r_xmm0, r_xmm3);
r_xmm4 = _mm_shuffle_epi32(r_xmm4, 0xff);
r_xmm2 = _mm_sub_epi32(r_xmm2, r_xmm0);
r_xmm7 = _mm_madd_epi16(r_xmm7, *((__m128i *)&shortM128_tab_i_26[16]));
r_xmm0 = _mm_add_epi32(r_xmm0, r_xmm1);
r_xmm2 = _mm_srai_epi32(r_xmm2, 12);
r_xmm5 = _mm_add_epi32(r_xmm5, *((__m128i *)shortM128_round_inv_row));
r_xmm4 = _mm_madd_epi16(r_xmm4, *((__m128i *)&shortM128_tab_i_26[24]));
r_xmm5 = _mm_add_epi32(r_xmm5, r_xmm6);
r_xmm6 = r_xmm5;
r_xmm0 = _mm_srai_epi32(r_xmm0, 12);
r_xmm2 = _mm_shuffle_epi32(r_xmm2, 0x1b);
row4 = _mm_packs_epi32(r_xmm0, r_xmm2);
r_xmm4 = _mm_add_epi32(r_xmm4, r_xmm7);
r_xmm6 = _mm_sub_epi32(r_xmm6, r_xmm4);
r_xmm4 = _mm_add_epi32(r_xmm4, r_xmm5);
r_xmm6 = _mm_srai_epi32(r_xmm6, 12);
r_xmm4 = _mm_srai_epi32(r_xmm4, 12);
r_xmm6 = _mm_shuffle_epi32(r_xmm6, 0x1b);
row6 = _mm_packs_epi32(r_xmm4, r_xmm6);
// Row 4 and row 2
pTab_i_04 = shortM128_tab_i_35;
pTab_i_26 = shortM128_tab_i_17;
r_xmm0 = _mm_load_si128((__m128i *)(&pInput[3 * 8]));
r_xmm4 = _mm_load_si128((__m128i *)(&pInput[1 * 8]));
r_xmm0 = _mm_shufflelo_epi16(r_xmm0, 0xd8);
r_xmm1 = _mm_shuffle_epi32(r_xmm0, 0);
r_xmm1 = _mm_madd_epi16(r_xmm1, *((__m128i *)pTab_i_04));
r_xmm3 = _mm_shuffle_epi32(r_xmm0, 0x55);
r_xmm0 = _mm_shufflehi_epi16(r_xmm0, 0xd8);
r_xmm3 = _mm_madd_epi16(r_xmm3, *((__m128i *)&pTab_i_04[16]));
r_xmm2 = _mm_shuffle_epi32(r_xmm0, 0xaa);
r_xmm0 = _mm_shuffle_epi32(r_xmm0, 0xff);
r_xmm2 = _mm_madd_epi16(r_xmm2, *((__m128i *)&pTab_i_04[8]));
r_xmm4 = _mm_shufflehi_epi16(r_xmm4, 0xd8);
r_xmm1 = _mm_add_epi32(r_xmm1, *((__m128i *)shortM128_round_inv_row));
r_xmm4 = _mm_shufflelo_epi16(r_xmm4, 0xd8);
r_xmm0 = _mm_madd_epi16(r_xmm0, *((__m128i *)&pTab_i_04[24]));
r_xmm5 = _mm_shuffle_epi32(r_xmm4, 0);
r_xmm6 = _mm_shuffle_epi32(r_xmm4, 0xaa);
r_xmm5 = _mm_madd_epi16(r_xmm5, *((__m128i *)&pTab_i_26[0]));
r_xmm1 = _mm_add_epi32(r_xmm1, r_xmm2);
r_xmm2 = r_xmm1;
r_xmm7 = _mm_shuffle_epi32(r_xmm4, 0x55);
r_xmm6 = _mm_madd_epi16(r_xmm6, *((__m128i *)&pTab_i_26[8]));
r_xmm0 = _mm_add_epi32(r_xmm0, r_xmm3);
r_xmm4 = _mm_shuffle_epi32(r_xmm4, 0xff);
r_xmm2 = _mm_sub_epi32(r_xmm2, r_xmm0);
r_xmm7 = _mm_madd_epi16(r_xmm7, *((__m128i *)&pTab_i_26[16]));
r_xmm0 = _mm_add_epi32(r_xmm0, r_xmm1);
r_xmm2 = _mm_srai_epi32(r_xmm2, 12);
r_xmm5 = _mm_add_epi32(r_xmm5, *((__m128i *)shortM128_round_inv_row));
r_xmm4 = _mm_madd_epi16(r_xmm4, *((__m128i *)&pTab_i_26[24]));
r_xmm5 = _mm_add_epi32(r_xmm5, r_xmm6);
r_xmm6 = r_xmm5;
r_xmm0 = _mm_srai_epi32(r_xmm0, 12);
r_xmm2 = _mm_shuffle_epi32(r_xmm2, 0x1b);
row3 = _mm_packs_epi32(r_xmm0, r_xmm2);
r_xmm4 = _mm_add_epi32(r_xmm4, r_xmm7);
r_xmm6 = _mm_sub_epi32(r_xmm6, r_xmm4);
r_xmm4 = _mm_add_epi32(r_xmm4, r_xmm5);
r_xmm6 = _mm_srai_epi32(r_xmm6, 12);
r_xmm4 = _mm_srai_epi32(r_xmm4, 12);
r_xmm6 = _mm_shuffle_epi32(r_xmm6, 0x1b);
row1 = _mm_packs_epi32(r_xmm4, r_xmm6);
// Row 6 and row 8
r_xmm0 = _mm_load_si128((__m128i *)(&pInput[5 * 8]));
r_xmm4 = _mm_load_si128((__m128i *)(&pInput[7 * 8]));
r_xmm0 = _mm_shufflelo_epi16(r_xmm0, 0xd8);
r_xmm1 = _mm_shuffle_epi32(r_xmm0, 0);
r_xmm1 = _mm_madd_epi16(r_xmm1, *((__m128i *)pTab_i_04));
r_xmm3 = _mm_shuffle_epi32(r_xmm0, 0x55);
r_xmm0 = _mm_shufflehi_epi16(r_xmm0, 0xd8);
r_xmm3 = _mm_madd_epi16(r_xmm3, *((__m128i *)&pTab_i_04[16]));
r_xmm2 = _mm_shuffle_epi32(r_xmm0, 0xaa);
r_xmm0 = _mm_shuffle_epi32(r_xmm0, 0xff);
r_xmm2 = _mm_madd_epi16(r_xmm2, *((__m128i *)&pTab_i_04[8]));
r_xmm4 = _mm_shufflehi_epi16(r_xmm4, 0xd8);
r_xmm1 = _mm_add_epi32(r_xmm1, *((__m128i *)shortM128_round_inv_row));
r_xmm4 = _mm_shufflelo_epi16(r_xmm4, 0xd8);
r_xmm0 = _mm_madd_epi16(r_xmm0, *((__m128i *)&pTab_i_04[24]));
r_xmm5 = _mm_shuffle_epi32(r_xmm4, 0);
r_xmm6 = _mm_shuffle_epi32(r_xmm4, 0xaa);
r_xmm5 = _mm_madd_epi16(r_xmm5, *((__m128i *)&pTab_i_26[0]));
r_xmm1 = _mm_add_epi32(r_xmm1, r_xmm2);
r_xmm2 = r_xmm1;
r_xmm7 = _mm_shuffle_epi32(r_xmm4, 0x55);
r_xmm6 = _mm_madd_epi16(r_xmm6, *((__m128i *)&pTab_i_26[8]));
r_xmm0 = _mm_add_epi32(r_xmm0, r_xmm3);
r_xmm4 = _mm_shuffle_epi32(r_xmm4, 0xff);
r_xmm2 = _mm_sub_epi32(r_xmm2, r_xmm0);
r_xmm7 = _mm_madd_epi16(r_xmm7, *((__m128i *)&pTab_i_26[16]));
r_xmm0 = _mm_add_epi32(r_xmm0, r_xmm1);
r_xmm2 = _mm_srai_epi32(r_xmm2, 12);
r_xmm5 = _mm_add_epi32(r_xmm5, *((__m128i *)shortM128_round_inv_row));
r_xmm4 = _mm_madd_epi16(r_xmm4, *((__m128i *)&pTab_i_26[24]));
r_xmm5 = _mm_add_epi32(r_xmm5, r_xmm6);
r_xmm6 = r_xmm5;
r_xmm0 = _mm_srai_epi32(r_xmm0, 12);
r_xmm2 = _mm_shuffle_epi32(r_xmm2, 0x1b);
row5 = _mm_packs_epi32(r_xmm0, r_xmm2);
r_xmm4 = _mm_add_epi32(r_xmm4, r_xmm7);
r_xmm6 = _mm_sub_epi32(r_xmm6, r_xmm4);
r_xmm4 = _mm_add_epi32(r_xmm4, r_xmm5);
r_xmm6 = _mm_srai_epi32(r_xmm6, 12);
r_xmm4 = _mm_srai_epi32(r_xmm4, 12);
r_xmm6 = _mm_shuffle_epi32(r_xmm6, 0x1b);
row7 = _mm_packs_epi32(r_xmm4, r_xmm6);
r_xmm1 = _mm_load_si128((__m128i *)shortM128_tg_3_16);
r_xmm2 = row5;
r_xmm3 = row3;
r_xmm0 = _mm_mulhi_epi16(row5, r_xmm1);
r_xmm1 = _mm_mulhi_epi16(r_xmm1, r_xmm3);
r_xmm5 = _mm_load_si128((__m128i *)shortM128_tg_1_16);
r_xmm6 = row7;
r_xmm4 = _mm_mulhi_epi16(row7, r_xmm5);
r_xmm0 = _mm_adds_epi16(r_xmm0, r_xmm2);
r_xmm5 = _mm_mulhi_epi16(r_xmm5, row1);
r_xmm1 = _mm_adds_epi16(r_xmm1, r_xmm3);
r_xmm7 = row6;
r_xmm0 = _mm_adds_epi16(r_xmm0, r_xmm3);
r_xmm3 = _mm_load_si128((__m128i *)shortM128_tg_2_16);
r_xmm2 = _mm_subs_epi16(r_xmm2, r_xmm1);
r_xmm7 = _mm_mulhi_epi16(r_xmm7, r_xmm3);
r_xmm1 = r_xmm0;
r_xmm3 = _mm_mulhi_epi16(r_xmm3, row2);
r_xmm5 = _mm_subs_epi16(r_xmm5, r_xmm6);
r_xmm4 = _mm_adds_epi16(r_xmm4, row1);
r_xmm0 = _mm_adds_epi16(r_xmm0, r_xmm4);
r_xmm0 = _mm_adds_epi16(r_xmm0, *((__m128i *)shortM128_one_corr));
r_xmm4 = _mm_subs_epi16(r_xmm4, r_xmm1);
r_xmm6 = r_xmm5;
r_xmm5 = _mm_subs_epi16(r_xmm5, r_xmm2);
r_xmm5 = _mm_adds_epi16(r_xmm5, *((__m128i *)shortM128_one_corr));
r_xmm6 = _mm_adds_epi16(r_xmm6, r_xmm2);
// Intermediate results, needed later
__m128i temp3, temp7;
temp7 = r_xmm0;
r_xmm1 = r_xmm4;
r_xmm0 = _mm_load_si128((__m128i *)shortM128_cos_4_16);
r_xmm4 = _mm_adds_epi16(r_xmm4, r_xmm5);
r_xmm2 = _mm_load_si128((__m128i *)shortM128_cos_4_16);
r_xmm2 = _mm_mulhi_epi16(r_xmm2, r_xmm4);
// Intermediate results, needed later
temp3 = r_xmm6;
r_xmm1 = _mm_subs_epi16(r_xmm1, r_xmm5);
r_xmm7 = _mm_adds_epi16(r_xmm7, row2);
r_xmm3 = _mm_subs_epi16(r_xmm3, row6);
r_xmm6 = row0;
r_xmm0 = _mm_mulhi_epi16(r_xmm0, r_xmm1);
r_xmm5 = row4;
r_xmm5 = _mm_adds_epi16(r_xmm5, r_xmm6);
r_xmm6 = _mm_subs_epi16(r_xmm6, row4);
r_xmm4 = _mm_adds_epi16(r_xmm4, r_xmm2);
r_xmm4 = _mm_or_si128(r_xmm4, *((__m128i *)shortM128_one_corr));
r_xmm0 = _mm_adds_epi16(r_xmm0, r_xmm1);
r_xmm0 = _mm_or_si128(r_xmm0, *((__m128i *)shortM128_one_corr));
r_xmm2 = r_xmm5;
r_xmm5 = _mm_adds_epi16(r_xmm5, r_xmm7);
r_xmm1 = r_xmm6;
r_xmm5 = _mm_adds_epi16(r_xmm5, *((__m128i *)shortM128_round_inv_col));
r_xmm2 = _mm_subs_epi16(r_xmm2, r_xmm7);
r_xmm7 = temp7;
r_xmm6 = _mm_adds_epi16(r_xmm6, r_xmm3);
r_xmm6 = _mm_adds_epi16(r_xmm6, *((__m128i *)shortM128_round_inv_col));
r_xmm7 = _mm_adds_epi16(r_xmm7, r_xmm5);
r_xmm7 = _mm_srai_epi16(r_xmm7, SHIFT_INV_COL);
r_xmm1 = _mm_subs_epi16(r_xmm1, r_xmm3);
r_xmm1 = _mm_adds_epi16(r_xmm1, *((__m128i *)shortM128_round_inv_corr));
r_xmm3 = r_xmm6;
r_xmm2 = _mm_adds_epi16(r_xmm2, *((__m128i *)shortM128_round_inv_corr));
r_xmm6 = _mm_adds_epi16(r_xmm6, r_xmm4);
// Store results for row 0
//_mm_store_si128((__m128i *) pOutput, r_xmm7);
__m128i r0 = r_xmm7;
r_xmm6 = _mm_srai_epi16(r_xmm6, SHIFT_INV_COL);
r_xmm7 = r_xmm1;
r_xmm1 = _mm_adds_epi16(r_xmm1, r_xmm0);
// Store results for row 1
//_mm_store_si128((__m128i *) (&pOutput[1*8]), r_xmm6);
__m128i r1 = r_xmm6;
r_xmm1 = _mm_srai_epi16(r_xmm1, SHIFT_INV_COL);
r_xmm6 = temp3;
r_xmm7 = _mm_subs_epi16(r_xmm7, r_xmm0);
r_xmm7 = _mm_srai_epi16(r_xmm7, SHIFT_INV_COL);
// Store results for row 2
//_mm_store_si128((__m128i *) (&pOutput[2*8]), r_xmm1);
__m128i r2 = r_xmm1;
r_xmm5 = _mm_subs_epi16(r_xmm5, temp7);
r_xmm5 = _mm_srai_epi16(r_xmm5, SHIFT_INV_COL);
// Store results for row 7
//_mm_store_si128((__m128i *) (&pOutput[7*8]), r_xmm5);
__m128i r7 = r_xmm5;
r_xmm3 = _mm_subs_epi16(r_xmm3, r_xmm4);
r_xmm6 = _mm_adds_epi16(r_xmm6, r_xmm2);
r_xmm2 = _mm_subs_epi16(r_xmm2, temp3);
r_xmm6 = _mm_srai_epi16(r_xmm6, SHIFT_INV_COL);
r_xmm2 = _mm_srai_epi16(r_xmm2, SHIFT_INV_COL);
// Store results for row 3
//_mm_store_si128((__m128i *) (&pOutput[3*8]), r_xmm6);
__m128i r3 = r_xmm6;
r_xmm3 = _mm_srai_epi16(r_xmm3, SHIFT_INV_COL);
// Store results for rows 4, 5, and 6
//_mm_store_si128((__m128i *) (&pOutput[4*8]), r_xmm2);
//_mm_store_si128((__m128i *) (&pOutput[5*8]), r_xmm7);
//_mm_store_si128((__m128i *) (&pOutput[6*8]), r_xmm3);
__m128i r4 = r_xmm2;
__m128i r5 = r_xmm7;
__m128i r6 = r_xmm3;
r0 = _mm_add_epi16(*(const __m128i *)shortM128_128, r0);
r1 = _mm_add_epi16(*(const __m128i *)shortM128_128, r1);
r2 = _mm_add_epi16(*(const __m128i *)shortM128_128, r2);
r3 = _mm_add_epi16(*(const __m128i *)shortM128_128, r3);
r4 = _mm_add_epi16(*(const __m128i *)shortM128_128, r4);
r5 = _mm_add_epi16(*(const __m128i *)shortM128_128, r5);
r6 = _mm_add_epi16(*(const __m128i *)shortM128_128, r6);
r7 = _mm_add_epi16(*(const __m128i *)shortM128_128, r7);
((__m128i *)pOutputUB)[0] = _mm_packus_epi16(r0, r1);
((__m128i *)pOutputUB)[1] = _mm_packus_epi16(r2, r3);
((__m128i *)pOutputUB)[2] = _mm_packus_epi16(r4, r5);
((__m128i *)pOutputUB)[3] = _mm_packus_epi16(r6, r7);
}

View File

@ -1,186 +0,0 @@
// jpge.h - C++ class for JPEG compression.
// Public Domain or Apache 2.0, Richard Geldreich <richgel99@gmail.com>
// Alex Evans: Added RGBA support, linear memory allocator.
#ifndef JPEG_ENCODER_H
#define JPEG_ENCODER_H
namespace jpge {
typedef unsigned char uint8;
typedef signed short int16;
typedef signed int int32;
typedef unsigned short uint16;
typedef unsigned int uint32;
typedef unsigned int uint;
// JPEG chroma subsampling factors. Y_ONLY (grayscale images) and H2V2 (color
// images) are the most common.
enum subsampling_t { Y_ONLY = 0, H1V1 = 1, H2V1 = 2, H2V2 = 3 };
// JPEG compression parameters structure.
struct params {
inline params()
: m_quality(85), m_subsampling(H2V2), m_no_chroma_discrim_flag(false),
m_two_pass_flag(false), m_use_std_tables(false) {}
inline bool check() const {
if ((m_quality < 1) || (m_quality > 100))
return false;
if ((uint)m_subsampling > (uint)H2V2)
return false;
return true;
}
// Quality: 1-100, higher is better. Typical values are around 50-95.
int m_quality;
// m_subsampling:
// 0 = Y (grayscale) only
// 1 = YCbCr, no subsampling (H1V1, YCbCr 1x1x1, 3 blocks per MCU)
// 2 = YCbCr, H2V1 subsampling (YCbCr 2x1x1, 4 blocks per MCU)
// 3 = YCbCr, H2V2 subsampling (YCbCr 4x1x1, 6 blocks per MCU-- very common)
subsampling_t m_subsampling;
// Disables CbCr discrimination - only intended for testing.
// If true, the Y quantization table is also used for the CbCr channels.
bool m_no_chroma_discrim_flag;
bool m_two_pass_flag;
// By default we use the same quantization tables as mozjpeg's default.
// Set to true to use the traditional tables from JPEG Annex K.
bool m_use_std_tables;
};
// Writes JPEG image to a file.
// num_channels must be 1 (Y) or 3 (RGB), image pitch must be
// width*num_channels.
bool compress_image_to_jpeg_file(const char *pFilename, int width, int height,
int num_channels, const uint8 *pImage_data,
const params &comp_params = params());
// Writes JPEG image to memory buffer.
// On entry, buf_size is the size of the output buffer pointed at by pBuf, which
// should be at least ~1024 bytes. If return value is true, buf_size will be set
// to the size of the compressed data.
bool compress_image_to_jpeg_file_in_memory(
void *pBuf, int &buf_size, int width, int height, int num_channels,
const uint8 *pImage_data, const params &comp_params = params());
// Output stream abstract class - used by the jpeg_encoder class to write to the
// output stream. put_buf() is generally called with len==JPGE_OUT_BUF_SIZE
// bytes, but for headers it'll be called with smaller amounts.
class output_stream {
public:
virtual ~output_stream(){};
virtual bool put_buf(const void *Pbuf, int len) = 0;
template <class T> inline bool put_obj(const T &obj) {
return put_buf(&obj, sizeof(T));
}
};
// Lower level jpeg_encoder class - useful if more control is needed than the
// above helper functions.
class jpeg_encoder {
public:
jpeg_encoder();
~jpeg_encoder();
// Initializes the compressor.
// pStream: The stream object to use for writing compressed data.
// params - Compression parameters structure, defined above.
// width, height - Image dimensions.
// channels - May be 1, or 3. 1 indicates grayscale, 3 indicates RGB source
// data. Returns false on out of memory or if a stream write fails.
bool init(output_stream *pStream, int width, int height, int src_channels,
const params &comp_params = params());
const params &get_params() const { return m_params; }
// Deinitializes the compressor, freeing any allocated memory. May be called
// at any time.
void deinit();
uint get_total_passes() const { return m_params.m_two_pass_flag ? 2 : 1; }
inline uint get_cur_pass() { return m_pass_num; }
// Call this method with each source scanline.
// width * src_channels bytes per scanline is expected (RGB or Y format).
// You must call with NULL after all scanlines are processed to finish
// compression. Returns false on out of memory or if a stream write fails.
bool process_scanline(const void *pScanline);
private:
jpeg_encoder(const jpeg_encoder &);
jpeg_encoder &operator=(const jpeg_encoder &);
typedef int32 sample_array_t;
output_stream *m_pStream;
params m_params;
uint8 m_num_components;
uint8 m_comp_h_samp[3], m_comp_v_samp[3];
int m_image_x, m_image_y, m_image_bpp, m_image_bpl;
int m_image_x_mcu, m_image_y_mcu;
int m_image_bpl_xlt, m_image_bpl_mcu;
int m_mcus_per_row;
int m_mcu_x, m_mcu_y;
uint8 *m_mcu_lines[16];
uint8 m_mcu_y_ofs;
sample_array_t m_sample_array[64];
int16 m_coefficient_array[64];
int32 m_quantization_tables[2][64];
uint m_huff_codes[4][256];
uint8 m_huff_code_sizes[4][256];
uint8 m_huff_bits[4][17];
uint8 m_huff_val[4][256];
uint32 m_huff_count[4][256];
int m_last_dc_val[3];
enum { JPGE_OUT_BUF_SIZE = 2048 };
uint8 m_out_buf[JPGE_OUT_BUF_SIZE];
uint8 *m_pOut_buf;
uint m_out_buf_left;
uint32 m_bit_buffer;
uint m_bits_in;
uint8 m_pass_num;
bool m_all_stream_writes_succeeded;
void optimize_huffman_table(int table_num, int table_len);
void emit_byte(uint8 i);
void emit_word(uint i);
void emit_marker(int marker);
void emit_jfif_app0();
void emit_dqt();
void emit_sof();
void emit_dht(uint8 *bits, uint8 *val, int index, bool ac_flag);
void emit_dhts();
void emit_sos();
void emit_markers();
void compute_huffman_table(uint *codes, uint8 *code_sizes, uint8 *bits,
uint8 *val);
void compute_quant_table(int32 *dst, int16 *src);
void adjust_quant_table(int32 *dst, int32 *src);
void first_pass_init();
bool second_pass_init();
bool jpg_open(int p_x_res, int p_y_res, int src_channels);
void load_block_8_8_grey(int x);
void load_block_8_8(int x, int y, int c);
void load_block_16_8(int x, int c);
void load_block_16_8_8(int x, int c);
void load_quantized_coefficients(int component_num);
void flush_output_buffer();
void put_bits(uint bits, uint len);
void code_coefficients_pass_one(int component_num);
void code_coefficients_pass_two(int component_num);
void code_block(int component_num);
void process_mcu_row();
bool terminate_pass_one();
bool terminate_pass_two();
bool process_end_of_image();
void load_mcu(const void *src);
void clear();
void init();
};
} // namespace jpge
#endif // JPEG_ENCODER

View File

@ -1,222 +0,0 @@
#pragma once
#include <cstdint>
#include <fstream>
#include <iostream>
#include <memory.h>
#include <memory>
#include <renderd7/external/jpgd.h>
#include <renderd7/external/jpge.h>
#include <sstream>
#include <vector>
struct NVID_Header {
char magic[4]; // Magic
int framerate; // Only Up to 60
int width; // Width
int height; // Height
uint32_t framecount; // Count of Frames
};
struct NVID_Frame {
char magic[4]; // Magic
uint32_t framesize; // Size of Frame
};
struct NVID_Image {
int framenum; // Register of Frame
int w; // Width of Frame
int h; // Height of Frame
int bpp; // bpp of Frame
void *pBuf; // Buffer
};
inline void CreateHeader(NVID_Header &header) {
header.magic[0] = 'N';
header.magic[1] = 'V';
header.magic[2] = 'I';
header.magic[3] = 'D';
}
inline void CreateFrame(NVID_Frame &frame) {
frame.magic[0] = 'N';
frame.magic[1] = 'F';
frame.magic[2] = 'R';
frame.magic[3] = 'M';
}
inline bool CheckHeader(NVID_Header &header) {
if (header.magic[0] == 'N' && header.magic[1] == 'V' &&
header.magic[2] == 'I' && header.magic[3] == 'D')
return true;
return false;
}
inline bool CheckFrame(NVID_Frame &frame) {
if (frame.magic[0] == 'N' && frame.magic[1] == 'F' && frame.magic[2] == 'R' &&
frame.magic[3] == 'M')
return true;
return false;
}
inline std::vector<std::unique_ptr<NVID_Image>>
LoadNVID(const std::string &path) {
std::vector<std::unique_ptr<NVID_Image>> res;
std::ifstream nvid_file(path, std::ios::binary | std::ios::in);
if (!nvid_file) {
std::cerr << "Failed to open NVID file: " << path << std::endl;
return res;
}
NVID_Header header;
nvid_file.read(reinterpret_cast<char *>(&header), sizeof(header));
if (!CheckHeader(header)) {
std::cerr << "Invalid NVID header" << std::endl;
return res;
}
for (int i = 0; i < (int)header.framecount; i++) {
NVID_Frame frame;
nvid_file.read(reinterpret_cast<char *>(&frame), sizeof(frame));
if (!CheckFrame(frame)) {
std::cerr << "Invalid NVID frame" << std::endl;
return res;
}
std::vector<uint8_t> compressed_data(frame.framesize);
nvid_file.read(reinterpret_cast<char *>(compressed_data.data()),
compressed_data.size());
int width, height, components;
unsigned char *decompressed_data = jpgd::decompress_jpeg_image_from_memory(
compressed_data.data(), compressed_data.size(), &width, &height,
&components, 3);
if (!decompressed_data) {
std::cerr << "Failed to decompress JPEG data" << std::endl;
return res;
}
auto image = std::make_unique<NVID_Image>();
image->bpp = components;
image->w = width;
image->h = height;
image->framenum = i;
image->pBuf = decompressed_data;
res.push_back(std::move(image));
}
return res;
}
inline std::vector<std::unique_ptr<NVID_Image>> LoadMemNVID(const void *data,
size_t size) {
std::vector<std::unique_ptr<NVID_Image>> res;
std::istringstream nvid_stream(
std::string(reinterpret_cast<const char *>(data), size));
NVID_Header header;
nvid_stream.read(reinterpret_cast<char *>(&header), sizeof(header));
if (!CheckHeader(header)) {
std::cerr << "Invalid NVID header" << std::endl;
return res;
}
for (int i = 0; i < (int)header.framecount; i++) {
NVID_Frame frame;
nvid_stream.read(reinterpret_cast<char *>(&frame), sizeof(frame));
if (!CheckFrame(frame)) {
std::cerr << "Invalid NVID frame" << std::endl;
return res;
}
std::vector<uint8_t> compressed_data(frame.framesize);
nvid_stream.read(reinterpret_cast<char *>(compressed_data.data()),
compressed_data.size());
int width, height, components;
unsigned char *decompressed_data = jpgd::decompress_jpeg_image_from_memory(
compressed_data.data(), compressed_data.size(), &width, &height,
&components, 3);
if (!decompressed_data) {
std::cerr << "Failed to decompress JPEG data" << std::endl;
return res;
}
auto image = std::make_unique<NVID_Image>();
image->bpp = components;
image->w = width;
image->h = height;
image->framenum = i;
image->pBuf = decompressed_data;
res.push_back(std::move(image));
}
return res;
}
class NVID_Stream {
public:
NVID_Stream(const std::string &path)
: file_(path, std::ios::binary | std::ios::in) {
if (!file_) {
std::cout << "Failed to open NVID file: " << path << std::endl;
return;
} else {
file_.read(reinterpret_cast<char *>(&header_), sizeof(header_));
if (!CheckHeader(header_)) {
std::cout << "Invalid NVID header" << std::endl;
return;
}
}
}
NVID_Stream(const void *data, std::size_t size) {
if (!data || size < sizeof(header_)) {
std::cout << "Invalid NVID data" << std::endl;
return;
} else {
memcpy(&header_, data, sizeof(header_));
if (!CheckHeader(header_)) {
std::cout << "Invalid NVID header" << std::endl;
return;
}
}
}
~NVID_Stream() { file_.close(); }
bool ReadNext(NVID_Image &image) {
if (!file_) {
return false;
}
NVID_Frame frame;
file_.read(reinterpret_cast<char *>(&frame), sizeof(frame));
if (!CheckFrame(frame)) {
std::cout << "Invalid NVID frame" << std::endl;
return false;
}
std::vector<uint8_t> compressed_data(frame.framesize);
file_.read(reinterpret_cast<char *>(compressed_data.data()),
compressed_data.size());
int width, height, components;
unsigned char *decompressed_data = jpgd::decompress_jpeg_image_from_memory(
compressed_data.data(), compressed_data.size(), &width, &height,
&components, 3);
if (!decompressed_data) {
std::cout << "Failed to decompress JPEG data" << std::endl;
return false;
}
image.bpp = components;
image.w = width;
image.h = height;
image.framenum = current_frame_++;
image.pBuf = decompressed_data;
return true;
}
private:
std::ifstream file_;
NVID_Header header_;
int current_frame_ = 0;
};

View File

@ -1,5 +0,0 @@
#pragma once
#include <cstddef>
extern unsigned char npi_intro[];
extern size_t npi_intro_size;

View File

@ -50,13 +50,14 @@
#include <renderd7/stringtool.hpp>
#include <renderd7/thread.hpp>
#define RENDERD7VSTRING "0.9.4"
#define RENDERD7VSTRING "0.9.5"
#define CHANGELOG \
"0.9.5: Remove Npi Intro and NVID Api\n" \
"0.9.4: Implement new Security System\n To prevent from crashes\nImplement " \
"Functiontrace for better\nTiming Tests\nImplement MemAlloc Tracker (only " \
"size)\nAdd some new Overlays (not functional yet)\nComplete Rewrite of " \
"Overlay System\nFixed the FrameEnd Crash\nNew System to get Hardware " \
"Info\nRemoved RD7SR\n0.9.3: Completly Documanted Everything\nFix typo " \
"Info\nRemoved RD7SR\n0.9.3: Completly Documented Everything\nFix typo " \
"in " \
"Sprite::getHeight()\nRemove Deprecated/Useless Stuff\n0.9.2: Add " \
"NpiSplashVideo\nNvid Support(v0.0.1)\nAdd " \
@ -266,8 +267,6 @@ void DrawMetrikOvl();
/// @return success ?
bool DrawImageFromSheet(RenderD7::Sheet *sheet, size_t index, float x, float y,
float scaleX = 1.0, float scaleY = 1.0);
/// @brief Display the Npi-D7 Video Intro (NVID)
void DoNpiIntro();
/// @brief Fade In
/// @param duration Duration in Frames
void FadeIn();

View File

@ -1,5 +0,0 @@
#pragma once
#include <cstddef>
extern unsigned char ui_elements[];
extern size_t ui_elements_size;

View File

@ -66,11 +66,17 @@ VERSION_MICRO := 0
#---------------------------------------------------------------------------------
# Make Sure to Change this paths if your Submodule
# is located somewhere else
# Using ../ cause rd7tf is shipped with the RenderD7
# Repository!
RENDERD7_SRC := ../source ../external
RENDERD7_INC := ../include
TARGET := rd7tf
BUILD := build
SOURCES := source
SOURCES := source $(RENDERD7_SRC)
DATA := data
INCLUDES := source
INCLUDES := source $(RENDERD7_INC)
GRAPHICS := gfx
#GFXBUILD := $(BUILD)
ROMFS := romfs
@ -97,14 +103,14 @@ CXXFLAGS := $(CFLAGS) -fno-rtti -fno-exceptions -std=gnu++20
ASFLAGS := -g $(ARCH)
LDFLAGS = -specs=3dsx.specs -g $(ARCH) -Wl,-Map,$(notdir $*.map)
LIBS := -lrenderd7d -lcurl -lstdc++ -lm -lz -lcitro2d -lcitro3d -lctru -ljpeg
LIBS := -lcurl -lstdc++ -lm -lz -lcitro2d -lcitro3d -lctru -ljpeg
#---------------------------------------------------------------------------------
# list of directories containing libraries, this must be the top level containing
# include and lib
#---------------------------------------------------------------------------------
LIBDIRS := $(PORTLIBS) $(CTRULIB) ../libs
LIBDIRS := $(PORTLIBS) $(CTRULIB)
#---------------------------------------------------------------------------------
@ -249,44 +255,18 @@ $(OUTPUT).3dsx : $(_3DSXDEPS)
@$(bin2o)
#---------------------------------------------------------------------------------
.PRECIOUS : %.t3x
.PRECIOUS : %.t3x %.shbin
#---------------------------------------------------------------------------------
%.t3x.o %_t3x.h : %.t3x
#---------------------------------------------------------------------------------
@echo $(notdir $<)
@$(bin2o)
$(SILENTMSG) $(notdir $<)
$(bin2o)
#---------------------------------------------------------------------------------
# rules for assembling GPU shaders
%.shbin.o %_shbin.h : %.shbin
#---------------------------------------------------------------------------------
define shader-as
$(eval CURBIN := $*.shbin)
$(eval DEPSFILE := $(DEPSDIR)/$*.shbin.d)
echo "$(CURBIN).o: $< $1" > $(DEPSFILE)
echo "extern const u8" `(echo $(CURBIN) | sed -e 's/^\([0-9]\)/_\1/' | tr . _)`"_end[];" > `(echo $(CURBIN) | tr . _)`.h
echo "extern const u8" `(echo $(CURBIN) | sed -e 's/^\([0-9]\)/_\1/' | tr . _)`"[];" >> `(echo $(CURBIN) | tr . _)`.h
echo "extern const u32" `(echo $(CURBIN) | sed -e 's/^\([0-9]\)/_\1/' | tr . _)`_size";" >> `(echo $(CURBIN) | tr . _)`.h
picasso -o $(CURBIN) $1
bin2s $(CURBIN) | $(AS) -o $*.shbin.o
endef
%.shbin.o %_shbin.h : %.v.pica %.g.pica
@echo $(notdir $^)
@$(call shader-as,$^)
%.shbin.o %_shbin.h : %.v.pica
@echo $(notdir $<)
@$(call shader-as,$<)
%.shbin.o %_shbin.h : %.shlist
@echo $(notdir $<)
@$(call shader-as,$(foreach file,$(shell cat $<),$(dir $<)$(file)))
#---------------------------------------------------------------------------------
%.t3x %.h : %.t3s
#---------------------------------------------------------------------------------
@echo $(notdir $<)
@tex3ds -i $< -H $*.h -d $*.d -o $*.t3x
$(SILENTMSG) $(notdir $<)
$(bin2o)
-include $(DEPSDIR)/*.d

View File

@ -1,381 +0,0 @@
#include <renderd7/battery_icons.hpp>
unsigned char battery_icons[] = {
0x9, 0x0, 0x2c, 0x0, 0x0, 0x32, 0x0, 0x32, 0x0, 0x90, 0x1, 0xa8,
0x1, 0x20, 0x3, 0xe0, 0x0, 0x32, 0x0, 0x32, 0x0, 0x90, 0x1, 0x70,
0x2, 0x20, 0x3, 0xa8, 0x1, 0x32, 0x0, 0x32, 0x0, 0x90, 0x1, 0x38,
0x3, 0x20, 0x3, 0x70, 0x2, 0x32, 0x0, 0x32, 0x0, 0x90, 0x1, 0x0,
0x4, 0x20, 0x3, 0x38, 0x3, 0x32, 0x0, 0x32, 0x0, 0x0, 0x0, 0xe0,
0x0, 0x90, 0x1, 0x18, 0x0, 0x32, 0x0, 0x32, 0x0, 0x0, 0x0, 0xa8,
0x1, 0x90, 0x1, 0xe0, 0x0, 0x32, 0x0, 0x32, 0x0, 0x0, 0x0, 0x70,
0x2, 0x90, 0x1, 0xa8, 0x1, 0x32, 0x0, 0x32, 0x0, 0x0, 0x0, 0x38,
0x3, 0x90, 0x1, 0x70, 0x2, 0x32, 0x0, 0x32, 0x0, 0x0, 0x0, 0x0,
0x4, 0x90, 0x1, 0x38, 0x3, 0x11, 0x0, 0x0, 0x2, 0x40, 0x0, 0x5,
0x60, 0x0, 0x58, 0x31, 0x1f, 0xe4, 0xa8, 0x30, 0x21, 0x1f, 0xe5, 0x70,
0x6f, 0x7, 0x24, 0x24, 0xda, 0x0, 0xb0, 0x2b, 0xe1, 0x30, 0x97, 0xb0,
0x2f, 0xb0, 0xa7, 0x6, 0x2a, 0x2a, 0xd4, 0x70, 0xb7, 0x0, 0xfc, 0x2f,
0x20, 0xe4, 0xff, 0x30, 0x20, 0xe5, 0xbb, 0x70, 0x3, 0xb6, 0x20, 0xf,
0x30, 0x5b, 0x70, 0xb, 0xb2, 0x20, 0x73, 0x30, 0x1f, 0xec, 0x30, 0x33,
0x70, 0xb, 0xb0, 0x2f, 0x0, 0x7, 0x60, 0x0, 0x0, 0x71, 0xf, 0xb8,
0x30, 0x3, 0x1f, 0xe4, 0x8, 0x3f, 0x1f, 0xdf, 0x30, 0xe3, 0x30, 0xb,
0xe2, 0x71, 0xaf, 0x30, 0x13, 0x1, 0xf1, 0xbb, 0x6, 0xd4, 0xd4, 0x81,
0x37, 0x71, 0xc, 0xcb, 0xc8, 0xbf, 0xad, 0x20, 0x3, 0x5, 0x71, 0xff,
0x4f, 0xcb, 0x2, 0xc8, 0xbe, 0xcc, 0xcb, 0xc9, 0xc0, 0x72, 0x6f, 0xdd,
0x18, 0xcc, 0xc8, 0xbf, 0x30, 0x3, 0x0, 0x32, 0x7f, 0x11, 0xd2, 0xc3,
0x44, 0xc3, 0x32, 0x97, 0x34, 0xcd, 0xc9, 0x80, 0x9f, 0xbb, 0xcc, 0x31,
0xc8, 0xc0, 0x30, 0x3, 0x32, 0xaf, 0x35, 0xca, 0xca, 0x40, 0xb, 0x40,
0xc9, 0x20, 0x43, 0xf6, 0xcc, 0xc9, 0xbf, 0xff, 0xcc, 0x3e, 0xc9, 0xc0,
0x2, 0x70, 0x3, 0x1, 0x72, 0xff, 0xf0, 0xaf, 0x0, 0xb0, 0xbf, 0x0,
0x33, 0x53, 0xcb, 0x3, 0xcb, 0xc8, 0xc0, 0x4d, 0xcd, 0xca, 0x0, 0x0,
0x6f, 0x2, 0xb0, 0xbb, 0xb0, 0x70, 0xf7, 0xf5, 0x21, 0x4b, 0x71, 0x3,
0x10, 0xcf, 0xcf, 0xbf, 0xff, 0xb1, 0x3b, 0xf1, 0x1b, 0x31, 0x3b, 0x33,
0xf3, 0x31, 0x3b, 0x71, 0x4f, 0x9, 0x30, 0x3, 0xb1, 0xff, 0xdf, 0x34,
0xb3, 0x32, 0xbb, 0x70, 0x1, 0xa1, 0x7f, 0xb2, 0xfb, 0x10, 0x1f, 0x70,
0x7, 0x6, 0xb3, 0x13, 0xf6, 0xf, 0xff, 0x0, 0xf8, 0x87, 0xf6, 0xaf,
0xb6, 0xf, 0xb6, 0x2f, 0xf6, 0xf, 0xf6, 0x2f, 0x6, 0x75, 0xff, 0xf6,
0xef, 0xff, 0x76, 0xf, 0x3, 0x35, 0xff, 0x0, 0xb6, 0xf, 0x3, 0x76,
0xff, 0x4, 0x7a, 0x27, 0xf6, 0xaf, 0xfa, 0x8f, 0x0, 0x76, 0xaf, 0xff,
0xf6, 0xf, 0x0, 0xfa, 0xc7, 0xf6, 0x2f, 0x10, 0x20, 0x36, 0xf, 0x10,
0x12, 0x88, 0x47, 0xaf, 0x8f, 0xff, 0x6f, 0x0, 0xff, 0xbf, 0xfc, 0x6,
0xff, 0x7f, 0x3f, 0x57, 0xb0, 0x3, 0xff, 0x6f, 0xf0, 0xcf, 0xf0, 0x2f,
0x3, 0xaa, 0x10, 0xaa, 0xaa, 0xc0, 0x2e, 0x9b, 0x54, 0xbc, 0xb6, 0xc2,
0x80, 0x0, 0x3e, 0x87, 0xda, 0x48, 0x3a, 0xdf, 0xff, 0xc8, 0xc4, 0x47,
0xc1, 0x40, 0x67, 0x5c, 0x4f, 0xda, 0x8e, 0xab, 0x30, 0x13, 0x6e, 0x7f,
0xf0, 0x2, 0xb1, 0x3f, 0xf0, 0xbf, 0x40, 0x63, 0xa0, 0x6f, 0xd9, 0x4c,
0x3d, 0xde, 0x80, 0x31, 0x8f, 0x83, 0xc4, 0xc2, 0xc0, 0xff, 0x60, 0x53,
0x7f, 0xda, 0x0, 0x0, 0x2f, 0x4, 0x28, 0x7f, 0x2, 0x4f, 0x8f, 0x61,
0xf, 0x0, 0xf, 0xcb, 0xe0, 0xcf, 0x1, 0x0, 0x2f, 0xa7, 0x10, 0x5,
0xe0, 0x13, 0xbf, 0x2b, 0x6b, 0x2, 0xff, 0x20, 0x0, 0x2b, 0x73, 0x3a,
0xcf, 0xc9, 0x0, 0x3, 0x5f, 0x2b, 0x8b, 0x7b, 0xcb, 0x5b, 0x8f, 0x80,
0xcb, 0x0, 0x19, 0xe3, 0xfc, 0x3, 0x3a, 0xff, 0x30, 0x57, 0x0, 0xb0,
0x5f, 0x0, 0xb0, 0x1f, 0x10, 0x13, 0xff, 0xff, 0x76, 0xf, 0x4e, 0xca,
0x7f, 0xc7, 0x0, 0x4e, 0x5f, 0xb3, 0xb, 0x4, 0x3d, 0x7f, 0xb3, 0xb,
0x0, 0x3e, 0xdf, 0xf0, 0x1f, 0x10, 0x13, 0xf0, 0x3, 0xff, 0xf6, 0xf,
0x0, 0x39, 0x13, 0xf3, 0x3, 0x3, 0xf8, 0x83, 0x0, 0xf2, 0xe3, 0x10,
0x15, 0xb6, 0xf, 0x10, 0x2c, 0xf2, 0x5f, 0x4c, 0x7b, 0x3f, 0xc8, 0xc5,
0x99, 0x4f, 0x7f, 0x63, 0x20, 0x13, 0x3f, 0x6f, 0x0, 0x49, 0x6f, 0x30,
0x1b, 0xff, 0x6f, 0x77, 0x3, 0xf9, 0xef, 0x1, 0xf7, 0xb, 0x4f, 0x57,
0xb0, 0x3, 0xff, 0x6f, 0xe0, 0xcf, 0x0, 0x0, 0x2f, 0xff, 0x3, 0x3f,
0xbf, 0xa1, 0xf, 0x0, 0x0, 0x6f, 0x0, 0x3f, 0xe3, 0xb0, 0x2f, 0x3,
0x70, 0xbf, 0x6, 0xff, 0xff, 0x2, 0xb1, 0x3f, 0xff, 0x6, 0xeb, 0xc7,
0x2, 0xbf, 0x7f, 0x10, 0x1b, 0xff, 0xff, 0x1, 0xff, 0x7f, 0x10, 0x1b,
0xff, 0xff, 0x1, 0xff, 0x7f, 0x10, 0x5b, 0x4f, 0xff, 0x1, 0x2f, 0x7f,
0x0, 0xbb, 0x9b, 0xc5, 0x66, 0xff, 0x86, 0xc4, 0x3d, 0xf0, 0x8f, 0xa3,
0x30, 0xb, 0x20, 0xf, 0x2, 0xff, 0xff, 0xc0, 0x9a, 0xc4, 0x62, 0xf,
0xff, 0x81, 0xc4, 0x33, 0x70, 0x7, 0xf0, 0x3, 0x0, 0xf0, 0x1f, 0x1,
0x8e, 0xff, 0xff, 0x60, 0xaf, 0x0, 0x40, 0xf, 0x1, 0x3f, 0xbf, 0xf0,
0x2f, 0x70, 0x4f, 0x0, 0x30, 0x93, 0x5, 0xb0, 0x13, 0x3f, 0x57, 0xe0,
0xb0, 0x3, 0xff, 0x6f, 0x70, 0xcf, 0x84, 0xc0, 0x41, 0xff, 0x4a, 0x31,
0x51, 0xb2, 0x0, 0x0, 0x2f, 0x1, 0xbf, 0xbf, 0x48, 0x4e, 0xb6, 0x8f,
0xff, 0x11, 0x84, 0xbf, 0x42, 0x80, 0xff, 0x7f, 0xc0, 0x37, 0x81, 0xbb,
0x1f, 0x49, 0x51, 0xaf, 0x4f, 0xeb, 0x30, 0x13, 0x30, 0xb, 0x0, 0x31,
0xb3, 0xb0, 0x2f, 0x80, 0xf0, 0xbf, 0x47, 0x4e, 0xb3, 0xff, 0x7f, 0xbf,
0x38, 0xff, 0x80, 0xb, 0xf0, 0x4f, 0x0, 0x70, 0xbf, 0x2, 0xa1, 0xff,
0x1, 0x4f, 0xff, 0x22, 0xfb, 0x33, 0x3, 0x0, 0xf, 0xff, 0xff, 0x80,
0xd3, 0x20, 0xb3, 0x0, 0x32, 0x9f, 0xf0, 0xcf, 0x0, 0x20, 0x2f, 0xb3,
0x3, 0x0, 0x30, 0x5f, 0x0, 0xb0, 0x1f, 0xff, 0x10, 0xb2, 0xff, 0xff,
0x2, 0xff, 0x7f, 0x7, 0xf, 0xff, 0x10, 0x3, 0x30, 0x13, 0x2, 0xbf,
0xbf, 0x6, 0xf1, 0x93, 0x3f, 0x57, 0xb0, 0x3, 0xfe, 0xff, 0x6f, 0xf0,
0xcf, 0xf0, 0x2f, 0x7f, 0x7f, 0x2f, 0xbf, 0x0, 0x4f, 0x7f, 0x2f, 0xbf,
0xc2, 0x10, 0x95, 0xbd, 0x67, 0x3f, 0xbf, 0xed, 0x48, 0x44, 0xc8, 0x87,
0x7f, 0xff, 0x8, 0x3f, 0x1f, 0xdf, 0x8f, 0xff, 0x2, 0xb1, 0x3f, 0xe0,
0xbf, 0xe, 0xb8, 0x30, 0x1f, 0xe4, 0x30, 0x5b, 0x70, 0xb, 0xb1, 0x8f,
0xec, 0x1f, 0x4a, 0x48, 0xc4, 0xf0, 0xef, 0x7, 0x7f, 0xff, 0x71, 0xf,
0xff, 0xff, 0xf0, 0xcf, 0xc0, 0x0, 0xf0, 0x2f, 0x10, 0xe, 0xff, 0xff,
0xa2, 0xab, 0xc6, 0x84, 0xff, 0xa4, 0x3f, 0xc7, 0x75, 0x76, 0x97, 0x1,
0x6, 0xaf, 0x6, 0xff, 0xff, 0x20, 0xab, 0x40, 0x3, 0x77, 0x3b, 0xff,
0xf0, 0xf, 0x0, 0xf6, 0xb3, 0x2, 0xf0, 0x3f, 0x10, 0x4, 0x20, 0xff,
0x1, 0xcf, 0xff, 0x4, 0x21, 0xff, 0x43, 0x3, 0x1, 0x69, 0x93, 0x90,
0x10, 0x54, 0xff, 0xff, 0xbd, 0x99, 0x5f, 0xff, 0x90, 0x9f, 0xc6, 0x6a,
0x80, 0x4, 0x3f, 0xff, 0x10, 0x9f, 0xbf, 0x7f, 0xf8, 0x8b, 0xc4, 0x42,
0x46, 0x3d, 0x77, 0x23, 0xa0, 0xc4, 0x7b, 0x7f, 0xff, 0xce, 0x1, 0x97,
0xc6, 0x5e, 0xf3, 0x8e, 0xc4, 0x4c, 0x0, 0xfc, 0xdf, 0x87, 0x7, 0x7f,
0xff, 0xf5, 0x8d, 0xc4, 0x4a, 0x30, 0x3, 0xf0, 0xf, 0x1, 0x70, 0xbf,
0xc2, 0x2, 0xf0, 0x3f, 0x10, 0x2, 0xb0, 0xff, 0xc1, 0x96, 0xc0, 0x65,
0x7c, 0x53, 0xb2, 0x21, 0x30, 0x1f, 0x4f, 0x8f, 0x6, 0x2a, 0x2a, 0xd4,
0x40, 0xb, 0x87, 0xa3, 0x3, 0x8e, 0x9e, 0xc5, 0x6b, 0x3f, 0xff, 0x30,
0x1b, 0x0, 0xf1, 0xbf, 0xe0, 0x32, 0xbb, 0x32, 0xc3, 0x0, 0xff, 0x9f,
0xf7, 0x8c, 0xc5, 0x47, 0xe, 0x1, 0xb6, 0xc8, 0x6d, 0x21, 0xaa, 0xc1,
0x73, 0x2, 0x3f, 0xcb, 0xfc, 0x3f, 0x57, 0xb0, 0x3, 0xff, 0x6f, 0x0,
0x0, 0xcf, 0xe0, 0x2f, 0x3, 0x3f, 0xbf, 0x7, 0x24, 0x21, 0x24, 0xda,
0x7f, 0xfb, 0xb6, 0x2f, 0x20, 0xe4, 0x3f, 0xeb, 0xfa, 0x30, 0x13, 0x30,
0xb, 0x0, 0x3f, 0xe3, 0xb0, 0x2f, 0xb0, 0xbf, 0xfc, 0x20, 0x3b, 0xa8,
0xcf, 0x21, 0x7f, 0x3f, 0xff, 0x58, 0x31, 0x50, 0x6b, 0x30, 0xf, 0x70,
0xb, 0x10, 0x6, 0x36, 0xf, 0xff, 0xff, 0xff, 0xf6, 0xf, 0x3, 0xff,
0xff, 0xf6, 0xf, 0x9, 0x75, 0xff, 0x76, 0xaf, 0x10, 0xa, 0x35, 0xff,
0x0, 0xbf, 0x5f, 0xfc, 0x0, 0xb9, 0x13, 0x36, 0xf, 0x3, 0x77, 0xff,
0x76, 0x2f, 0x2, 0xf6, 0xf, 0x10, 0x69, 0x30, 0x33, 0x11, 0xd2, 0x21,
0xc3, 0xc3, 0x3f, 0xff, 0x34, 0xcd, 0xc9, 0xbf, 0x7f, 0xdf, 0x0, 0x4f,
0xcb, 0xc8, 0xbe, 0xcc, 0xcb, 0xc9, 0xc0, 0x84, 0x7f, 0xef, 0xdd, 0xcc,
0xc8, 0xbf, 0x30, 0x3, 0xf6, 0xcc, 0x3, 0xc9, 0xbf, 0xff, 0xcc, 0xc9,
0xc0, 0x0, 0x70, 0x3, 0x7, 0x7d, 0x17, 0xf0, 0x70, 0xaf, 0xf0, 0xbf,
0x0, 0xb0, 0xbb, 0xb0, 0xbf, 0xcb, 0xcb, 0xc8, 0xc0, 0x1a, 0x4d, 0xcd,
0xca, 0x0, 0x0, 0xcf, 0x30, 0xfb, 0xf5, 0xa0, 0x47, 0x10, 0x1f, 0xcf,
0xcf, 0xbf, 0xf1, 0x3b, 0x10, 0x3c, 0x39, 0x27, 0xb6, 0xf, 0xb6, 0x2f,
0xf6, 0xf, 0xff, 0xb, 0x75, 0xff, 0xf6, 0x3f, 0x76, 0xf, 0x0, 0x36,
0xfb, 0xb6, 0xf, 0x8, 0xff, 0x23, 0x10, 0x3d, 0x76, 0xaf, 0x10, 0xb,
0x3f, 0xff, 0x8, 0x6, 0xd4, 0xd4, 0xd4, 0x7f, 0xff, 0x71, 0xcb, 0xc8,
0x20, 0xbf, 0xad, 0x20, 0x3, 0x3, 0xaa, 0xaa, 0xaa, 0xc0, 0x2, 0xcc,
0xc8, 0xc0, 0x4e, 0xca, 0xc7, 0x4, 0x4e, 0x7f, 0x7b, 0x4f, 0xcb, 0x5e,
0xdb, 0x80, 0xcb, 0x0, 0x5e, 0xe7, 0x70, 0x17, 0x0, 0x70, 0x1f, 0x7f,
0xff, 0x71, 0xbb, 0x20, 0xa3, 0x30, 0x3, 0x3f, 0xff, 0x35, 0xca, 0xca,
0x40, 0xb, 0x7f, 0xc9, 0x1, 0x2e, 0x7f, 0xf, 0xf0, 0x1f, 0x31, 0x3b,
0x3f, 0xff, 0x31, 0x3b, 0x31, 0x53, 0x8, 0xf1, 0x3f, 0xee, 0x0, 0x31,
0xff, 0x3f, 0xff, 0x32, 0xbb, 0x70, 0x1, 0xaa, 0x7f, 0xb2, 0xfb, 0xbf,
0xff, 0xbf, 0x9f, 0x2b, 0x6b, 0x2, 0xff, 0x20, 0x0, 0x2b, 0x73, 0x3a,
0x8f, 0xff, 0xff, 0x3, 0x32, 0x5f, 0xff, 0xb3, 0x3, 0x0, 0x30, 0x5f,
0xb3, 0x3, 0x10, 0x16, 0x76, 0xf, 0x7f, 0xff, 0xf6, 0xf, 0x3, 0xff,
0xff, 0xf6, 0xf, 0xff, 0xff, 0xff, 0xf6, 0xf, 0xf6, 0xaf, 0xf6, 0xf,
0x1, 0x3e, 0x7f, 0x10, 0x2, 0xb6, 0x2f, 0x7, 0xf6, 0xaf, 0x2, 0x31,
0xff, 0xff, 0xb6, 0x2f, 0xf9, 0xb, 0xf8, 0xf3, 0xf6, 0xf, 0x4, 0x38,
0x5f, 0x1, 0xb9, 0x13, 0x10, 0x52, 0xff, 0xff, 0x0, 0xff, 0x5f, 0xff,
0x1, 0x7f, 0x7f, 0x6, 0x70, 0x7f, 0x10, 0x13, 0x30, 0x13, 0x0, 0xbf,
0x5f, 0x1, 0x30, 0x1f, 0x6, 0xb0, 0x7f, 0x10, 0x14, 0xf6, 0xf, 0x1,
0xf0, 0x1f, 0x82, 0x4, 0xf0, 0x7f, 0x8d, 0xbd, 0xc8, 0xa4, 0xff, 0x20,
0x3, 0xc0, 0x1, 0x9a, 0xc4, 0x62, 0xff, 0x81, 0xc4, 0x33, 0x9, 0xf,
0xaf, 0xff, 0x60, 0xaf, 0x40, 0xab, 0x30, 0xaf, 0xf0, 0xf, 0x4, 0xf0,
0x3f, 0x10, 0x2, 0x20, 0xff, 0x3, 0xc8, 0x93, 0x2, 0x21, 0xff, 0xdf,
0xc9, 0x93, 0x0, 0x22, 0x3f, 0x8d, 0x62, 0x4f, 0x33, 0x3, 0x10, 0xb3,
0xff, 0xff, 0x7f, 0x57, 0x7f, 0x5f, 0xfe, 0x1, 0xf0, 0x1f, 0x5, 0xf0,
0x7f, 0x10, 0x14, 0x30, 0x3, 0x0, 0xf2, 0x63, 0x4, 0xf2, 0x83, 0x1,
0xb0, 0x7f, 0x11, 0x5a, 0xff, 0xff, 0x7d, 0x42, 0xcc, 0x5f, 0xff, 0x57,
0xcd, 0xca, 0xc1, 0x0, 0x3f, 0xff, 0x8, 0x2, 0xbf, 0xbf, 0xbf, 0xd4,
0xcc, 0xc8, 0x40, 0x67, 0x12, 0x10, 0xc6, 0xc6, 0xc6, 0x7f, 0xff, 0x8f,
0xcb, 0xc9, 0xc0, 0x27, 0xc7, 0xcb, 0x9, 0x9f, 0xff, 0xcc, 0xcb, 0x50,
0x3, 0x0, 0x70, 0xf, 0x4, 0xf0, 0x3f, 0xf6, 0x10, 0x0, 0xb0, 0xff,
0x5, 0x3f, 0xff, 0xf1, 0xff, 0x32, 0xbb, 0x8f, 0x62, 0xbf, 0x73, 0x3,
0x55, 0xa0, 0x0, 0x23, 0x4f, 0xd3, 0x22, 0xfb, 0x7, 0xda, 0xda, 0xb6,
0x11, 0x19, 0xd2, 0xc3, 0xc3, 0x10, 0x15, 0x39, 0xeb, 0x6, 0xff, 0xff,
0xbd, 0x99, 0x5f, 0xff, 0x8, 0x90, 0x9f, 0xc6, 0x6a, 0x0, 0x3f, 0xff,
0x10, 0x9f, 0xbf, 0x4, 0x7f, 0xf8, 0x8b, 0xc4, 0x46, 0x3c, 0xf7, 0x23,
0xa0, 0x20, 0xc4, 0x7b, 0x9, 0x7f, 0xff, 0xce, 0x97, 0xc6, 0x5e, 0xf3,
0x10, 0x8e, 0xc4, 0x4c, 0x7f, 0xff, 0xf5, 0x8d, 0xc4, 0x4a, 0xff, 0x30,
0x3, 0x1, 0x7f, 0xff, 0xf0, 0x2f, 0x1, 0xf0, 0x3f, 0x6, 0xff, 0xff,
0x2, 0xf0, 0xbf, 0x5, 0xb0, 0xff, 0x4, 0x3f, 0xff, 0xc3, 0x1, 0xb1,
0xbf, 0x73, 0x3, 0x8e, 0x9e, 0xc5, 0x6b, 0x7f, 0xff, 0x32, 0x3b, 0x80,
0x32, 0x43, 0xf7, 0x8c, 0xc5, 0x47, 0xe, 0xb6, 0xc8, 0x2, 0x6d, 0x21,
0xaa, 0xc1, 0x73, 0x0, 0x10, 0x6d, 0xa0, 0x0, 0x4f, 0x90, 0x2b, 0x93,
0xcc, 0x80, 0x9b, 0x8f, 0xdd, 0x81, 0xc4, 0x32, 0xf0, 0x30, 0x3, 0x9,
0x7e, 0x13, 0xf0, 0xaf, 0x1, 0xf0, 0xbf, 0xcb, 0x81, 0xc3, 0x33, 0x8,
0x4d, 0x81, 0xc3, 0x31, 0x10, 0x3f, 0x86, 0xf, 0xcb, 0xc8, 0xbe, 0x8,
0xcc, 0xcb, 0xc9, 0xc0, 0x9, 0x85, 0xff, 0xcc, 0xc8, 0xbf, 0xe0, 0x30,
0x3, 0x0, 0x70, 0xf, 0x1, 0xf0, 0x3f, 0xcb, 0xcb, 0xc8, 0xc0, 0x4d,
0x10, 0xcd, 0xca, 0xc0, 0x10, 0x65, 0xbf, 0x3, 0x6, 0x7f, 0xd4, 0x2a,
0xac, 0x7f, 0xff, 0x71, 0x2e, 0x8b, 0xad, 0x2e, 0x93, 0x2, 0xff, 0xff,
0x3, 0xaa, 0x0, 0xaa, 0x55, 0xc0, 0x80, 0xc4, 0x32, 0x4e, 0x7f, 0x19,
0xc4, 0x34, 0xff, 0x2e, 0xe3, 0xf0, 0x3, 0x7b, 0x80, 0x50, 0x13, 0x70,
0x80, 0x2d, 0xff, 0x0, 0x30, 0x1f, 0x0, 0x3f, 0xff, 0x11, 0x87, 0xc3,
0x2d, 0x8a, 0x3f, 0xff, 0x34, 0x7f, 0xc4, 0x8e, 0x2f, 0xbb, 0x2f, 0x2f,
0xbb, 0x84, 0x6f, 0x2f, 0x35, 0x81, 0xc5, 0x34, 0x30, 0xf, 0xc9, 0x81,
0x3, 0xc3, 0x32, 0xf6, 0x80, 0xc3, 0x32, 0x0, 0x30, 0x77, 0xd, 0xb0,
0x13, 0x43, 0xf5, 0xa1, 0x5b, 0x10, 0x7f, 0xbf, 0x2f, 0xb1, 0x3b, 0xf1,
0x93, 0xff, 0x31, 0x3b, 0x3f, 0xff, 0x31, 0x3b, 0x31, 0x53, 0x6, 0xf1,
0x3b, 0x1, 0x7f, 0xff, 0xb1, 0xff, 0x3f, 0xff, 0xbd, 0x32, 0xbb, 0x70,
0x21, 0xff, 0x2, 0x32, 0xfb, 0xbf, 0xff, 0x2, 0xf2, 0x3b, 0xbf, 0x22,
0x97, 0x10, 0x2, 0x7f, 0xff, 0x41, 0x67, 0x4d, 0x81, 0xc3, 0x31, 0xe3,
0x0, 0x30, 0x5f, 0xb3, 0x3, 0x10, 0x17, 0xc6, 0xf, 0xd4, 0xd4, 0xd4,
0x3, 0xff, 0xff, 0x26, 0xf, 0x0, 0xaa, 0xc0, 0xcc, 0xc8, 0xc0, 0x4e,
0xca, 0xc7, 0x16, 0xc0, 0xff, 0xcc, 0x0, 0x1e, 0xdf, 0x7b, 0x2e, 0xf3,
0x30, 0x17, 0x80, 0x18, 0xcb, 0xc9, 0xbf, 0x0, 0x30, 0x1f, 0x0, 0x7f,
0xff, 0x71, 0xcb, 0xc8, 0x3e, 0xbf, 0xad, 0x20, 0x3, 0x86, 0xf, 0x20,
0x63, 0x30, 0x3, 0x46, 0x2f, 0xd2, 0x20, 0xc3, 0xc3, 0x46, 0x2f, 0xcd,
0xc9, 0xbf, 0xf6, 0xcc, 0xe5, 0x50, 0x57, 0x70, 0x3, 0x46, 0x2f, 0xca,
0xca, 0x40, 0x2b, 0xc9, 0x2e, 0xc3, 0xd0, 0xb0, 0x1b, 0xc, 0x70, 0xb,
0xf5, 0x9, 0xa0, 0xe7, 0x10, 0xcf, 0xcf, 0xbf, 0xff, 0x71, 0xbb, 0x0,
0x3f, 0xff, 0x31, 0xbb, 0x46, 0xaf, 0x21, 0xbb, 0x71, 0xef, 0xf1, 0xff,
0x1, 0x3f, 0xff, 0xba, 0x32, 0x3b, 0x70, 0x21, 0xff, 0xf2, 0xfb, 0x3,
0xf2, 0xf, 0xbf, 0x22, 0xf3, 0x2, 0x63, 0xff, 0x20, 0x0, 0x22, 0xfb,
0x4d, 0xcd, 0xca, 0x0, 0x42, 0x6b, 0xb3, 0x3, 0xfd, 0x10, 0x52, 0xff,
0xff, 0x7f, 0x57, 0x0, 0x7f, 0x5f, 0x0, 0xf0, 0x1f, 0x6, 0xf0, 0x7f,
0x6, 0xcf, 0xbb, 0x80, 0x4, 0x60, 0x93, 0x0, 0x7d, 0xbe, 0x31, 0xff,
0x7f, 0xc1, 0x32, 0xff, 0x18, 0x7a, 0xba, 0x31, 0xc0, 0x67, 0x30, 0x17,
0x7b, 0xbc, 0x31, 0x0, 0xff, 0x75, 0xb1, 0x2f, 0xff, 0x78, 0xb6, 0x30,
0xa, 0xff, 0x62, 0xb8, 0x55, 0xd0, 0x8f, 0xc2, 0x9f, 0xff, 0x7e, 0x2,
0xbf, 0x32, 0xff, 0x7e, 0xc0, 0x32, 0x40, 0x47, 0x7b, 0x40, 0xba, 0x90,
0x37, 0x77, 0xb5, 0x2f, 0xff, 0x79, 0xb7, 0x0, 0x30, 0xff, 0x58, 0xbe,
0x6d, 0xff, 0x6c, 0xb3, 0x48, 0x3e, 0x1, 0x0, 0xcb, 0x7c, 0xbc, 0x50,
0x83, 0x7a, 0xb9, 0x30, 0x18, 0xff, 0x7f, 0xc2, 0x0, 0x1f, 0xef, 0x70,
0x87, 0x71, 0xb0, 0x31, 0x0, 0xff, 0x2b, 0xd7, 0xd5, 0xff, 0x1b, 0xe0,
0xfa, 0x8, 0xff, 0x5f, 0xba, 0x5c, 0x20, 0x7, 0xfb, 0xff, 0x70, 0x0,
0xb1, 0x35, 0xff, 0x45, 0xc9, 0x98, 0xff, 0x19, 0x30, 0xe1, 0xfe, 0x40,
0x17, 0x30, 0x7, 0x29, 0xd8, 0xd8, 0xff, 0x0, 0x74, 0xb0, 0x2e, 0xff,
0x3b, 0xce, 0xae, 0xff, 0x3f, 0x75, 0xb2, 0x50, 0x8b, 0x70, 0xa3, 0xb0,
0xbf, 0x7f, 0xff, 0x30, 0xef, 0x40, 0x87, 0x3f, 0xbd, 0x31, 0x4, 0x71,
0xff, 0xb3, 0x3, 0x0, 0x3f, 0xdf, 0x0, 0xf0, 0x1f, 0x6, 0xb0, 0x7f,
0x10, 0x14, 0x6, 0xf, 0xc0, 0x6f, 0x57, 0x0, 0x7f, 0x5f, 0x99, 0xb4,
0xc8, 0x91, 0xff, 0xae, 0x3, 0xc7, 0x87, 0xc0, 0x9a, 0xc4, 0x62, 0x3,
0x35, 0xff, 0xff, 0xff, 0xff, 0x70, 0x57, 0x0, 0x70, 0x5f, 0xf0, 0x1f,
0x1, 0xf, 0x8f, 0x20, 0xab, 0x40, 0x3, 0x76, 0xdb, 0xf0, 0xf, 0xff,
0x2, 0xf0, 0x3f, 0x6, 0xf6, 0x93, 0x10, 0x4, 0x20, 0xff, 0xc3, 0x3,
0x0, 0x22, 0x3f, 0x43, 0x3, 0xb2, 0x83, 0x3, 0xe8, 0x97, 0xfe, 0x0,
0x2, 0xe3, 0x0, 0xa0, 0x1f, 0x10, 0x60, 0xcf, 0xff, 0x0, 0x7f, 0x9f,
0xbf, 0x5f, 0x7f, 0x67, 0x7f, 0x57, 0x71, 0x20, 0xb0, 0x33, 0x2e, 0xa3,
0xd9, 0xff, 0x44, 0xc8, 0x99, 0xd7, 0x4e, 0xb7, 0x5f, 0x67, 0x56, 0x2e,
0xdf, 0x34, 0x40, 0x17, 0x7e, 0xc7, 0x70, 0x3, 0xe3, 0xcf, 0x9f, 0x2f,
0x73, 0xbf, 0x9f, 0x61, 0xb9, 0x59, 0xcf, 0x43, 0x3f, 0xd7, 0x8c, 0x3f,
0xbb, 0x34, 0xd2, 0xbe, 0x4f, 0xbf, 0x30, 0x53, 0x44, 0xc9, 0x58, 0x9b,
0x6f, 0x1f, 0xfb, 0xc0, 0x57, 0xf0, 0xb, 0x6d, 0xb2, 0x3c, 0xe2, 0x40,
0x3, 0x0, 0x70, 0xf, 0x70, 0x93, 0x4d, 0xc4, 0x85, 0x4f, 0xe3, 0x5f,
0x31, 0xba, 0x5b, 0x4f, 0xe7, 0xb0, 0x5b, 0x29, 0xd8, 0xd7, 0x4f, 0x93,
0xe7, 0x3f, 0x6b, 0x3f, 0x83, 0x3f, 0x73, 0x7e, 0xbf, 0x5f, 0xd3, 0x3f,
0x83, 0x0, 0x41, 0x43, 0x74, 0xc2, 0x51, 0x47, 0x3f, 0x9f, 0x4f, 0xa3,
0xc3, 0x6f, 0x97, 0xbb, 0x31, 0xf1, 0x4f, 0x93, 0x3f, 0xdb, 0x3f, 0xcb,
0x71, 0x13, 0x73, 0xaf, 0x2e, 0x40, 0x3, 0x8e, 0xf0, 0xcb, 0x3a, 0xcf,
0xb2, 0x0, 0x40, 0xdf, 0xf0, 0x2f, 0x30, 0x3f, 0x78, 0x8c, 0x20, 0xb7,
0x36, 0xd1, 0xbb, 0x41, 0x8f, 0x31, 0x83, 0x1a, 0xe0, 0x40, 0xfc, 0x41,
0x8b, 0x3f, 0xcc, 0xa5, 0xff, 0x5c, 0xbb, 0x4f, 0x62, 0x40, 0xdf, 0x74,
0xb1, 0x20, 0xbf, 0x61, 0x57, 0x2, 0xb2, 0xb, 0x2, 0xff, 0xff, 0xff,
0x31, 0xf3, 0xb1, 0xe3, 0x0, 0x32, 0x6b, 0x71, 0x47, 0x10, 0x19, 0x2f,
0xff, 0x1, 0xff, 0x7f, 0x7, 0xf, 0xff, 0x10, 0x14, 0x20, 0x3, 0xff,
0x1, 0xbf, 0x7f, 0x10, 0x67, 0x4f, 0xff, 0xbf, 0xe7, 0x3f, 0x6b, 0x3e,
0xdf, 0x0, 0xed, 0x73, 0x8e, 0xeb, 0x3f, 0xfb, 0xef, 0x3f, 0xff, 0x3e,
0xe7, 0x3f, 0x3, 0x7a, 0xaf, 0x1b, 0x3f, 0xf3, 0xbf, 0x1b, 0x3f, 0x2b,
0x88, 0x3f, 0x53, 0x60, 0xba, 0x59, 0x4f, 0x63, 0x4e, 0xc4, 0x83, 0xf0,
0x3, 0x4a, 0x83, 0x3f, 0x47, 0x4f, 0x53, 0x2e, 0xcf, 0x76, 0xb3, 0x2f,
0xff, 0x11, 0x3c, 0xce, 0xac, 0x4f, 0x9f, 0x2a, 0xd8, 0xd6, 0x4f, 0x7f,
0xc4, 0x3f, 0xaf, 0x3f, 0x9f, 0x79, 0xb8, 0x30, 0x40, 0x93, 0x1b, 0xe0,
0x7, 0xf9, 0xff, 0x61, 0xb9, 0x59, 0x4f, 0x17, 0x30, 0x23, 0x5f, 0xe3,
0x70, 0xf9, 0x0, 0xf, 0x73, 0x7f, 0x37, 0xff, 0x8b, 0x40, 0xcb, 0xa3,
0xff, 0x1, 0x25, 0xdb, 0xe3, 0xff, 0x6f, 0xb2, 0x38, 0x80, 0x7, 0x20,
0x5d, 0xbc, 0x5f, 0x57, 0x7a, 0xb9, 0x30, 0xff, 0x7e, 0x3e, 0xc0, 0x32,
0x80, 0x93, 0x7f, 0x67, 0x70, 0x17, 0xfe, 0xc7, 0xbf, 0x9f, 0x41, 0x2,
0xcb, 0xa1, 0xff, 0x5d, 0xbb, 0x61, 0xcf, 0x9f, 0x25, 0x0, 0xda, 0xe2,
0xff, 0x6f, 0xb1, 0x37, 0xff, 0x5e, 0x3f, 0xbb, 0x5e, 0x0, 0x40, 0x5f,
0x70, 0xfb, 0x0, 0xaf, 0x9f, 0x4, 0xfb, 0xe7, 0x2, 0xcf, 0xff, 0x6,
0xe0, 0x7f, 0xa1, 0x10, 0xbc, 0xff, 0xff, 0x7d, 0x6f, 0xdb, 0x57, 0x80,
0xc4, 0x31, 0x4, 0x4e, 0x1f, 0xd0, 0x7f, 0x57, 0x3e, 0x7f, 0x7c, 0x2f,
0x7f, 0x6a, 0xb4, 0x44, 0xff, 0x4, 0x52, 0xc1, 0x7a, 0xff, 0x78, 0x2f,
0xe7, 0x77, 0xb4, 0x41, 0x2f, 0x0, 0xe, 0x9b, 0x7e, 0xbf, 0x32, 0xff,
0x7d, 0x20, 0x3, 0x88, 0x7, 0x7a, 0x7b, 0x75, 0xb1, 0x2f, 0x4f, 0x9f,
0x7b, 0xba, 0x31, 0xc7, 0x40, 0xcb, 0xff, 0x47, 0x7f, 0xc2, 0x32, 0x10,
0x0, 0xfb, 0x27, 0x8, 0xff, 0xff, 0x73, 0x3, 0x48, 0x55, 0x10, 0x1f,
0x2f, 0xff, 0xbd, 0x99, 0x5f, 0xff, 0x90, 0x9f, 0xc6, 0x61, 0x6a, 0x10,
0x1e, 0x7f, 0xff, 0x73, 0x3, 0x8e, 0x9e, 0xc5, 0x6b, 0x10, 0x52, 0xff,
0xff, 0x0, 0x8, 0x7f, 0xbf, 0x3f, 0xd4, 0x80, 0xc4, 0x32, 0x84, 0x3f,
0xc7, 0x12, 0x7f, 0xc6, 0x38, 0x7f, 0xff, 0x8f, 0x80, 0x1c, 0xc4, 0x33,
0xc7, 0x4, 0x29, 0xdf, 0x3, 0xfc, 0xbf, 0x7f, 0xff, 0xcc, 0x80, 0xf6,
0x50, 0x3, 0xf0, 0xf, 0x4, 0xf0, 0x3f, 0x10, 0x8, 0x70, 0xff, 0xc7,
0x62, 0xc3, 0x0, 0xff, 0x2f, 0xd3, 0x0, 0x81, 0xc3, 0x32, 0x7, 0x91,
0xb6, 0x24, 0x11, 0x10, 0x87, 0xc3, 0x2d, 0x10, 0x1f, 0x39, 0x4b, 0x10,
0x9f, 0xbf, 0x7f, 0x8, 0xf8, 0x8b, 0xc4, 0x46, 0x3f, 0xf7, 0x23, 0xa0,
0xc4, 0x40, 0x7b, 0x9, 0x75, 0xff, 0xce, 0x97, 0xc6, 0x5e, 0xf3, 0x8e,
0x21, 0xc4, 0x4c, 0x7f, 0xff, 0xf5, 0x8d, 0xc4, 0x4a, 0x30, 0x3, 0xff,
0x1, 0x76, 0x3f, 0x70, 0x2f, 0x1, 0xf0, 0x3f, 0x7, 0x76, 0xff, 0x2,
0x70, 0xbf, 0xf, 0x70, 0xff, 0x32, 0x3b, 0x32, 0x43, 0x0, 0xf7, 0x8c,
0xc5, 0x47, 0xe, 0xb6, 0xc8, 0x6d, 0x4, 0x21, 0xaa, 0xc1, 0x73, 0x0,
0x10, 0x65, 0xe0, 0x0, 0x6, 0xd4, 0x20, 0xd4, 0xd4, 0x7f, 0xff, 0x71,
0xcb, 0xc8, 0xbf, 0xad, 0x80, 0x20, 0x3, 0x3, 0xaa, 0xaa, 0xaa, 0xc0,
0xcc, 0xc8, 0x0, 0xc0, 0x4e, 0xca, 0xc7, 0xc0, 0xff, 0xcc, 0xc9, 0xc2,
0x0, 0x0, 0x3, 0x2, 0x3f, 0x9f, 0x11, 0xd2, 0xc3, 0xc3, 0x3f, 0xff,
0x34, 0x10, 0xcd, 0xc9, 0xbf, 0x7f, 0xdf, 0x4f, 0xcb, 0xc8, 0xbe, 0x21,
0xcc, 0xcb, 0x90, 0x4f, 0xdd, 0xcc, 0xc8, 0xbf, 0x30, 0x3, 0xd, 0xf6,
0xcc, 0xc9, 0xbf, 0x0, 0x30, 0x77, 0xf0, 0x7f, 0xbb, 0x20, 0xa3, 0xc5,
0x30, 0x3, 0x3f, 0xff, 0x35, 0xca, 0xca, 0x40, 0xb, 0xc9, 0x20, 0x43,
0xf8, 0x0, 0xb0, 0x3b, 0x3, 0x30, 0x1b, 0xf0, 0xaf, 0xf0, 0xbf, 0x1,
0x70, 0x3f, 0xcb, 0xcb, 0xc8, 0xd, 0xc0, 0x4d, 0xcd, 0xca, 0x0, 0x1,
0x4f, 0x31, 0x73, 0xf5, 0xa0, 0xc7, 0xf, 0x10, 0xcf, 0xcf, 0xbf, 0xb1,
0x3b, 0x3, 0xf0, 0xdf, 0x31, 0x3b, 0x3f, 0xff, 0xfe, 0x31, 0x3b, 0x31,
0x53, 0x1, 0x70, 0xff, 0x6, 0xff, 0xbb, 0xb1, 0xff, 0x3f, 0xff, 0x32,
0xbb, 0x70, 0xe9, 0x1, 0xa1, 0x7f, 0xb2, 0xfb, 0xbf, 0xff, 0xbf, 0x22,
0xf3, 0x2, 0xff, 0x20, 0x0, 0xe3, 0x22, 0xfb, 0x0, 0x31, 0x9f, 0x10,
0x1c, 0xc6, 0xf, 0x7f, 0xd4, 0x2a, 0xff, 0xff, 0x26, 0xf, 0x0, 0x55,
0xc0, 0x80, 0xc4, 0x32, 0x4e, 0x7f, 0xc4, 0x69, 0x34, 0x3f, 0xfb, 0x4,
0x7f, 0x9f, 0x4f, 0x2f, 0x57, 0xcc, 0x80, 0x50, 0x5f, 0x8, 0x11, 0x87,
0xc3, 0x2d, 0x46, 0x2f, 0x7f, 0xc4, 0x31, 0xd, 0xf6, 0x80, 0xc3, 0x32,
0x7f, 0x73, 0xb0, 0x7f, 0x71, 0x20, 0x2b, 0x43, 0xad, 0xa0, 0x8f, 0xbb,
0x81, 0xc4, 0x32, 0x30, 0x3, 0xb0, 0x2b, 0xc4, 0x0, 0x30, 0xb, 0x46,
0x2f, 0x81, 0xc5, 0x34, 0x30, 0x2f, 0xc9, 0x81, 0xfe, 0xd0, 0x5b, 0x1,
0x30, 0xb, 0x86, 0xaf, 0x20, 0x6f, 0x30, 0x3, 0xf0, 0xf, 0x2, 0x70,
0x3f, 0xcb, 0x1, 0x81, 0xc3, 0x33, 0x4d, 0x81, 0xc3, 0x31, 0x0, 0x30,
0xbf, 0x78, 0xf5, 0x20, 0x1b, 0x1, 0xf0, 0xa7, 0x4, 0x70, 0x2f, 0x0,
0xff, 0xdf, 0x10, 0x7f, 0xbf, 0x7f, 0x2f, 0x71, 0xbb, 0x4, 0x3f, 0xcf,
0x31, 0xbb, 0x46, 0xaf, 0x21, 0xbb, 0x31, 0xf3, 0x2, 0x31, 0xff, 0xdd,
0x46, 0x2f, 0x22, 0xcb, 0x70, 0x21, 0xff, 0xf2, 0xfb, 0xf2, 0x3f, 0xbf,
0x22, 0x57, 0x1c, 0x2, 0x7f, 0xff, 0x40, 0x17, 0x31, 0x9f, 0x10, 0x52,
0xff, 0xff, 0x7b, 0xcb, 0x9f, 0x5f, 0x53, 0x80, 0xcb, 0x0, 0x5e, 0xe7,
0x70, 0x17, 0x0, 0x70, 0x1f, 0x2, 0xff, 0xff, 0x0, 0xf0, 0x5f, 0xc0,
0x0, 0xf0, 0x7f, 0xe, 0x0, 0x13, 0xc8, 0xc5, 0xc2, 0xff, 0xa4, 0x9f,
0x0, 0xcd, 0xff, 0xa1, 0x9c, 0xce, 0xff, 0x49, 0x3d, 0x47, 0xed, 0x9,
0x1, 0x13, 0xa0, 0x9a, 0xcf, 0x40, 0x3, 0x30, 0xab, 0x30, 0xaf, 0x1,
0xa4, 0x9e, 0xce, 0xff, 0xc9, 0xc6, 0xc1, 0x40, 0xbb, 0x1f, 0xa7, 0xa0,
0xcd, 0x7, 0x31, 0xd3, 0xb3, 0x3, 0xff, 0xff, 0xf3, 0x3, 0x0, 0x30,
0x1f, 0xf5, 0x2, 0xf2, 0x97, 0x0, 0xf0, 0x5f, 0x0, 0xb0, 0x7f, 0x10,
0x14, 0x6, 0xf, 0x80, 0x5e, 0xdb, 0x80, 0x6d, 0xe3, 0xff, 0x0, 0x5,
0xaf, 0x6d, 0xfb, 0x0, 0x70, 0x1f, 0x3, 0x6, 0xf, 0x0, 0xe0, 0x5f,
0xf0, 0x7f, 0x10, 0x14, 0x30, 0x3, 0xf3, 0x3, 0xff, 0xff, 0xc3, 0x4,
0xf2, 0x83, 0x0, 0xf2, 0xe3, 0xb3, 0x83, 0x10, 0x52, 0xff, 0xff, 0x2,
0xff, 0x7f, 0xc, 0xf, 0xff, 0x7f, 0x57, 0x11, 0xa7, 0xa1, 0xcd, 0x0,
0x4f, 0x5f, 0xac, 0xa6, 0xcc, 0x4f, 0x77, 0x11, 0xb1, 0xac, 0xc9, 0x4,
0x4f, 0x7f, 0xb6, 0xb1, 0xc8, 0x4f, 0xd7, 0x11, 0xbb, 0xb6, 0xc6, 0x0,
0x4f, 0xdf, 0xbf, 0xbb, 0xc4, 0x4f, 0xf7, 0x1e, 0xc4, 0xc1, 0xc3, 0x8f,
0x53, 0xf0, 0x7, 0x3f, 0x57, 0x3f, 0x6f, 0xac, 0x31, 0xa7, 0xcb, 0x0,
0x40, 0x23, 0x70, 0xbb, 0xb6, 0xb2, 0xc7, 0x3, 0xf, 0xff, 0x92, 0x0,
0x30, 0x83, 0xbb, 0xb8, 0x50, 0xbb, 0xc0, 0xbd, 0x0, 0x50, 0xa3, 0xc5,
0x23, 0xc3, 0xc2, 0x4f, 0xff, 0xcb, 0xc8, 0xc1, 0x7, 0x3f, 0xff, 0x2,
0xbf, 0x7f, 0xf8, 0x10, 0x1b, 0xff, 0xff, 0x1, 0xff, 0x7f, 0x10, 0x1c,
0x3f, 0xff, 0x1, 0xbf, 0x7f, 0x10, 0x6c, 0xf, 0xff, 0xc9, 0xc5, 0xc1,
0x88, 0x8f, 0xf7, 0x4b, 0x3f, 0xec, 0x0, 0x4f, 0xdf, 0x4f, 0x44, 0xeb,
0x88, 0x4f, 0xf7, 0x54, 0x49, 0xe9, 0x4, 0x4e, 0xbf, 0x83, 0x7b, 0xd9,
0x80, 0x0, 0xcf, 0x97, 0xcb, 0xc8, 0xc0, 0xff, 0xc5, 0xc1, 0xc2, 0x9,
0xff, 0x67, 0x5e, 0xe2, 0x0, 0xf, 0xff, 0x4d, 0x41, 0x50, 0xb3, 0x11,
0x52, 0x47, 0xea, 0x0, 0x4f, 0x9f, 0x57, 0x4c, 0xe8, 0x4f, 0xf3, 0x11,
0x5c, 0x52, 0xe7, 0x3, 0x4f, 0x7b, 0x63, 0x59, 0xe4, 0x40, 0x3, 0x88,
0x7f, 0xc7, 0x8a, 0x82, 0xd7, 0xcf, 0xd3, 0xba, 0xb5, 0xc7, 0x9, 0xff,
0xb9, 0xb6, 0xc6, 0x8f, 0xff, 0xcb, 0xc7, 0x5f, 0xef, 0x1, 0x67, 0x5c,
0xe3, 0xff, 0xc4, 0xc1, 0xc3, 0x10, 0xd8, 0xf, 0xff, 0x11, 0x8d, 0x85,
0xd5, 0x4f, 0xff, 0x85, 0x7e, 0xd8, 0x4f, 0x5b, 0x81, 0xff, 0xff, 0xb9,
0xb5, 0xc6, 0xff, 0x52, 0x46, 0x5f, 0x5b, 0x1e, 0xc0, 0xbc, 0xc4, 0x7,
0xe, 0xbf, 0xff, 0xff, 0x3f, 0xef, 0x70, 0xc3, 0x86, 0x20, 0x7d, 0xd8,
0x8f, 0xff, 0x96, 0x8f, 0xd3, 0xff, 0x95, 0x0, 0x8e, 0xd3, 0xff, 0x4f,
0x44, 0xeb, 0xff, 0xb7, 0x3, 0xb3, 0xc7, 0xff, 0xbe, 0xba, 0xc5, 0x7,
0x3f, 0x7b, 0x10, 0xc6, 0xff, 0xff, 0x21, 0x7d, 0xcc, 0x5f, 0xff, 0x57,
0xcd, 0xca, 0xc1, 0x0, 0x3f, 0xff, 0x1, 0x8, 0xbf, 0xbf, 0xbf, 0xd4,
0xcc, 0xc8, 0x4f, 0xe7, 0x8, 0x12, 0xc6, 0xc6, 0xc6, 0x7f, 0xff, 0x8f,
0xcb, 0xc9, 0x39, 0xc0, 0xc7, 0x20, 0x3, 0x6, 0xfc, 0x8f, 0x1, 0x7f,
0xff, 0xcc, 0xcb, 0x50, 0x3, 0xf6, 0x0, 0x70, 0xf, 0x2, 0x70, 0x3f,
0x10, 0xa, 0x70, 0xff, 0x32, 0xbb, 0x8f, 0x62, 0xf, 0x73, 0x3, 0x55,
0x50, 0xcc, 0x0, 0x12, 0xcf, 0xd3, 0x22, 0xfb, 0x7, 0xda, 0xda, 0xb6,
0xa, 0x11, 0xd2, 0xc3, 0xc3, 0x10, 0x1d, 0x46, 0xf, 0x80, 0x5f, 0xff,
0x57, 0x10, 0x80, 0xc4, 0x31, 0x0, 0x3f, 0xff, 0x8, 0x7f, 0xbf, 0x3f,
0x8, 0xd4, 0x80, 0xc4, 0x32, 0x46, 0xf, 0x7f, 0xc6, 0x38, 0xc1, 0x7,
0x5, 0xff, 0x1, 0x6f, 0xff, 0x8f, 0x80, 0xc4, 0x33, 0xc7, 0xaf, 0xff,
0x3f, 0xcc, 0x80, 0x50, 0x3, 0x1, 0x7f, 0xff, 0xf0, 0x2f, 0x70, 0x3f,
0x9, 0x70, 0xff, 0x0, 0x70, 0xbf, 0xd4, 0x10, 0x0, 0x30, 0xff, 0x73,
0x3, 0x55, 0xaf, 0xff, 0xc7, 0x62, 0x43, 0xd3, 0x81, 0x0, 0xc3, 0x32,
0x7, 0x91, 0xb6, 0x24, 0x11, 0x87, 0x10, 0xc3, 0x2d, 0x0, 0x10, 0x65,
0xe0, 0x0, 0x6, 0xd4, 0xd4, 0xd4, 0x83, 0x7f, 0xff, 0x71, 0xcb, 0xc8,
0xbf, 0xad, 0x20, 0x3, 0x5, 0x7f, 0x7f, 0x8, 0x4f, 0xcb, 0xc8, 0xbe,
0xbf, 0xef, 0xdd, 0xcc, 0xc8, 0x71, 0xbf, 0x30, 0x3, 0x0, 0x3f, 0xff,
0x7e, 0x2b, 0x34, 0xcd, 0xc9, 0x80, 0x9f, 0x71, 0xbb, 0x2e, 0x47, 0x30,
0x3, 0x3f, 0xff, 0x35, 0xca, 0xca, 0x40, 0xb, 0x5f, 0xc9, 0x20, 0x43,
0xf6, 0x6e, 0x7b, 0x2, 0x70, 0x3, 0x1, 0x7f, 0x7f, 0xf0, 0xaf, 0x0,
0xb0, 0xbf, 0x80, 0x0, 0x3f, 0xd3, 0xcb, 0xcb, 0xc8, 0xc0, 0x4d, 0xcd,
0xca, 0xec, 0x0, 0xf, 0xef, 0x2, 0xb0, 0xbb, 0x7f, 0xbb, 0xf5, 0x21,
0x4b, 0x7f, 0xc7, 0x10, 0xcf, 0x3f, 0xcf, 0xbf, 0xb1, 0x3b, 0xff, 0xdf,
0x31, 0x3b, 0x3f, 0xff, 0x31, 0x3b, 0x71, 0x4f, 0xf7, 0x9, 0x3f, 0x97,
0xb1, 0xff, 0x3f, 0xff, 0x32, 0xbb, 0x70, 0x1, 0xa1, 0x7f, 0xb2, 0xfb,
0x10, 0xb3, 0xb0, 0x7, 0x4, 0x3, 0xaa, 0xaa, 0xaa, 0xc0, 0x2e, 0x9b,
0x4e, 0xca, 0x49, 0xc7, 0x0, 0x4e, 0x83, 0x7b, 0xcb, 0x5e, 0x9b, 0x80,
0xcb, 0x0, 0x5e, 0xa7, 0xfa, 0x2, 0xff, 0xff, 0x70, 0x57, 0x0, 0x70,
0x5f, 0x0, 0xf0, 0x1f, 0x10, 0x12, 0xf0, 0x13, 0xbf, 0x22, 0xf3, 0x2,
0x63, 0xff, 0x20, 0x0, 0x22, 0xfb, 0x4d, 0xcd, 0xca, 0x0, 0x2, 0xcf,
0xf3, 0x3, 0xff, 0x0, 0x30, 0x1f, 0x2, 0xf2, 0x97, 0xb3, 0x3, 0x0,
0x30, 0x7f, 0x0, 0xb0, 0x1f, 0x10, 0xb2, 0xff, 0xff, 0x2, 0xff, 0x7f,
0x10, 0x1a, 0xff, 0xff, 0xc0, 0x2, 0xff, 0x7f, 0x11, 0xc5, 0x7f, 0xff,
0x99, 0xa1, 0x9b, 0xce, 0xff, 0x97, 0x3f, 0x91, 0xd2, 0x8f, 0xff, 0x30,
0xb, 0xb0, 0xf, 0x8, 0xff, 0xff, 0xf0, 0xaf, 0x1, 0xf0, 0xbf, 0xff,
0x2, 0xf0, 0x3f, 0x10, 0x0, 0xa0, 0xff, 0x5, 0x4f, 0xff, 0x0, 0xa1,
0xff, 0x1, 0x4f, 0xff, 0x22, 0xfb, 0x33, 0x3, 0x10, 0xb3, 0xff, 0xff,
0x0, 0xc0, 0x74, 0x6b, 0xdd, 0xff, 0x49, 0x3d, 0xed, 0xc8, 0x70, 0x7,
0xf0, 0x3, 0xbd, 0x75, 0x50, 0x1f, 0x90, 0x7d, 0x74, 0x60, 0xdb, 0x0,
0x30, 0x1f, 0x2, 0xff, 0xff, 0x10, 0x7f, 0x7f, 0xcf, 0xf8, 0x10, 0x5c,
0x51, 0xe6, 0x3d, 0x77, 0x23, 0x83, 0x7b, 0xda, 0x80, 0x70, 0x83, 0xce,
0x70, 0x67, 0xde, 0xf3, 0x60, 0x56, 0x70, 0xe4, 0x0, 0xfc, 0xef, 0x0,
0x30, 0xb3, 0x6, 0x30, 0x13, 0xf5, 0x5e, 0x54, 0xe6, 0xff, 0x30, 0x3,
0xf0, 0xf, 0x1, 0x70, 0xbf, 0x2, 0xf0, 0x3f, 0x10, 0x2, 0xb0, 0xff,
0xb3, 0x3, 0x0, 0x32, 0x5f, 0x73, 0x3, 0xf, 0x8e, 0x7b, 0x74, 0xdb,
0x1, 0x71, 0xbf, 0x32, 0xbb, 0x32, 0xc3, 0x0, 0xff, 0xaf, 0x0, 0xf7,
0x5b, 0x51, 0xe6, 0xe, 0x91, 0x91, 0xda, 0x4, 0x21, 0x8b, 0x7b, 0xd8,
0x0, 0x11, 0xa2, 0x20, 0x0};
size_t battery_icons_size = 0x1199;

34
source/li2.v.pica Normal file
View File

@ -0,0 +1,34 @@
; Project Li7
; Copyright (C) 2023 NPI-D7
; Projection Matrix
.fvec projection[4]
; Constants
.constf constants(1.0, 0.0, 0.00392156862745, 0.0)
; Outputs
.out outPos position
.out outUv texcoord0
.out outColor color
; Inputs
.alias inPos v0
.alias inUv v1
.alias inColor v2
.proc main
mov r0.xy, inPos.xy
mov r0.zw, constants.yx
dp4 outPos.x, projection[0], r0
dp4 outPos.y, projection[1], r0
dp4 outPos.z, projection[2], r0
dp4 outPos.w, projection[3], r0
mov outUv, inUv
; Convert from u32 to float
mul r1, constants.zzzz, inColor
mov outColor, r1
end
.end

File diff suppressed because it is too large Load Diff

View File

@ -1,12 +1,10 @@
#include <regex>
#include <renderd7/external/nvid.hpp>
#include <renderd7/log.hpp>
#include <renderd7/npi_intro.hpp>
#include <renderd7/renderd7.hpp>
#include <renderd7/renderd7_logo.hpp>
#define D7_NOTHING 0x00000000
#define CFGVER "5"
#define CFGVER "6"
bool isndspinit = false;
bool running = true;
@ -81,6 +79,14 @@ u64 delta_time;
u64 last_tm;
float dtm;
// Lets define them to prevent from red lines in vscode lol
#ifndef V_TIME
#define V_TIME "0"
#endif
#ifndef V_STRING
#define V_STRING "0"
#endif
// Screen Fade
bool fadeout = false, fadein = false, fadeout2 = false, fadein2 = false;
int fadealpha = 0;
@ -419,9 +425,7 @@ Result RenderD7::Init::Main(std::string app_name) {
D_app_name = app_name;
cfgpath = "sdmc:/RenderD7/Apps/";
cfgpath += D_app_name;
mkdir("sdmc:/RenderD7/", 0777);
mkdir("sdmc:/RenderD7/Apps", 0777);
mkdir(cfgpath.c_str(), 0777);
std::filesystem::create_directories(cfgpath.c_str());
bool renew = false;
printf("folderset\n");
if (FS::FileExist(cfgpath + "/config.ini")) {
@ -435,6 +439,7 @@ Result RenderD7::Init::Main(std::string app_name) {
if (!FS::FileExist(cfgpath + "/config.ini") || renew) {
cfgfile = std::make_unique<INI::INIFile>(cfgpath + "/config.ini");
cfgfile->read(cfgstruct);
cfgstruct.clear();
cfgstruct["info"]["version"] = CFGVER;
cfgstruct["info"]["renderd7ver"] = RENDERD7VSTRING;
cfgstruct["settings"]["doscreentimeout"] = "0";
@ -442,10 +447,8 @@ Result RenderD7::Init::Main(std::string app_name) {
cfgstruct["settings"]["renderer"] = "c3d_c2d";
cfgstruct["metrik-settings"]["enableoverlay"] = "0";
cfgstruct["metrik-settings"]["Screen"] = "0";
cfgstruct["metrik-settings"]["txtColor"] = "#ffffff";
cfgstruct["metrik-settings"]["txtColorA"] = "255";
cfgstruct["metrik-settings"]["ColorA"] = "255";
cfgstruct["metrik-settings"]["Color"] = "#000000";
cfgstruct["metrik-settings"]["txtColor"] = "#ffffffff";
cfgstruct["metrik-settings"]["Color"] = "#aa000000";
cfgstruct["metrik-settings"]["txtSize"] = "0.7f";
cfgfile->write(cfgstruct);
}
@ -454,13 +457,6 @@ Result RenderD7::Init::Main(std::string app_name) {
////C3D_FrameRate(RenderD7::Convert::StringtoFloat(Fps));
metrikd = RenderD7::Convert::FloatToBool(RenderD7::Convert::StringtoFloat(
cfgstruct["metrik-settings"]["enableoverlay"]));
mt_txtcolor =
RenderD7::Color::Hex(cfgstruct["metrik-settings"]["txtColor"],
(u8)RenderD7::Convert::StringtoFloat(
cfgstruct["metrik-settings"]["txtColorA"]));
mt_color = RenderD7::Color::Hex(cfgstruct["metrik-settings"]["Color"],
(u8)RenderD7::Convert::StringtoFloat(
cfgstruct["metrik-settings"]["ColorA"]));
mt_txtSize =
RenderD7::Convert::StringtoFloat(cfgstruct["metrik-settings"]["txtSize"]);
mt_screen =
@ -513,9 +509,7 @@ Result RenderD7::Init::Minimal(std::string app_name) {
}
cfgpath = "sdmc:/RenderD7/Apps/";
cfgpath += D_app_name;
mkdir("sdmc:/RenderD7/", 0777);
mkdir("sdmc:/RenderD7/Apps", 0777);
mkdir(cfgpath.c_str(), 0777);
std::filesystem::create_directories(cfgpath.c_str());
bool renew = false;
printf("folderset\n");
if (FS::FileExist(cfgpath + "/config.ini")) {
@ -529,6 +523,7 @@ Result RenderD7::Init::Minimal(std::string app_name) {
if (!FS::FileExist(cfgpath + "/config.ini") || renew) {
cfgfile = std::make_unique<INI::INIFile>(cfgpath + "/config.ini");
cfgfile->read(cfgstruct);
cfgstruct.clear();
cfgstruct["info"]["version"] = CFGVER;
cfgstruct["info"]["renderd7ver"] = RENDERD7VSTRING;
cfgstruct["settings"]["doscreentimeout"] = "0";
@ -536,10 +531,8 @@ Result RenderD7::Init::Minimal(std::string app_name) {
cfgstruct["settings"]["renderer"] = "c3d_c2d";
cfgstruct["metrik-settings"]["enableoverlay"] = "0";
cfgstruct["metrik-settings"]["Screen"] = "0";
cfgstruct["metrik-settings"]["txtColor"] = "#ffffff";
cfgstruct["metrik-settings"]["txtColorA"] = "255";
cfgstruct["metrik-settings"]["ColorA"] = "255";
cfgstruct["metrik-settings"]["Color"] = "#000000";
cfgstruct["metrik-settings"]["txtColor"] = "#ffffffff";
cfgstruct["metrik-settings"]["Color"] = "#aa000000";
cfgstruct["metrik-settings"]["txtSize"] = "0.7f";
cfgfile->write(cfgstruct);
}
@ -550,13 +543,6 @@ Result RenderD7::Init::Minimal(std::string app_name) {
// C3D_FrameRate(RenderD7::Convert::StringtoFloat(Fps));
metrikd = RenderD7::Convert::FloatToBool(RenderD7::Convert::StringtoFloat(
cfgstruct["metrik-settings"]["enableoverlay"]));
mt_txtcolor =
RenderD7::Color::Hex(cfgstruct["metrik-settings"]["txtColor"],
(u8)RenderD7::Convert::StringtoFloat(
cfgstruct["metrik-settings"]["txtColorA"]));
mt_color = RenderD7::Color::Hex(cfgstruct["metrik-settings"]["Color"],
(u8)RenderD7::Convert::StringtoFloat(
cfgstruct["metrik-settings"]["ColorA"]));
mt_txtSize =
RenderD7::Convert::StringtoFloat(cfgstruct["metrik-settings"]["txtSize"]);
mt_screen =
@ -1108,65 +1094,6 @@ void RenderD7::AddToast(std::unique_ptr<RenderD7::Ovl> overlay) {
toast_overlays.push_back(std::move(overlay));
}
void RenderD7::DoNpiIntro() {
// May be stream in future
/*NVID_Stream* stream = new NVID_Stream(npi_intro, npi_intro_size);
int c = 0;
float xc = 0;
NVID_Image nimg;
RenderD7::Image img;
uint64_t lastT = osGetTime();
stream->ReadNext(nimg);
while(true)
{
C3D_FrameBegin(C3D_FRAME_SYNCDRAW);
C2D_TargetClear(Top, RenderD7::Color::Hex("#000000"));
C2D_TargetClear(Bottom, RenderD7::Color::Hex("#000000"));
RenderD7::ClearTextBufs();
RenderD7::OnScreen(Top);
img.LoadPixels(nimg.w, nimg.h, nimg.bpp, nimg.pBuf);
img.Draw(0, 0);
xc += osGetTime() - lastT;
lastT = osGetTime();
if (xc > 24 / 60) {
c++;
if(!stream->ReadNext(nimg))
break;
xc = 0;
}
if (c > 59)
break;
C3D_FrameEnd(0);
}*/
RenderD7::Ftrace::Beg("rd7-core", "load_nvid");
auto images = LoadMemNVID(npi_intro, npi_intro_size);
RenderD7::Ftrace::End("rd7-core", "load_nvid");
int c = 0;
float xc = 0;
RenderD7::Image img;
uint64_t lastT = osGetTime();
while (c < 59) {
C3D_FrameBegin(C3D_FRAME_SYNCDRAW);
C2D_TargetClear(Top, RenderD7::Color::Hex("#000000"));
C2D_TargetClear(Bottom, RenderD7::Color::Hex("#000000"));
RenderD7::ClearTextBufs();
RenderD7::OnScreen(Top);
img.LoadPixels(images[c]->w, images[c]->h, images[c]->bpp, images[c]->pBuf);
img.Draw(0, 0);
xc += osGetTime() - lastT;
lastT = osGetTime();
if (xc > 24 / 60) {
c++;
xc = 0;
}
if (c > (int)(images.size() - 1))
c = 0;
C3D_FrameEnd(0);
}
}
void RenderD7::FadeOut() {
if (!waitFade) {
fadein = true;

File diff suppressed because it is too large Load Diff