This project is inspired by Vincent D. Warmerdam's brain fart.
You may train the most awesome model in the world but if you can't deploy it then people can't enjoy your work. In my experience, deployment is a topic that gets least discussed during courses. It is assumed that you can just do this without any formal training. In my experience, it not as easy to deploy models that's why I thought it woulbe be great to create serveitlearn
. It creates an extremely thin layer around FastAPI library which allows you to create an end point super fast. More specifically, It provides /predict
end point. You can only send POST request with JSON body. The following code sample will make it clear.
from serveitlearn.decorator import app, predict, initalize
# Declare function that initalizes the model and any other data sources
@initalize
def my_initalization():
pass
# Declare function that will make the prediction based on the query
@predict
def my_prediction(query_dict):
pass
You need at least python 3.7. I will use conda for this
-
Create environment (if you don't already have one)
conda create -n serveitlearn_env python=3.7
-
Activate it
conda activate serveitlearn_env
-
Install it
pip install serveitlearn
The example, loads iris dataset, trains a simple SVC model and deploys it using serveitlearn
.
$ git clone https://github.com/samarpan-rai/serveitlearn
$ cd serveitlearn/examples/
$ pip install -r requirements.txt
$ uvicorn svc_iris_example:app --reload
$ curl --location --request POST 'localhost:8000/predict' \
--header 'Content-Type: application/json' \
--data-raw '{"plant_dimensions" : [[5.1,3.5,1.4,0.2],[5.1,3.5,1.4,0.2]]}'
- No authentication or security measures implemented.
- The documentation could be better.