jax VS Nuitka

Compare jax vs Nuitka and see what are their differences.

jax

Composable transformations of Python+NumPy programs: differentiate, vectorize, JIT to GPU/TPU, and more (by google)
Jax

Nuitka

Nuitka is a Python compiler written in Python. It's fully compatible with Python 2.6, 2.7, 3.4, 3.5, 3.6, 3.7, 3.8, 3.9, 3.10, and 3.11. You feed it your Python app, it does a lot of clever things, and spits out an executable or extension module. (by Nuitka)
InfluxDB - Power Real-Time Data Analytics at Scale
Get real-time insights from all types of time series data with InfluxDB. Ingest, query, and analyze billions of data points in real-time with unbounded cardinality.
www.influxdata.com
featured
SaaSHub - Software Alternatives and Reviews
SaaSHub helps you find the best software and product alternatives
www.saashub.com
featured
jax Nuitka
82 94
28,004 10,884
1.8% 2.5%
10.0 10.0
4 days ago 3 days ago
Python Python
Apache License 2.0 Apache License 2.0
The number of mentions indicates the total number of mentions that we've tracked plus the number of user suggested alternatives.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.

jax

Posts with mentions or reviews of jax. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2024-03-22.
  • The Elements of Differentiable Programming
    5 projects | news.ycombinator.com | 22 Mar 2024
    The dual numbers exist just as surely as the real numbers and have been used well over 100 years

    https://en.m.wikipedia.org/wiki/Dual_number

    Pytorch has had them for many years.

    https://pytorch.org/docs/stable/generated/torch.autograd.for...

    JAX implements them and uses them exactly as stated in this thread.

    https://github.com/google/jax/discussions/10157#discussionco...

    As you so eloquently stated, "you shouldn't be proclaiming things you don't actually know on a public forum," and doubly so when your claimed "corrections" are so demonstrably and totally incorrect.

  • Julia GPU-based ODE solver 20x-100x faster than those in Jax and PyTorch
    6 projects | news.ycombinator.com | 23 Dec 2023
    On your last point, as long as you jit the topmost level, it doesn't matter whether or not you have inner jitted functions. The end result should be the same.

    Source: https://github.com/google/jax/discussions/5199#discussioncom...

  • Apple releases MLX for Apple Silicon
    4 projects | /r/LocalLLaMA | 8 Dec 2023
    The design of MLX is inspired by frameworks like NumPy, PyTorch, Jax, and ArrayFire.
  • MLPerf training tests put Nvidia ahead, Intel close, and Google well behind
    1 project | news.ycombinator.com | 14 Nov 2023
    I'm still not totally sure what the issue is. Jax uses program transformations to compile programs to run on a variety of hardware, for example, using XLA for TPUs. It can also run cuda ops for Nvidia gpus without issue: https://jax.readthedocs.io/en/latest/installation.html

    There is also support for custom cpp and cuda ops if that's what is needed: https://jax.readthedocs.io/en/latest/Custom_Operation_for_GP...

    I haven't worked with float4, but can imagine that new numerical types would require some special handling. But I assume that's the case for any ml environment.

    But really you probably mean fixed point 4bit integer types? Looks like that has had at least some work done in Jax: https://github.com/google/jax/issues/8566

  • MatX: Efficient C++17 GPU numerical computing library with Python-like syntax
    5 projects | news.ycombinator.com | 3 Oct 2023
    >

    Are they even comparing apples to apples to claim that they see these improvements over NumPy?

    > While the code complexity and length are roughly the same, the MatX version shows a 2100x over the Numpy version, and over 4x faster than the CuPy version on the same GPU.

    NumPy doesn't use GPU by default unless you use something like Jax [1] to compile NumPy code to run on GPUs. I think more honest comparison will mainly compare MatX running on same CPU like NumPy as focus the GPU comparison against CuPy.

    [1] https://github.com/google/jax

  • JAX – NumPy on the CPU, GPU, and TPU, with great automatic differentiation
    12 projects | news.ycombinator.com | 28 Sep 2023
    Actually that never changed. The README has always had an example of differentiating through native Python control flow:

    https://github.com/google/jax/commit/948a8db0adf233f333f3e5f...

    The constraints on control flow expressions come from jax.jit (because Python control flow can't be staged out) and jax.vmap (because we can't take multiple branches of Python control flow, which we might need to do for different batch elements). But autodiff of Python-native control flow works fine!

  • Julia and Mojo (Modular) Mandelbrot Benchmark
    10 projects | news.ycombinator.com | 8 Sep 2023
    For a similar "benchmark" (also Mandelbrot) but took place in Jax repo discussion: https://github.com/google/jax/discussions/11078#discussionco...
  • Functional Programming 1
    3 projects | news.ycombinator.com | 16 Aug 2023
    2. https://github.com/fantasyland/fantasy-land (A bit heavy on jargon)

    Note there is a python version of Ramda available on pypi and there’s a lot of FP tidbits inside JAX:

    3. https://pypi.org/project/ramda/ (Worth making your own version if you want to learn, though)

    4. For nested data, JAX tree_util is epic: https://jax.readthedocs.io/en/latest/jax.tree_util.html and also their curry implementation is funny: https://github.com/google/jax/blob/4ac2bdc2b1d71ec0010412a32...

    Anyway don’t put FP on a pedestal, main thing is to focus on the core principles of avoiding external mutation and making helper functions. Doesn’t always work because some languages like Rust don’t have legit support for currying (afaik in 2023 August), but in those cases you can hack it with builder methods to an extent.

    Finally, if you want to understand the middle of the midwit meme, check out this wiki article and connect the free monoid to the Kleene star (0 or more copies of your pattern) and Kleene plus (1 or more copies of your pattern). Those are also in regex so it can help you remember the regex symbols. https://en.wikipedia.org/wiki/Free_monoid?wprov=sfti1

    The simplest example might be {0}^* in which case

    0: “” // because we use *

  • Best Way to Learn JAX
    1 project | /r/learnmachinelearning | 13 May 2023
    Hello! I'm trying to learn JAX over the next couple of weeks. Ideally, I want to be comfortable with using it for projects after about 3 weeks to a month, although I understand that may not be realistic. I currently have experience with PyTorch and TensorFlow. How should I go about learning JAX? Is there a specific YouTube tutorial or online course I should use, or should I just use the tutorial on https://jax.readthedocs.io/? Any information, advice, or experience you can share would be much appreciated!
  • Codon: Python Compiler
    9 projects | news.ycombinator.com | 8 May 2023

Nuitka

Posts with mentions or reviews of Nuitka. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2024-04-22.
  • Py2wasm – A Python to WASM Compiler
    4 projects | news.ycombinator.com | 22 Apr 2024
    Thanks for the feedback! I'm Syrus, main author of the work on py2wasm.

    We already opened a PR into Nuitka to bring the relevant changes upstream: https://github.com/Nuitka/Nuitka/pull/2814

    We envision py2wasm being a thin layer on top of Nuitka, as also commented in the article.

    From what we gathered, we believe that there's usefulness on having py2wasm as a separate package, as py2wasm would also need to ship the precompiled Python distribution (3.11) for WASI (which will not be needed for the other Nuitka use cases), apart of also shipping other tools that are not directly relevant for Nuitka

  • Python Is Portable
    6 projects | news.ycombinator.com | 15 Apr 2024
    This is a good place to mention https://nuitka.net/ which aims to compile python programs into standalone binaries.
  • We are under DDoS attack and we do nothing
    2 projects | news.ycombinator.com | 30 Mar 2024
    For Python, you could make a proper deployment binary using Nuitka (in standalone mode – avoid onefile mode for this). I'm not pretending it's as easy as building a Go executable: you may have to do some manual hacking for more unusual unusual packages, and I don't think you can cross compile. I think a key element you're getting at is that Go executables have very few dependencies on OS packages, but with Python (once you've sorted the actual Python dependencies) you only need the packages used for manylinux [2], which is not too onerous.

    [1] https://nuitka.net/

    [2] https://peps.python.org/pep-0599/#the-manylinux2014-policy

  • Faster Blogging: A Developer's Dream Setup
    4 projects | dev.to | 22 Feb 2024
    glee is rich in blogging features but has some drawbacks. One of the main drawbacks is its compatibility with multiple operating systems and system architectures. We lost one potential customer due to glee incompatibility in macOS. Another major issue is the deployment time. We built the first version of glee entirely in Python and used nuitka, nuitka compiles Python programs into a single executable binary file. We need to create three separate stages for creating executable binaries for Windows, Mac, and Linux in deployment, and it takes around 20 minutes to complete.
  • Python 3.13 Gets a JIT
    11 projects | news.ycombinator.com | 9 Jan 2024
    There is already an AOT compiler for Python: Nuitka[0]. But I don't think it's much faster.

    And then there is mypyc[1] which uses mypy's static type annotations but is only slightly faster.

    And various other compilers like Numba and Cython that work with specialized dialects of Python to achieve better results, but then it's not quite Python anymore.

    [0] https://nuitka.net/

    [1] https://github.com/python/mypy/tree/master/mypyc

  • Briefcase: Convert a Python project into a standalone native application
    4 projects | news.ycombinator.com | 3 Aug 2023
    Nuitka deals pretty well with those in general: https://nuitka.net/
  • Ask HN: How does Nuitka (Python compiler) work?
    1 project | news.ycombinator.com | 22 Jul 2023
    Hi HN,

    Has anyone explored Nuitka [1] and developed understanding from a blank slate?

    Is there any toy version of this, so that one can start playing with the language translation concepts?

    Is there any underlying theory/inspiration upon which this project is built?

    Are there any similar projects, in say other languages?

    [1] https://github.com/Nuitka/Nuitka

  • Why not tell people to “simply” use pyenv, poetry or anaconda
    7 projects | news.ycombinator.com | 13 Jun 2023
    That's more of cultural problem in the Python community.

    If I provide an end user software to my client written an Python (so not a backend, not a lib...), I will compile it with nuitka (https://github.com/Nuitka/Nuitka) and hide the stack trace (https://www.bitecode.dev/p/why-and-how-to-hide-the-python-st...) to provide a stand alone executable.

    This means the users don't have to know it's made with Python or install anything, and it just works.

    However, Python is not like Go or Rust, and providing such an installer requires more than work, so a huge part of the user base (which have a lot of non professional coders) don't have the skill, time or resources to do it.

    And few people make the promotion of it.

    I should write an article on that because really, nobody wants to setup python just to use a tool.

  • Python cruising on back of c++
    3 projects | /r/ProgrammerHumor | 18 May 2023
  • Is cython a safe option for obfuscate a python project?
    1 project | /r/learnpython | 13 May 2023
    As for a simpler option, you could use a "compiler": https://github.com/Nuitka/Nuitka

What are some alternatives?

When comparing jax and Nuitka you can also consider the following projects:

Numba - NumPy aware dynamic Python compiler using LLVM

PyInstaller - Freeze (package) Python programs into stand-alone executables

functorch - functorch is JAX-like composable function transforms for PyTorch.

pyarmor - A tool used to obfuscate python scripts, bind obfuscated scripts to fixed machine or expire obfuscated scripts.

julia - The Julia Programming Language

PyOxidizer - A modern Python application packaging and distribution tool

Pytorch - Tensors and Dynamic neural networks in Python with strong GPU acceleration

py2exe - modified py2exe to support unicode paths

Cython - The most widely used Python to C compiler

false-positive-malware-reporting - Trying to release your software sucks, mostly because of antivirus false positives. I don't have an answer, but I do have a list of links to help get your code whitelisted.

jax-windows-builder - A community supported Windows build for jax.

py2app