Modin is a drop-in replacement for pandas that scales the single-threaded pandas to become multi-threaded, using all of your cores and offering instant speedup to your workflows. Modin works especially well on larger datasets, where pandas becomes painfully slow or runs out of memory.
Using modin is as simple as replacing the pandas import:
# import pandas as pd
import modin.pandas as pd
Modin can be installed with pip
:
pip install modin[all] # (Recommended) Install Modin with all of Modin's currently supported engines.
If you want to install Modin with a specific engine, we recommend:
pip install modin[ray] # Install Modin dependencies and Ray.
pip install modin[dask] # Install Modin dependencies and Dask.
Modin automatically detects which engine(s) you have installed and uses that for scheduling computation.
Installing from conda forge using modin-all
will install Modin and 3 engines: (Ray,
Dask and Omnisci)
conda install -c conda-forge modin-all
Each engine can also be installed individually:
conda install -c conda-forge modin-ray # Install Modin dependencies and Ray.
conda install -c conda-forge modin-dask # Install Modin dependencies and Dask.
conda install -c conda-forge modin-omnisci # Install Modin dependencies and Omnisci.
pandas Object | Modin's Ray Engine Coverage | Modin's Dask Engine Coverage |
---|---|---|
pd.DataFrame |
||
pd.Series |
||
pd.read_csv |
✅ | ✅ |
pd.read_table |
✅ | ✅ |
pd.read_parquet |
✅ | ✅ |
pd.read_sql |
✅ | ✅ |
pd.read_feather |
✅ | ✅ |
pd.read_excel |
✅ | ✅ |
pd.read_json |
✳️ | ✳️ |
pd.read_<other> |
✴️ | ✴️ |
If you want to choose a specific compute engine to run on, you can set the environment
variable MODIN_ENGINE
and Modin will do computation with that engine:
export MODIN_ENGINE=ray # Modin will use Ray
export MODIN_ENGINE=dask # Modin will use Dask
This can also be done within a notebook/interpreter before you import Modin:
import os
os.environ["MODIN_ENGINE"] = "ray" # Modin will use Ray
os.environ["MODIN_ENGINE"] = "dask" # Modin will use Dask
import modin.pandas as pd
Check this Modin docs section for Omnisci engine setup.
Note: You should not change the engine after you have imported Modin as it will result in undefined behavior
If you are on Windows, you must use Dask. Ray does not support Windows. If you are on Linux or Mac OS, you can install and use either engine. There is no knowledge required to use either of these engines as Modin abstracts away all of the complexity, so feel free to pick either!
On Linux you also can choose Omnisci which is an experimental engine based on OmnisciDB and included into Intel® Distribution of Modin which is a part of Intel® oneAPI AI Analytics Toolkit (AI Kit)
In Modin, you can start a custom environment in Dask or Ray and Modin will connect to that environment automatically. For example, if you'd like to limit the amount of resources that Modin uses, you can start a Dask Client or Initialize Ray and Modin will use those instances. Make sure you've set the correct environment variable so Modin knows which engine to connect to!
For Ray:
import ray
ray.init(plasma_directory="/path/to/custom/dir", object_store_memory=10**10)
# Modin will connect to the existing Ray environment
import modin.pandas as pd
For Dask:
from distributed import Client
client = Client(n_workers=6)
# Modin will connect to the Dask Client
import modin.pandas as pd
This gives you the flexibility to start with custom resource constraints and limit the amount of resources Modin uses.
Visit the complete documentation on readthedocs: https://modin.readthedocs.io
import modin.pandas as pd
import numpy as np
frame_data = np.random.randint(0, 100, size=(2**10, 2**8))
df = pd.DataFrame(frame_data)
In local (without a cluster) modin will create and manage a local (dask or ray) cluster for the execution
To use Modin, you do not need to know how many cores your system has and you do not need to specify how to distribute the data. In fact, you can continue using your previous pandas notebooks while experiencing a considerable speedup from Modin, even on a single machine. Once you've changed your import statement, you're ready to use Modin just like you would pandas.
The modin.pandas
DataFrame is an extremely light-weight parallel DataFrame. Modin
transparently distributes the data and computation so that all you need to do is
continue using the pandas API as you were before installing Modin. Unlike other parallel
DataFrame systems, Modin is an extremely light-weight, robust DataFrame. Because it is
so light-weight, Modin provides speed-ups of up to 4x on a laptop with 4 physical cores.
In pandas, you are only able to use one core at a time when you are doing computation of
any kind. With Modin, you are able to use all of the CPU cores on your machine. Even in
read_csv
, we see large gains by efficiently distributing the work across your entire
machine.
import modin.pandas as pd
df = pd.read_csv("my_dataset.csv")
We have focused heavily on bridging the solutions between DataFrames for small data (e.g. pandas) and large data. Often data scientists require different tools for doing the same thing on different sizes of data. The DataFrame solutions that exist for 1KB do not scale to 1TB+, and the overheads of the solutions for 1TB+ are too costly for datasets in the 1KB range. With Modin, because of its light-weight, robust, and scalable nature, you get a fast DataFrame at small and large data. With preliminary cluster and out of core support, Modin is a DataFrame library with great single-node performance and high scalability in a cluster.
We designed Modin to be modular so we can plug in different components as they develop and improve:
Visit the Documentation for more information, and checkout the difference between Modin and Dask!
modin.pandas
is currently under active development. Requests and contributions are welcome!
- Read the documentation for more information.
- Check out our paper to learn more about the theory underlying Modin.
- Ask questions or participate in discussions on our Discourse.
- Let us know how you're using Modin! Join our community Slack to discuss and ask questions.
- Submit bug reports to our GitHub Issues Page.
- Contributions are welcome! Open a pull request.