Skip to content

Delnegend/artefact

Repository files navigation

artefact

Decode JPEG without artifacts

  • Written in pure Rust, no unsafe code.
  • WASM-ready, check out the web version, everything runs in your browser.
  • FASTER (~2x) than the of the original implementation jpeg2png project. (backup link)

Tests

Photo by Aleksandar Pasaric

Photo by Toa Heftiba Şinca

CLI version

Pre-build binaries

WIP

Build

Pre-requisites: Rust toolchain

cargo build --release --package artefact-cli

The binary will be located at ./target/release/artefact-cli

Build features

To toggle specific features when building the CLI, modify artefact-cli/Cargo.toml and add the desired features to the [dependencies.artefact-lib] features list.

[dependencies.artefact-lib]
path = "../artefact-lib"
features = [
    "simd", # enable SIMD acceleration using `wide` crate
    "simd_std", # enable SIMD acceleration using `std::simd` module, requires nightly Rust
    "mozjpeg", # use `mozjpeg` instead of `zune-jpeg` for decoding, might provide better compatibility
]

Recommendation: just stick with simd only.

Cross-compile

  • Windows x64:
sudo apt update && sudo apt install gcc-mingw-w64-x86-64
rustup target add x86_64-pc-windows-gnu
nrr build-win-64
  • Windows x86:
sudo apt update && sudo apt install gcc-mingw-w64-i686
rustup target add i686-pc-windows-gnu
nrr build-win-32

Usage

Usage: artefact-cli [OPTIONS] <INPUT>

Arguments:
  <INPUT>
          The input jpeg file

Options:
  -o, --output <OUTPUT>
          The output png file

          Default: input file with png extension

  -y, --overwrite
          Overwrite existing output file

  -w, --weight <WEIGHT>
          Second order weight
          Higher values give smoother transitions with less staircasing

          Default: 0.3 for all channels, use comma separated values for each channel

  -p, --pweight <PWEIGHT>
          Probability weight
          Higher values make the result more similar to the source JPEG

          Default: 0.001 for all channels, use comma separated values for each channel

  -i, --iterations <ITERATIONS>
          Iterations
          Higher values give better results but take more time

          Default: 50 for all channels, use comma separated values for each channel

  -s, --spearate-components <SPEARATE_COMPONENTS>
          Separate components
          Separately optimize components instead of all together

          Default: false

          [possible values: true, false]

  -h, --help
          Print help (see a summary with '-h')

  -V, --version
          Print version

Developement

Directories

License

Licensed under either of

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.