/bench

Testing of various jxl implementations in terms of conformance, speed, compression, ...

Primary LanguagePythonBSD 3-Clause "New" or "Revised" LicenseBSD-3-Clause

🚧 Work in Progress 🚧

JPEG XL conformance bench

We compare how different implementations of JPEG XL perform on the conformance tests.

Currently we compare the following:

  • libjxl, the reference implementation in C++
  • libjxl decoding to png
  • jxl-oxide a decoder written in pure Rust
  • jxlatte a pure java decoder
  • j40 a single-header-file C decoder

How to generate a report

Some of the decoder are and the conformance tests are included as submodules, so as a first step after cloning this repo let's

git submodule update --recursive --init --depth 1 --recommend-shallow

Building the decoders

libjxl

A simple way of building libjxl is

SKIP_TEST=1 ./third_party/libjxl/ci.sh opt

which should provide ./third_party/libjxl/build/tools/djxl.

jxl-oxide

Make sure you have an up-to-date rust version, e.g. by running

rustup update

Then run

cargo install jxl-oxide-cli

which should provide the jxl-dec binary.

jxlatte

For building jxlatte, install meson and run

mkdir -p third_party/jxlatte/build
meson setup third_party/jxlatte/build third_party/jxlatte/
ninja -C third_party/jxlatte/build/

which should allow you to run java -jar ./jxlatte/build/java/jxlatte.jar.

j40

Building j40 is just

make -C third_party/j40

Running the conformance tests

Get conformance test data from Google Cloud bucket

First we need to get the actual test data for the conformance test, see instructions at (https://github.com/libjxl/conformance) after installing gsutils, this boils down to

gcloud auth login
[follow instructions]
./third_party/conformance/scripts/download_and_symlink.sh

Then you can run the conformance test, let's say on the main_level5 tests with all decoders, updating ./docs/dumps, which are displayed by docs/index.html. Make sure to have the python packages pypng, numpy and apng installed.

python3 ./third_party/conformance/scripts/conformance.py --decoder "./third_party/libjxl/build/tools/djxl"  --corpus  ./third_party/conformance/testcases/main_level5.txt --results=./docs/dumps/dump_djxl.json
python3 ./third_party/conformance/scripts/conformance.py --decoder "python3 scripts/wrap_png.py --decoder './third_party/libjxl/build/tools/djxl %s %s --bits_per_sample 16'" --corpus  ./third_party/conformance/testcases/main_level10.txt --results=./docs/dumps/dump_djxl_via_png.json --lax
python3 ./third_party/conformance/scripts/conformance.py --decoder "python3 scripts/wrap_png.py --decoder 'jxl-dec %s -o %s -f png16'" --corpus ./third_party/conformance/testcases/main_level5.txt --results=./docs/dumps/dump_jxl-dec.json --lax
python3 ./third_party/conformance/scripts/conformance.py --decoder "python3 scripts/wrap_png.py --decoder 'java -jar ./third_party/jxlatte/build/java/jxlatte.jar %s %s'"  --corpus  ./third_party/conformance/testcases/main_level5.txt --results=./docs/dumps/dump_jxlatte.json --lax
python3 ./third_party/conformance/scripts/conformance.py --decoder "python3 scripts/wrap_png.py --decoder './third_party/j40/dj40 %s %s'"  --corpus  ./third_party/conformance/testcases/main_level5.txt --results=./docs/dumps/dump_j40.json --lax

Alternative this can be done by running the update_dumps.sh script:

./scripts/update_dumps.sh ./third_party/conformance/testcases/main_level5.txt ./docs/dumps/

To see the report locally, you can then run

python3 -m http.server -d docs/