nim-stint VS nimpy

Compare nim-stint vs nimpy and see what are their differences.

nim-stint

Stack-based arbitrary-precision integers - Fast and portable with natural syntax for resource-restricted devices. (by status-im)
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
nim-stint nimpy
3 38
77 1,420
- -
7.0 5.8
about 2 months ago 3 months ago
Nim Nim
Apache License 2.0 MIT License
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.

nim-stint

Posts with mentions or reviews of nim-stint. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2022-01-19.
  • Stint (Stack-based multiprecision integers)
    1 project | news.ycombinator.com | 3 Jul 2023
  • Why static languages suffer from complexity
    5 projects | news.ycombinator.com | 19 Jan 2022
    > I think the message is more nuanced

    I thought it was more nuanced too as they were explaining how integer types can be derived, until I finished the article, and they really did just seem to be complaining that there's a mismatch between compile time and run time.

    Dynamic types don't really solve the problems they mention as far as I can tell either (perhaps I am misunderstanding), they just don't provide any guarantees at all and so "work" in the loosest sense.

    > otherwise wouldn't lisp with its homoiconicity and compile time macros fit the bill perfectly?

    That's a good point, I do wonder why they didn't mention Lisp at all.

    > we don't have a solution yet

    What they want to do can, as far as I can see, be implemented in Nim easily in a standard, imperative form, without any declarative shenanigans. Indeed, it is implemented here: https://github.com/nim-lang/Nim/blob/ce44cf03cc4a78741c423b2...

    Of course, that implementation is more complex than the one in the article because it handles a lot more.

    At the end of the day, it's really a capability mismatch at the language level and the author even states this:

    > Programming languages ought to be rethought.

    I'd argue that Nim has been 'rethought' specifically to address the issues they mention. The language was built with extension in mind, and whilst the author states that macros are a bad thing, I get the impression this is because most languages implement them as tacked on substitution mechanisms (Rust/D), and/or are declarative rather than "simple" imperative processes. IMHO, most people want to write general code for compile time work (like Zig), not learn a new sub-language. The author states this as well.

    Nim has a VM for running the language at compile time so you can do whatever you want, including the recursive type decomposition (for example: https://github.com/status-im/nim-stint). It also has 'real' macros that aren't substitutions but work on the core AST directly, can inspect types at compile time, and is a system language but also high level. It seems to solve their problems, but of course, they simply might not have used or even heard of it.

  • Donald Knuth’s Algorithm D, its implementation in Hacker’s Delight and elsewhere
    5 projects | news.ycombinator.com | 23 Mar 2021

nimpy

Posts with mentions or reviews of nimpy. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-10-19.
  • Mojo is now available on Mac
    13 projects | news.ycombinator.com | 19 Oct 2023
    I mean honestly, the closest language to Mojo really is Nim. In the latest Lex Fridman interview [0] when he talks about his ideas behind Mojo it pretty much sounds like he's describing Nim. Ok fair, he wants Mojo to be a full superset of Python, but honestly with nimpy [1] our Python interop is about as seamless as it can really be (without being a superset, which Mojo clearly is not yet). Even the syntax of Mojo looks a damn lot like Nim imo. Anyway, I guess he has the ability to raise enough funds to hire enough people to write his own language within ~2 years so as not have to follow random peoples whim about where to take the language. So I guess I can't blame him. But as someone who's pretty invested in the Nim community it's quite a shame to see such a hyped language receive so much attention by people who should really check out Nim. ¯\_(ツ)_/¯

    [0]: https://youtu.be/pdJQ8iVTwj8?si=LfPSNDq8UKKIsJd3

    [1]: https://github.com/yglukhov/nimpy

  • Show HN: Pip Imports in Deno
    6 projects | news.ycombinator.com | 11 Aug 2023
    You can also do this in Nim, which basically means you can write any program you could in Python with libraries in Nim. https://github.com/yglukhov/nimpy
  • Nim v2.0 Released
    49 projects | news.ycombinator.com | 1 Aug 2023
    Ones that have not been mentioned so far:

    nlvm is an unofficial LLVM backend: https://github.com/arnetheduck/nlvm

    npeg lets you write PEGs inline in almost normal PEG notation: https://github.com/zevv/npeg

    futhark provides for much more automatic C interop: https://github.com/PMunch/futhark

    nimpy allows calling Python code from Nim and vice versa: https://github.com/yglukhov/nimpy

    questionable provides a lot of syntax sugar surrounding Option/Result types: https://github.com/codex-storage/questionable

    ratel is a framework for embedded programming: https://github.com/PMunch/ratel

    cps allows arbitrary procedure rewriting to continuation passing style: https://github.com/nim-works/cps

    chronos is an alternative async/await backend: https://github.com/status-im/nim-chronos

    zero-functional fixes some inefficiencies when chaining list operations: https://github.com/zero-functional/zero-functional

    owlkettle is a declarative macro-oriented library for GTK: https://github.com/can-lehmann/owlkettle

    A longer list can be found at https://github.com/ringabout/awesome-nim.

  • Prospects of utilising Nim in scientific computation?
    3 projects | /r/nim | 3 Jun 2023
    I use Python daily for its massive momentum for scientific stuff, but I also use Nim for everything else. Nim compiles to C, and making Python native modules with Nim is easy with Nimpy.
  • Can't run compiled nim code in Python
    1 project | /r/learnpython | 28 May 2023
  • Returning to Nim from Python and Rust
    2 projects | news.ycombinator.com | 18 Feb 2023
    If are a data scientist and come from python take a look at nimpy, a great way to just import python libraries and use them! https://github.com/yglukhov/nimpy Numpy, pandas, pytorch all usable in Nim.

    Nim is the ultimate glue language, use libraries from anything: python, c, js, objc.

  • Python's “Disappointing” Superpowers
    9 projects | news.ycombinator.com | 1 Feb 2023
    I've come to really enjoy programming in Nim. Note that Nim is very different language despite sharing a similar syntax. However, I feel it keeps a lot of the "feel" of Python 2 days of being a fairly simple neat language but that lets you do things at compile time (like compile time duck typing).

    There's a good Python -> Nim bridge: https://github.com/yglukhov/nimpy

  • Dunder methods in nimpy
    2 projects | /r/nim | 3 Jan 2023
    See this nimpy issue about it: https://github.com/yglukhov/nimpy/issues/43
  • What language to move to from python to speed up algo?
    4 projects | /r/algotrading | 7 Dec 2022
    It has pretty good integration with python, either for having your main code in python and writing small hot functions as nim and importing via nimporter or using python libraries in nim via nimpy.
  • ABI compatibility in Python: How hard could it be?
    5 projects | news.ycombinator.com | 19 Nov 2022
    Related: Nimpy[0] provides an easy way to write Python extensions in Nim, which manages the ABI side very well.

    Python 2 is now gone, but until it was, Nimpy was an easy way to write Python extension modules that only needed to be compiled once, and would work with any of your installed Python 2 and Python 3. Magic.

    [0] https://github.com/yglukhov/nimpy

What are some alternatives?

When comparing nim-stint and nimpy you can also consider the following projects:

constantine - Constantine: modular, high-performance, zero-dependency cryptography stack for proof systems and blockchain protocols.

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).

nimbus-eth1 - Nimbus: an Ethereum Execution Client for Resource-Restricted Devices

Box - Python dictionaries with advanced dot notation access

tiny-bignum-c - Small portable multiple-precision unsigned integer arithmetic in C

nimporter - Compile Nim Extensions for Python On Import!

libtorsion - C crypto library

scinim - The core types and functions of the SciNim ecosystem

Fermat - A library providing math and statistics operations for numbers of arbitrary size.

nimpylib - Some python standard library functions ported to Nim

go - The Go programming language

nimskull - An in development statically typed systems programming language; with sustainability at its core. We, the community of users, maintain it.