simplification VS cunumeric

Compare simplification vs cunumeric and see what are their differences.

simplification

Very fast Python line simplification using either the RDP or Visvalingam-Whyatt algorithm implemented in Rust (by urschrei)

cunumeric

An Aspiring Drop-In Replacement for NumPy at Scale (by nv-legate)
Our great sponsors
  • InfluxDB - Power Real-Time Data Analytics at Scale
  • WorkOS - The modern identity platform for B2B SaaS
  • SaaSHub - Software Alternatives and Reviews
simplification cunumeric
2 9
155 595
- 1.2%
7.7 8.5
13 days ago 3 days ago
Python Python
MIT License 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.

simplification

Posts with mentions or reviews of simplification. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2022-09-15.
  • Making large line-charts (visualizations) scalable with plotly-resampler
    3 projects | /r/Python | 15 Sep 2022
    Looks great! I have been using https://github.com/urschrei/simplification Visvalingam-Whyatt algo as per suggestion of Mike Bostock https://bost.ocks.org/mike/simplify/, don't know if it's comptetitive with the EffLTTB. It is surposesd to be fast and good in terms of shape preservation.
  • Julia is the better language for extending Python
    13 projects | news.ycombinator.com | 19 Apr 2021
    Rust doesn’t need to copy the data. It’s trivial to pass e.g. Numpy arrays to Rust as slices via Cython (let alone originating in Cython!), modify them, and return them, or use them as input for a new returned struct.

    https://github.com/urschrei/simplification

    https://github.com/urschrei/lonlat_bng

    https://github.com/urschrei/pypolyline

    Each of those repos has links to the corresponding Rust “shim” libraries that provide FFIs for dealing with the incoming data, constructing Rust data structures from it, and then transforming it back on the way out.

    As a more general comment, using a GC language as the FFI target from a GC language is begging for difficult-if-not-impossible-to-debug crashes down the line.

cunumeric

Posts with mentions or reviews of cunumeric. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-10-09.
  • Announcing Chapel 1.32
    6 projects | news.ycombinator.com | 9 Oct 2023
  • Is Parallel Programming Hard, and, If So, What Can You Do About It? [pdf]
    4 projects | news.ycombinator.com | 19 Feb 2023
    I am biased because this is my research area, but I have to respectfully disagree. Actor models are awful, and the only reason it's not obvious is because everything else is even more awful.

    But if you look at e.g., the recent work on task-based models, you'll see that you can have literally sequential programs that parallelize automatically. No message passing, no synchronization, no data races, no deadlocks. Read your programs as if they're sequential, and you immediately understand their semantics. Some of these systems are able to scale to thousands of nodes.

    An interesting example of this is cuNumeric, which allows you to take sequential Python programs that use NumPy, and by changing one line (the import statement), run automatically on clusters of GPUs. It is 100% pure awesomeness.

    https://github.com/nv-legate/cunumeric

    (I don't work on cuNumeric, but I do work on the runtime framework that cuNumeric uses.)

  • GPT in 60 Lines of NumPy
    9 projects | news.ycombinator.com | 9 Feb 2023
    I know this probably isn't intended for performance, but it would be fun to run this in cuNumeric [1] and see how it scales.

    [1]: https://github.com/nv-legate/cunumeric

  • Dask – a flexible library for parallel computing in Python
    8 projects | news.ycombinator.com | 17 Nov 2021
    If you want built-in GPU support (and distributed), you should check out cuNumeric (released by NVIDIA in the last week or so). Also avoids needing to manually specify chunk sizes, like it says in a sibling comment.

    https://github.com/nv-legate/cunumeric

  • Julia is the better language for extending Python
    13 projects | news.ycombinator.com | 19 Apr 2021
    Try dask

    Distribute your data and run everything as dask.delayed and then compute only at the end.

    Also check out legate.numpy from Nvidia which promises to be a drop in numpy replacement that will use all your CPU cores without any tweaks on your part.

    https://github.com/nv-legate/legate.numpy

  • Learning more about HPC as a python guy
    1 project | /r/HPC | 19 Apr 2021
    Something for the HPC tools category: https://github.com/nv-legate/legate.numpy
  • Unifying the CUDA Python Ecosystem
    13 projects | news.ycombinator.com | 16 Apr 2021
    You might be interested in Legate [1]. It supports the NumPy interface as a drop-in replacement, supports GPUs and also distributed machines. And you can see for yourself their performance results; they're not far off from hand-tuned MPI.

    [1]: https://github.com/nv-legate/legate.numpy

    Disclaimer: I work on the library Legate uses for distributed computing, but otherwise have no connection.

  • Legate NumPy: An Aspiring Drop-In Replacement for NumPy at Scale
    1 project | news.ycombinator.com | 13 Apr 2021

What are some alternatives?

When comparing simplification and cunumeric you can also consider the following projects:

pyrdp - RDP monster-in-the-middle (mitm) and library for Python with the ability to watch connections live or after the fact

cupy - NumPy & SciPy for GPU