magnus
polars-ruby
magnus | polars-ruby | |
---|---|---|
13 | 10 | |
589 | 749 | |
- | - | |
8.8 | 9.7 | |
about 1 month ago | 15 days ago | |
Rust | Ruby | |
MIT License | MIT License |
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.
magnus
-
Regarding using multiple languages in one project
You can also use Rust to write an extension module that can be loaded into the Ruby interpreter, so that everything runs in the same process: https://github.com/matsadler/magnus
- Magnus β Write Ruby extension gems in Rust, or call Ruby code from a Rust binary
- Magnus 0.5 released (Library for writing Ruby gems in Rust)
-
Tried polars in Ruby
So while the Arrow C binding for the Ruby language is relatively well-developed, polars-df is not an Arrow C binding, but a binding to Polars implemented in Rust. magnus is used for the connection between Ruby and Rust. In fact, there is also a Ruby data frame that uses the Arrow binding, which is called RedAmber. But we are not talking about that now.
-
Ruby 3.2.0 Released
The template generated with bundle gem β-ext=rust uses the Magnus[1] library that provides a high-level friendly Rust wrapper over the Ruby C API, but you can also use rb-sys[2] which is lower level bindings direct to the Ruby C API.
[1]: https://github.com/matsadler/magnus
- 0.4.0 Release of Magnus. Write Ruby Gems in Rust, or Call Ruby from Rust
- 0.4.0 release of Magnus (Write Ruby gems in Rust)
- Magnus (bindings to Ruby) version 0.3.0
- Magnus (Rust library for writing Ruby gems) version 0.3.0
- Magnus: High level Ruby bindings for Rust
polars-ruby
-
Rails version of Python Dataframes
You might give this https://github.com/ankane/polars-ruby a look.
-
Magnus 0.5 released (Library for writing Ruby gems in Rust)
polars-df
-
Bundler: Bundler v2.4: new resolver, gems with Rust extensions, and more
https://github.com/ankane/polars-ruby is an example that was just posted here recently
-
Tried polars in Ruby
Polars is a data frame in the Rust language using Apache Arrow Columnar Format. polars-ruby is the Ruby binding for Polars created by Andrew Kane.
- GitHub - ankane/polars-ruby: Blazingly fast DataFrames for Ruby
-
Fast DataFrames for Ruby
I think its really interesting such gems offering a layer ruby on top of rust libs. One issue that I have with that is - and maybe it's my ignorance - but is that necessary to bundle the original lib as https://github.com/ankane/polars-ruby/tree/master/ext/polars ? I can imagine that makes easier to avoid breakage but couldn't we at least lock its version in Cargo.toml?
- Blazingly fast DataFrames for Ruby, powered by Polars
What are some alternatives?
rutie - βThe Tie Between Ruby and Rust.β
rucaptcha - Captcha Gem for Rails, which generates captcha image by Rust.
tokenizers-ruby - Fast state-of-the-art tokenizers for Ruby
ruby-spark - Ruby wrapper for Apache Spark
CommonMarker - Ruby wrapper for the comrak (CommonMark parser) Rust crate
bundix - Generates a Nix expression for your Bundler-managed application. [maintainer=@manveru]
wasmtime-rb - Ruby WebAssembly runtime powered by Wasmtime
halton-rb - A Ruby library, written in Rust, for generating Halton sequences
ruby-rust-extension-benchmark - Benchmark Ruby extension using Rust (Helix, Ruru, Rutie, FFI) and C
yrb - Ruby bindings for yrs.
Apache Arrow - Apache Arrow is a multi-language toolbox for accelerated data interchange and in-memory processing