manot
data:image/s3,"s3://crabby-images/56c63/56c63fa14426bf4f3ed7ef8126efd2e142f295ca" alt="license"
The manot SDK is a wrapper on top of our API to make it easier to work with our model performance monitoring system.
Using our SDK you can quickly set up your project by defining a few key parameters, including the paths to your data,
classes and model. Once the project is set up you will be able to use the insight method to extract outliers that manot
has detected on the new unstructured data that the performance of the model is evaluated on.
Installation
Install manot using pip
:
pip install manot
Example
This is an example how to start:
from manot import manotAI
manot = manotAI("manot_service_url", "token")
Uploading data for creating a project
manot.upload_data(dir_path="/path/to/data", process="project")
Running project
project = manot.create_project(
data_provider="s3",
arguments={
"name": "project_example",
"images_path": "/path/to/images",
"ground_truths_path": "/path/to/ground_truths",
"detections_path": "/path/to/detections",
"detections_metadata_format": "xyx2y2",
"classes_txt_path": "/path/to/classes.txt",
"task": 'task_type',
"weight_name": "yolov5s",
"description": "The project description",
}
)
project = manot.create_project(
data_provider="deeplake",
arguments={
"name": "project_example",
"detections_metadata_format": "xyx2y2",
"deeplake_token": "your deeplake token",
"data_set": "user/dataset/",
"detections_boxes_key": "deeplake key where detection boxes are stored",
"detections_labels_key": "deeplake key where where detection labels are stored",
"detections_score_key": "deeplake key where detections score is stored",
"ground_truths_boxes_key": "deeplake key where ground truth boxes are stored",
"ground_truths_labels_key": "deeplake key where ground truth labels are stored",
"classes": "classes for deeplake",
"task": 'task_type',
"weight_name": "yolov5s",
"description": "The project description",
}
)
print(project)
Get project by id
project_info = manot.get_project(project["id"])
Upload data to get insights from
manot.upload_data(dir_path="/path/to/data", process="evaluation")
Running evaluation on data in s3, gcs or local machine
evaluation = manot.evaluate(
name="insight_example",
project_id=project["id"],
data_path="/path/to/data",
data_provider="s3",
percentage="percentage",
description="The evaluation description",
)
print(evaluation)
evaluation_info = manot.get_evaluation(evaluation["id"])
Running evaluation on hugging face model and dataset
evaluation = manot.huggingface_evaluation(
name='manot-huggingface',
data_path="huggingface_dataset",
model_path="huggingface_model",
task="detection",
percentage=0.5,
description="The evaluation description",
)
evaluation_info = manot.get_evaluation(evaluation["id"])
scores = manot.get_score(evaluation['id'])
#returns list of all processed images graded by their score from 0 to 10 (higher is more impactful image)
# if the image cannot be assigned a score it will not be showing in the list
manot.visualize_data_set(evaluation_info['data_set']['id'], deeplake_token,group_similar=True)
In case of detection task use this to calculate mAP on your data
manot.calculate_map(
ground_truths_path="/path/to/ground_truths",
detections_path="/path/to/detections",
classes_txt_path="/path/to/classes.txt",
data_provider="local",
data_set_id="data_set_id",
)
In case of classification use this to calculate accuracy on your data
manot.calculate_accuracy(
images_path="/path/to/images",
predictions_path="/path/to/predictions",
classes_txt_path="/path/to/classes.txt",
data_provider="local",
data_set_id="data_set_id",
)
Resources