Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ibis-project/ibis-ml
IbisML is a library for building scalable ML pipelines using Ibis.
https://github.com/ibis-project/ibis-ml
feature-engineering ibis machine-learning sql
Last synced: 6 days ago
JSON representation
IbisML is a library for building scalable ML pipelines using Ibis.
- Host: GitHub
- URL: https://github.com/ibis-project/ibis-ml
- Owner: ibis-project
- License: apache-2.0
- Created: 2023-01-13T17:51:53.000Z (about 2 years ago)
- Default Branch: main
- Last Pushed: 2024-12-25T15:19:37.000Z (about 1 month ago)
- Last Synced: 2025-01-18T12:44:46.232Z (6 days ago)
- Topics: feature-engineering, ibis, machine-learning, sql
- Language: Python
- Homepage: https://ibis-project.github.io/ibis-ml/
- Size: 2.61 MB
- Stars: 96
- Watchers: 9
- Forks: 13
- Open Issues: 25
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# IbisML
[![Build status](https://github.com/ibis-project/ibis-ml/actions/workflows/ci.yml/badge.svg)](https://github.com/ibis-project/ibis-ml/actions/workflows/ci.yml)
[![Docs](https://img.shields.io/badge/docs-latest-blue.svg)](https://ibis-project.github.io/ibis-ml/)
[![License](https://img.shields.io/github/license/ibis-project/ibis-ml.svg)](https://github.com/ibis-project/ibis-ml/blob/main/LICENSE)
[![PyPI](https://img.shields.io/pypi/v/ibis-ml.svg)](https://pypi.org/project/ibis-ml/)## What is IbisML?
IbisML is a library for building scalable ML pipelines using Ibis:
- Preprocess your data at scale on any [Ibis](https://ibis-project.org/)-supported
backend.
- Compose [`Recipe`](/reference/core.html#ibis_ml.Recipe)s with other scikit-learn
estimators using
[`Pipeline`](https://scikit-learn.org/stable/modules/compose.html#pipeline-chaining-estimators)s.
- Seamlessly integrate with [scikit-learn](https://scikit-learn.org/stable/),
[XGBoost](https://xgboost.readthedocs.io/en/stable/python/sklearn_estimator.html), and
[PyTorch](https://skorch.readthedocs.io/en/stable/) models.## How do I install IbisML?
```bash
pip install ibis-ml
```## How do I use IbisML?
With recipes, you can define sequences of feature engineering steps to get your data
ready for modeling. For example, create a recipe to replace missing values using the
mean of each numeric column and then normalize numeric data to have a standard deviation
of one and a mean of zero.```python
import ibis_ml as mlimputer = ml.ImputeMean(ml.numeric())
scaler = ml.ScaleStandard(ml.numeric())
rec = ml.Recipe(imputer, scaler)
```A recipe can be chained in a
[`Pipeline`](https://scikit-learn.org/stable/modules/generated/sklearn.pipeline.Pipeline.html)
like any other
[transformer](https://scikit-learn.org/stable/glossary.html#term-transformer).```python
from sklearn.pipeline import Pipeline
from sklearn.svm import SVCpipe = Pipeline([("rec", rec), ("svc", SVC())])
```The pipeline can be used as any other estimator and avoids leaking the test set into the
train set.```python
from sklearn.datasets import make_classification
from sklearn.model_selection import train_test_splitX, y = make_classification(random_state=0)
X_train, X_test, y_train, y_test = train_test_split(X, y, random_state=0)
pipe.fit(X_train, y_train).score(X_test, y_test)
```