#include <string.h>
#include <math.h>
#include "src/enc/cost_enc.h"
#include "src/enc/vp8i_enc.h"
#include "src/dsp/dsp.h"
#include "src/webp/format_constants.h"
#define SEGMENT_VISU …
#define DEBUG_SEARCH …
#define HEADER_SIZE_ESTIMATE …
#define DQ_LIMIT …
#define PARTITION0_SIZE_LIMIT …
static float Clamp(float v, float min, float max) { … }
PassStats;
static int InitPassStats(const VP8Encoder* const enc, PassStats* const s) { … }
static float ComputeNextQ(PassStats* const s) { … }
const uint8_t VP8Cat3[] = …;
const uint8_t VP8Cat4[] = …;
const uint8_t VP8Cat5[] = …;
const uint8_t VP8Cat6[] = …;
static void ResetStats(VP8Encoder* const enc) { … }
#define SKIP_PROBA_THRESHOLD …
static int CalcSkipProba(uint64_t nb, uint64_t total) { … }
static int FinalizeSkipProba(VP8Encoder* const enc) { … }
static int CalcTokenProba(int nb, int total) { … }
static int BranchCost(int nb, int total, int proba) { … }
static void ResetTokenStats(VP8Encoder* const enc) { … }
static int FinalizeTokenProbas(VP8EncProba* const proba) { … }
static int GetProba(int a, int b) { … }
static void ResetSegments(VP8Encoder* const enc) { … }
static void SetSegmentProbas(VP8Encoder* const enc) { … }
static int PutCoeffs(VP8BitWriter* const bw, int ctx, const VP8Residual* res) { … }
static void CodeResiduals(VP8BitWriter* const bw, VP8EncIterator* const it,
const VP8ModeScore* const rd) { … }
static void RecordResiduals(VP8EncIterator* const it,
const VP8ModeScore* const rd) { … }
#if !defined(DISABLE_TOKEN_BUFFER)
static int RecordTokens(VP8EncIterator* const it, const VP8ModeScore* const rd,
VP8TBuffer* const tokens) { … }
#endif
#if !defined(WEBP_DISABLE_STATS)
#if SEGMENT_VISU
static void SetBlock(uint8_t* p, int value, int size) {
int y;
for (y = 0; y < size; ++y) {
memset(p, value, size);
p += BPS;
}
}
#endif
static void ResetSSE(VP8Encoder* const enc) {
enc->sse_[0] = 0;
enc->sse_[1] = 0;
enc->sse_[2] = 0;
enc->sse_count_ = 0;
}
static void StoreSSE(const VP8EncIterator* const it) {
VP8Encoder* const enc = it->enc_;
const uint8_t* const in = it->yuv_in_;
const uint8_t* const out = it->yuv_out_;
enc->sse_[0] += VP8SSE16x16(in + Y_OFF_ENC, out + Y_OFF_ENC);
enc->sse_[1] += VP8SSE8x8(in + U_OFF_ENC, out + U_OFF_ENC);
enc->sse_[2] += VP8SSE8x8(in + V_OFF_ENC, out + V_OFF_ENC);
enc->sse_count_ += 16 * 16;
}
static void StoreSideInfo(const VP8EncIterator* const it) {
VP8Encoder* const enc = it->enc_;
const VP8MBInfo* const mb = it->mb_;
WebPPicture* const pic = enc->pic_;
if (pic->stats != NULL) {
StoreSSE(it);
enc->block_count_[0] += (mb->type_ == 0);
enc->block_count_[1] += (mb->type_ == 1);
enc->block_count_[2] += (mb->skip_ != 0);
}
if (pic->extra_info != NULL) {
uint8_t* const info = &pic->extra_info[it->x_ + it->y_ * enc->mb_w_];
switch (pic->extra_info_type) {
case 1: *info = mb->type_; break;
case 2: *info = mb->segment_; break;
case 3: *info = enc->dqm_[mb->segment_].quant_; break;
case 4: *info = (mb->type_ == 1) ? it->preds_[0] : 0xff; break;
case 5: *info = mb->uv_mode_; break;
case 6: {
const int b = (int)((it->luma_bits_ + it->uv_bits_ + 7) >> 3);
*info = (b > 255) ? 255 : b; break;
}
case 7: *info = mb->alpha_; break;
default: *info = 0; break;
}
}
#if SEGMENT_VISU
SetBlock(it->yuv_out_ + Y_OFF_ENC, mb->segment_ * 64, 16);
SetBlock(it->yuv_out_ + U_OFF_ENC, it->preds_[0] * 64, 8);
SetBlock(it->yuv_out_ + V_OFF_ENC, mb->uv_mode_ * 64, 8);
#endif
}
static void ResetSideInfo(const VP8EncIterator* const it) {
VP8Encoder* const enc = it->enc_;
WebPPicture* const pic = enc->pic_;
if (pic->stats != NULL) {
memset(enc->block_count_, 0, sizeof(enc->block_count_));
}
ResetSSE(enc);
}
#else
static void ResetSSE(VP8Encoder* const enc) { … }
static void StoreSideInfo(const VP8EncIterator* const it) { … }
static void ResetSideInfo(const VP8EncIterator* const it) { … }
#endif
static double GetPSNR(uint64_t mse, uint64_t size) { … }
static void SetLoopParams(VP8Encoder* const enc, float q) { … }
static uint64_t OneStatPass(VP8Encoder* const enc, VP8RDLevel rd_opt,
int nb_mbs, int percent_delta,
PassStats* const s) { … }
static int StatLoop(VP8Encoder* const enc) { … }
static const uint8_t kAverageBytesPerMB[8] = …;
static int PreLoopInitialize(VP8Encoder* const enc) { … }
static int PostLoopFinalize(VP8EncIterator* const it, int ok) { … }
static void ResetAfterSkip(VP8EncIterator* const it) { … }
int VP8EncLoop(VP8Encoder* const enc) { … }
#if !defined(DISABLE_TOKEN_BUFFER)
#define MIN_COUNT …
int VP8EncTokenLoop(VP8Encoder* const enc) { … }
#else
int VP8EncTokenLoop(VP8Encoder* const enc) {
(void)enc;
return 0;
}
#endif