0.9.2 (NVID, SPLASH_IMG_VID, CHANGELOG_IMPL)

This commit is contained in:
tobid7 2023-03-11 15:56:40 +01:00
parent 67edfa4245
commit cd677cf3e8
15 changed files with 36408 additions and 36 deletions

View File

@ -7,7 +7,9 @@
"C:/devkitpro/libctru/include/**",
"C:/devkitpro/devkitARM/include/**",
"C:/devkitpro/devkitARM/arm-none-eabi/include/**",
"C:/devkitpro/portlibs/3ds/include/**"
"C:/devkitpro/portlibs/3ds/include/**",
"/opt/devkitpro/libctru/include/**",
"/opt/devkitpro/portlibs/**"
]
}

3185
external/source/jpgd.cpp vendored Normal file

File diff suppressed because it is too large Load Diff

1246
external/source/jpge.cpp vendored Normal file

File diff suppressed because it is too large Load Diff

View File

@ -28,6 +28,7 @@ public:
void LoadPFromBuffer(const std::vector<u8> &buffer);
void LoadFromBitmap(BMP bitmap);
void LoadJpg(std::string path);
void LoadPixels(int w, int h, int bpp, void *buffer);
/// Draw the Image directly
/// \param x The x position
/// \param y the y position

422
include/renderd7/external/jpgd.h vendored Normal file
View File

@ -0,0 +1,422 @@
// 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

478
include/renderd7/external/jpgd_idct.h vendored Normal file
View File

@ -0,0 +1,478 @@
// 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);
}

186
include/renderd7/external/jpge.h vendored Normal file
View File

@ -0,0 +1,186 @@
// 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

253
include/renderd7/external/nvid.hpp vendored Normal file
View File

@ -0,0 +1,253 @@
#pragma once
#include <cstdint>
#include <fstream>
#include <iostream>
#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<NVID_Image> LoadNVID(std::string path) {
std::vector<NVID_Image> res;
NVID_Header t_header;
std::ifstream nvid_file2("out.nvid", std::ios::binary | std::ios::in);
nvid_file2.read((char *)&t_header, sizeof(NVID_Header));
if (!CheckHeader(t_header))
return res;
for (int i = 0; i < t_header.framecount; i++) {
NVID_Image tmp;
NVID_Frame frm;
nvid_file2.read((char *)&frm, sizeof(NVID_Frame));
if (!CheckFrame(frm)) {
return res;
}
void *pBuf = malloc(frm.framesize);
nvid_file2.read((char *)pBuf, frm.framesize);
int lw, lh, lc;
unsigned char *dat_s = jpgd::decompress_jpeg_image_from_memory(
(unsigned char *)pBuf, frm.framesize, &lw, &lh, &lc, 3);
tmp.bpp = lc;
tmp.w = lw;
tmp.h = lh;
tmp.framenum = i;
tmp.pBuf = dat_s;
res.push_back(tmp);
}
return res;
}*/
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() {}
~NVID_Stream() {}
bool Load(const std::string &path) {
file.open(path, std::ios::in | std::ios::binary);
if (!file) {
std::cerr << "Error: failed to open " << path << std::endl;
return false;
}
file.read(reinterpret_cast<char *>(&t_header), sizeof(NVID_Header));
if (!CheckHeader(t_header)) {
std::cerr << "Error: invalid NVID file header" << std::endl;
return false;
}
currentreg = 0;
return true;
}
void Update() {
if (!file) {
return;
}
NVID_Frame frm;
file.read(reinterpret_cast<char *>(&frm), sizeof(NVID_Frame));
if (!CheckFrame(frm)) {
return;
}
if (frm.framesize > buffer.size()) {
buffer.resize(frm.framesize);
}
file.read(reinterpret_cast<char *>(buffer.data()), frm.framesize);
int lw, lh, lc;
unsigned char *dat_s = jpgd::decompress_jpeg_image_from_memory(
buffer.data(), frm.framesize, &lw, &lh, &lc, 3);
if (!dat_s) {
std::cerr << "Error: failed to decompress JPEG data" << std::endl;
return;
}
current_frame.bpp = lc;
current_frame.w = lw;
current_frame.h = lh;
current_frame.framenum = currentreg;
current_frame.pBuf = dat_s;
currentreg++;
if (currentreg > (int)t_header.framecount) {
file.seekg(sizeof(NVID_Header));
currentreg = 0;
}
}
NVID_Image GetImage() const { return current_frame; }
private:
bool CheckHeader(const NVID_Header &header) const {
// TODO: implement header validation logic
return true;
}
bool CheckFrame(const NVID_Frame &frame) const {
// TODO: implement frame validation logic
return true;
}
NVID_Image current_frame;
NVID_Header t_header;
int currentreg = 0;
std::ifstream file;
std::vector<unsigned char> buffer;
};

View File

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

View File

@ -44,14 +44,16 @@
#include <renderd7/stringtool.hpp>
#include <renderd7/thread.hpp>
#define RENDERD7VSTRING "0.9.1"
#define RENDERD7VSTRING "0.9.2"
#define CHANGELOG \
"0.9.1: Fix Critical bug in Spritesheet animations\nFix Color " \
"0.9.2: Add NpiSplashVideo\nNvid Support(v0.0.1)\nAdd Basic RenderD7 " \
"Splash\nFaster Graphics Init\nFade Effects\nFix Screen for this " \
"Changelog\n0.9.1: Fix Critical bug in\nSpritesheet animations\nFix Color " \
"Conver(Hex)\n0.9.0: Remove Stupid try of Console\nAdd Services list and " \
"Clean up " \
"Code.\nAlso added Minimal Init for hax2.x\n0.8.5: Fix Deltatime \n0.8.4: " \
"A lot of Fixes and new\nFeatures for BitmapPrinter! \n0.8.3: Addet " \
"Overlaycount to Info\nand Addet ResultDecoder for errors.\n0.8.2: Fix a " \
"Overlaycount to Info\nand Addet ResultDecoder for errors.\n\n0.8.2: Fix a " \
"lot of Stuff and\nadd c++17 based filesystem class.\n0.8.1: Add abillity " \
"to Get Stdout as string\nto render it to the screen.\n0.8.0: Implement " \
"BitmapPrinter\n0.7.3: Implement Over\nRender Overlay Framework\n0.7.2: " \
@ -81,6 +83,8 @@ extern touchPosition d7_touch;
extern std::string dspststus;
extern bool rd7_do_splash;
/// RenderD7
namespace RenderD7 {
float GetDeltaTime();
@ -113,10 +117,16 @@ public:
class RSettings : public RenderD7::Scene {
private:
void calculate_screens(const std::vector<std::string> &lines,
int &screen_index, int &screens);
enum RState { RSETTINGS, RINFO, RSERVICES, RCLOG };
RenderD7::RSettings::RState m_state = RenderD7::RSettings::RState::RSETTINGS;
mutable float txtposy = 30;
int screens = 0;
int screen_index = 0;
std::vector<std::string> lines;
std::string rd7srstate = "false";
std::string mtovlstate = "false";
@ -160,6 +170,14 @@ int GetRandomInt(int b, int e);
void DrawMetrikOvl();
bool DrawImageFromSheet(RenderD7::Sheet *sheet, size_t index, float x, float y,
float scaleX = 1.0, float scaleY = 1.0);
void DoNpiIntro();
/// @brief Fade In
/// @param duration Duration in Frames
void FadeIn();
/// @brief Fade Out
/// @param duration Duration in Frames
void FadeOut();
void FadeDisplay();
namespace Error {
void DisplayError(std::string toptext, std::string errortext, int timesec = 3);
void DisplayFatalError(std::string toptext, std::string errortext);

View File

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

View File

@ -5,6 +5,20 @@
#include <renderd7/external/stb_image.h>
extern bool usedbgmsg;
void convert24to32(unsigned char *inputImage, int width, int height,
unsigned char *outputImage) {
for (int y = 0; y < height; y++) {
for (int x = 0; x < width; x++) {
int i = (y * width + x) * 3; // index of current pixel in input image
int j = (y * width + x) * 4; // index of current pixel in output image
outputImage[j] = inputImage[i]; // copy red channel
outputImage[j + 1] = inputImage[i + 1]; // copy green channel
outputImage[j + 2] = inputImage[i + 2]; // copy blue channel
outputImage[j + 3] = 255; // set alpha channel to 255 (fully opaque)
}
}
}
static u32 GetNextPowerOf2(u32 v) {
v--;
v |= v >> 1;
@ -281,4 +295,46 @@ void Image::LoadJpg(std::string path) {
IMG_LoadImageFile(&this->img, path.c_str());
loadet = true;
}
void Image::LoadPixels(int w, int h, int bpp, void *buffer) {
if (loadet) {
C3D_TexDelete(this->img.tex);
loadet = false;
}
unsigned width, height;
width = w;
height = h;
uint8_t *ImageBuffer = new uint8_t[w * h * 4];
if (bpp == 3)
convert24to32((uint8_t *)buffer, width, height, ImageBuffer);
img.tex = new C3D_Tex;
img.subtex =
new Tex3DS_SubTexture({(u16)width, (u16)height, 0.0f, 1.0f,
width / 512.0f, 1.0f - (height / 512.0f)});
C3D_TexInit(img.tex, 512, 512, GPU_RGBA8);
C3D_TexSetFilter(img.tex, GPU_LINEAR, GPU_LINEAR);
img.tex->border = 0xFFFFFFFF;
C3D_TexSetWrap(img.tex, GPU_CLAMP_TO_BORDER, GPU_CLAMP_TO_BORDER);
for (u32 x = 0; x < width && x < 512; x++) {
for (u32 y = 0; y < height && y < 512; y++) {
const u32 dstPos = ((((y >> 3) * (512 >> 3) + (x >> 3)) << 6) +
((x & 1) | ((y & 1) << 1) | ((x & 2) << 1) |
((y & 2) << 2) | ((x & 4) << 2) | ((y & 4) << 3))) *
4;
const u32 srcPos = (y * width + x) * 4;
((uint8_t *)img.tex->data)[dstPos + 0] = ImageBuffer[srcPos + 3];
((uint8_t *)img.tex->data)[dstPos + 1] = ImageBuffer[srcPos + 2];
((uint8_t *)img.tex->data)[dstPos + 2] = ImageBuffer[srcPos + 1];
((uint8_t *)img.tex->data)[dstPos + 3] = ImageBuffer[srcPos + 0];
}
}
delete[] ImageBuffer;
loadet = true;
}
} // namespace RenderD7

29960
source/npi_intro.cpp Normal file

File diff suppressed because it is too large Load Diff

View File

@ -1,6 +1,9 @@
#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 TICKS_PER_MSEC 268111.856
@ -12,12 +15,14 @@ float animtime;
bool isndspinit = false;
bool running = true;
std::stack<std::unique_ptr<RenderD7::Scene>> RenderD7::Scene::scenes;
std::unique_ptr<RenderD7::Scene> tmpFadeS;
std::stack<std::unique_ptr<RenderD7::Ovl>> overlays;
bool usedbgmsg = false;
std::string dspststus = "Not Initialisized!";
int cobj___;
int maxobj__;
bool rd7_do_splash = false;
// INI::INIFile cfgfile;
std::unique_ptr<INI::INIFile> cfgfile = nullptr;
@ -86,7 +91,9 @@ float dtm;
bool fadeout = false, fadein = false, fadeout2 = false, fadein2 = false;
int fadealpha = 0;
int fadecolor = 0;
bool waitFade = false;
bool FadeExit = false;
bool SceneFadeWait = false;
// Sercices
int sv_gfx = 0;
int sv_dsp = 0;
@ -94,6 +101,71 @@ int sv_cfgu = 0;
int sv_apt = 0;
int sv_romfs = 0;
std::vector<std::string> string_to_lines(std::string input_str) {
std::vector<std::string> lines;
std::stringstream ss(input_str);
std::string line;
while (std::getline(ss, line)) {
lines.push_back(line);
}
return lines;
}
void Npifade() {
if (fadein) {
if (fadealpha < 255) {
RenderD7::OnScreen(Top);
RenderD7::Draw::Rect(0, 0, RenderD7::IsRD7SR() ? 800 : 400, 240,
((fadealpha << 24) | 0x00000000));
RenderD7::OnScreen(Bottom);
RenderD7::Draw::Rect(0, 0, 320, 240, ((fadealpha << 24) | 0x00000000));
fadealpha += 3;
} else {
fadein = false;
}
} else if (fadeout) {
if (fadealpha > 0) {
RenderD7::OnScreen(Top);
RenderD7::Draw::Rect(0, 0, RenderD7::IsRD7SR() ? 800 : 400, 240,
((fadealpha << 24) | 0x00000000));
RenderD7::OnScreen(Bottom);
RenderD7::Draw::Rect(0, 0, 320, 240, ((fadealpha << 24) | 0x00000000));
fadealpha -= 3;
} else {
fadeout = false;
}
} else {
if (waitFade)
waitFade = false;
if (FadeExit)
running = false;
if (SceneFadeWait) {
RenderD7::Scene::scenes.push(std::move(tmpFadeS));
SceneFadeWait = false;
}
// No fade
RenderD7::OnScreen(Top);
RenderD7::Draw::Rect(0, 0, RenderD7::IsRD7SR() ? 800 : 400, 240,
((fadealpha << 24) | 0x00000000));
RenderD7::OnScreen(Bottom);
RenderD7::Draw::Rect(0, 0, 320, 240, ((fadealpha << 24) | 0x00000000));
}
}
void PushSplash() {
C2D_SpriteSheet sheet;
sheet = C2D_SpriteSheetLoadFromMem((void *)renderd7_logo, renderd7_logo_size);
C3D_FrameBegin(C3D_FRAME_SYNCDRAW);
C2D_TargetClear(Top, DSEVENBLACK);
C2D_TargetClear(Bottom, DSEVENBLACK);
RenderD7::ClearTextBufs();
RenderD7::OnScreen(Top);
C2D_DrawImageAt(C2D_SpriteSheetGetImage(sheet, 0), 400 / 2 - 300 / 2,
240 / 2 - 100 / 2, 0.5);
C3D_FrameEnd(0);
C2D_SpriteSheetFree(sheet);
}
std::string _FMT_(const std::string &fmt_str, ...) {
va_list ap;
char *fp = NULL;
@ -267,7 +339,11 @@ void RenderD7::Scene::doLogic(u32 hDown, u32 hHeld, u32 hUp,
}
void RenderD7::Scene::Load(std::unique_ptr<Scene> scene, bool fade) {
Scene::scenes.push(std::move(scene));
if (fade) {
tmpFadeS = std::move(scene);
SceneFadeWait = true;
} else
Scene::scenes.push(std::move(scene));
}
void RenderD7::Scene::Back() {
@ -373,6 +449,20 @@ Result RenderD7::Init::Main(std::string app_name) {
sv_apt = R_FAILED(res) ? 1 : 2;
res = romfsInit();
sv_romfs = R_FAILED(res) ? 1 : 2;
C3D_Init(C3D_DEFAULT_CMDBUF_SIZE);
C2D_Init(C2D_DEFAULT_MAX_OBJECTS);
C2D_Prepare();
Top = C2D_CreateScreenTarget(GFX_TOP, GFX_LEFT);
TopRight = C2D_CreateScreenTarget(GFX_TOP, GFX_RIGHT);
Bottom = C2D_CreateScreenTarget(GFX_BOTTOM, GFX_LEFT);
TextBuf = C2D_TextBufNew(4096);
Font = C2D_FontLoadSystem(CFG_REGION_USA);
printf("Graphical Interface\n");
last_tm = svcGetSystemTick();
if (rd7_do_splash)
PushSplash();
res = cfguInit();
sv_cfgu = R_FAILED(res) ? 1 : 2;
printf("stuff\n");
@ -465,16 +555,7 @@ Result RenderD7::Init::Main(std::string app_name) {
printf("rd7sr\n");
// consoleInit(GFX_BOTTOM, NULL);
printf("csv\n");
C3D_Init(C3D_DEFAULT_CMDBUF_SIZE);
C2D_Init(C2D_DEFAULT_MAX_OBJECTS);
C2D_Prepare();
Top = C2D_CreateScreenTarget(GFX_TOP, GFX_LEFT);
TopRight = C2D_CreateScreenTarget(GFX_TOP, GFX_RIGHT);
Bottom = C2D_CreateScreenTarget(GFX_BOTTOM, GFX_LEFT);
TextBuf = C2D_TextBufNew(4096);
Font = C2D_FontLoadSystem(CFG_REGION_USA);
printf("Graphical Interface\n");
last_tm = svcGetSystemTick();
// RenderD7::Msg::Display("RenderD7", "RenderD7 init success!\nWaiting for
// MainLoop!", Top);
return 0;
@ -487,6 +568,19 @@ Result RenderD7::Init::Minimal(std::string app_name) {
sv_gfx = 2;
res_ = romfsInit();
sv_romfs = R_FAILED(res_) ? 1 : 2;
osSetSpeedupEnable(true);
C3D_Init(C3D_DEFAULT_CMDBUF_SIZE);
C2D_Init(C2D_DEFAULT_MAX_OBJECTS);
C2D_Prepare();
Top = C2D_CreateScreenTarget(GFX_TOP, GFX_LEFT);
TopRight = C2D_CreateScreenTarget(GFX_TOP, GFX_RIGHT);
Bottom = C2D_CreateScreenTarget(GFX_BOTTOM, GFX_LEFT);
TextBuf = C2D_TextBufNew(4096);
Font = C2D_FontLoadSystem(CFG_REGION_USA);
if (rd7_do_splash)
PushSplash();
// Check if citra
s64 citracheck = 0;
svcGetSystemInfo(&citracheck, 0x20000, 0);
@ -569,16 +663,6 @@ Result RenderD7::Init::Minimal(std::string app_name) {
if (consoleModel != 3)
gfxSetWide(true);
}
osSetSpeedupEnable(true);
C3D_Init(C3D_DEFAULT_CMDBUF_SIZE);
C2D_Init(C2D_DEFAULT_MAX_OBJECTS);
C2D_Prepare();
Top = C2D_CreateScreenTarget(GFX_TOP, GFX_LEFT);
TopRight = C2D_CreateScreenTarget(GFX_TOP, GFX_RIGHT);
Bottom = C2D_CreateScreenTarget(GFX_BOTTOM, GFX_LEFT);
TextBuf = C2D_TextBufNew(4096);
Font = C2D_FontLoadSystem(CFG_REGION_USA);
return 0;
}
@ -691,8 +775,12 @@ void RenderD7::DrawTLBtns(std::vector<RenderD7::TLBtn> btns, u32 color,
}
void RenderD7::ExitApp() {
if (!rd7settings)
running = false;
if (!rd7settings) {
if (waitFade) {
FadeExit = true;
} else
running = false;
}
}
bool RenderD7::touchTObj(touchPosition touch, RenderD7::TObject button) {
@ -931,20 +1019,18 @@ void RenderD7::FrameEnd() {
RenderD7::DrawMetrikOvl();
if (!shouldbe_disabled)
OvlHandler();
/*if (d7_hHeld & KEY_R && d7_hDown & KEY_SELECT)
{
RenderD7::LoadSettings();
}*/
lp++;
Npifade();
C3D_FrameEnd(0);
}
RenderD7::RSettings::RSettings() {
RenderD7::FadeOut();
cfgfile = std::make_unique<INI::INIFile>(cfgpath + "/config.ini");
cfgfile->read(cfgstruct);
rd7settings = true;
lines = string_to_lines(CHANGELOG);
calculate_screens(lines, screen_index, screens);
}
RenderD7::RSettings::~RSettings() { cfgfile->write(cfgstruct); }
@ -1019,9 +1105,18 @@ void RenderD7::RSettings::Draw(void) const {
} else if (m_state == RCLOG) {
RenderD7::OnScreen(Top);
int start_index = screen_index * 9;
int end_index = std::min((int)lines.size(), start_index + 9);
RenderD7::Draw::Rect(0, 21, 400, 220, RenderD7::Color::Hex("#eeeeee"));
RenderD7::Draw::Text(5, 30, 0.7f, DSEVENBLACK, std::string(CHANGELOG));
for (int i = start_index; i < end_index; i++) {
RenderD7::Draw::Text(5, 23 + 20 * (i - start_index), 0.7f, DSEVENBLACK,
lines[i]);
}
RenderD7::Draw::Rect(0, 219, 400, 21, RenderD7::Color::Hex("#111111"));
RenderD7::Draw::Text(0, 220, 0.7f, RenderD7::Color::Hex("#ffffff"),
"Site: " + std::to_string(screen_index + 1) + "/" +
std::to_string(screens + 1));
RenderD7::Draw::Rect(0, 0, 400, 21, RenderD7::Color::Hex("#111111"));
RenderD7::Draw::Text(0, 0, 0.7f, DSEVENWHITE, "RenderD7->Changelog");
@ -1140,13 +1235,74 @@ void RenderD7::RSettings::Logic(u32 hDown, u32 hHeld, u32 hUp,
if (d7_hDown & KEY_B) {
m_state = RSETTINGS;
}
if (d7_hDown & KEY_R)
if (screen_index < screens)
screen_index++;
if (d7_hDown & KEY_L)
if (screen_index > 0)
screen_index--;
}
}
void RenderD7::RSettings::calculate_screens(
const std::vector<std::string> &lines, int &screen_index, int &screens) {
int num_lines = lines.size();
screens = (num_lines + 8) / 9; // round up to nearest multiple of 9
screen_index = 0;
screens -= 1;
}
void RenderD7::LoadSettings() {
RenderD7::Scene::Load(std::make_unique<RenderD7::RSettings>());
}
void RenderD7::AddOvl(std::unique_ptr<RenderD7::Ovl> overlay) {
overlays.push(std::move(overlay));
}
}
void RenderD7::DoNpiIntro() {
auto images = LoadMemNVID(npi_intro, npi_intro_size);
int c = 0;
float xc = 0;
RenderD7::Image img;
uint64_t lastT = osGetTime();
while (c < 59) {
shouldbe_disabled = true;
cnttttt = 0;
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::FadeIn() {
if (!waitFade) {
fadein = true;
fadealpha = 0;
waitFade = true;
}
}
void RenderD7::FadeOut() {
if (!waitFade) {
fadeout = true;
fadealpha = 255;
waitFade = true;
}
}
void RenderD7::FadeDisplay() { Npifade(); }

399
source/renderd7_logo.cpp Normal file
View File

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