Picsellia SDK Client can be used to communicate with Picsellia services.
You need an API Token, available on web platform in Profile Settings > Token.
From this client object, you will be able to retrieve python objects representing your data in the platform.
Examples
client = Client(api_token="a0c9f3bbf7e8bc175494fc44bfc6f89aae3eb9d0")
Arguments
-
api_token (str, optional) : your api token, that can be found on the web platform.
Defaults to None, client will try to find it into your environment variable as 'PICSELLIA_TOKEN' -
organization_id : (str or UUID, optional): Specify an organization to connect to by giving its id.
Defaults to None, you will be connected to your main Organization. -
organization_name : (str, optional): Specify an organization to connect to by giving its name.
If id is also given, client will use organization_id.
Defaults to None, you will be connected to your main Organization. -
host (str, optional) : Define a custom host used for platform.
Defaults to our Picsellia environment "https://app.picsellia.com". -
session (requests.Session, optional) : Set up your own requests.Session object to add headers or proxies.
Properties
-
id
Organization UUID connected with this (Client) -
name
Organization name connected with this (Client)
Methods
is_sdk_outdated
is_sdk_outdated(
cls, sdk: str, platform: str
)
Description
get_datalake
get_datalake(
id: Optional[Union[str, UUID]] = None, name: Optional[str] = None
)
Description
Retrieve a datalake of your organization.
By default, is nothing is given, this will return your default datalake.
Examples
datalake = client.get_datalake()
datalake = client.get_datalake(name="default")
datalake = client.get_datalake(id="0188e773-db65-7546-8e3e-b38fe5bed6d2")
Arguments
-
id (str or UUID, optional) : id of the datalake to retrieve. Defaults to None.
-
name (str, optional) : name of the datalake to retrieve. Defaults to None.
Returns
The Datalake of the client that you are using
list_datalakes
list_datalakes()
Description
Retrieve all datalakes linked to this organization
Examples
datalakes = client.list_datalakes()
Returns
List of Datalake of the client that you are using
create_dataset
create_dataset(
name: str, description: str = '', private: bool = None
)
Description
Create a Dataset in this organization.
This method allows user to create a dataset into the organization currently connected.
A dataset can then be versioned into DatasetVersion.
User can specify name of the dataset, a description and if the dataset is private or not.
Examples
Create a dataset named datatest with data from datalake and version it
foo_dataset = client.create_dataset('foo_dataset')
foo_dataset_version_1 = foo_dataset.create_version('first')
some_data = client.get_datalake().list_data(limit=10)
foo_dataset_version_1.add_data(some_data)
Arguments
-
name (str) : Name of the dataset. It must be unique in the organization.
-
description (str, optional) : A description of the dataset. Defaults to ''.
-
private (bool, optional) : Specify if the dataset is private. Defaults to True.
Returns
A Dataset that you can manipulate, connected to Picsellia
get_dataset
get_dataset(
name: str
)
Description
Retrieve a dataset by its name
Examples
foo_dataset = client.get_dataset('datatest')
foo_dataset_version = foo_dataset.get_version('first')
Arguments
- name (str) : Name of the dataset
Returns
A Dataset that you can use and manipulate
get_dataset_by_id
get_dataset_by_id(
id: Union[UUID, str]
)
Description
Get a dataset by its id
Examples
dataset = client.get_dataset_by_id('918351d2-3e96-4970-bb3b-420f33ded895')
Arguments
- id (str) : id of the dataset to retrieve
Returns
A Dataset that you can use and manipulate
list_datasets
list_datasets(
limit: Optional[int] = None, offset: Optional[int] = None,
order_by: Optional[list[str]] = None
)
Description
Retrieve all dataset of current organization
Examples
datasets = client.list_datasets()
Arguments
-
limit (int, optional) : Limit number of datasets to retrieve. Defaults to None, all datasets will be retrieved.
-
offset (int, optional) : Offset to begin with when listing datasets. Defaults to None, starting at 0.
-
order_by (list[str], optional) : Some fields to order datasets against. Defaults to None, datasets will not be sorted
Returns
A list of Dataset object that belongs to your organization
get_dataset_version_by_id
get_dataset_version_by_id(
id: Union[UUID, str]
)
Description
Get a dataset version by its id
Examples
dataset_version = client.get_dataset_version_by_id('918351d2-3e96-4970-bb3b-420f33ded895')
Arguments
- id (str or UUID) : id of the dataset version to retrieve
Returns
create_model
create_model(
name: str, description: str = None
)
Description
Create a new model.
Examples
model = client.create_model(name="foo_model", description="A brand new model!")
Arguments
-
name (str) : Model name to create.
-
description (str, optional) : Description of this model. Defaults to None
Returns
A Model object that you can manipulate
get_model_by_id
get_model_by_id(
id: Union[UUID, str]
)
Description
Retrieve a model by its id
Examples
model = client.get_model_by_id(UUID("d8fae655-5c34-4a0a-a59a-e49c89f20998"))
Arguments
- id (str) : id of the model that you are looking for
Returns
A Model object that you can manipulate
get_model
get_model(
name: str
)
Description
Retrieve a model by its name.
Examples
model = client.get_model("foo_model")
Arguments
- name (str) : name of the model you are looking for
Returns
A Model object that you can manipulate
get_public_model
get_public_model(
name: str
)
Description
Retrieve a public model by its name.
It can only retrieve public model.
Examples
model = client.get_public_model("foo_public_model")
Arguments
- name (str) : name of the public model you are looking for
Returns
A Model object that you can manipulate
list_models
list_models(
limit: Optional[int] = None, offset: Optional[int] = None,
order_by: Optional[list[str]] = None
)
Description
List all models stored in this organization
This will return all the models stored
If no project is found, will throw a ResourceNotFoundError
Examples
models = client.list_models()
Arguments
-
limit (int, optional) : Limit number of models to retrieve. Defaults to None, all models will be retrieved.
-
offset (int, optional) : Offset to begin with when listing models. Defaults to None, starting at 0.
-
order_by (list[str], optional) : Some fields to order models against. Defaults to None, models will not be sorted
Returns
A list of all Model that belong to this organization
list_public_models
list_public_models(
limit: Optional[int] = None, offset: Optional[int] = None,
order_by: Optional[list[str]] = None, name: Optional[str] = None, type: Union[str,
InferenceType, None] = None
)
Description
List all public models of Picsellia Hub
This will return all public models of the hub
Arguments
-
limit (int, optional) : Limit number of public models to retrieve.
Defaults to None, all public models will be retrieved. -
offset (int, optional) : Offset to begin with when listing public models.
Defaults to None, starting at 0. -
order_by (list[str], optional) : Some fields to order models against.
Defaults to None, models will not be sorted -
name (str, optional) : A name to filter public models. It will return models with name containing
this parameter. Defaults to None, models will not be filtered -
type (str or InferenceType, optional) : A type to filter public models on.
Examples
public_detection_models = client.list_public_models(name="yolo")
Returns
A list of all public Model objects
get_model_version_by_id
get_model_version_by_id(
id: Union[UUID, str]
)
Description
Get a model version by its id
Examples
model_version = client.get_model_version_by_id('918351d2-3e96-4970-bb3b-420f33ded895')
Arguments
- id (str or UUID) : id of the model version to retrieve
Returns
create_project
create_project(
name: str, description: Optional[str] = None, private: Optional[bool] = True
)
Description
Create a project with given name and parameters
This project will be registered into used organization.
Examples
my_project = client.create_project("my_project", description="My first project!")
Arguments
-
name (str) : name of the project
-
description (str) : description of the project
-
private (bool, deprecated) : This parameter is deprecated
Returns
A Project that you can manipulate to run experiments, or attach dataset
get_project
get_project(
project_name: str
)
Description
Get a project from its name
Retrieve a project from its name.
Project must belong to used organization.
Examples
my_project = client.get_project("my_project")
Arguments
- project_name (str) : name of the project to retrieve
Returns
A Project of your organization, you can manipulate to run experiments, or attach dataset
get_project_by_id
get_project_by_id(
id: Union[UUID, str]
)
Description
Get a project from its id
Retrieve a project from its id.
Project must belong to used organization.
If no project is found, will throw a ResourceNotFoundError
Examples
my_project = client.get_project_by_id("2214aacc-b884-41e1-b70f-420c0cd7eefb")
Arguments
- id (str) : id of the project to retrieve
Returns
A Project of your organization, you can manipulate to run experiments, or attach dataset
list_projects
list_projects(
limit: Optional[int] = None, offset: Optional[int] = None,
order_by: Optional[list[str]] = None
)
Description
List all projects of your organization.
Retrieve all projects of your organization
Examples
projects = client.list_projects()
Arguments
-
limit (int, optional) : Limit number of projects to retrieve. Defaults to None, all projects will be retrieved.
-
offset (int, optional) : Offset to begin with when listing projects. Defaults to None, starting at 0.
-
order_by (list[str], optional) : Some fields to order projects against. Defaults to None, projects will not be sorted
Returns
A list of Project of your organization
get_experiment_by_id
get_experiment_by_id(
id: Union[UUID, str]
)
Description
Get an experiment by its id
Examples
experiment = client.get_experiment_by_id('918351d2-3e96-4970-bb3b-420f33ded895')
Arguments
- id (str or UUID) : id of the experiment to retrieve
Returns
get_deployment
get_deployment(
name: str
)
Description
Get a Deployment from its name.
Examples
deployment = client.get_deployment(
name="awesome-deploy"
)
Arguments
- name (str) : auto-generated name of your deployment.
Returns
A Deployment object connected and authenticated to all the services.
get_deployment_by_id
get_deployment_by_id(
id: Union[UUID, str]
)
Description
Get a Deployment from its name.
Examples
deployment = client.get_deployment_by_id(
id="YOUR DEPLOYMENT ID"
)
Arguments
- id (str) : deployment id displayed in your deployment settings.
Returns
A Deployment object connected and authenticated to all the services.
list_deployments
list_deployments(
limit: Optional[int] = None, offset: Optional[int] = None,
order_by: Optional[list[str]] = None
)
Description
List all Deployment of your organization
Examples
our_deployments = client.list_deployments()
Arguments
-
limit (int, optional) : number max of results to return
-
offset (int, optional) : offset of page for pagination
-
order_by (list[str], optional) : keys on which deployments shall be sorted
Returns
- of Deployment : all deployments object connected and authenticated to all the services.
create_deployment
create_deployment(
model_version: ModelVersion, shadow_model_version: Optional[ModelVersion] = None,
name: Optional[str] = None, min_threshold: Optional[float] = None,
target_datalake: Optional[Datalake] = None,
disable_serving: Optional[bool] = False
)
Description
Create a Deployment from a model.
This method allows you to create a Deployment on Picsellia. You will then have
access to the monitoring dashboard and eventually a hosted endpoint.
Examples
Create a serverless deployment
model_version = client.get_model_version_by_id('918351d2-3e96-4970-bb3b-420f33ded895')
deployment = client.create_deployment(model_version=model_version)
Arguments
-
model_version ModelVersion : ModelVersion to deploy.
-
shadow_model_version (ModelVersion, optional) : ModelVersion to perform shadow predictions.
-
name (str, optional) : Name of your deployment. Defaults to a random name.
-
min_threshold (float, optional) : Threshold of detection scores used by models when predicting. Defaults to 0.
-
target_datalake (Datalake, optional) : Datalake to use when data are pushed into Picsellia.
Defaults to organization default Datalake. -
disable_serving (bool, optional) : Whether to not use Picsellia Serving. Defaults to False.
Returns
create_datasource
create_datasource(
name: str
)
Description
Create a data source into this organization
Examples
data_source = client.create_datasource()
Arguments
- name (str) : Name of the datasource to create
Returns
A DataSource object that belongs to your organization
get_datasource
get_datasource(
name: str
)
Description
Retrieve a datasource by its name
Examples
data_sources = client.get_datasource("datasource_1")
Arguments
- name (str) : Name of the datasource to retrieve
Returns
A DataSource object that belongs to your organization
get_or_create_datasource
get_or_create_datasource(
name: str
)
Description
Retrieve a datasource by its name or create it if it does not exist.
Examples
datasource = client.get_or_create_datasource("new_source")
Arguments
- name (str) : Datasource name to retrieve or create
Returns
A DataSource object
list_datasources
list_datasources(
limit: Optional[int] = None, offset: Optional[int] = None,
order_by: Optional[list[str]] = None
)
Description
Retrieve all data source of current organization
Examples
data_sources = client.list_datasources()
Arguments
-
limit (int, optional) : Limit number of data sources to retrieve. Defaults to None, all data sources will be retrieved.
-
offset (int, optional) : Offset to begin with when listing data sources. Defaults to None, starting at 0.
-
order_by (list[str], optional) : Some fields to order data sources against. Defaults to None, data sources will not be sorted
Returns
A list of DataSource object that belongs to your organization
create_dataset_tag
create_dataset_tag(
name: str
)
Description
Create a Dataset Tag, usable only on Dataset objects
Examples
tag = client.create_dataset_tag("global")
Arguments
- name (str) : Name of the tag
Returns
A Tag object
create_dataset_version_tag
create_dataset_version_tag(
name: str
)
Description
Create a Dataset Version Tag, usable only on Dataset Version objects
Examples
tag = client.create_dataset_version_tag("train")
Arguments
- name (str) : Name of the tag
Returns
A Tag object
create_model_tag
create_model_tag(
name: str
)
Description
Create a Model Tag, usable only on Model objects
Examples
tag = client.create_model_tag("model")
Arguments
- name (str) : Name of the tag
Returns
A Tag object
create_model_version_tag
create_model_version_tag(
name: str
)
Description
Create a Model Version Tag, usable only on Model Version objects
Examples
tag = client.create_model_version_tag("initial")
Arguments
- name (str) : Name of the tag
Returns
A Tag object
create_deployment_tag
create_deployment_tag(
name: str
)
Description
Create a Deployment Tag, usable only on Deployment objects
Examples
tag = client.create_deployment_tag("operation")
Arguments
- name (str) : Name of the tag
Returns
A Tag object
list_dataset_tags
list_dataset_tags()
Description
List all Dataset tags, usable only on Dataset objects
Examples
tags = client.list_dataset_tags()
Returns
A list of Tag objects
list_dataset_version_tags
list_dataset_version_tags()
Description
List all Dataset Version tags, usable only on Dataset Version objects
Examples
tags = client.list_dataset_version_tags()
Returns
A list of Tag objects
list_model_tags
list_model_tags()
Description
List all Model tags, usable only on Model objects
Examples
tags = client.list_model_tags()
Returns
A list of Tag objects
list_model_version_tags
list_model_version_tags()
Description
List all Model Version tags, usable only on Model Version objects
Examples
tags = client.list_model_version_tags()
Returns
A list of Tag objects
list_deployment_tags
list_deployment_tags()
Description
List all Deployment tags, usable only on Deployment Version objects
Examples
tags = client.list_deployment_tags()
Returns
A list of Tag objects
find_dataset_tag
find_dataset_tag(
name: str
)
Description
Find a Dataset tag, usable only on Dataset objects, from its name
Examples
tag = client.find_dataset_tag("global")
Arguments
- name (str) : Name of the tag
Returns
A Tag object
find_dataset_version_tag
find_dataset_version_tag(
name: str
)
Description
Find a Dataset Version tag, usable only on Dataset Version objects, from its name
Examples
tag = client.find_dataset_version_tag("train")
Arguments
- name (str) : Name of the tag
Returns
A Tag object
find_model_tag
find_model_tag(
name: str
)
Description
Find a Model tag, usable only on Model objects, from its name
Examples
tag = client.find_model_tag("model")
Arguments
- name (str) : Name of the tag
Returns
A Tag object
find_model_version_tag
find_model_version_tag(
name: str
)
Description
Find a Model Version tag, usable only on Model version objects, from its name
Examples
tag = client.find_model_version_tag("initial")
Arguments
- name (str) : Name of the tag
Returns
A Tag object
find_deployment_tag
find_deployment_tag(
name: str
)
Description
Find a Deployment tag, usable only on Deployment objects, from its name
Examples
tag = client.find_deployment_tag("operation")
Arguments
- name (str) : Name of the tag
Returns
A Tag object
get_job_by_id
get_job_by_id(
id: Union[UUID, str]
)
Description
Get a Job from its id.
Examples
job = client.get_job_by_id(
id="YOUR JOB ID"
)
Arguments
- id (str) : job id displayed in your job page.
Returns
A Job object
create_processing
create_processing(
name: str, type: Union[str, ProcessingType], default_cpu: int, default_gpu: int,
default_parameters: dict, docker_image: str, docker_tag: str,
docker_flags: Optional[list[str]] = None, description: Optional[str] = None
)
Description
Create a Processing in this organization.
Examples
Create a dataset named datatest with data from datalake and version it
foo_dataset = client.create_processing(
name="processing-1",
type="AUTO_TAGGING",
default_cpu=4,
default_gpu=0,
)
Arguments
-
name (str) : Name of the processing.
-
type (str or ProcessingType) : Type of the processing.
-
default_cpu (int) : Default cpu used by this processing.
-
default_gpu (int) : Default gpu used by this processing.
-
default_parameters (dict) : Default parameters used by this processing.
-
docker_image (str) : Docker image of the processing.
-
docker_tag (str) : Docker tag of the processing.
-
docker_flags (list of str, optional) : Docker flags of the processing.
-
description (str, optional) : Description of the processing. Default to None.
Returns
list_processings
list_processings(
limit: Optional[int] = None, offset: Optional[int] = None,
order_by: Optional[list[str]] = None
)
Description
List all processings stored in this organization
Examples
processings = client.list_processings()
Arguments
-
limit (int, optional) : Limit number of processings to retrieve. Defaults to None, all models will be retrieved.
-
offset (int, optional) : Offset to begin with when listing processings. Defaults to None, starting at 0.
-
order_by (list[str], optional) : Some fields to order processings against. Defaults to None, processings will not be sorted
Returns
A list of all Processing that belong to this organization
get_processing
get_processing(
name: str
)
Description
Find a processing in this organization
Examples
processing = client.get_processing(name="auto-tagging-dataset")
Arguments
- name (str) : Name of the processing you are looking for
Returns
A Processing that belong to this organization
list_annotation_campaigns
list_annotation_campaigns(
is_closed: Optional[bool] = None
)
Description
List annotation campaigns of this organization, created on dataset versions.
Examples
campaigns = client.list_annotation_campaigns()
Returns
A list of AnnotationCampaign of this organization
list_review_campaigns
list_review_campaigns(
is_closed: Optional[bool] = None
)
Description
List review campaigns of this organization, created on deployments.
Examples
campaigns = client.list_review_campaigns()
Returns
A list of (ReviewCampaign) of this organization