From 6bf0a5cb5034a7e684dcc3500e841785237ce2dd Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Sun, 7 Apr 2024 19:32:43 +0200 Subject: Adding upstream version 1:115.7.0. Signed-off-by: Daniel Baumann --- third_party/jpeg-xl/lib/jpegli/entropy_coding.h | 45 +++++++++++++++++++++++++ 1 file changed, 45 insertions(+) create mode 100644 third_party/jpeg-xl/lib/jpegli/entropy_coding.h (limited to 'third_party/jpeg-xl/lib/jpegli/entropy_coding.h') diff --git a/third_party/jpeg-xl/lib/jpegli/entropy_coding.h b/third_party/jpeg-xl/lib/jpegli/entropy_coding.h new file mode 100644 index 0000000000..6d9dd2303b --- /dev/null +++ b/third_party/jpeg-xl/lib/jpegli/entropy_coding.h @@ -0,0 +1,45 @@ +// 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_JPEGLI_ENTROPY_CODING_H_ +#define LIB_JPEGLI_ENTROPY_CODING_H_ + +/* clang-format off */ +#include +#include +/* clang-format on */ + +#include + +#include "lib/jpegli/encode_internal.h" + +namespace jpegli { + +void CopyHuffmanCodes(j_compress_ptr cinfo, bool* is_baseline); + +size_t RestartIntervalForScan(j_compress_ptr cinfo, size_t scan_index); + +struct Histogram { + int count[kJpegHuffmanAlphabetSize]; + Histogram() { memset(count, 0, sizeof(count)); } +}; + +struct JpegClusteredHistograms { + std::vector histograms; + std::vector histogram_indexes; + std::vector slot_ids; +}; + +void ClusterJpegHistograms(const Histogram* histograms, size_t num, + JpegClusteredHistograms* clusters); + +void AddJpegHuffmanCode(const Histogram& histogram, size_t slot_id, + JPEGHuffmanCode* huff_codes, size_t* num_huff_codes); + +void OptimizeHuffmanCodes(j_compress_ptr cinfo, bool* is_baseline); + +} // namespace jpegli + +#endif // LIB_JPEGLI_ENTROPY_CODING_H_ -- cgit v1.2.3