Skip to main content

Yummy Optimizer for Gorgeous Assets

Project description

Github Discord PYPI Version Build Status Black License

YOGA is a command-line tool and a library that can:

  • convert and optimize images from various format to JPEG, PNG and WEBP,

  • convert and optimize 3D models from various formats to glTF and GLB.

Images are opened using Pillow and optimized using Guetzli (for JPEGs), Zopflipng (for PNGs) and libwebp (for WEBPs).

3D Models are converted and optimized using assimp. If models contain or reference images, they are processed by YOGA’s image optimizer.

EXAMPLE: Converting and optimizing an image from CLI:

yoga  image  input.png  output.png
yoga  image  --output-format=jpeg  --jpeg-quality=84  input.png  output.jpg
yoga  image  --help

EXAMPLE: Converting and optimizing a 3D model from CLI:

yoga  model  input.fbx  output.glb
yoga  model  --no-graph-optimization  --no-meshes-optimization  --image-output-format=jpeg  --image-jpeg-quality=84  input.fbx  output.glb
yoga  model  --help

Install

Documentation

Changelog

  • [NEXT] (changes on master that have not been released yet):

    • Nothing yet ;)

  • v1.3.1:

    • chore(sdist): Fixed included files in sdist package

  • v1.3.0:

    • feat(assimp): Updated assimp to v5.3.1 (fixed build on GCC >= 13)

    • chore: Removed a script that is no more needed

    • docs: Updated contributing documentation (libraries, supported Python version, assimp update)

  • v1.2.3:

    • Code quality: more robust type comparison (@flozz)

    • Code quality: cleanup some Python 2.7 specific code (@flozz)

    • Added Python 3.12 support (@flozz)

    • Removed Python 3.7 support (@flozz)

  • v1.2.2:

    • Updated the code to not use deprecated constants on newer Pillow versions

    • Various typo fixed (@kianmeng, #45)

    • Added Python 3.11 support

  • v1.2.1:

    • No change: fix an upload error on PYPI

  • v1.2.0:

    • Add color quantization options (based on libimagequant)

    • arm64 and universal2 wheels for macOS

    • x86 and x68_64 wheels for musl-based Linux distro (Alpine,…)

    • MAINTAINERS: New dependency: imagequant

  • v1.1.2:

    • Add flag to CFFI builder to fix MacOS build

  • v1.1.1 (not published):

    • JPEG: ignore invalid values for the orientation tag (#38)

    • Python 3.10 support and wheels

  • v1.1.0:

    • JPEG Optimization:

      • Honor the JPEG orientation EXIF tag

      • JPEG optimization has been improved by using some optimizations from MozJPEG after the Guetzli encoding (from 2.4 % to 7.3 % of additional size reduction)

    • PNG Optimization:

      • YOGA can no more output a PNG larger than the input one when performing a PNG to PNG optimization

    • CLI:

      • Allow to cancel an optimization using Ctrl+C (NOTE: may not work on Windows)

      • Add a --version option to get YOGA’s version

      • Improve yoga --help usage

    • Python versions:

      • Python 2.7 support dropped

    • NOTE for packagers:

  • v1.0.0:

    • WEBP (lossy and lossless) images supported as output format

    • PNG default optimization preset changed to a 10× faster preset (old preset still available with --png-slow-optimization flag)

    • New model flag --no-fix-infacing-normals to disable Assimp’s “fix infacing normals” postprocess (#32, #33)

    • Show CLI usage when no parameter given

    • Developer documentation improved (#31)

    • ASSIMP library updated

    • WARNING: This is the last version to actively support Python 2.7!

  • v0.11.1:

    • Automated workflow for deploying the PyPI packages

    • Wheel are now distributed on PyPI

  • v0.11.0:

    • Allows to build YOGA on Windows

    • Scripts and workflow to build Windows standalone versions

  • v0.10.2:

    • Updates assimp and python libraries

  • v0.10.1:

    • Fixes an issue that occurs when output file does not already exist

  • v0.10.0:

    • Prevent overwriting of the output file when an error occurs (#17)

    • Unicode path support (#16)

  • v0.10.0b1:

    • Verbose and quiet modes,

    • Allows to pass textures from memory instead of looking on the filesystem,

    • Allows to pass a fallback texture instead of raising an error.

  • v0.9.1b1:

    • Automatic selection of the output format (png or jpeg),

    • Prevent duplication of textures that are shared between materials,

    • Fixes Windows paths of textures.

  • v0.9.0b1: First release (only GLB output for models, no image auto output format)

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

yoga-1.3.1.tar.gz (3.2 MB view hashes)

Uploaded Source

Built Distributions

yoga-1.3.1-pp310-pypy310_pp73-win_amd64.whl (2.3 MB view hashes)

Uploaded PyPy Windows x86-64

yoga-1.3.1-pp310-pypy310_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (6.7 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ x86-64

yoga-1.3.1-pp310-pypy310_pp73-manylinux_2_17_i686.manylinux2014_i686.whl (6.9 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ i686

yoga-1.3.1-pp310-pypy310_pp73-macosx_10_9_x86_64.whl (5.7 MB view hashes)

Uploaded PyPy macOS 10.9+ x86-64

yoga-1.3.1-pp39-pypy39_pp73-win_amd64.whl (2.3 MB view hashes)

Uploaded PyPy Windows x86-64

yoga-1.3.1-pp39-pypy39_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (6.7 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ x86-64

yoga-1.3.1-pp39-pypy39_pp73-manylinux_2_17_i686.manylinux2014_i686.whl (6.9 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ i686

yoga-1.3.1-pp39-pypy39_pp73-macosx_10_9_x86_64.whl (5.7 MB view hashes)

Uploaded PyPy macOS 10.9+ x86-64

yoga-1.3.1-pp38-pypy38_pp73-win_amd64.whl (2.3 MB view hashes)

Uploaded PyPy Windows x86-64

yoga-1.3.1-pp38-pypy38_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (6.7 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ x86-64

yoga-1.3.1-pp38-pypy38_pp73-manylinux_2_17_i686.manylinux2014_i686.whl (6.9 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ i686

yoga-1.3.1-pp38-pypy38_pp73-macosx_10_9_x86_64.whl (5.7 MB view hashes)

Uploaded PyPy macOS 10.9+ x86-64

yoga-1.3.1-pp37-pypy37_pp73-win_amd64.whl (2.3 MB view hashes)

Uploaded PyPy Windows x86-64

yoga-1.3.1-pp37-pypy37_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (6.8 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ x86-64

yoga-1.3.1-pp37-pypy37_pp73-manylinux_2_17_i686.manylinux2014_i686.whl (7.0 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ i686

yoga-1.3.1-pp37-pypy37_pp73-macosx_10_9_x86_64.whl (5.7 MB view hashes)

Uploaded PyPy macOS 10.9+ x86-64

yoga-1.3.1-cp312-cp312-win_amd64.whl (2.3 MB view hashes)

Uploaded CPython 3.12 Windows x86-64

yoga-1.3.1-cp312-cp312-musllinux_1_1_x86_64.whl (7.5 MB view hashes)

Uploaded CPython 3.12 musllinux: musl 1.1+ x86-64

yoga-1.3.1-cp312-cp312-musllinux_1_1_i686.whl (7.9 MB view hashes)

Uploaded CPython 3.12 musllinux: musl 1.1+ i686

yoga-1.3.1-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (7.0 MB view hashes)

Uploaded CPython 3.12 manylinux: glibc 2.17+ x86-64

yoga-1.3.1-cp312-cp312-manylinux_2_17_i686.manylinux2014_i686.whl (7.2 MB view hashes)

Uploaded CPython 3.12 manylinux: glibc 2.17+ i686

yoga-1.3.1-cp312-cp312-macosx_11_0_arm64.whl (43.4 kB view hashes)

Uploaded CPython 3.12 macOS 11.0+ ARM64

yoga-1.3.1-cp312-cp312-macosx_10_9_x86_64.whl (5.7 MB view hashes)

Uploaded CPython 3.12 macOS 10.9+ x86-64

yoga-1.3.1-cp312-cp312-macosx_10_9_universal2.whl (5.7 MB view hashes)

Uploaded CPython 3.12 macOS 10.9+ universal2 (ARM64, x86-64)

yoga-1.3.1-cp311-cp311-win_amd64.whl (2.3 MB view hashes)

Uploaded CPython 3.11 Windows x86-64

yoga-1.3.1-cp311-cp311-musllinux_1_1_x86_64.whl (7.5 MB view hashes)

Uploaded CPython 3.11 musllinux: musl 1.1+ x86-64

yoga-1.3.1-cp311-cp311-musllinux_1_1_i686.whl (7.9 MB view hashes)

Uploaded CPython 3.11 musllinux: musl 1.1+ i686

yoga-1.3.1-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (7.0 MB view hashes)

Uploaded CPython 3.11 manylinux: glibc 2.17+ x86-64

yoga-1.3.1-cp311-cp311-manylinux_2_17_i686.manylinux2014_i686.whl (7.2 MB view hashes)

Uploaded CPython 3.11 manylinux: glibc 2.17+ i686

yoga-1.3.1-cp311-cp311-macosx_11_0_arm64.whl (43.3 kB view hashes)

Uploaded CPython 3.11 macOS 11.0+ ARM64

yoga-1.3.1-cp311-cp311-macosx_10_9_x86_64.whl (5.7 MB view hashes)

Uploaded CPython 3.11 macOS 10.9+ x86-64

yoga-1.3.1-cp311-cp311-macosx_10_9_universal2.whl (5.7 MB view hashes)

Uploaded CPython 3.11 macOS 10.9+ universal2 (ARM64, x86-64)

yoga-1.3.1-cp310-cp310-win_amd64.whl (2.3 MB view hashes)

Uploaded CPython 3.10 Windows x86-64

yoga-1.3.1-cp310-cp310-musllinux_1_1_x86_64.whl (7.5 MB view hashes)

Uploaded CPython 3.10 musllinux: musl 1.1+ x86-64

yoga-1.3.1-cp310-cp310-musllinux_1_1_i686.whl (7.9 MB view hashes)

Uploaded CPython 3.10 musllinux: musl 1.1+ i686

yoga-1.3.1-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (7.0 MB view hashes)

Uploaded CPython 3.10 manylinux: glibc 2.17+ x86-64

yoga-1.3.1-cp310-cp310-manylinux_2_17_i686.manylinux2014_i686.whl (7.2 MB view hashes)

Uploaded CPython 3.10 manylinux: glibc 2.17+ i686

yoga-1.3.1-cp310-cp310-macosx_11_0_arm64.whl (43.3 kB view hashes)

Uploaded CPython 3.10 macOS 11.0+ ARM64

yoga-1.3.1-cp310-cp310-macosx_10_9_x86_64.whl (5.7 MB view hashes)

Uploaded CPython 3.10 macOS 10.9+ x86-64

yoga-1.3.1-cp310-cp310-macosx_10_9_universal2.whl (5.7 MB view hashes)

Uploaded CPython 3.10 macOS 10.9+ universal2 (ARM64, x86-64)

yoga-1.3.1-cp39-cp39-win_amd64.whl (2.3 MB view hashes)

Uploaded CPython 3.9 Windows x86-64

yoga-1.3.1-cp39-cp39-musllinux_1_1_x86_64.whl (7.5 MB view hashes)

Uploaded CPython 3.9 musllinux: musl 1.1+ x86-64

yoga-1.3.1-cp39-cp39-musllinux_1_1_i686.whl (7.9 MB view hashes)

Uploaded CPython 3.9 musllinux: musl 1.1+ i686

yoga-1.3.1-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (7.0 MB view hashes)

Uploaded CPython 3.9 manylinux: glibc 2.17+ x86-64

yoga-1.3.1-cp39-cp39-manylinux_2_17_i686.manylinux2014_i686.whl (7.2 MB view hashes)

Uploaded CPython 3.9 manylinux: glibc 2.17+ i686

yoga-1.3.1-cp39-cp39-macosx_11_0_arm64.whl (43.3 kB view hashes)

Uploaded CPython 3.9 macOS 11.0+ ARM64

yoga-1.3.1-cp39-cp39-macosx_10_9_x86_64.whl (5.7 MB view hashes)

Uploaded CPython 3.9 macOS 10.9+ x86-64

yoga-1.3.1-cp39-cp39-macosx_10_9_universal2.whl (5.7 MB view hashes)

Uploaded CPython 3.9 macOS 10.9+ universal2 (ARM64, x86-64)

yoga-1.3.1-cp38-cp38-win_amd64.whl (2.3 MB view hashes)

Uploaded CPython 3.8 Windows x86-64

yoga-1.3.1-cp38-cp38-musllinux_1_1_x86_64.whl (7.5 MB view hashes)

Uploaded CPython 3.8 musllinux: musl 1.1+ x86-64

yoga-1.3.1-cp38-cp38-musllinux_1_1_i686.whl (7.9 MB view hashes)

Uploaded CPython 3.8 musllinux: musl 1.1+ i686

yoga-1.3.1-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (7.0 MB view hashes)

Uploaded CPython 3.8 manylinux: glibc 2.17+ x86-64

yoga-1.3.1-cp38-cp38-manylinux_2_17_i686.manylinux2014_i686.whl (7.2 MB view hashes)

Uploaded CPython 3.8 manylinux: glibc 2.17+ i686

yoga-1.3.1-cp38-cp38-macosx_11_0_arm64.whl (43.3 kB view hashes)

Uploaded CPython 3.8 macOS 11.0+ ARM64

yoga-1.3.1-cp38-cp38-macosx_10_9_x86_64.whl (5.7 MB view hashes)

Uploaded CPython 3.8 macOS 10.9+ x86-64

yoga-1.3.1-cp38-cp38-macosx_10_9_universal2.whl (5.7 MB view hashes)

Uploaded CPython 3.8 macOS 10.9+ universal2 (ARM64, x86-64)

yoga-1.3.1-cp37-cp37m-win_amd64.whl (2.3 MB view hashes)

Uploaded CPython 3.7m Windows x86-64

yoga-1.3.1-cp37-cp37m-musllinux_1_1_x86_64.whl (7.5 MB view hashes)

Uploaded CPython 3.7m musllinux: musl 1.1+ x86-64

yoga-1.3.1-cp37-cp37m-musllinux_1_1_i686.whl (7.9 MB view hashes)

Uploaded CPython 3.7m musllinux: musl 1.1+ i686

yoga-1.3.1-cp37-cp37m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (7.0 MB view hashes)

Uploaded CPython 3.7m manylinux: glibc 2.17+ x86-64

yoga-1.3.1-cp37-cp37m-manylinux_2_17_i686.manylinux2014_i686.whl (7.2 MB view hashes)

Uploaded CPython 3.7m manylinux: glibc 2.17+ i686

yoga-1.3.1-cp37-cp37m-macosx_10_9_x86_64.whl (5.7 MB view hashes)

Uploaded CPython 3.7m macOS 10.9+ x86-64

yoga-1.3.1-cp36-cp36m-win_amd64.whl (2.3 MB view hashes)

Uploaded CPython 3.6m Windows x86-64

yoga-1.3.1-cp36-cp36m-musllinux_1_1_x86_64.whl (7.5 MB view hashes)

Uploaded CPython 3.6m musllinux: musl 1.1+ x86-64

yoga-1.3.1-cp36-cp36m-musllinux_1_1_i686.whl (7.9 MB view hashes)

Uploaded CPython 3.6m musllinux: musl 1.1+ i686

yoga-1.3.1-cp36-cp36m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (7.0 MB view hashes)

Uploaded CPython 3.6m manylinux: glibc 2.17+ x86-64

yoga-1.3.1-cp36-cp36m-manylinux_2_17_i686.manylinux2014_i686.whl (7.2 MB view hashes)

Uploaded CPython 3.6m manylinux: glibc 2.17+ i686

yoga-1.3.1-cp36-cp36m-macosx_10_9_x86_64.whl (5.7 MB view hashes)

Uploaded CPython 3.6m macOS 10.9+ x86-64

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page