Skip to content

Studio Client

EdgeFirst Client Library This library provides a client for the EdgeFirst API, allowing users to interact with the EdgeFirst Studio Server and perform various operations such as logging in, managing projects, and working with datasets and snapshots.

This is the Python API binding for the EdgeFirst Client Library. A Rust library and a command-line interface are also available. The CLI tool is bundgled with the Python wheel and can be called using the edgefirst-client command.

The Python API is available as the edgefirst_client module. The main class is Client, which provides methods for interacting with the EdgeFirst Studio Server. To use the Client object you need to create an instance, with an optional authentication token or username and password.

__all__ module

__all__ = [
    "Client",
    "AnnotationType",
    "AnnotationGroup",
    "Box2d",
    "Box3d",
    "Segmentation",
]

Built-in mutable sequence.

If no argument is given, the constructor creates a new empty list. The argument must be an iterable if specified.

__cached__ module

__cached__ = "/Users/sebastien/Documents/EdgeFirst Studio/venv/lib/python3.13/site-packages/edgefirst_client/__pycache__/__init__.cpython-313.pyc"

str(object='') -> str str(bytes_or_buffer[, encoding[, errors]]) -> str

Create a new string object from the given object. If encoding or errors is specified, then the object must expose a data buffer that will be decoded using the given encoding and error handler. Otherwise, returns the result of object.str() (if defined) or repr(object). encoding defaults to 'utf-8'. errors defaults to 'strict'.

__doc__ module

__doc__ = "EdgeFirst Client Library\nThis library provides a client for the EdgeFirst API, allowing users to\ninteract with the EdgeFirst Studio Server and perform various operations\nsuch as logging in, managing projects, and working with datasets and\nsnapshots.\n\nThis is the Python API binding for the EdgeFirst Client Library.  A Rust\nlibrary and a command-line interface are also available.  The CLI tool is\nbundgled with the Python wheel and can be called using the\n`edgefirst-client` command.\n\nThe Python API is available as the `edgefirst_client` module.  The main\nclass is `Client`, which provides methods for interacting with the EdgeFirst\nStudio Server.  To use the `Client` object you need to create an instance,\nwith an optional authentication token or username and password."

str(object='') -> str str(bytes_or_buffer[, encoding[, errors]]) -> str

Create a new string object from the given object. If encoding or errors is specified, then the object must expose a data buffer that will be decoded using the given encoding and error handler. Otherwise, returns the result of object.str() (if defined) or repr(object). encoding defaults to 'utf-8'. errors defaults to 'strict'.

__file__ module

__file__ = "/Users/sebastien/Documents/EdgeFirst Studio/venv/lib/python3.13/site-packages/edgefirst_client/__init__.py"

str(object='') -> str str(bytes_or_buffer[, encoding[, errors]]) -> str

Create a new string object from the given object. If encoding or errors is specified, then the object must expose a data buffer that will be decoded using the given encoding and error handler. Otherwise, returns the result of object.str() (if defined) or repr(object). encoding defaults to 'utf-8'. errors defaults to 'strict'.

__name__ module

__name__ = 'edgefirst_client'

str(object='') -> str str(bytes_or_buffer[, encoding[, errors]]) -> str

Create a new string object from the given object. If encoding or errors is specified, then the object must expose a data buffer that will be decoded using the given encoding and error handler. Otherwise, returns the result of object.str() (if defined) or repr(object). encoding defaults to 'utf-8'. errors defaults to 'strict'.

__package__ module

__package__ = 'edgefirst_client'

str(object='') -> str str(bytes_or_buffer[, encoding[, errors]]) -> str

Create a new string object from the given object. If encoding or errors is specified, then the object must expose a data buffer that will be decoded using the given encoding and error handler. Otherwise, returns the result of object.str() (if defined) or repr(object). encoding defaults to 'utf-8'. errors defaults to 'strict'.

__path__ module

__path__ = [
    "/Users/sebastien/Documents/EdgeFirst Studio/venv/lib/python3.13/site-packages/edgefirst_client"
]

Built-in mutable sequence.

If no argument is given, the constructor creates a new empty list. The argument must be an iterable if specified.

AnnotationGroup

__doc__ class

__doc__ = None

The type of the None singleton.

__module__ class

__module__ = 'edgefirst_client'

str(object='') -> str str(bytes_or_buffer[, encoding[, errors]]) -> str

Create a new string object from the given object. If encoding or errors is specified, then the object must expose a data buffer that will be decoded using the given encoding and error handler. Otherwise, returns the result of object.str() (if defined) or repr(object). encoding defaults to 'utf-8'. errors defaults to 'strict'.

__new__ builtin

__new__(*args, **kwargs)

Create and return a new object. See help(type) for accurate signature.

__repr__ method descriptor

__repr__()

Return repr(self).

AnnotationType

AnnotationType is used to identify the type of annotation in the dataset.

Box2d class

Box2d = AnnotationType.Box2d

AnnotationType is used to identify the type of annotation in the dataset.

Box3d class

Box3d = AnnotationType.Box3d

AnnotationType is used to identify the type of annotation in the dataset.

Segmentation class

Segmentation = AnnotationType.Segmentation

AnnotationType is used to identify the type of annotation in the dataset.

__doc__ class

__doc__ = "AnnotationType is used to identify the type of annotation in the dataset."

str(object='') -> str str(bytes_or_buffer[, encoding[, errors]]) -> str

Create a new string object from the given object. If encoding or errors is specified, then the object must expose a data buffer that will be decoded using the given encoding and error handler. Otherwise, returns the result of object.str() (if defined) or repr(object). encoding defaults to 'utf-8'. errors defaults to 'strict'.

__hash__ class

__hash__ = None

The type of the None singleton.

__module__ class

__module__ = 'edgefirst_client'

str(object='') -> str str(bytes_or_buffer[, encoding[, errors]]) -> str

Create a new string object from the given object. If encoding or errors is specified, then the object must expose a data buffer that will be decoded using the given encoding and error handler. Otherwise, returns the result of object.str() (if defined) or repr(object). encoding defaults to 'utf-8'. errors defaults to 'strict'.

__eq__ method descriptor

__eq__(value)

Return self==value.

__ge__ method descriptor

__ge__(value)

Return self>=value.

__gt__ method descriptor

__gt__(value)

Return self>value.

__int__ method descriptor

__int__()

int(self)

__le__ method descriptor

__le__(value)

Return self<=value.

__lt__ method descriptor

__lt__(value)

Return self<value.

__ne__ method descriptor

__ne__(value)

Return self!=value.

__new__ builtin

__new__(*args, **kwargs)

Create and return a new object. See help(type) for accurate signature.

__repr__ method descriptor

__repr__()

Return repr(self).

Box2d

__doc__ class

__doc__ = None

The type of the None singleton.

__module__ class

__module__ = 'edgefirst_client'

str(object='') -> str str(bytes_or_buffer[, encoding[, errors]]) -> str

Create a new string object from the given object. If encoding or errors is specified, then the object must expose a data buffer that will be decoded using the given encoding and error handler. Otherwise, returns the result of object.str() (if defined) or repr(object). encoding defaults to 'utf-8'. errors defaults to 'strict'.

__new__ builtin

__new__(*args, **kwargs)

Create and return a new object. See help(type) for accurate signature.

Box3d

__doc__ class

__doc__ = None

The type of the None singleton.

__module__ class

__module__ = 'edgefirst_client'

str(object='') -> str str(bytes_or_buffer[, encoding[, errors]]) -> str

Create a new string object from the given object. If encoding or errors is specified, then the object must expose a data buffer that will be decoded using the given encoding and error handler. Otherwise, returns the result of object.str() (if defined) or repr(object). encoding defaults to 'utf-8'. errors defaults to 'strict'.

__new__ builtin

__new__(*args, **kwargs)

Create and return a new object. See help(type) for accurate signature.

Client

The EdgeFirst Client handles the connection to the EdgeFirst Studio Server and manages authentication and the client RPC calls. The client also provides various utility methods for interacting with datasets and converting them to and from Polars DataFrames.

__doc__ class

__doc__ = "The EdgeFirst Client handles the connection to the EdgeFirst Studio Server\nand manages authentication and the client RPC calls.  The client also\nprovides various utility methods for interacting with datasets and\nconverting them to and from Polars DataFrames."

str(object='') -> str str(bytes_or_buffer[, encoding[, errors]]) -> str

Create a new string object from the given object. If encoding or errors is specified, then the object must expose a data buffer that will be decoded using the given encoding and error handler. Otherwise, returns the result of object.str() (if defined) or repr(object). encoding defaults to 'utf-8'. errors defaults to 'strict'.

__module__ class

__module__ = 'edgefirst_client'

str(object='') -> str str(bytes_or_buffer[, encoding[, errors]]) -> str

Create a new string object from the given object. If encoding or errors is specified, then the object must expose a data buffer that will be decoded using the given encoding and error handler. Otherwise, returns the result of object.str() (if defined) or repr(object). encoding defaults to 'utf-8'. errors defaults to 'strict'.

__new__ builtin

__new__(*args, **kwargs)

Create and return a new object. See help(type) for accurate signature.

annotation_sets_sync method descriptor

annotation_sets_sync(dataset_id)

List available annotation sets for the specified dataset.

annotations_dataframe_sync method descriptor

annotations_dataframe_sync(
    annotation_set_id, types=Ellipsis
)

Get the AnnotationGroup for the specified annotation set with the requested annotation types. The annotation type is used to filter the annotations returned. Images which do not have any annotations are included in the result.

The result is a DataFrame following the EdgeFirst Dataset Format definition.

To get the annotations as a vector of AnnotationGroup objects, use the annotations_sync method instead.

annotations_sync method descriptor

annotations_sync(annotation_set_id, types=Ellipsis)

Get the AnnotationGroup for the specified annotation set with the requested annotation types. The annotation type is used to filter the annotations returned. Images which do not have any annotations are included in the result.

The result is a vector of AnnotationGroup objects which contain the full dataset along with the annotations for the specified types.

To get the annotations as a DataFrame, use the annotations_dataframe_sync method instead.

artifacts_sync method descriptor

artifacts_sync(trainer_session_id)

List the artifacts for the specified trainer session. The artifacts are returned as a vector of strings.

create_snapshot_sync method descriptor

create_snapshot_sync(path, progress=None)

Create a new snapshot from the file at the specified path. If the path is a directory then all the files in the directory are uploaded. The snapshot name will be the specified path, either file or directory.

The progress callback can be used to monitor the progress of the upload. The callback must have the signature fn(current: int, total: int).

dataset_images_sync method descriptor

dataset_images_sync(dataset_id)

Get image ids for the dataset with the specified dataset ID.

dataset_sync method descriptor

dataset_sync(dataset_id)

Return the dataset with the specified dataset ID. If the dataset does not exist, an error is returned.

datasets_sync method descriptor

datasets_sync(project_id)

Returns a list of datasets available to the user. The datasets are returned as a vector of Dataset objects.

download_artifact_sync method descriptor

download_artifact_sync(
    trainer_session_id, modelname, filename, progress=None
)

Download the model artifact for the specified trainer session to the specified file path. A progress callback can be provided to monitor the progress of the download over a watch channel.

download_dataset_sync method descriptor

download_dataset_sync(
    dataset_id, output=None, progress=None
)

Downloads the dataset with the specified dataset ID to the specified file path. A progress callback can be provided to monitor the progress of the download.

The callback must have the signature fn(current: int, total: int).

download_snapshot_sync method descriptor

download_snapshot_sync(
    snapshot_id, output=None, progress=None
)

Downloads a snapshot from the server. The snapshot could be a single file or a directory of files. The snapshot is downloaded to the specified path.

A progress callback can be provided to monitor the progress of the download.

The callback must have the signature fn(current: int, total: int).

find_dataset_sync method descriptor

find_dataset_sync(project_id, name)

Find a dataset by name within the project with the specified project ID.

find_project_sync method descriptor

find_project_sync(name)

Find a project by name. If the project does not exist, None is returned.

find_snapshots_sync method descriptor

find_snapshots_sync(name)

Find the snapshots containing the provided description.

find_trainer_session_sync method descriptor

find_trainer_session_sync(trainer_id, name)

Find a trainer session by name within the trainer with the specified trainer ID. If the trainer session does not exist, None is returned.

find_trainer_sync method descriptor

find_trainer_sync(project_id, name)

Find a trainer by name within the project with the specified project ID. If the trainer does not exist, None is returned.

image_sync method descriptor

image_sync(image_id)

Get image metadata for the specified image ID.

login_sync method descriptor

login_sync(username, password)

Login to the server using the specified username and password. The server will authenticate the user and return a token that can be used to authenticate future requests. The token is stored in the client and used to authenticate the client with the server.

project_sync method descriptor

project_sync(project_id)

Return the project with the specified project ID. If the project does not exist, an error is returned.

projects_sync method descriptor

projects_sync()

Returns a list of projects available to the user. The projects are returned as a vector of Project objects.

Projects are the top-level organizational unit in Deep View Enterprise. Projects contain datasets, trainers, and trainer sessions. Projects are used to group related datasets and trainers together.

restore_snapshot_sync method descriptor

restore_snapshot_sync(
    project_id,
    snapshot_id,
    depth_gen,
    agtg_pipeline,
    dataset_name=None,
    dataset_description=None,
)

The snapshot restore method is used to restore a snapshot to the server. The restore method can perform a few different operations depending on the snapshot type.

For MCAP snapshots the restore function will convert the MCAP into a dataset and optionally run the auto-annotation pipeline.

snapshot_sync method descriptor

snapshot_sync(snapshot_id)

Get the snapshot with the specified id.

snapshots_sync method descriptor

snapshots_sync()

List available snapshots.

token_sync method descriptor

token_sync()

Return the token used to authenticate the client with the server. When logging into the server using a username and password, the token is returned by the server and stored in the client for future interactions.

trainer_session_sync method descriptor

trainer_session_sync(trainer_session_id)

Return the trainer session with the specified trainer session ID. If the trainer session does not exist, an error is returned.

trainer_sessions_sync method descriptor

trainer_sessions_sync(trainer_id)

Returns a list of trainer sessions available to the user. The trainer sessions are returned as a vector of TrainerSession objects. Trainer sessions are akin to runs in MLFlow terminology. These represent an actual training session which will produce metrics and model artifacts.

trainer_sync method descriptor

trainer_sync(trainer_id)

Return the trainer with the specified trainer ID. If the trainer does not exist, an error is returned.

trainers_sync method descriptor

trainers_sync(project_id)

Returns a list of trainers available to the user. The trainers are returned as a vector of Trainer objects. Trainers are akin to an Experiment in MLFlow terminology. Each trainer can have multiple trainer sessions associated with it, these would be akin to runs in MLFlow.

verify_token_sync method descriptor

verify_token_sync()

Verify the token used to authenticate the client with the server. This method is used to ensure that the token is still valid and has not expired. If the token is invalid, the server will return an error and the client will need to login again.

version_sync method descriptor

version_sync()

Return the version of the Deep View Enterprise server for the current client connection.

Segmentation

__doc__ class

__doc__ = None

The type of the None singleton.

__module__ class

__module__ = 'edgefirst_client'

str(object='') -> str str(bytes_or_buffer[, encoding[, errors]]) -> str

Create a new string object from the given object. If encoding or errors is specified, then the object must expose a data buffer that will be decoded using the given encoding and error handler. Otherwise, returns the result of object.str() (if defined) or repr(object). encoding defaults to 'utf-8'. errors defaults to 'strict'.

__new__ builtin

__new__(*args, **kwargs)

Create and return a new object. See help(type) for accurate signature.