2015-11-27 10:27:11 +00:00
|
|
|
/* Copyright 2013 Google Inc. All Rights Reserved.
|
|
|
|
|
|
|
|
Distributed under MIT license, or public domain if desired and
|
|
|
|
recognized in your jurisdiction.
|
|
|
|
See file LICENSE for detail or copy at https://opensource.org/licenses/MIT
|
|
|
|
*/
|
|
|
|
|
2013-10-23 11:06:13 +00:00
|
|
|
// Literal cost model to allow backward reference replacement to be efficient.
|
|
|
|
|
|
|
|
#ifndef BROTLI_ENC_LITERAL_COST_H_
|
|
|
|
#define BROTLI_ENC_LITERAL_COST_H_
|
|
|
|
|
2015-10-01 10:08:14 +00:00
|
|
|
#include "./types.h"
|
2013-10-23 11:06:13 +00:00
|
|
|
|
|
|
|
namespace brotli {
|
|
|
|
|
2013-11-15 18:02:17 +00:00
|
|
|
// Estimates how many bits the literals in the interval [pos, pos + len) in the
|
|
|
|
// ringbuffer (data, mask) will take entropy coded and writes these estimates
|
2015-10-01 13:10:42 +00:00
|
|
|
// to the cost[0..len) array.
|
2013-11-15 18:02:17 +00:00
|
|
|
void EstimateBitCostsForLiterals(size_t pos, size_t len, size_t mask,
|
2015-10-01 13:10:42 +00:00
|
|
|
const uint8_t *data, float *cost);
|
2013-10-23 11:06:13 +00:00
|
|
|
|
|
|
|
} // namespace brotli
|
|
|
|
|
|
|
|
#endif // BROTLI_ENC_LITERAL_COST_H_
|