Arraymancer VS awesome-tensor-compilers

Compare Arraymancer vs awesome-tensor-compilers and see what are their differences.

Our great sponsors
  • WorkOS - The modern identity platform for B2B SaaS
  • InfluxDB - Power Real-Time Data Analytics at Scale
  • SaaSHub - Software Alternatives and Reviews
Arraymancer awesome-tensor-compilers
21 9
1,304 2,171
- -
8.2 4.4
7 days ago 3 months ago
Nim
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.

Arraymancer

Posts with mentions or reviews of Arraymancer. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2024-03-28.
  • Arraymancer – Deep Learning Nim Library
    6 projects | news.ycombinator.com | 28 Mar 2024
    It is a small DSL written using macros at https://github.com/mratsim/Arraymancer/blob/master/src/array....

    Nim has pretty great meta-programming capabilities and arraymancer employs some cool features like emitting cuda-kernels on the fly using standard templates depending on backend !

  • Go, Python, Rust, and production AI applications
    4 projects | news.ycombinator.com | 12 Mar 2024
    Nim has also a powerful deep learning library called Arraymancer. It's selling point is that you don't have to rewrite your code from research to production. It's used in various machine learning projects, but one recent one that caught my eye was https://github.com/amkrajewski/nimCSO "Composition Space Optimization"

    https://github.com/mratsim/Arraymancer

  • D Programming Language
    13 projects | news.ycombinator.com | 3 Dec 2023
    - https://github.com/mratsim/Arraymancer/blob/master/src/array...

    It's worth noting that nim async/await transformation is fully implemented as a library in macros.

  • Prospects of utilising Nim in scientific computation?
    3 projects | /r/nim | 3 Jun 2023
  • How to write performant Nim?
    1 project | /r/nim | 7 Nov 2022
    https://github.com/mratsim/Arraymancer 11. « Premature optimisation is the root of all evil », Donald Knuth, The art of computer Programming It would be quite useful that someone writes one with examples for all these recommendations and more ...
  • Deeplearning in Nim?
    6 projects | /r/nim | 4 Jul 2022
    In particular for deep learning as bobsyourunkl already mentioned there is arraymancer on the one hand and also flambeau on the other. The latter is a Nim wrapper around libtorch (i.e. the PyTorch C++ backend). It is missing things (to be wrapped by adding a few lines) and has some rough edges, but if one needs to get stuff done, it's possible.
  • Mastering Nim – now available on Amazon
    9 projects | news.ycombinator.com | 29 Jun 2022
    how are u compiling (optimization, custom compilation flags etc.?) In my case https://github.com/mratsim/Arraymancer big project compile under your 4.2s so or you have like 10k+ lines of codes with macros or you just pass some debug flags to compiler :D
  • Nim Version 1.6.6 Released
    9 projects | news.ycombinator.com | 5 May 2022
  • The counter-intuitive rise of Python in scientific computing (2020)
    9 projects | news.ycombinator.com | 26 Mar 2022
  • Computer Programming with Nim
    13 projects | news.ycombinator.com | 27 Feb 2022
    We have both raw wrappers for BLAS:

    https://github.com/andreaferretti/nimblas

    as well as LAPACK:

    https://github.com/andreaferretti/nimlapack

    For an example, consider calling the least squares routine `dgelsd` in arraymancer:

    https://github.com/mratsim/Arraymancer/blob/master/src/array...

    wrapped up in a nicer user facing API.

    Feel free to hop onto matrix, if you have more questions!

awesome-tensor-compilers

Posts with mentions or reviews of awesome-tensor-compilers. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-08-05.
  • MatX: Faster Chips for LLMs
    2 projects | news.ycombinator.com | 5 Aug 2023
    > So long as Pytorch only practically works with Nvidia GPUs, everything else is little more than a rounding error.

    This is changing.

    https://github.com/merrymercy/awesome-tensor-compilers

    There are more and better projects that can compile an existing PyTorch codebase into a more optimized format for a range of devices. Triton (which is part of PyTorch) TVM and the MLIR based efforts (like torch-MLIR or IREE) are big ones, but there are smaller fish like GGML and Tinygrad, or more narrowly focused projects like Meta's AITemplate (which works on AMD datacenter GPUs).

    Hardware is in a strange place now... It feels like everyone but Cerebras and AMD/Intel was squeezed out, but with all the money pouring in, I think this is temporary.

  • Run Llama2-70B in Web Browser with WebGPU Acceleration
    1 project | news.ycombinator.com | 24 Jul 2023
    I think this is true of AI compilation in general. Torch MLIR, AITemplate and really everything here fly under the radar.

    https://github.com/merrymercy/awesome-tensor-compilers#open-...

  • Ask HN: How to get good as a self taught ML engineer?
    1 project | news.ycombinator.com | 4 Jul 2023
    > I really want to do some great work and help people.

    Have you looked into ML compilation?

    https://github.com/merrymercy/awesome-tensor-compilers

    IMO there is low hanging fruit in the space between high performance ML compilers/runtimes and the actual projects people use. If you practice porting projects you use to these frameworks, that would give you a massive performance edge.

  • Ask HN: What new programming language(s) are you most excited about?
    1 project | news.ycombinator.com | 2 Jul 2023
    While not all "languages" persay, I am excited about the various ML compilation efforts:

    https://github.com/merrymercy/awesome-tensor-compilers

    Modern ML training/inference is inefficient, and lacks any portability. These frameworks are how that changes.

  • Research Papers on ML in Compilers
    2 projects | news.ycombinator.com | 21 Jun 2023
    You might be interested in this: https://github.com/merrymercy/awesome-tensor-compilers
  • The Distributed Tensor Algebra Compiler (2022)
    4 projects | news.ycombinator.com | 15 Jun 2023
    * collection of papers in https://github.com/merrymercy/awesome-tensor-compilers

    I also have an interest in the community more widely associated with pandas/dataframes-like languages (e.g. modin/dask/ray/polars/ibis) with substrait/calcite/arrow their choice of IR

  • A list of compiler projects and papers for tensor computation and deep learning
    1 project | news.ycombinator.com | 7 Feb 2021
  • A List of Tensor Compilers
    1 project | news.ycombinator.com | 4 Feb 2021
  • C-for-Metal: High Performance SIMD Programming on Intel GPUs
    2 projects | news.ycombinator.com | 29 Jan 2021
    Compiling from high-level lang to GPU is a huge problem, and we greatly appreciate efforts to solve it.

    If I understand correctly, this (CM) allows for C-style fine-level control over a GPU device as though it were a CPU.

    However, it does not appear to address data transit (critical for performance). Compilation and operator fusing to minimize transit is possibly more important. See Graphcore Poplar, Tensorflow XLA, Arrayfire, Pytorch Glow, etc.

    Further, this obviously only applies to Intel GPUs, so investing time in utilizing low-level control is possibly a hardware dead-end.

    Dream world for programmers is one where data transit and hardware architecture are taken into account without living inside a proprietary DSL Conversely, it is obviously against hardware manufacturers' interests to create this.

    Is MLIR / LLVM going to solve this? This list has been interesting to consider:

    https://github.com/merrymercy/awesome-tensor-compilers

What are some alternatives?

When comparing Arraymancer and awesome-tensor-compilers you can also consider the following projects:

nimtorch - PyTorch - Python + Nim

alpa - Training and serving large-scale neural networks with auto parallelization.

Nim - Nim is a statically typed compiled systems programming language. It combines successful concepts from mature languages like Python, Ada and Modula. Its design focuses on efficiency, expressiveness, and elegance (in that order of priority).

Fable - The project has moved to a separate organization. This project provides redirect for old Fable web site.

nimble - Package manager for the Nim programming language.

Distributed-Systems-Guide - Distributed Systems Guide

nvim-treesitter - Nvim Treesitter configurations and abstraction layer

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

prologue - Powerful and flexible web framework written in Nim

tvm - Open deep learning compiler stack for cpu, gpu and specialized accelerators

application - Buckets Desktop Application

awesome-machine-learning-in-compilers - Must read research papers and links to tools and datasets that are related to using machine learning for compilers and systems optimisation