Hubro Documentation Help

AI integration

Hubro seamlessly integrates with MlFlow - a platform for the machine learning lifecycle.

Preparing your environment

  1. Install Poetry tool by following the guide linked below

    https://python-poetry.org/docs/#installation

  2. Follow the sequence below to set up virtual env in your project

    poetry init poetry add mlflow poetry shell
  1. Install Conda tool by following the guide linked below

    https://conda.io/projects/conda/en/latest/user-guide/install/index.html

  2. Follow the sequence below to set up virtual env in your project

    conda create -n mlflow-env python=3.10 conda activate mlflow-env conda install -c conda-forge mlflow

Afterwards, you can start the mlflow tracking server using mlflow server

Preparing your models

As a first step, you need to prepare and save your AI models locally. Generally, we can run into two types of scenarios: a basic one, in which you implement your model as a Python function; or an advanced one, in which you use an ML framework such as Keras, PyTorch or similar.

Using Python functions/classes as predictors

Save the following snippet as train.py and run python train.py to save the AddN class and its metadata as a model.

import mlflow mlflow.set_tracking_uri(uri="http://127.0.0.1:5000") mlflow.set_experiment("Class-based model") # Define the model class class AddN(mlflow.pyfunc.PythonModel): def __init__(self, n): self.n = n def predict(self, context, model_input, params=None): return model_input.apply(lambda column: column + self.n) with mlflow.start_run(): mlflow.pyfunc.log_model(path=model_path, python_model=add5_model)
import mlflow import pandas as pd mlflow.set_tracking_uri(uri="http://127.0.0.1:5000") mlflow.set_experiment("Function-based model") # Define a simple function to log def predict(model_input): return model_input.apply(lambda x: x * 2) # Save the function as a model with mlflow.start_run(): mlflow.pyfunc.log_model("model", python_model=predict, pip_requirements=["pandas"])

Using ML framework (Keras)

As you can see from the snippet below, in principle using a ML framework is very similar to the previous scenario. Again, save the snippet into a .py file and run it.

from sklearn.model_selection import train_test_split X_train, X_test, y_train, y_test = train_test_split(images_arrays, prices, test_size=0.2) # Load the ResNet50 model base_model = MobileNetV3Small(include_top=False, input_shape=(224, 224, 3)) # Create a new model on top inputs = keras.Input(shape=(224, 224, 3)) x = preprocess_input(inputs) x = base_model(x, training=False) x = keras.layers.GlobalAveragePooling2D()(x) x = keras.layers.Dropout(0.2)(x) # add dropout to prevent overfitting outputs = keras.layers.Dense(1)(x) model = keras.Model(inputs, outputs) # Freeze the base_model base_model.trainable = False # Compile the model optimizer = keras.optimizers.Adam(learning_rate=0.15) model.compile(optimizer=optimizer, loss='mean_squared_error', metrics=['mean_absolute_error']) # Train the model on your regression dataset model.fit(X_train, y_train, epochs=3, validation_split=0.1) with mlflow.start_run() as run: mlflow.tensorflow.log_model(model, "mole_detection_dev")

Check the run and logged model

You can view successfully saved model in the server's UI (http://127.0.0.1:5000)

Screenshot 2024-07-18 at 9.42.01.png

Resulting artifacts can be viewed by clicking on the Run Name, and by navigation into the Artifacts section. These files are defining requirements of the model, model's environment and the model itself.

Screenshot 2024-07-18 at 9.41.10.png

Local serving of inference API

Logged model can be served locally on your PC/Mac by using the mlflow command below. This will export the REST API through which you can query the model.

mlflow models serve -m my_model --host=0.0.0.0 --port 5000

Now you can invoke the curl command from your command line to call the inference API.

curl http://localhost:5000/invocations -H ‘Content-Type: text/csv’ --data-binary @test.csv

Deploying models to Hubro

The deployment to Hubro can be done either as a lightweight serverless deployment, where you only specify storage path to resulting or by building a full docker image and deploying it using KNative orchestrator.

  1. Upload model to a public object storage

  2. Deploy the following YAML file to your Kubernetes namespace

    apiVersion: "serving.kserve.io/v1beta1" kind: "InferenceService" metadata: name: "mlflow-v2-wine-classifier" spec: predictor: model: modelFormat: name: mlflow protocolVersion: v2 storageUri: "gs://kfserving-examples/models/mlflow/wine"
  1. Install mlflow-knative package

  2. Deploy the following YAML file to your Kubernetes namespace

    mlflow deployments create --target knative:/context \ --name deployment-name \ --model-uri models:/model-name/model-version \ --config image_repository=docker.io/mmuzny/test \ --config image_tag=latest \ --config service_template=service_template.yaml

By running the command above, the following sequence of steps will be triggered

  1. A docker image with a name registry.hubroplatform.no/machinelearning/your-predictor-name will be built locally

  2. This docker image will be pushed to registry at registry.hubroplatform.no and deployed to Hubro Kubernetes cluster

  3. A Kubernetes ClusterIp service your-service-name will be created and will point to a newly deployed docker image

Interacting with your models through the app

Your deployed AI models are hosted behind Hubro's authentication layer i.e., they are not publicly accessible. The inference can be initiated directly from the application by the Hubro Connect API.

Notes on performance

Deployed models are orchestrated using Kubernetes engine and ultimately will consume system resources when running the inference. In most cases, a CPU power will suffice the inference engine requirements.

apiVersion: serving.kserve.io/v1beta1 kind: InferenceService metadata: name: "mlflow-wine-classifier" namespace: "mlflow-kserve-test" spec: predictor: serviceAccountName: sa model: modelFormat: name: mlflow protocolVersion: v2 storageUri: "gs://kfserving-examples/models/mlflow/wine" resources: requests: cpu: 100m memory: 250Mi nvidia.com/k915: 1
apiVersion: serving.knative.dev/v1 kind: Service metadata: name: "mlflow-wine-classifier" namespace: "mlflow-knative-test" spec: template: spec: containers: - image: docker.io/user/image ports: - containerPort: 8080 resources: requests: cpu: 100m memory: 250Mi nvidia.com/k915: 1
Last modified: 07 January 2025