ragged-buffer VS PyO3

Compare ragged-buffer vs PyO3 and see what are their differences.

ragged-buffer

Efficient numpy-like ragged array datatype for Python. (by entity-neural-network)
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
ragged-buffer PyO3
2 147
19 11,044
- 2.3%
3.8 9.8
about 1 year ago 3 days ago
Rust Rust
Apache License 2.0 GNU General Public License v3.0 or later
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.

ragged-buffer

Posts with mentions or reviews of ragged-buffer. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2022-05-16.
  • Entity Gym: A new entity based API for reinforcement learning environments
    5 projects | /r/reinforcementlearning | 16 May 2022
    We are also releasing enn-trainer, a PPO implementation that takes full advantage of the Entity Gym interface. Variable-length observations are efficiently processed using ragged sample buffers and a general ragged batch transformer implementation that can be applied to any Entity Gym environment. With many performance optimizations still missing, enn-trainer can already reach a throughput of 10s of thousands of samples per second per GPU when it is not bottlenecked by stepping the environment. More typically, environments implemented in Python reach thousands of samples per second, but can share a single GPU between multiple concurrent training runs.
  • Writing Rust libraries for the Python scientific computing ecosystem
    12 projects | /r/rust | 19 Dec 2021
    One of Rust's many strengths is that it can be seamlessly integrated with Python and speed up critical code sections. I recently wrote a small library with an efficient ragged array datatype, and I figured it would make for a good example of how to set up a Rust Python package with PyO3 and maturin that interoperates with numpy. There are a lot of little details that took me quite a while to figure out:

PyO3

Posts with mentions or reviews of PyO3. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2024-04-05.
  • Encapsulation in Rust and Python
    4 projects | dev.to | 5 Apr 2024
    Integrating Rust into Python, Edward Wright, 2021-04-12 Examples for making rustpython run actual python code Calling Rust from Python using PyO3 Writing Python inside your Rust code — Part 1, 2020-04-17 RustPython, RustPython Rust for Python developers: Using Rust to optimize your Python code PyO3 (Rust bindings for Python) Musing About Pythonic Design Patterns In Rust, Teddy Rendahl, 2023-07-14
  • Rust Bindings for the Python Interpreter
    1 project | news.ycombinator.com | 20 Feb 2024
  • Polars – A bird's eye view of Polars
    4 projects | news.ycombinator.com | 13 Feb 2024
  • In Rust for Python: A Match from Heaven
    2 projects | dev.to | 3 Jan 2024
    This story unfolds as a captivating journey where the agile Flounder, representing the Python programming language, navigates the vast seas of coding under the wise guidance of Sebastian, symbolizing Rust. Central to their adventure are three powerful tridents: cargo, PyO3, and maturin.
  • Segunda linguagem
    3 projects | /r/brdev | 10 Dec 2023
  • Calling Rust from Python
    2 projects | news.ycombinator.com | 8 Oct 2023
    I would not recommend FFI + ctypes. Maintaining the bindings is tedious and error-prone. Also, Rust FFI/unsafe can be tricky even for experienced Rust devs.

    Instead PyO3 [1] lets you "write a native Python module in Rust", and it works great. A much better choice IMO.

    [1] https://github.com/PyO3/pyo3

  • Python 3.12
    6 projects | news.ycombinator.com | 2 Oct 2023
    Same w/ Rust and Python, this is really neat because now each thread could have a GIL without doing exactly what you said. The pyO3 commit to allow subinterpreters was merged 21 days ago, so this might "just work" today: https://github.com/PyO3/pyo3/pull/3446
  • Removing Garbage Collection from the Rust Language (2013)
    9 projects | news.ycombinator.com | 11 Sep 2023
    I expected someone to write a rust-based scripting language which tightly integrated with rust itself.

    In reality, it seems like the python developers and toolchain are embracing rust enough to reduce the benefits to a new alternative.

    https://github.com/PyO3/pyo3

  • Bytewax: Stream processing library built using Python and Rust
    2 projects | news.ycombinator.com | 25 Jul 2023
    Hey HN! I am one of the people working on Bytewax. Bytewax came out of our experience working with ML infrastructure at GitHub. We wanted to use Python because we could move fast, the team was very fluent in it, and the rest of our tooling was Python-native already. We didn't want to introduce JVM-based solutions into our stack because of the lack of experience and the friction we had trying to get Python-centric tooling working with existing solutions like Flink.

    In our research, we found Timely Dataflow (https://timelydataflow.github.io/timely-dataflow/, https://news.ycombinator.com/item?id=24837031) and the Naiad project (https://www.microsoft.com/en-us/research/project/naiad/) as well as PyO3 (https://github.com/PyO3/pyo3) and we thought we found a match made in heaven :). Bytewax leverages both of these projects and builds on them to provide a clean API (at least we think so) and table stakes features like connectors, state recovery, and cloud-native scaling. It has been really cool to learn about the dataflow computation model, Rust, and how to wrangle the GIL with Rust and Python :P.

    Would love to get your feedback :).

    `pip install bytewax` to get started. We have a page of guides (https://www.bytewax.io/guides) with ready-to-run examples.

  • Tell HN: Rust Is the Superglue
    3 projects | news.ycombinator.com | 15 Jul 2023
    You can practice your Rust skills by writing performant and/or gluey extensions for higher-level language such as NodeJS (checkout napi-rs) and Python or complementing JS in the browser if you target Webassembly.

    For instance, checkout Llama-node https://github.com/Atome-FE/llama-node for an involved Rust-based NodeJS extension. Python has PyO3, a Rust-Python extension toolset: https://github.com/PyO3/pyo3.

    They can help you leverage your Rust for writing cool new stuff.

What are some alternatives?

When comparing ragged-buffer and PyO3 you can also consider the following projects:

maturin-action - GitHub Action to install and run a custom maturin command with built-in support for cross compilation

rust-cpython - Rust <-> Python bindings

rogue-net - Entity Gym compatible ragged batch transformer implementation.

pybind11 - Seamless operability between C++11 and Python

enn-trainer - Reinforcement learning training framework for entity-gym environments.

RustPython - A Python Interpreter written in Rust

entity-gym - Standard interface for entity based reinforcement learning environments.

milksnake - A setuptools/wheel/cffi extension to embed a binary data in wheels

enn-zoo - Collection of entity-gym bindings for different reinforcement learning environments.

bincode - A binary encoder / decoder implementation in Rust.

maturin - Build and publish crates with pyo3, cffi and uniffi bindings as well as rust binaries as python packages

uniffi-rs - a multi-language bindings generator for rust