36 #include "libavutil/attributes.h"
37 #include "libavutil/avassert.h"
64 const int64_t one = 1LL << 32;
73 for (i = 0; i < 128; i++) {
74 p8 = (256 * p + one / 2) >> 32;
77 if (last_p8 && last_p8 < 256 && p8 <= max_p)
80 p += ((one - p) * factor + one / 2) >> 32;
84 for (i = 256 - max_p; i <= max_p; i++) {
88 p = (i * one + 128) >> 8;
89 p += ((one - p) * factor + one / 2) >> 32;
90 p8 = (256 * p + one / 2) >> 32;
98 for (i = 1; i < 255; i++)
120 #include "libavutil/lfg.h"
121 #include "libavutil/log.h"
137 memset(state, 128,
sizeof(state));
139 for (i = 0; i <
SIZE; i++)
142 for (i = 0; i <
SIZE; i++)
149 memset(state, 128,
sizeof(state));
151 for (i = 0; i <
SIZE; i++)
152 if ((r[i] & 1) !=
get_rac(&c, state)) {
void av_log(void *avcl, int level, const char *fmt,...) av_printf_format(3
Send the specified message to the log if the level is less than or equal to the current av_log_level...
int ff_rac_terminate(RangeCoder *c)
static int get_rac(RangeCoder *c, uint8_t *const state)
static unsigned int av_lfg_get(AVLFG *c)
Get the next random unsigned 32-bit number using an ALFG.
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
static void renorm_encoder(RangeCoder *c)
Libavcodec external API header.
void ff_build_rac_states(RangeCoder *c, int factor, int max_p)
void av_lfg_init(AVLFG *c, unsigned int seed)
av_cold void ff_init_range_encoder(RangeCoder *c, uint8_t *buf, int buf_size)
av_cold void ff_init_range_decoder(RangeCoder *c, const uint8_t *buf, int buf_size)
static const int factor[16]
#define av_assert1(cond)
assert() equivalent, that does not lie in speed critical code.
uint8_t * bytestream_start
int main(int argc, char **argv)