modin
Ray
Our great sponsors
modin | Ray | |
---|---|---|
11 | 42 | |
9,476 | 31,101 | |
1.3% | 3.4% | |
9.6 | 10.0 | |
4 days ago | 3 days ago | |
Python | Python | |
Apache License 2.0 | Apache License 2.0 |
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.
modin
- The Distributed Tensor Algebra Compiler (2022)
-
A Polars exploration into Kedro
The interesting thing about Polars is that it does not try to be a drop-in replacement to pandas, like Dask, cuDF, or Modin, and instead has its own expressive API. Despite being a young project, it quickly got popular thanks to its easy installation process and its “lightning fast” performance.
-
Modern Polars: an extensive side-by-side comparison of Polars and Pandas
Yeah, tried Polars a couple of times: the API seems worse than Pandas to me too. eg the decision only to support autoincrementing integer indexes seems like it would make debugging "hmmm, that answer is wrong, what exactly did I select?" bugs much more annoying. Polars docs write "blazingly fast" all over them but I doubt that is a compelling point for people using single-node dataframe libraries. It isn't for me.
Modin (https://github.com/modin-project/modin) seems more promising at this point, particularly since a migration path for standing Pandas code is highly desirable.
-
Polars: The Next Big Python Data Science Library... written in RUST?
If anyone wants a faster version of pandas it’s not hard to find, modin for example uses multiple cores to speed it up, so if you have 4 cores it’s about 4 times faster than pandas, and has the same API as pandas.
-
Working with more than 10gb csv
Modin should fit. It implements Pandas APIs with e.g. Ray as backend. https://github.com/modin-project/modin
- Modern Python Performance Considerations
-
I made a video about efficient memory use in pandas dataframes!
If you really want speed you should try modin.pandas which makes pandas multi-threaded.
-
Almost no one knows how easily you can optimize your AI models
I am guessing XGB is fairly optimised as it is. If you would want to use the sklearn libraries with pandas, look into Modin
-
TIL about modin.pandas which significantly speeds up pandas if you import modin.pandas instead of pandas.
Source
- How to Speed Up Pandas with 1 Line of Code
Ray
-
Open Source Advent Fun Wraps Up!
22. Ray | Github | tutorial
-
Fine-Tuning Llama-2: A Comprehensive Case Study for Tailoring Custom Models
Training times for GSM8k are mentioned here: https://github.com/ray-project/ray/tree/master/doc/source/te...
- Ray – an open source project for scaling AI workloads
-
Methods to keep agents inside grid world.
Here's a reference from RLlib that points to docs and an example, and here's one from one of my projects that includes all my own implementations
-
TransformerXL + PPO Baseline + MemoryGym
RLlib
- Is dynamic action masking possible in Rllib?
-
AWS re:Invent 2022 Recap | Data & Analytics services
⦿ AWS Glue Data Quality - Automatic data quality rule recommendations based on your data AWS Glue for Ray - Data integration with Ray (ray.io), a popular new open-source compute framework that helps you scale Python workloads
-
Think about it for a second
https://ray.io (just dropping the link)
-
Elixir Livebook now as a desktop app
I've wondered whether it's easier to add data analyst stuff to Elixir that Python seems to have, or add features to Python that Erlang (and by extension Elixir) provides out of the box.
By what I can see, if you want multiprocessing on Python in an easier way (let's say running async), you have to use something like ray core[0], then if you want multiple machines you need redis(?). Elixir/Erlang supports this out of the box.
Explorer[1] is an interesting approach, where it uses Rust via Rustler (Elixir library to call Rust code) and uses Polars as its dataframe library. I think Rustler needs to be reworked for this usecase, as it can be slow to return data. I made initial improvements which drastically improves encoding (https://github.com/elixir-nx/explorer/pull/282 and https://github.com/elixir-nx/explorer/pull/286, tldr 20+ seconds down to 3).
[0] https://github.com/ray-project/ray
-
Learn various techniques to reduce data processing time by using multiprocessing, joblib, and tqdm concurrent
Adding these for anyone who had a similar question about Ray vs dask 1, 2, 3
What are some alternatives?
polars - Dataframes powered by a multithreaded, vectorized query engine, written in Rust
optuna - A hyperparameter optimization framework
swifter - A package which efficiently applies any function to a pandas dataframe or series in the fastest available manner
stable-baselines3 - PyTorch version of Stable Baselines, reliable implementations of reinforcement learning algorithms.
fugue - A unified interface for distributed computing. Fugue executes SQL, Python, Pandas, and Polars code on Spark, Dask and Ray without any rewrites.
Faust - Python Stream Processing
mars - Mars is a tensor-based unified framework for large-scale data computation which scales numpy, pandas, scikit-learn and Python functions.
gevent - Coroutine-based concurrency library for Python
PandasGUI - A GUI for Pandas DataFrames
stable-baselines - A fork of OpenAI Baselines, implementations of reinforcement learning algorithms
pyjanitor - Clean APIs for data cleaning. Python implementation of R package Janitor
SCOOP (Scalable COncurrent Operations in Python) - SCOOP (Scalable COncurrent Operations in Python)