forked from richgel999/bc7enc_rdo
-
Notifications
You must be signed in to change notification settings - Fork 1
/
ert.h
81 lines (67 loc) · 3.07 KB
/
ert.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
#pragma once
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#include <math.h>
#include <algorithm>
#include <assert.h>
#include <time.h>
#include <vector>
#include <string>
namespace ert
{
struct color_rgba { uint8_t m_c[4]; };
struct reduce_entropy_params
{
// m_lambda: The post-processor tries to reduce distortion*smooth_block_scale + rate*lambda (rate is approximate LZ bits and distortion is scaled MS error multiplied against the smooth block MSE weighting factor).
// Larger values push the postprocessor towards optimizing more for lower rate, and smaller values more for distortion. 0=minimal distortion.
float m_lambda;
// m_lookback_window_size: The number of bytes the encoder can look back from each block to find matches. The larger this value, the slower the encoder but the higher the quality per LZ compressed bit.
uint32_t m_lookback_window_size;
// m_max_allowed_rms_increase_ratio: How much the RMS error of a block is allowed to increase before a trial is rejected. 1.0=no increase allowed, 1.05=5% increase allowed, etc.
float m_max_allowed_rms_increase_ratio;
float m_max_smooth_block_std_dev;
float m_smooth_block_max_mse_scale;
uint32_t m_color_weights[4];
bool m_try_two_matches;
bool m_allow_relative_movement;
bool m_skip_zero_mse_blocks;
bool m_debug_output;
reduce_entropy_params() { clear(); }
void clear()
{
m_lookback_window_size = 256;
m_lambda = 1.0f;
m_max_allowed_rms_increase_ratio = 10.0f;
m_max_smooth_block_std_dev = 18.0f;
m_smooth_block_max_mse_scale = 10.0f;
m_color_weights[0] = 1;
m_color_weights[1] = 1;
m_color_weights[2] = 1;
m_color_weights[3] = 1;
m_try_two_matches = false;
m_allow_relative_movement = false;
m_skip_zero_mse_blocks = false;
m_debug_output = false;
}
void print()
{
printf("lambda: %f\n", m_lambda);
printf("Lookback window size: %u\n", m_lookback_window_size);
printf("Max allowed RMS increase ratio: %f\n", m_max_allowed_rms_increase_ratio);
printf("Max smooth block std dev: %f\n", m_max_smooth_block_std_dev);
printf("Smooth block max MSE scale: %f\n", m_smooth_block_max_mse_scale);
printf("Color weights: %u %u %u %u\n", m_color_weights[0], m_color_weights[1], m_color_weights[2], m_color_weights[3]);
printf("Try two matches: %u\n", m_try_two_matches);
printf("Allow relative movement: %u\n", m_allow_relative_movement);
printf("Skip zero MSE blocks: %u\n", m_skip_zero_mse_blocks);
}
};
typedef bool (*pUnpack_block_func)(const void* pBlock, color_rgba* pPixels, uint32_t block_index, void* pUser_data);
// BC7 entropy reduction transform with Deflate/LZMA/LZHAM optimizations
bool reduce_entropy(void* pBlocks, uint32_t num_blocks,
uint32_t total_block_stride_in_bytes, uint32_t block_size_to_optimize_in_bytes, uint32_t block_width, uint32_t block_height, uint32_t num_comps,
const color_rgba* pBlock_pixels, const reduce_entropy_params& params, uint32_t& total_modified,
pUnpack_block_func pUnpack_block_func, void* pUnpack_block_func_user_data,
std::vector<float>* pBlock_mse_scales = nullptr);
} // namespace ert