summaryrefslogtreecommitdiffstats
path: root/third_party/jpeg-xl/lib/jxl/enc_cache.h
diff options
context:
space:
mode:
Diffstat (limited to 'third_party/jpeg-xl/lib/jxl/enc_cache.h')
-rw-r--r--third_party/jpeg-xl/lib/jxl/enc_cache.h93
1 files changed, 93 insertions, 0 deletions
diff --git a/third_party/jpeg-xl/lib/jxl/enc_cache.h b/third_party/jpeg-xl/lib/jxl/enc_cache.h
new file mode 100644
index 0000000000..6c7870ba00
--- /dev/null
+++ b/third_party/jpeg-xl/lib/jxl/enc_cache.h
@@ -0,0 +1,93 @@
+// Copyright (c) the JPEG XL Project Authors. All rights reserved.
+//
+// Use of this source code is governed by a BSD-style
+// license that can be found in the LICENSE file.
+
+#ifndef LIB_JXL_ENC_CACHE_H_
+#define LIB_JXL_ENC_CACHE_H_
+
+#include <stddef.h>
+#include <stdint.h>
+
+#include <vector>
+
+#include "lib/jxl/ac_strategy.h"
+#include "lib/jxl/base/data_parallel.h"
+#include "lib/jxl/coeff_order.h"
+#include "lib/jxl/coeff_order_fwd.h"
+#include "lib/jxl/common.h"
+#include "lib/jxl/dct_util.h"
+#include "lib/jxl/enc_ans.h"
+#include "lib/jxl/enc_heuristics.h"
+#include "lib/jxl/enc_params.h"
+#include "lib/jxl/enc_progressive_split.h"
+#include "lib/jxl/frame_header.h"
+#include "lib/jxl/image.h"
+#include "lib/jxl/image_bundle.h"
+#include "lib/jxl/passes_state.h"
+#include "lib/jxl/quant_weights.h"
+#include "lib/jxl/quantizer.h"
+
+namespace jxl {
+
+struct AuxOut;
+
+// Contains encoder state.
+struct PassesEncoderState {
+ PassesSharedState shared;
+
+ ImageF initial_quant_field; // Invalid in Falcon mode.
+ ImageF initial_quant_masking; // Invalid in Falcon mode.
+
+ // Per-pass DCT coefficients for the image. One row per group.
+ std::vector<std::unique_ptr<ACImage>> coeffs;
+
+ // Raw data for special (reference+DC) frames.
+ std::vector<std::unique_ptr<BitWriter>> special_frames;
+
+ // For splitting into passes.
+ ProgressiveSplitter progressive_splitter;
+
+ CompressParams cparams;
+
+ struct PassData {
+ std::vector<std::vector<Token>> ac_tokens;
+ std::vector<uint8_t> context_map;
+ EntropyEncodingData codes;
+ };
+
+ std::vector<PassData> passes;
+ std::vector<uint8_t> histogram_idx;
+
+ // Coefficient orders that are non-default.
+ std::vector<uint32_t> used_orders;
+
+ // Multiplier to be applied to the quant matrices of the x channel.
+ float x_qm_multiplier = 1.0f;
+ float b_qm_multiplier = 1.0f;
+
+ // Heuristics to be used by the encoder.
+ std::unique_ptr<EncoderHeuristics> heuristics =
+ make_unique<DefaultEncoderHeuristics>();
+};
+
+// Initialize per-frame information.
+class ModularFrameEncoder;
+Status InitializePassesEncoder(const Image3F& opsin, const JxlCmsInterface& cms,
+ ThreadPool* pool,
+ PassesEncoderState* passes_enc_state,
+ ModularFrameEncoder* modular_frame_encoder,
+ AuxOut* aux_out);
+
+// Working area for ComputeCoefficients (per-group!)
+struct EncCache {
+ // Allocates memory when first called, shrinks images to current group size.
+ void InitOnce();
+
+ // TokenizeCoefficients
+ Image3I num_nzeroes;
+};
+
+} // namespace jxl
+
+#endif // LIB_JXL_ENC_CACHE_H_