Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/khuyentran1401/machine-learning-pipeline

Example machine learning pipeline with MLflow and Hydra
https://github.com/khuyentran1401/machine-learning-pipeline

data-science hydra machine-learning machine-learning-pipeline mlflow

Last synced: 2 months ago
JSON representation

Example machine learning pipeline with MLflow and Hydra

Awesome Lists containing this project

README

        

# Machine learning pipeline
This repo provides an example of how to incorporate popular machine learning tools such as DVC, MLflow, and Hydra in your machine learning project. I use my project on predicting aggressive tweets as an example.

Find the article on how to use MLflow and Hydra [here](https://towardsdatascience.com/achieve-reproducibility-in-machine-learning-with-these-two-tools-7bb20609cbb8?source=friends_link&sk=8e1e186294f46df97e0325ce9790f2d7)

Find the article on how to use DVC [here](https://towardsdatascience.com/introduction-to-dvc-data-version-control-tool-for-machine-learning-projects-7cb49c229fe0)

# DVC
[DVC](https://dvc.org/doc/start) is a data version control tool. To install DVC, run
```bash
pip install dvc
```

# Hydra
With [Hydra](https://hydra.cc/), you can compose your configuration dynamically. To install Hydra, simply run
```bash
pip install hydra-core --upgrade
```
# MLflow
[MLflow](https://mlflow.org/) is a platform to manage the ML lifecycle, including experimentation, reproducibility, and deployment. Install MLflow with
```bash
pip install mlflow
```

# Structure's explanation
* **src**: file for source code
* **mlruns**: file for mlflow runs
* **configs**: to keep config files
* **outputs**: results from the runs of Hydra. Each time you run your function nested inside Hydra's decoration, the output will be saved here. If you want to change the directory in mlflow folder, use
```python
import mlflow
import hydra
from hydra import utils

mlflow.set_tracking_uri('file://' + utils.get_original_cwd() + '/mlruns')
```
* `src/preprocessing.py`: file for preprocessing
* `src/train_pipeline.py`: training's pipeline
* `src/train.py`: file for training and saving model
* `src/predict.py`: file for prediction and loading model

# How to pull the data with DVC

Pull the data from Google Drive
```bash
dvc pull
```

# How to run this file
To run the configs and see how these experiments are displayed on MLflow's server, clone this repo and run
```
python src/train.py
```
Once the run is completed, you can access to MLflow's server with
```
mlflow ui
```
Access http://localhost:5000/ from the same directory that you run the file, you should be able to see your experiment like this
![image](https://github.com/khuyentran1401/Machine-learning-pipeline/blob/master/Screenshot%20from%202020-05-03%2016-41-21.png)