This project was initiated as part of Shape's Hard Skill Test for the Machine Learning Engineer role. The core objective was to take an initial script named `job_test_challenge.py` and transform it into a more organized 📐, maintainable 🛠️, and production-ready codebase.
Project description
Welcome to Shape MLOps Project
🌐 Overview
This project was initiated as part of Shape's Hard Skill Test for the Machine Learning Engineer role. The core objective was to take an initial script named job_test_challenge.py
and transform it into a more organized 📐, maintainable 🛠️, and production-ready codebase, all the while preserving its primary functionality. The envisioned transformation entailed the integration of best practices, robust documentation 📄, and a modularized (preferentially object-oriented 📦) design to render the code apt for product release.
Key Tasks 🔑:
-
Code Modularization and Refactoring: The original script needed an overhaul to reach a modular, and potentially object-oriented, structure 🔄.
-
Documentation: Implementing clear and concise documentation 📚 to ensure smooth navigation and comprehension for fellow developers.
-
Preservation of Output: Despite alterations in the code's structure and logic, the model's predictions (output) ought to remain consistent ✔️.
-
Configuration File Modification: The structure of
artifacts/pipeline.jsonc
was amenable to changes to ensure it meshed seamlessly with the revamped code structure 🔧. -
Incorporate TODOs: The code housed multiple TODOs that had to be addressed and realized as part of the challenge 📝.
-
Scalability Consideration: The reshaped code was anticipated to cater to hefty data scenarios, suggesting that the supplied sample data file might, in a real-world setting, symbolize a table spanning several gigabytes in a data lake 📊.
Constraints and Considerations 🚫:
-
The generated code should be portable and capable of executing flawlessly in an alternate Python environment 🐍.
-
The provided "pickle" files were crafted using Python version 3.8.13 and Scikit-learn version 1.0.2. Though other libraries might be pivotal for diverse facets of the project, these particular versions were indispensable for the "pickle" files 📌.
-
Intricate or time-intensive modifications, if not instantly implementable, should be signposted within the code as TODOs. These markers should also sketch out the strategic approach intended for their eventual fulfillment 🕰️.
🚀 Run the project
The provided configuration appears to be from a pyproject.toml
file, which is a configuration file for the Poetry dependency management and packaging tool in Python. To install and execute this project, follow the steps below:
- Prerequisites:
- Docker
- Poetry
- Python
1️⃣ Install Poetry:
If you haven't installed Poetry yet, you can do so with the following command:
curl -sSL https://install.python-poetry.org | python3 -
Or you can use other installation methods detailed in the official documentation.
2️⃣ Clone the project (if you haven't already):
Assuming the project is hosted on a Git repository, clone it:
git clone https://github.com/JuniorTorresMTJ/mlops_shape_project.git
cd mlops-shape-project
3️⃣ Install project dependencies:
Navigate to the project directory and install the dependencies using Poetry:
poetry install
This command installs both the main dependencies and the dev dependencies of the project.
4️⃣ Activate the virtual environment:
Poetry creates a virtual environment for your project. Activate it with:
poetry shell
5️⃣ Build the Docker image:
The exact command to run the project depends on its structure. Typically, there's a main Python script or module you'd execute to start the project. If there's a clear entry point, you can run:
docker build -t mlops-shape-project:latest .
6️⃣ Build the Docker image:
docker run -p 8000:8000 mlops-shape-project:latest
API should now be running and accessible at http://localhost:8000.
Additional tasks:
The provided configuration also contains some tasks defined with taskipy
. You can run these tasks using the poetry run task
command. For example:
- To run the lint task:
poetry run task lint
- To serve the documentation:
poetry run task doc
7️⃣ Endpoints:
✅ GET /data
-
Purpose:
- This endpoint retrieves the original dataset from a predefined file location.
-
Usage:
- You simply send a GET request to this endpoint without any parameters.
-
Example with
curl
:
curl -X 'GET' http://localhost:8000/data
- Response:
If successful, you'll receive a JSON representation of the dataset. The structure will be a dictionary with columns as keys and their associated data as corresponding values.
✅ POST /process_data
-
Purpose:
- Processes data from an uploaded file and returns the processed output.
-
Usage:
- Send a POST request to this endpoint with an attached file containing the data you want to process.
-
Example with
curl
:
curl -X 'POST' -F 'file=@path_to_your_file.csv' http://localhost:8000/process_data
- Response:
If successful, you'll receive processed data (like predictions) as a JSON response.
✅ POST /predict
-
Purpose:
- This endpoint takes input data in the form of a JSON object and returns a prediction based on the provided data.
-
Usage:
- Send a POST request with a JSON payload representing the data for which you want a prediction.
-
Example with
curl
:
`curl -X 'POST' -H "Content-Type: application/json" -d '{"column1": "value1", "column2": "value2", ...}' http://localhost:8000/predict`
- Response:
If successful, you'll receive a JSON response with the prediction status and the predicted class.
✅ POST /predict_batch
-
Purpose:
- Provides batch predictions based on the provided data.
-
Usage:
- Send a POST request with a JSON payload containing multiple rows of data for batch processing.
-
Example with
curl
:
curl -X 'POST' -H "Content-Type: application/json" -d '[{"column1": "value1_1", "column2": "value1_2", ...}, {"column1": "value2_1", "column2": "value2_2", ...}, ...]' http://localhost:8000/predict_batch
- Response:
If successful, you'll receive a JSON response with the prediction status and the predicted classes for each input data row.
For each of the endpoints, if there's an error, the API will return a clear message indicating what went wrong, along with a status code indicating the nature of the error. Always make sure to check the returned message and status code to understand any issues.
📖 Documentation:
The documentation of this project is an essential component for understanding its structure, functionalities, and usage guides. We strongly believe that comprehensive documentation can speed up the adoption, contribution, and debugging processes of the project. The documentation was crafted using MkDocs, a swift and straightforward tool for creating documentation websites from markdown files. It allows us to concentrate on the content while automating the process of converting Markdown into a structured and styled website.
📑 Overview of Project Technologies
This section offers a comprehensive understanding of the technologies incorporated into our project, shedding light on each tool in detail. Grasping these technologies is pivotal for any developer or stakeholder aiming to become acquainted with the infrastructure and the project code.
- Python 3.8.10 🐍
- Description: Language used for application development.
- Poetry 📦
- Description: A tool for dependency management and packaging in Python. Poetry provides a streamlined and consistent approach to handle Python projects and their dependencies, ensuring transparency and reproducibility throughout the process.
- Scikit-learn 1.0.2 📊
- Description: A machine learning library in Python. Scikit-learn, together with Pandas, stands as an essential tool for data processing, analysis, and the deployment of machine learning models. Both libraries bring forth a vast set of features and are widely recognized in the community.
- Pandas ^2.0.3 🐼
- Description: Used for data reading and transformations.
- Blue ^0.9.1 🔵
- Description: Coding standard adopted for the project.
- isort ^5.12.0 📑
- Description: A coding utility to organize imports in a consistent format.
- taskipy ^1.11.0 🛠️
- Description: Facilitates development by creating tasks.
- pyarrow ^12.0.1 🏹
- Description: Enables reading of .parquet data files.
- Docker 🐳
- Description: Docker is a platform designed to develop, ship, and run applications within containers. It ensures our application and its dependencies are packaged into an isolated container, which enhances portability and ease of deployment across varied environments.
Grasping the intricate details of these technologies will significantly augment the efficiency and effectiveness of engagement with the project. 🚀🌟
📝 Next Steps
Here are some next steps that can be implemented in the future:
1️⃣ API Creation using FastAPI
Development of an API using FastAPI, a modern and fast framework for creating Python APIs. This will facilitate integration with other platforms and allow remote access to the project's resources.
2️⃣ Validation with Stakeholders
We plan to conduct several feedback sessions with our stakeholders to ensure the project aligns with the expectations and needs of the end users.
3️⃣ Monitoring Setup
Monitoring the performance and functionality of the system is crucial to ensure its reliability and efficiency. It's important to implement tools and processes for keeping an eye on the system.
4️⃣ Alert Setup for Slack or Email
To ensure a swift response to any issues that may arise, we'll implement alerts that will send notifications to Slack or predetermined emails in case of system failures.
5️⃣ Refactoring of the dataframe_checker.py
class
Currently, the dataframe_checker.py
class is responsible for validating input data. Initially, it wasn't built with PySpark, but ideally, its internal logic should be replaced with PySpark to optimize validation and preparation of data on large datasets.
6️⃣ Scheduling with Airflow
To automate and orchestrate our workflows, we will use Airflow. It will assist us in defining, scheduling, and monitoring workflows programmatically.
7️⃣ Model Registration in MLflow
Lastly, to track and manage our machine learning model iterations, we will use MLflow to register, version, and share models.
💻 CONTACT ME 💻
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file mlops_shape_project-0.3.2.tar.gz
.
File metadata
- Download URL: mlops_shape_project-0.3.2.tar.gz
- Upload date:
- Size: 12.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.5.1 CPython/3.8.10 Windows/10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | bea2bec0f5eefc0e933c2b6dedf0bd7e2d38ff6be2056527c91eb81060c8f83e |
|
MD5 | 586fa4fa3e38b96a1fe6fbfe1774b1bb |
|
BLAKE2b-256 | 2c91b54495bdc0e87967463681e381fda8c47b091808d261b1aa1f7d3033b872 |
File details
Details for the file mlops_shape_project-0.3.2-py3-none-any.whl
.
File metadata
- Download URL: mlops_shape_project-0.3.2-py3-none-any.whl
- Upload date:
- Size: 14.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.5.1 CPython/3.8.10 Windows/10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 728a14cf34742c77d6b62b0ea738adf2a6f9fd41280be66474e1ad50364db4a5 |
|
MD5 | a0b9681ef3312692a9c3f721b97fcf04 |
|
BLAKE2b-256 | 92a5a526708394471152e3602ffad313e214bdd533698d07b0e4e342321c8c17 |