Enable entropy based merge histo for (q<100)
Enable bin-partition entropy based heuristic for merging histograms for higher (q >= 90) qualities as well. Keep the old behavior at the maximum quality level (q==100). This speeds up the compression between Q=90-99 (method=4) by factor 5-7X and with loss of 0.5-0.8% in the compression density. Change-Id: I011182cb8ae5403c565a150362bc302630b3f330
This commit is contained in:
parent
572022a350
commit
abf04205b3
@ -949,10 +949,12 @@ static void HistogramRemap(const VP8LHistogramSet* const orig_histo,
|
|||||||
|
|
||||||
static double GetCombineCostFactor(int histo_size, int quality) {
|
static double GetCombineCostFactor(int histo_size, int quality) {
|
||||||
double combine_cost_factor = 0.16;
|
double combine_cost_factor = 0.16;
|
||||||
if (histo_size > 256) combine_cost_factor /= 2.;
|
if (quality < 90) {
|
||||||
if (histo_size > 512) combine_cost_factor /= 2.;
|
if (histo_size > 256) combine_cost_factor /= 2.;
|
||||||
if (histo_size > 1024) combine_cost_factor /= 2.;
|
if (histo_size > 512) combine_cost_factor /= 2.;
|
||||||
if (quality <= 50) combine_cost_factor /= 2.;
|
if (histo_size > 1024) combine_cost_factor /= 2.;
|
||||||
|
if (quality <= 50) combine_cost_factor /= 2.;
|
||||||
|
}
|
||||||
return combine_cost_factor;
|
return combine_cost_factor;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -983,9 +985,8 @@ int VP8LGetHistoImageSymbols(int xsize, int ysize,
|
|||||||
|
|
||||||
// Don't attempt linear bin-partition heuristic for:
|
// Don't attempt linear bin-partition heuristic for:
|
||||||
// histograms of small sizes, as bin_map will be very sparse and;
|
// histograms of small sizes, as bin_map will be very sparse and;
|
||||||
// Higher qualities (> 90), to preserve the compression gains at those
|
// Maximum quality (q==100), to preserve the compression gains at that level.
|
||||||
// quality settings.
|
if (orig_histo->size > 2 * BIN_SIZE && quality < 100) {
|
||||||
if (orig_histo->size > 2 * BIN_SIZE && quality < 90) {
|
|
||||||
const int bin_map_size = bin_depth * BIN_SIZE;
|
const int bin_map_size = bin_depth * BIN_SIZE;
|
||||||
bin_map = (int16_t*)WebPSafeCalloc(bin_map_size, sizeof(*bin_map));
|
bin_map = (int16_t*)WebPSafeCalloc(bin_map_size, sizeof(*bin_map));
|
||||||
if (bin_map == NULL) goto Error;
|
if (bin_map == NULL) goto Error;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user