fiftyone.utils.cvat¶
Utilities for working with datasets in CVAT format.
Functions:
|
Imports annotations from the specified CVAT project or task(s) into the given sample collection. |
|
Loads the CVAT image annotations from the given XML file. |
|
Loads the CVAT video annotations from the given XML file. |
Classes:
|
Importer for CVAT image datasets stored on disk. |
|
Importer for CVAT video datasets stored on disk. |
|
Exporter that writes CVAT image datasets to disk. |
|
Exporter that writes CVAT video datasets to disk. |
|
Description of the labels in a CVAT image annotation task. |
|
An annotated image in CVAT image format. |
|
Mixin for CVAT annotations that store a list of |
|
Mixin for annotations in CVAT image format. |
|
A tag in CVAT image format. |
|
An object bounding box in CVAT image format. |
|
A polygon in CVAT image format. |
|
A polyline in CVAT image format. |
|
A set of keypoints in CVAT image format. |
|
An annotation track in CVAT video format. |
|
Mixin for annotations in CVAT video format. |
|
An object bounding box in CVAT video format. |
|
A polygon in CVAT video format. |
|
A polyline in CVAT video format. |
|
A set of keypoints in CVAT video format. |
|
An attribute in CVAT image format. |
Class for writing annotations in CVAT image format. |
|
Class for writing annotations in CVAT video format. |
|
|
Class for configuring |
|
Class for interacting with the CVAT annotation backend. |
|
Class that stores all relevant information needed to monitor the progress of an annotation run sent to CVAT and download the results. |
|
A class to facilitate connection to and management of tasks in CVAT. |
|
A label returned by the CVAT API. |
|
A shape returned by the CVAT API. |
|
A tag returned by the CVAT API. |
-
fiftyone.utils.cvat.
import_annotations
(sample_collection, project_name=None, project_id=None, task_ids=None, data_path=None, label_types=None, insert_new=True, download_media=False, num_workers=None, occluded_attr=None, group_id_attr=None, backend='cvat', **kwargs)¶ Imports annotations from the specified CVAT project or task(s) into the given sample collection.
Provide one of
project_name
,project_id
, ortask_ids
to perform an import.This method can be configured in any of the following three ways:
Pass the
data_path
argument to define a mapping between media filenames in CVAT and local filepaths to the same media.Pass the
download_media=True
option to download both the annotations and the media files themselves, which are stored in a directory you specify via thedata_path
argument.Don’t provide
data_path
ordownload_media=True
, in which case it is assumed that the CVAT filenames correspond to the base filenames of existing sample filepaths in the providedsample_collection
.
- Parameters
sample_collection – a
fiftyone.core.collections.SampleCollection
project_name (None) – the name of a CVAT project to import
project_id (None) – the ID of a CVAT project to import
task_ids (None) – a CVAT task ID or iterable of CVAT task IDs to import
data_path (None) –
a parameter that defines the correspondence between the filenames in CVAT and the filepaths of
sample_collection
. Can be any of the following:a directory on disk where the media files reside. In this case, the filenames must match those in CVAT
a dict mapping CVAT filenames to absolute filepaths to the corresponding media on disk
the path to a JSON manifest on disk containing a mapping between CVAT filenames and absolute filepaths to the media on disk
By default, only annotations whose filename matches an existing filepath in
sample_collection
will be importedlabel_types (None) –
an optional parameter specifying the label types to import. Can be any of the following:
None
(default): all label types will be stored in fields of the same name onsample_collection
a list of label types to load. In this case, the labels will be stored in fields of the same names in
sample_collection
a dict mapping label types to field names of
sample_collection
in which to store the labels"prompt"
: present an interactive prompt to decide/discard field names in which to store each label type
insert_new (True) – whether to create new samples for any media for which annotations are found in CVAT but which do not exist in
sample_collection
download_media (False) – whether to download the images or videos found in CVAT to the directory or filepaths in
data_path
if not already presentnum_workers (None) – a suggested number of threads to use when downloading media
occluded_attr (None) – an optional attribute name in which to store the occlusion information for all spatial labels
group_id_attr (None) – an optional attribute name in which to store the group id for labels
backend ("cvat") – the name of the CVAT backend to use
**kwargs – CVAT authentication credentials to pass to
CVATBackendConfig
-
class
fiftyone.utils.cvat.
CVATImageDatasetImporter
(dataset_dir=None, data_path=None, labels_path=None, include_all_data=False, shuffle=False, seed=None, max_samples=None)¶ Bases:
fiftyone.utils.data.importers.LabeledImageDatasetImporter
,fiftyone.utils.data.importers.ImportPathsMixin
Importer for CVAT image datasets stored on disk.
See this page for format details.
- Parameters
dataset_dir (None) – the dataset directory. If omitted,
data_path
and/orlabels_path
must be provideddata_path (None) –
an optional parameter that enables explicit control over the location of the media. Can be any of the following:
a folder name like
"data"
or"data/"
specifying a subfolder ofdataset_dir
where the media files residean absolute directory path where the media files reside. In this case, the
dataset_dir
has no effect on the location of the dataa filename like
"data.json"
specifying the filename of the JSON data manifest file indataset_dir
an absolute filepath specifying the location of the JSON data manifest. In this case,
dataset_dir
has no effect on the location of the dataa dict mapping filenames to absolute filepaths
If None, this parameter will default to whichever of
data/
ordata.json
exists in the dataset directorylabels_path (None) –
an optional parameter that enables explicit control over the location of the labels. Can be any of the following:
a filename like
"labels.xml"
specifying the location of the labels indataset_dir
an absolute filepath to the labels. In this case,
dataset_dir
has no effect on the location of the labels
If None, the parameter will default to
labels.xml
include_all_data (False) – whether to generate samples for all images in the data directory (True) rather than only creating samples for images with label entries (False)
shuffle (False) – whether to randomly shuffle the order in which the samples are imported
seed (None) – a random seed to use when shuffling
max_samples (None) – a maximum number of samples to import. By default, all samples are imported
Attributes:
Whether this importer produces a dataset info dictionary.
Whether this importer produces
fiftyone.core.metadata.ImageMetadata
instances for each image.The
fiftyone.core.labels.Label
class(es) returned by this importer.Methods:
setup
()Performs any necessary setup before importing the first sample in the dataset.
Returns the dataset info for the dataset.
close
(*args)Performs any necessary actions after the last sample has been imported.
-
property
has_dataset_info
¶ Whether this importer produces a dataset info dictionary.
-
property
has_image_metadata
¶ Whether this importer produces
fiftyone.core.metadata.ImageMetadata
instances for each image.
-
property
label_cls
¶ The
fiftyone.core.labels.Label
class(es) returned by this importer.This can be any of the following:
a
fiftyone.core.labels.Label
class. In this case, the importer is guaranteed to return labels of this typea list or tuple of
fiftyone.core.labels.Label
classes. In this case, the importer can produce a single label field of any of these typesa dict mapping keys to
fiftyone.core.labels.Label
classes. In this case, the importer will return label dictionaries with keys and value-types specified by this dictionary. Not all keys need be present in the imported labelsNone
. In this case, the importer makes no guarantees about the labels that it may return
-
setup
()¶ Performs any necessary setup before importing the first sample in the dataset.
This method is called when the importer’s context manager interface is entered,
DatasetImporter.__enter__()
.
-
get_dataset_info
()¶ Returns the dataset info for the dataset.
By convention, this method should be called after all samples in the dataset have been imported.
- Returns
a dict of dataset info
-
close
(*args)¶ Performs any necessary actions after the last sample has been imported.
This method is called when the importer’s context manager interface is exited,
DatasetImporter.__exit__()
.- Parameters
*args – the arguments to
DatasetImporter.__exit__()
-
class
fiftyone.utils.cvat.
CVATVideoDatasetImporter
(dataset_dir=None, data_path=None, labels_path=None, include_all_data=False, shuffle=False, seed=None, max_samples=None)¶ Bases:
fiftyone.utils.data.importers.LabeledVideoDatasetImporter
,fiftyone.utils.data.importers.ImportPathsMixin
Importer for CVAT video datasets stored on disk.
See this page for format details.
- Parameters
dataset_dir (None) – the dataset directory. If omitted,
data_path
and/orlabels_path
must be provideddata_path (None) –
an optional parameter that enables explicit control over the location of the media. Can be any of the following:
a folder name like
"data"
or"data/"
specifying a subfolder ofdataset_dir
where the media files residean absolute directory path where the media files reside. In this case, the
dataset_dir
has no effect on the location of the dataa filename like
"data.json"
specifying the filename of the JSON data manifest file indataset_dir
an absolute filepath specifying the location of the JSON data manifest. In this case,
dataset_dir
has no effect on the location of the dataa dict mapping filenames to absolute filepaths
If None, this parameter will default to whichever of
data/
ordata.json
exists in the dataset directorylabels_path (None) –
an optional parameter that enables explicit control over the location of the labels. Can be any of the following:
a folder name like
"labels"
or"labels/"
specifying the location of the labels indataset_dir
an absolute folder path to the labels. In this case,
dataset_dir
has no effect on the location of the labels
If None, the parameter will default to
labels/
include_all_data (False) – whether to generate samples for all videos in the data directory (True) rather than only creating samples for videos with label entries (False)
shuffle (False) – whether to randomly shuffle the order in which the samples are imported
seed (None) – a random seed to use when shuffling
max_samples (None) – a maximum number of samples to import. By default, all samples are imported
Attributes:
Whether this importer produces a dataset info dictionary.
Whether this importer produces
fiftyone.core.metadata.VideoMetadata
instances for each video.The
fiftyone.core.labels.Label
class(es) returned by this importer within the sample-level labels that it produces.The
fiftyone.core.labels.Label
class(es) returned by this importer within the frame labels that it produces.Methods:
setup
()Performs any necessary setup before importing the first sample in the dataset.
Returns the dataset info for the dataset.
close
(*args)Performs any necessary actions after the last sample has been imported.
-
property
has_dataset_info
¶ Whether this importer produces a dataset info dictionary.
-
property
has_video_metadata
¶ Whether this importer produces
fiftyone.core.metadata.VideoMetadata
instances for each video.
-
property
label_cls
¶ The
fiftyone.core.labels.Label
class(es) returned by this importer within the sample-level labels that it produces.This can be any of the following:
a
fiftyone.core.labels.Label
class. In this case, the importer is guaranteed to return sample-level labels of this typea list or tuple of
fiftyone.core.labels.Label
classes. In this case, the importer can produce a single sample-level label field of any of these typesa dict mapping keys to
fiftyone.core.labels.Label
classes. In this case, the importer will return sample-level label dictionaries with keys and value-types specified by this dictionary. Not all keys need be present in the imported labelsNone
. In this case, the importer makes no guarantees about the sample-level labels that it may return
-
property
frame_labels_cls
¶ The
fiftyone.core.labels.Label
class(es) returned by this importer within the frame labels that it produces.This can be any of the following:
a
fiftyone.core.labels.Label
class. In this case, the importer is guaranteed to return frame labels of this typea list or tuple of
fiftyone.core.labels.Label
classes. In this case, the importer can produce a single frame label field of any of these typesa dict mapping keys to
fiftyone.core.labels.Label
classes. In this case, the importer will return frame label dictionaries with keys and value-types specified by this dictionary. Not all keys need be present in each frameNone
. In this case, the importer makes no guarantees about the frame labels that it may return
-
setup
()¶ Performs any necessary setup before importing the first sample in the dataset.
This method is called when the importer’s context manager interface is entered,
DatasetImporter.__enter__()
.
-
get_dataset_info
()¶ Returns the dataset info for the dataset.
By convention, this method should be called after all samples in the dataset have been imported.
- Returns
a dict of dataset info
-
close
(*args)¶ Performs any necessary actions after the last sample has been imported.
This method is called when the importer’s context manager interface is exited,
DatasetImporter.__exit__()
.- Parameters
*args – the arguments to
DatasetImporter.__exit__()
-
class
fiftyone.utils.cvat.
CVATImageDatasetExporter
(export_dir=None, data_path=None, labels_path=None, export_media=None, rel_dir=None, abs_paths=False, image_format=None)¶ Bases:
fiftyone.utils.data.exporters.LabeledImageDatasetExporter
,fiftyone.utils.data.exporters.ExportPathsMixin
Exporter that writes CVAT image datasets to disk.
See this page for format details.
- Parameters
export_dir (None) – the directory to write the export. This has no effect if
data_path
andlabels_path
are absolute pathsdata_path (None) –
an optional parameter that enables explicit control over the location of the exported media. Can be any of the following:
a folder name like
"data"
or"data/"
specifying a subfolder ofexport_dir
in which to export the mediaan absolute directory path in which to export the media. In this case, the
export_dir
has no effect on the location of the dataa JSON filename like
"data.json"
specifying the filename of the manifest file inexport_dir
generated whenexport_media
is"manifest"
an absolute filepath specifying the location to write the JSON manifest file when
export_media
is"manifest"
. In this case,export_dir
has no effect on the location of the data
If None, the default value of this parameter will be chosen based on the value of the
export_media
parameterlabels_path (None) –
an optional parameter that enables explicit control over the location of the exported labels. Can be any of the following:
a filename like
"labels.xml"
specifying the location inexport_dir
in which to export the labelsan absolute filepath to which to export the labels. In this case, the
export_dir
has no effect on the location of the labels
If None, the labels will be exported into
export_dir
using the default filenameexport_media (None) –
controls how to export the raw media. The supported values are:
True
: copy all media files into the output directoryFalse
: don’t export media"move"
: move all media files into the output directory"symlink"
: create symlinks to the media files in the output directory"manifest"
: create adata.json
in the output directory that maps UUIDs used in the labels files to the filepaths of the source media, rather than exporting the actual media
If None, the default value of this parameter will be chosen based on the value of the
data_path
parameterrel_dir (None) – an optional relative directory to strip from each input filepath to generate a unique identifier for each image. When exporting media, this identifier is joined with
data_path
to generate an output path for each exported image. This argument allows for populating nested subdirectories that match the shape of the input paths. The path is converted to an absolute path (if necessary) viafiftyone.core.storage.normalize_path()
abs_paths (False) – whether to store absolute paths to the images in the exported labels
image_format (None) – the image format to use when writing in-memory images to disk. By default,
fiftyone.config.default_image_ext
is used
Attributes:
Whether this exporter requires
fiftyone.core.metadata.ImageMetadata
instances for each sample being exported.The
fiftyone.core.labels.Label
class(es) exported by this exporter.Methods:
setup
()Performs any necessary setup before exporting the first sample in the dataset.
log_collection
(sample_collection)Logs any relevant information about the
fiftyone.core.collections.SampleCollection
whose samples will be exported.export_sample
(image_or_path, labels[, metadata])Exports the given sample to the dataset.
close
(*args)Performs any necessary actions after the last sample has been exported.
-
property
requires_image_metadata
¶ Whether this exporter requires
fiftyone.core.metadata.ImageMetadata
instances for each sample being exported.
-
property
label_cls
¶ The
fiftyone.core.labels.Label
class(es) exported by this exporter.This can be any of the following:
a
fiftyone.core.labels.Label
class. In this case, the exporter directly exports labels of this typea list or tuple of
fiftyone.core.labels.Label
classes. In this case, the exporter can export a single label field of any of these typesa dict mapping keys to
fiftyone.core.labels.Label
classes. In this case, the exporter can handle label dictionaries with value-types specified by this dictionary. Not all keys need be present in the exported label dictsNone
. In this case, the exporter makes no guarantees about the labels that it can export
-
setup
()¶ Performs any necessary setup before exporting the first sample in the dataset.
This method is called when the exporter’s context manager interface is entered,
DatasetExporter.__enter__()
.
-
log_collection
(sample_collection)¶ Logs any relevant information about the
fiftyone.core.collections.SampleCollection
whose samples will be exported.Subclasses can optionally implement this method if their export format can record information such as the
fiftyone.core.collections.SampleCollection.info()
of the collection being exported.By convention, this method must be optional; i.e., if it is not called before the first call to
export_sample()
, then the exporter must make do without any information about thefiftyone.core.collections.SampleCollection
(which may not be available, for example, if the samples being exported are not stored in a collection).- Parameters
sample_collection – the
fiftyone.core.collections.SampleCollection
whose samples will be exported
-
export_sample
(image_or_path, labels, metadata=None)¶ Exports the given sample to the dataset.
- Parameters
image_or_path – an image or the path to the image on disk
label – an instance of
label_cls()
, or a dictionary mapping field names tofiftyone.core.labels.Label
instances, orNone
if the sample is unlabeledmetadata (None) – a
fiftyone.core.metadata.ImageMetadata
instance for the sample. Only required whenrequires_image_metadata()
isTrue
-
close
(*args)¶ Performs any necessary actions after the last sample has been exported.
This method is called when the exporter’s context manager interface is exited,
DatasetExporter.__exit__()
.- Parameters
*args – the arguments to
DatasetExporter.__exit__()
-
class
fiftyone.utils.cvat.
CVATVideoDatasetExporter
(export_dir=None, data_path=None, labels_path=None, export_media=None, rel_dir=None)¶ Bases:
fiftyone.utils.data.exporters.LabeledVideoDatasetExporter
,fiftyone.utils.data.exporters.ExportPathsMixin
Exporter that writes CVAT video datasets to disk.
See this page for format details.
- Parameters
export_dir (None) – the directory to write the export. This has no effect if
data_path
andlabels_path
are absolute pathsdata_path (None) –
an optional parameter that enables explicit control over the location of the exported media. Can be any of the following:
a folder name like
"data"
or"data/"
specifying a subfolder ofexport_dir
in which to export the mediaan absolute directory path in which to export the media. In this case, the
export_dir
has no effect on the location of the dataa JSON filename like
"data.json"
specifying the filename of the manifest file inexport_dir
generated whenexport_media
is"manifest"
an absolute filepath specifying the location to write the JSON manifest file when
export_media
is"manifest"
. In this case,export_dir
has no effect on the location of the data
If None, the default value of this parameter will be chosen based on the value of the
export_media
parameterlabels_path (None) –
an optional parameter that enables explicit control over the location of the exported labels. Can be any of the following:
a folder name like
"labels"
or"labels/"
specifying the location inexport_dir
in which to export the labelsan absolute filepath to which to export the labels. In this case, the
export_dir
has no effect on the location of the labels
If None, the labels will be exported into
export_dir
using the default folder nameexport_media (None) –
controls how to export the raw media. The supported values are:
True
: copy all media files into the output directoryFalse
: don’t export media"move"
: move all media files into the output directory"symlink"
: create symlinks to the media files in the output directory"manifest"
: create adata.json
in the output directory that maps UUIDs used in the labels files to the filepaths of the source media, rather than exporting the actual media
If None, the default value of this parameter will be chosen based on the value of the
data_path
parameterrel_dir (None) – an optional relative directory to strip from each input filepath to generate a unique identifier for each video. When exporting media, this identifier is joined with
data_path
to generate an output path for each exported video. This argument allows for populating nested subdirectories that match the shape of the input paths. The path is converted to an absolute path (if necessary) viafiftyone.core.storage.normalize_path()
Attributes:
Whether this exporter requires
fiftyone.core.metadata.VideoMetadata
instances for each sample being exported.The
fiftyone.core.labels.Label
class(es) that can be exported at the sample-level.The
fiftyone.core.labels.Label
class(es) that can be exported by this exporter at the frame-level.Methods:
setup
()Performs any necessary setup before exporting the first sample in the dataset.
log_collection
(sample_collection)Logs any relevant information about the
fiftyone.core.collections.SampleCollection
whose samples will be exported.export_sample
(video_path, _, frames[, metadata])Exports the given sample to the dataset.
close
(*args)Performs any necessary actions after the last sample has been exported.
-
property
requires_video_metadata
¶ Whether this exporter requires
fiftyone.core.metadata.VideoMetadata
instances for each sample being exported.
-
property
label_cls
¶ The
fiftyone.core.labels.Label
class(es) that can be exported at the sample-level.This can be any of the following:
a
fiftyone.core.labels.Label
class. In this case, the exporter directly exports sample-level labels of this typea list or tuple of
fiftyone.core.labels.Label
classes. In this case, the exporter can export a single sample-level label field of any of these typesa dict mapping keys to
fiftyone.core.labels.Label
classes. In this case, the exporter can export multiple label fields with value-types specified by this dictionary. Not all keys need be present in the exported sample-level labelsNone
. In this case, the exporter makes no guarantees about the sample-level labels that it can export
-
property
frame_labels_cls
¶ The
fiftyone.core.labels.Label
class(es) that can be exported by this exporter at the frame-level.This can be any of the following:
a
fiftyone.core.labels.Label
class. In this case, the exporter directly exports frame labels of this typea list or tuple of
fiftyone.core.labels.Label
classes. In this case, the exporter can export a single frame label field of any of these typesa dict mapping keys to
fiftyone.core.labels.Label
classes. In this case, the exporter can export multiple frame label fields with value-types specified by this dictionary. Not all keys need be present in the exported frame labelsNone
. In this case, the exporter makes no guarantees about the frame labels that it can export
-
setup
()¶ Performs any necessary setup before exporting the first sample in the dataset.
This method is called when the exporter’s context manager interface is entered,
DatasetExporter.__enter__()
.
-
log_collection
(sample_collection)¶ Logs any relevant information about the
fiftyone.core.collections.SampleCollection
whose samples will be exported.Subclasses can optionally implement this method if their export format can record information such as the
fiftyone.core.collections.SampleCollection.info()
of the collection being exported.By convention, this method must be optional; i.e., if it is not called before the first call to
export_sample()
, then the exporter must make do without any information about thefiftyone.core.collections.SampleCollection
(which may not be available, for example, if the samples being exported are not stored in a collection).- Parameters
sample_collection – the
fiftyone.core.collections.SampleCollection
whose samples will be exported
-
export_sample
(video_path, _, frames, metadata=None)¶ Exports the given sample to the dataset.
- Parameters
video_path – the path to a video on disk
label – an instance of
label_cls()
, or a dictionary mapping field names tofiftyone.core.labels.Label
instances, orNone
if the sample has no sample-level labelsframes – a dictionary mapping frame numbers to dictionaries that map field names to
fiftyone.core.labels.Label
instances, orNone
if the sample has no frame-level labelsmetadata (None) – a
fiftyone.core.metadata.VideoMetadata
instance for the sample. Only required whenrequires_video_metadata()
isTrue
-
close
(*args)¶ Performs any necessary actions after the last sample has been exported.
This method is called when the exporter’s context manager interface is exited,
DatasetExporter.__exit__()
.- Parameters
*args – the arguments to
DatasetExporter.__exit__()
-
class
fiftyone.utils.cvat.
CVATTaskLabels
(labels=None)¶ Bases:
object
Description of the labels in a CVAT image annotation task.
- Parameters
labels (None) –
a list of label dicts in the following format:
[ { "name": "car", "attributes": [ { "name": "type" "categories": ["coupe", "sedan", "truck"] }, ... } }, ... ]
Methods:
merge_task_labels
(task_labels)Merges the given
CVATTaskLabels
into this instance.Returns an
eta.core.image.ImageLabelsSchema
representation of the task labels.from_cvat_images
(cvat_images)Creates a
CVATTaskLabels
instance that describes the active schema of the given annotations.from_cvat_tracks
(cvat_tracks)Creates a
CVATTaskLabels
instance that describes the active schema of the given annotations.Creates a
CVATTaskLabels
instance from the<labels>
tag of a CVAT annotation XML file.from_schema
(schema)Creates a
CVATTaskLabels
instance from aneta.core.image.ImageLabelsSchema
.-
merge_task_labels
(task_labels)¶ Merges the given
CVATTaskLabels
into this instance.- Parameters
task_labels – a
CVATTaskLabels
-
to_schema
()¶ Returns an
eta.core.image.ImageLabelsSchema
representation of the task labels.Note that CVAT’s task labels schema does not distinguish between boxes, polylines, and keypoints, so the returned schema stores all annotations under the
"objects"
field.- Returns
an
eta.core.image.ImageLabelsSchema
-
classmethod
from_cvat_images
(cvat_images)¶ Creates a
CVATTaskLabels
instance that describes the active schema of the given annotations.- Parameters
cvat_images – a list of
CVATImage
instances- Returns
-
classmethod
from_cvat_tracks
(cvat_tracks)¶ Creates a
CVATTaskLabels
instance that describes the active schema of the given annotations.- Parameters
cvat_tracks – a list of
CVATTrack
instances- Returns
-
classmethod
from_labels_dict
(d)¶ Creates a
CVATTaskLabels
instance from the<labels>
tag of a CVAT annotation XML file.- Parameters
d – a dict representation of a
<labels>
tag- Returns
-
classmethod
from_schema
(schema)¶ Creates a
CVATTaskLabels
instance from aneta.core.image.ImageLabelsSchema
.- Parameters
schema – an
eta.core.image.ImageLabelsSchema
- Returns
-
class
fiftyone.utils.cvat.
CVATImage
(id, name, width, height, tags=None, boxes=None, polygons=None, polylines=None, points=None, subset=None)¶ Bases:
object
An annotated image in CVAT image format.
- Parameters
id – the ID of the image
name – the filename of the image
width – the width of the image, in pixels
height – the height of the image, in pixels
tags (None) – a list of
CVATImageTag
instancesboxes (None) – a list of
CVATImageBox
instancespolygons (None) – a list of
CVATImagePolygon
instancespolylines (None) – a list of
CVATImagePolyline
instancespoints (None) – a list of
CVATImagePoints
instancessubset (None) – the project subset of the image, if any
Attributes:
Whether this image has tags.
Whether this image has 2D boxes.
Whether this image has polygons or polylines.
Whether this image has keypoints.
Methods:
Returns an iterator over the annotations in the image.
Returns a
fiftyone.core.metadata.ImageMetadata
instance for the annotations.Returns
fiftyone.core.labels.Label
representations of the annotations.from_labels
(labels, metadata)Creates a
CVATImage
from a dictionary of labels.Creates a
CVATImage
from an<image>
tag of a CVAT image annotations XML file.Whether this image has tags.
-
property
has_boxes
¶ Whether this image has 2D boxes.
-
property
has_polylines
¶ Whether this image has polygons or polylines.
-
property
has_points
¶ Whether this image has keypoints.
-
iter_annos
()¶ Returns an iterator over the annotations in the image.
- Returns
an iterator that emits
CVATImageAnno
instances
-
get_image_metadata
()¶ Returns a
fiftyone.core.metadata.ImageMetadata
instance for the annotations.- Returns
-
to_labels
()¶ Returns
fiftyone.core.labels.Label
representations of the annotations.- Returns
a dict mapping field keys to
fiftyone.core.labels.Label
instances
-
classmethod
from_labels
(labels, metadata)¶ Creates a
CVATImage
from a dictionary of labels.- Parameters
labels – a dict mapping keys to
fiftyone.core.labels.Label
instancesmetadata – a
fiftyone.core.metadata.ImageMetadata
for the image
- Returns
-
class
fiftyone.utils.cvat.
HasCVATPoints
(points)¶ Bases:
object
Mixin for CVAT annotations that store a list of
(x, y)
pixel coordinates.-
points
¶ a list of
(x, y)
pixel coordinates defining points
Attributes:
-
property
points_str
¶
-
-
class
fiftyone.utils.cvat.
CVATImageAnno
(occluded=None, attributes=None)¶ Bases:
object
Mixin for annotations in CVAT image format.
- Parameters
occluded (None) – whether the object is occluded
attributes (None) – a list of
CVATAttribute
instances
-
class
fiftyone.utils.cvat.
CVATImageTag
(label, attributes=None)¶ Bases:
fiftyone.utils.cvat.CVATImageAnno
A tag in CVAT image format.
- Parameters
label – the tag string
attributes (None) – a list of
CVATAttribute
instances
Methods:
Returns a
fiftyone.core.labels.Classification
representation of the tag.from_classification
(classification)Creates a
CVATImageTag
from afiftyone.core.labels.Classification
.Creates a
CVATImageTag
from a<tag>
tag of a CVAT image annotation XML file.-
to_classification
()¶ Returns a
fiftyone.core.labels.Classification
representation of the tag.- Returns
-
classmethod
from_classification
(classification)¶ Creates a
CVATImageTag
from afiftyone.core.labels.Classification
.- Parameters
classification – a
fiftyone.core.labels.Classification
- Returns
-
classmethod
from_tag_dict
(d)¶ Creates a
CVATImageTag
from a<tag>
tag of a CVAT image annotation XML file.- Parameters
d – a dict representation of a
<tag>
tag- Returns
-
class
fiftyone.utils.cvat.
CVATImageBox
(label, xtl, ytl, xbr, ybr, occluded=None, attributes=None)¶ Bases:
fiftyone.utils.cvat.CVATImageAnno
An object bounding box in CVAT image format.
- Parameters
label – the object label string
xtl – the top-left x-coordinate of the box, in pixels
ytl – the top-left y-coordinate of the box, in pixels
xbr – the bottom-right x-coordinate of the box, in pixels
ybr – the bottom-right y-coordinate of the box, in pixels
occluded (None) – whether the object is occluded
attributes (None) – a list of
CVATAttribute
instances
Methods:
to_detection
(frame_size)Returns a
fiftyone.core.labels.Detection
representation of the box.from_detection
(detection, metadata)Creates a
CVATImageBox
from afiftyone.core.labels.Detection
.Creates a
CVATImageBox
from a<box>
tag of a CVAT image annotation XML file.-
to_detection
(frame_size)¶ Returns a
fiftyone.core.labels.Detection
representation of the box.- Parameters
frame_size – the
(width, height)
of the image- Returns
-
classmethod
from_detection
(detection, metadata)¶ Creates a
CVATImageBox
from afiftyone.core.labels.Detection
.- Parameters
detection – a
fiftyone.core.labels.Detection
metadata – a
fiftyone.core.metadata.ImageMetadata
for the image
- Returns
-
classmethod
from_box_dict
(d)¶ Creates a
CVATImageBox
from a<box>
tag of a CVAT image annotation XML file.- Parameters
d – a dict representation of a
<box>
tag- Returns
-
class
fiftyone.utils.cvat.
CVATImagePolygon
(label, points, occluded=None, attributes=None)¶ Bases:
fiftyone.utils.cvat.CVATImageAnno
,fiftyone.utils.cvat.HasCVATPoints
A polygon in CVAT image format.
- Parameters
label – the polygon label string
points – a list of
(x, y)
pixel coordinates defining the vertices of the polygonoccluded (None) – whether the polygon is occluded
attributes (None) – a list of
CVATAttribute
instances
Methods:
to_polyline
(frame_size)Returns a
fiftyone.core.labels.Polyline
representation of the polygon.from_polyline
(polyline, metadata)Creates a
CVATImagePolygon
from afiftyone.core.labels.Polyline
.Creates a
CVATImagePolygon
from a<polygon>
tag of a CVAT image annotation XML file.Attributes:
-
to_polyline
(frame_size)¶ Returns a
fiftyone.core.labels.Polyline
representation of the polygon.- Parameters
frame_size – the
(width, height)
of the image- Returns
-
classmethod
from_polyline
(polyline, metadata)¶ Creates a
CVATImagePolygon
from afiftyone.core.labels.Polyline
.If the
fiftyone.core.labels.Polyline
is composed of multiple shapes, oneCVATImagePolygon
per shape will be generated.- Parameters
polyline – a
fiftyone.core.labels.Polyline
metadata – a
fiftyone.core.metadata.ImageMetadata
for the image
- Returns
a list of
CVATImagePolygon
instances
-
classmethod
from_polygon_dict
(d)¶ Creates a
CVATImagePolygon
from a<polygon>
tag of a CVAT image annotation XML file.- Parameters
d – a dict representation of a
<polygon>
tag- Returns
-
property
points_str
¶
-
class
fiftyone.utils.cvat.
CVATImagePolyline
(label, points, occluded=None, attributes=None)¶ Bases:
fiftyone.utils.cvat.CVATImageAnno
,fiftyone.utils.cvat.HasCVATPoints
A polyline in CVAT image format.
- Parameters
label – the polyline label string
points – a list of
(x, y)
pixel coordinates defining the vertices of the polylineoccluded (None) – whether the polyline is occluded
attributes (None) – a list of
CVATAttribute
instances
Methods:
to_polyline
(frame_size)Returns a
fiftyone.core.labels.Polyline
representation of the polyline.from_polyline
(polyline, metadata)Creates a
CVATImagePolyline
from afiftyone.core.labels.Polyline
.Creates a
CVATImagePolyline
from a<polyline>
tag of a CVAT image annotation XML file.Attributes:
-
to_polyline
(frame_size)¶ Returns a
fiftyone.core.labels.Polyline
representation of the polyline.- Parameters
frame_size – the
(width, height)
of the image- Returns
-
classmethod
from_polyline
(polyline, metadata)¶ Creates a
CVATImagePolyline
from afiftyone.core.labels.Polyline
.If the
fiftyone.core.labels.Polyline
is composed of multiple shapes, oneCVATImagePolyline
per shape will be generated.- Parameters
polyline – a
fiftyone.core.labels.Polyline
metadata – a
fiftyone.core.metadata.ImageMetadata
for the image
- Returns
a list of
CVATImagePolyline
instances
-
classmethod
from_polyline_dict
(d)¶ Creates a
CVATImagePolyline
from a<polyline>
tag of a CVAT image annotation XML file.- Parameters
d – a dict representation of a
<polyline>
tag- Returns
-
property
points_str
¶
-
class
fiftyone.utils.cvat.
CVATImagePoints
(label, points, occluded=None, attributes=None)¶ Bases:
fiftyone.utils.cvat.CVATImageAnno
,fiftyone.utils.cvat.HasCVATPoints
A set of keypoints in CVAT image format.
- Parameters
label – the keypoints label string
points – a list of
(x, y)
pixel coordinates defining the vertices of the keypointsoccluded (None) – whether the keypoints are occluded
attributes (None) – a list of
CVATAttribute
instances
Methods:
to_keypoint
(frame_size)Returns a
fiftyone.core.labels.Keypoint
representation of the points.from_keypoint
(keypoint, metadata)Creates a
CVATImagePoints
from afiftyone.core.labels.Keypoint
.Creates a
CVATImagePoints
from a<points>
tag of a CVAT image annotation XML file.Attributes:
-
to_keypoint
(frame_size)¶ Returns a
fiftyone.core.labels.Keypoint
representation of the points.- Parameters
frame_size – the
(width, height)
of the image- Returns
-
classmethod
from_keypoint
(keypoint, metadata)¶ Creates a
CVATImagePoints
from afiftyone.core.labels.Keypoint
.- Parameters
keypoint – a
fiftyone.core.labels.Keypoint
metadata – a
fiftyone.core.metadata.ImageMetadata
for the image
- Returns
-
classmethod
from_points_dict
(d)¶ Creates a
CVATImagePoints
from a<points>
tag of a CVAT image annotation XML file.- Parameters
d – a dict representation of a
<points>
tag- Returns
-
property
points_str
¶
-
class
fiftyone.utils.cvat.
CVATTrack
(id, label, width, height, boxes=None, polygons=None, polylines=None, points=None)¶ Bases:
object
An annotation track in CVAT video format.
- Parameters
id – the ID of the track
label – the label for the track
width – the width of the video frames, in pixels
height – the height of the video frames, in pixels
boxes (None) – a dict mapping frame numbers to
CVATVideoBox
instancespolygons (None) – a dict mapping frame numbers to
CVATVideoPolygon
instancespolylines (None) – a dict mapping frame numbers to
CVATVideoPolyline
instancespoints (None) – a dict mapping frame numbers to
CVATVideoPoints
instances
Attributes:
Whether this track has 2D boxes.
Whether this track has polygons or polylines.
Whether this track has keypoints.
Methods:
Returns an iterator over the annotations in the track.
Returns
fiftyone.core.labels.Label
representations of the annotations.from_labels
(id, labels, frame_size)Creates a
CVATTrack
from a dictionary of labels.from_track_dict
(d, frame_size)Creates a
CVATTrack
from a<track>
tag of a CVAT video annotation XML file.-
property
has_boxes
¶ Whether this track has 2D boxes.
-
property
has_polylines
¶ Whether this track has polygons or polylines.
-
property
has_points
¶ Whether this track has keypoints.
-
iter_annos
()¶ Returns an iterator over the annotations in the track.
- Returns
an iterator that emits
CVATVideoAnno
instances
-
to_labels
()¶ Returns
fiftyone.core.labels.Label
representations of the annotations.- Returns
a dict mapping frame numbers to
fiftyone.core.labels.Label
instances
-
classmethod
from_labels
(id, labels, frame_size)¶ Creates a
CVATTrack
from a dictionary of labels.- Parameters
id – the ID of the track
labels – a dict mapping frame numbers to
fiftyone.core.labels.Label
instancesframe_size – the
(width, height)
of the video frames
- Returns
-
class
fiftyone.utils.cvat.
CVATVideoAnno
(outside=None, occluded=None, keyframe=None, attributes=None)¶ Bases:
object
Mixin for annotations in CVAT video format.
- Parameters
outside (None) – whether the object is outside (invisible)
occluded (None) – whether the object is occluded
keyframe (None) – whether the frame is a keyframe
attributes (None) – a list of
CVATAttribute
instances
-
class
fiftyone.utils.cvat.
CVATVideoBox
(frame, label, xtl, ytl, xbr, ybr, outside=None, occluded=None, keyframe=None, attributes=None)¶ Bases:
fiftyone.utils.cvat.CVATVideoAnno
An object bounding box in CVAT video format.
- Parameters
frame – the 0-based frame number
label – the object label string
xtl – the top-left x-coordinate of the box, in pixels
ytl – the top-left y-coordinate of the box, in pixels
xbr – the bottom-right x-coordinate of the box, in pixels
ybr – the bottom-right y-coordinate of the box, in pixels
outside (None) – whether the object is outside (invisible)
occluded (None) – whether the object is occluded
keyframe (None) – whether the frame is a keyframe
attributes (None) – a list of
CVATAttribute
instances
Methods:
to_detection
(frame_size)Returns a
fiftyone.core.labels.Detection
representation of the box.from_detection
(frame_number, detection, …)Creates a
CVATVideoBox
from afiftyone.core.labels.Detection
.from_box_dict
(label, d)Creates a
CVATVideoBox
from a<box>
tag of a CVAT video annotation XML file.-
to_detection
(frame_size)¶ Returns a
fiftyone.core.labels.Detection
representation of the box.- Parameters
frame_size – the
(width, height)
of the video frames- Returns
-
classmethod
from_detection
(frame_number, detection, frame_size)¶ Creates a
CVATVideoBox
from afiftyone.core.labels.Detection
.- Parameters
frame_number – the frame number
detection – a
fiftyone.core.labels.Detection
frame_size – the
(width, height)
of the video frames
- Returns
-
classmethod
from_box_dict
(label, d)¶ Creates a
CVATVideoBox
from a<box>
tag of a CVAT video annotation XML file.- Parameters
label – the object label
d – a dict representation of a
<box>
tag
- Returns
-
class
fiftyone.utils.cvat.
CVATVideoPolygon
(frame, label, points, outside=None, occluded=None, keyframe=None, attributes=None)¶ Bases:
fiftyone.utils.cvat.CVATVideoAnno
,fiftyone.utils.cvat.HasCVATPoints
A polygon in CVAT video format.
- Parameters
frame – the 0-based frame number
label – the polygon label string
points – a list of
(x, y)
pixel coordinates defining the vertices of the polygonoutside (None) – whether the polygon is outside (invisible)
occluded (None) – whether the polygon is occluded
keyframe (None) – whether the frame is a keyframe
attributes (None) – a list of
CVATAttribute
instances
Methods:
to_polyline
(frame_size)Returns a
fiftyone.core.labels.Polyline
representation of the polygon.from_polyline
(frame_number, polyline, frame_size)Creates a
CVATVideoPolygon
from afiftyone.core.labels.Polyline
.from_polygon_dict
(label, d)Creates a
CVATVideoPolygon
from a<polygon>
tag of a CVAT video annotation XML file.Attributes:
-
to_polyline
(frame_size)¶ Returns a
fiftyone.core.labels.Polyline
representation of the polygon.- Parameters
frame_size – the
(width, height)
of the video frames- Returns
-
classmethod
from_polyline
(frame_number, polyline, frame_size)¶ Creates a
CVATVideoPolygon
from afiftyone.core.labels.Polyline
.- Parameters
frame_number – the frame number
polyline – a
fiftyone.core.labels.Polyline
frame_size – the
(width, height)
of the video frames
- Returns
-
classmethod
from_polygon_dict
(label, d)¶ Creates a
CVATVideoPolygon
from a<polygon>
tag of a CVAT video annotation XML file.- Parameters
label – the object label
d – a dict representation of a
<polygon>
tag
- Returns
-
property
points_str
¶
-
class
fiftyone.utils.cvat.
CVATVideoPolyline
(frame, label, points, outside=None, occluded=None, keyframe=None, attributes=None)¶ Bases:
fiftyone.utils.cvat.CVATVideoAnno
,fiftyone.utils.cvat.HasCVATPoints
A polyline in CVAT video format.
- Parameters
frame – the 0-based frame number
label – the polyline label string
points – a list of
(x, y)
pixel coordinates defining the vertices of the polylineoutside (None) – whether the polyline is outside (invisible)
occluded (None) – whether the polyline is occluded
keyframe (None) – whether the frame is a keyframe
attributes (None) – a list of
CVATAttribute
instances
Methods:
to_polyline
(frame_size)Returns a
fiftyone.core.labels.Polyline
representation of the polyline.from_polyline
(frame_number, polyline, frame_size)Creates a
CVATVideoPolyline
from afiftyone.core.labels.Polyline
.from_polyline_dict
(label, d)Creates a
CVATVideoPolyline
from a<polyline>
tag of a CVAT video annotation XML file.Attributes:
-
to_polyline
(frame_size)¶ Returns a
fiftyone.core.labels.Polyline
representation of the polyline.- Parameters
frame_size – the
(width, height)
of the video frames- Returns
-
classmethod
from_polyline
(frame_number, polyline, frame_size)¶ Creates a
CVATVideoPolyline
from afiftyone.core.labels.Polyline
.- Parameters
frame_number – the frame number
polyline – a
fiftyone.core.labels.Polyline
frame_size – the
(width, height)
of the video frames
- Returns
-
classmethod
from_polyline_dict
(label, d)¶ Creates a
CVATVideoPolyline
from a<polyline>
tag of a CVAT video annotation XML file.- Parameters
label – the object label
d – a dict representation of a
<polyline>
tag
- Returns
-
property
points_str
¶
-
class
fiftyone.utils.cvat.
CVATVideoPoints
(frame, label, points, outside=None, occluded=None, keyframe=None, attributes=None)¶ Bases:
fiftyone.utils.cvat.CVATVideoAnno
,fiftyone.utils.cvat.HasCVATPoints
A set of keypoints in CVAT video format.
- Parameters
frame – the 0-based frame number
label – the keypoints label string
points – a list of
(x, y)
pixel coordinates defining the keypointsoutside (None) – whether the keypoints is outside (invisible)
occluded (None) – whether the keypoints are occluded
keyframe (None) – whether the frame is a keyframe
attributes (None) – a list of
CVATAttribute
instances
Methods:
to_keypoint
(frame_size)Returns a
fiftyone.core.labels.Keypoint
representation of the points.from_keypoint
(frame_number, keypoint, frame_size)Creates a
CVATVideoPoints
from afiftyone.core.labels.Keypoint
.from_points_dict
(label, d)Creates a
CVATVideoPoints
from a<points>
tag of a CVAT video annotation XML file.Attributes:
-
to_keypoint
(frame_size)¶ Returns a
fiftyone.core.labels.Keypoint
representation of the points.- Parameters
frame_size – the
(width, height)
of the video frames- Returns
-
classmethod
from_keypoint
(frame_number, keypoint, frame_size)¶ Creates a
CVATVideoPoints
from afiftyone.core.labels.Keypoint
.- Parameters
frame_number – the frame number
keypoint – a
fiftyone.core.labels.Keypoint
frame_size – the
(width, height)
of the video frames
- Returns
-
classmethod
from_points_dict
(label, d)¶ Creates a
CVATVideoPoints
from a<points>
tag of a CVAT video annotation XML file.- Parameters
label – the object label
d – a dict representation of a
<points>
tag
- Returns
-
property
points_str
¶
-
class
fiftyone.utils.cvat.
CVATAttribute
(name, value)¶ Bases:
object
An attribute in CVAT image format.
- Parameters
name – the attribute name
value – the attribute value
Methods:
Returns an
eta.core.data.Attribute
representation of the attribute.Returns a
fiftyone.core.labels.Attribute
representation of the attribute.-
to_eta_attribute
()¶ Returns an
eta.core.data.Attribute
representation of the attribute.- Returns
an
eta.core.data.Attribute
-
to_attribute
()¶ Returns a
fiftyone.core.labels.Attribute
representation of the attribute. :returns: afiftyone.core.labels.Attribute
-
class
fiftyone.utils.cvat.
CVATImageAnnotationWriter
¶ Bases:
object
Class for writing annotations in CVAT image format.
See this page for format details.
Methods:
write
(cvat_task_labels, cvat_images, xml_path)Writes the annotations to disk.
-
write
(cvat_task_labels, cvat_images, xml_path, id=None, name=None)¶ Writes the annotations to disk.
- Parameters
cvat_task_labels – a
CVATTaskLabels
instancecvat_images – a list of
CVATImage
instancesxml_path – the path to write the annotations XML file
id (None) – an ID for the task
name (None) – a name for the task
-
-
class
fiftyone.utils.cvat.
CVATVideoAnnotationWriter
¶ Bases:
object
Class for writing annotations in CVAT video format.
See this page for format details.
Methods:
write
(cvat_task_labels, cvat_tracks, …[, …])Writes the annotations to disk.
-
write
(cvat_task_labels, cvat_tracks, metadata, xml_path, id=None, name=None)¶ Writes the annotations to disk.
- Parameters
cvat_task_labels – a
CVATTaskLabels
instancecvat_tracks – a list of
CVATTrack
instancesmetadata – the
fiftyone.core.metadata.VideoMetadata
instance for the videoxml_path – the path to write the annotations XML file
id (None) – an ID for the task
name (None) – a name for the task
-
-
class
fiftyone.utils.cvat.
CVATBackendConfig
(name, label_schema, media_field='filepath', url=None, username=None, email=None, password=None, headers=None, task_size=None, segment_size=None, image_quality=75, use_cache=True, use_zip_chunks=True, chunk_size=None, task_assignee=None, job_assignees=None, job_reviewers=None, project_name=None, project_id=None, task_name=None, occluded_attr=None, group_id_attr=None, issue_tracker=None, organization=None, frame_start=None, frame_stop=None, frame_step=None, **kwargs)¶ Bases:
fiftyone.utils.annotations.AnnotationBackendConfig
Class for configuring
CVATBackend
instances.- Parameters
name – the name of the backend
label_schema – a dictionary containing the description of label fields, classes and attribute to annotate
media_field ("filepath") – string field name containing the paths to media files on disk to upload
url (None) – the url of the CVAT server
username (None) – the CVAT username
email (None) – the CVAT email
password (None) – the CVAT password
headers (None) – an optional dict of headers to add to all CVAT API requests
task_size (None) – an optional maximum number of images to upload per task. Videos are always uploaded one per task
segment_size (None) – maximum number of images per job. Not applicable to videos
image_quality (75) – an int in
[0, 100]
determining the image quality to upload to CVATuse_cache (True) – whether to use a cache when uploading data. Using a cache reduces task creation time as data will be processed on-the-fly and stored in the cache when requested
use_zip_chunks (True) – when annotating videos, whether to upload video frames in smaller chunks. Setting this option to
False
may result in reduced video quality in CVAT due to size limitations on ZIP files that can be uploaded to CVATchunk_size (None) – the number of frames to upload per ZIP chunk
task_assignee (None) – the username(s) to which the task(s) were assigned. This argument can be a list of usernames when annotating videos as each video is uploaded to a separate task
job_assignees (None) – a list of usernames to which jobs were assigned
job_reviewers (None) – a list of usernames to which job reviews were assigned. Only available in CVAT v1 servers
project_name (None) – an optional project name to which to upload the created CVAT task. If a project with this name is found, it will be used, otherwise a new project with this name is created. By default, no project is used
project_id (None) – an optional ID of an existing CVAT project to which to upload the annotation tasks. By default, no project is used
task_name (None) – an optional task name to use for the created CVAT task
occluded_attr (None) – an optional attribute name containing existing occluded values and/or in which to store downloaded occluded values for all objects in the annotation run
group_id_attr (None) – an optional attribute name containing existing group ids and/or in which to store downloaded group ids for all objects in the annotation run
issue_tracker (None) – URL(s) of an issue tracker to link to the created task(s). This argument can be a list of URLs when annotating videos or when using
task_size
and generating multiple tasksorganization (None) – the name of the organization to use when sending requests to CVAT
frame_start (None) –
nonnegative integer(s) defining the first frame of videos to upload when creating video tasks. Supported values are:
integer
: the first frame to upload for each videolist
: a list of first frame integers corresponding to videos in the given samplesdict
: a dictionary mapping sample filepaths to first frame integers to use for the corresponding videos
frame_stop (None) –
nonnegative integer(s) defining the last frame of videos to upload when creating video tasks. Supported values are:
integer
: the last frame to upload for each videolist
: a list of last frame integers corresponding to videos in the given samplesdict
: a dictionary mapping sample filepaths to last frame integers to use for the corresponding videos
frame_step (None) –
positive integer(s) defining which frames to sample when creating video tasks. Supported values are:
integer
: the frame step to apply to each video tasklist
: a list of frame step integers corresponding to videos in the given samplesdict
: a dictionary mapping sample filepaths to frame step integers to use for the corresponding videos
Note that this argument cannot be provided when uploading existing tracks
Attributes:
The fully-qualified name of this
BaseRunConfig
class.The name of the annotation backend.
The
BaseRun
class associated with this config.The type of run.
Methods:
load_credentials
([url, username, password, …])Loads any necessary credentials from the given keyword arguments or the relevant FiftyOne config.
Returns the list of class attributes that will be serialized by
serialize()
.base_config_cls
(type)Returns the config class for the given run type.
build
()Builds the
BaseRun
instance associated with this config.builder
()Returns a ConfigBuilder instance for this class.
copy
()Returns a deep copy of the object.
custom_attributes
([dynamic, private])Returns a customizable list of class attributes.
default
()Returns the default config instance.
from_dict
(d)Constructs a
BaseRunConfig
from a serialized JSON dict representation of it.from_json
(path, *args, **kwargs)Constructs a Serializable object from a JSON file.
from_kwargs
(**kwargs)Constructs a Config object from keyword arguments.
from_str
(s, *args, **kwargs)Constructs a Serializable object from a JSON string.
Returns the fully-qualified class name string of this object.
Loads the default config instance from file.
parse_array
(d, key[, default])Parses a raw array attribute.
parse_bool
(d, key[, default])Parses a boolean value.
parse_categorical
(d, key, choices[, default])Parses a categorical JSON field, which must take a value from among the given choices.
parse_dict
(d, key[, default])Parses a dictionary attribute.
parse_int
(d, key[, default])Parses an integer attribute.
parse_mutually_exclusive_fields
(fields)Parses a mutually exclusive dictionary of pre-parsed fields, which must contain exactly one field with a truthy value.
parse_number
(d, key[, default])Parses a number attribute.
parse_object
(d, key, cls[, default])Parses an object attribute.
parse_object_array
(d, key, cls[, default])Parses an array of objects.
parse_object_dict
(d, key, cls[, default])Parses a dictionary whose values are objects.
parse_path
(d, key[, default])Parses a path attribute.
parse_raw
(d, key[, default])Parses a raw (arbitrary) JSON field.
parse_string
(d, key[, default])Parses a string attribute.
serialize
(*args, **kwargs)Serializes the object into a dictionary.
to_str
([pretty_print])Returns a string representation of this object.
validate_all_or_nothing_fields
(fields)Validates a dictionary of pre-parsed fields checking that either all or none of the fields have a truthy value.
write_json
(path[, pretty_print])Serializes the object and writes it to disk.
-
property
username
¶
-
property
email
¶
-
property
password
¶
-
property
headers
¶
-
load_credentials
(url=None, username=None, password=None, email=None, headers=None)¶ Loads any necessary credentials from the given keyword arguments or the relevant FiftyOne config.
- Parameters
**kwargs – subclass-specific credentials
-
attributes
()¶ Returns the list of class attributes that will be serialized by
serialize()
.- Returns
a list of attributes
-
static
base_config_cls
(type)¶ Returns the config class for the given run type.
- Parameters
type – a
BaseRunConfig.type
- Returns
a
BaseRunConfig
subclass
-
build
()¶ Builds the
BaseRun
instance associated with this config.- Returns
a
BaseRun
instance
-
classmethod
builder
()¶ Returns a ConfigBuilder instance for this class.
-
property
cls
¶ The fully-qualified name of this
BaseRunConfig
class.
-
copy
()¶ Returns a deep copy of the object.
- Returns
a Serializable instance
-
custom_attributes
(dynamic=False, private=False)¶ Returns a customizable list of class attributes.
By default, all attributes in vars(self) are returned, minus private attributes (those starting with “_”).
- Parameters
dynamic – whether to include dynamic properties, e.g., those defined by getter/setter methods or the @property decorator. By default, this is False
private – whether to include private properties, i.e., those starting with “_”. By default, this is False
- Returns
a list of class attributes
-
classmethod
default
()¶ Returns the default config instance.
By default, this method instantiates the class from an empty dictionary, which will only succeed if all attributes are optional. Otherwise, subclasses should override this method to provide the desired default configuration.
-
classmethod
from_dict
(d)¶ Constructs a
BaseRunConfig
from a serialized JSON dict representation of it.- Parameters
d – a JSON dict
- Returns
a
BaseRunConfig
-
classmethod
from_json
(path, *args, **kwargs)¶ Constructs a Serializable object from a JSON file.
Subclasses may override this method, but, by default, this method simply reads the JSON and calls from_dict(), which subclasses must implement.
- Parameters
path – the path to the JSON file on disk
*args – optional positional arguments for self.from_dict()
**kwargs – optional keyword arguments for self.from_dict()
- Returns
an instance of the Serializable class
-
classmethod
from_kwargs
(**kwargs)¶ Constructs a Config object from keyword arguments.
- Parameters
**kwargs – keyword arguments that define the fields expected by cls
- Returns
an instance of cls
-
classmethod
from_str
(s, *args, **kwargs)¶ Constructs a Serializable object from a JSON string.
Subclasses may override this method, but, by default, this method simply parses the string and calls from_dict(), which subclasses must implement.
- Parameters
s – a JSON string representation of a Serializable object
*args – optional positional arguments for self.from_dict()
**kwargs – optional keyword arguments for self.from_dict()
- Returns
an instance of the Serializable class
-
classmethod
get_class_name
()¶ Returns the fully-qualified class name string of this object.
-
classmethod
load_default
()¶ Loads the default config instance from file.
Subclasses must implement this method if they intend to support default instances.
-
property
method
¶ The name of the annotation backend.
-
static
parse_array
(d, key, default=<eta.core.config.NoDefault object>)¶ Parses a raw array attribute.
- Parameters
d – a JSON dictionary
key – the key to parse
default – a default list to return if key is not present
- Returns
a list of raw (untouched) values
- Raises
ConfigError – if the field value was the wrong type or no default value was provided and the key was not found in the dictionary
-
static
parse_bool
(d, key, default=<eta.core.config.NoDefault object>)¶ Parses a boolean value.
- Parameters
d – a JSON dictionary
key – the key to parse
default – a default bool to return if key is not present
- Returns
True/False
- Raises
ConfigError – if the field value was the wrong type or no default value was provided and the key was not found in the dictionary
-
static
parse_categorical
(d, key, choices, default=<eta.core.config.NoDefault object>)¶ Parses a categorical JSON field, which must take a value from among the given choices.
- Parameters
d – a JSON dictionary
key – the key to parse
choices – either an iterable of possible values or an enum-like class whose attributes define the possible values
default – a default value to return if key is not present
- Returns
the raw (untouched) value of the given field, which is equal to a value from choices
- Raises
ConfigError – if the key was present in the dictionary but its value was not an allowed choice, or if no default value was provided and the key was not found in the dictionary
-
static
parse_dict
(d, key, default=<eta.core.config.NoDefault object>)¶ Parses a dictionary attribute.
- Parameters
d – a JSON dictionary
key – the key to parse
default – a default dict to return if key is not present
- Returns
a dictionary
- Raises
ConfigError – if the field value was the wrong type or no default value was provided and the key was not found in the dictionary
-
static
parse_int
(d, key, default=<eta.core.config.NoDefault object>)¶ Parses an integer attribute.
- Parameters
d – a JSON dictionary
key – the key to parse
default – a default integer value to return if key is not present
- Returns
an int
- Raises
ConfigError – if the field value was the wrong type or no default value was provided and the key was not found in the dictionary
-
static
parse_mutually_exclusive_fields
(fields)¶ Parses a mutually exclusive dictionary of pre-parsed fields, which must contain exactly one field with a truthy value.
- Parameters
fields – a dictionary of pre-parsed fields
- Returns
the (field, value) that was set
- Raises
ConfigError – if zero or more than one truthy value was found
-
static
parse_number
(d, key, default=<eta.core.config.NoDefault object>)¶ Parses a number attribute.
- Parameters
d – a JSON dictionary
key – the key to parse
default – a default numeric value to return if key is not present
- Returns
a number (e.g. int, float)
- Raises
ConfigError – if the field value was the wrong type or no default value was provided and the key was not found in the dictionary
-
static
parse_object
(d, key, cls, default=<eta.core.config.NoDefault object>)¶ Parses an object attribute.
The value of d[key] can be either an instance of cls or a serialized dict from an instance of cls.
- Parameters
d – a JSON dictionary
key – the key to parse
cls – the class of d[key]
default – a default cls instance to return if key is not present
- Returns
an instance of cls
- Raises
ConfigError – if the field value was the wrong type or no default value was provided and the key was not found in the dictionary
-
static
parse_object_array
(d, key, cls, default=<eta.core.config.NoDefault object>)¶ Parses an array of objects.
The values in d[key] can be either instances of cls or serialized dicts from instances of cls.
- Parameters
d – a JSON dictionary
key – the key to parse
cls – the class of the elements of list d[key]
default – the default list to return if key is not present
- Returns
a list of cls instances
- Raises
ConfigError – if the field value was the wrong type or no default value was provided and the key was not found in the dictionary
-
static
parse_object_dict
(d, key, cls, default=<eta.core.config.NoDefault object>)¶ Parses a dictionary whose values are objects.
The values in d[key] can be either instances of cls or serialized dicts from instances of cls.
- Parameters
d – a JSON dictionary
key – the key to parse
cls – the class of the values of dictionary d[key]
default – the default dict of cls instances to return if key is not present
- Returns
a dictionary whose values are cls instances
- Raises
ConfigError – if the field value was the wrong type or no default value was provided and the key was not found in the dictionary
-
static
parse_path
(d, key, default=<eta.core.config.NoDefault object>)¶ Parses a path attribute.
The path is converted to an absolute path if necessary via
os.path.abspath(os.path.expanduser(value))
.- Parameters
d – a JSON dictionary
key – the key to parse
default – a default string to return if key is not present
- Returns
a path string
- Raises
ConfigError – if the field value was the wrong type or no default value was provided and the key was not found in the dictionary
-
static
parse_raw
(d, key, default=<eta.core.config.NoDefault object>)¶ Parses a raw (arbitrary) JSON field.
- Parameters
d – a JSON dictionary
key – the key to parse
default – a default value to return if key is not present
- Returns
the raw (untouched) value of the given field
- Raises
ConfigError – if no default value was provided and the key was not found in the dictionary
-
static
parse_string
(d, key, default=<eta.core.config.NoDefault object>)¶ Parses a string attribute.
- Parameters
d – a JSON dictionary
key – the key to parse
default – a default string to return if key is not present
- Returns
a string
- Raises
ConfigError – if the field value was the wrong type or no default value was provided and the key was not found in the dictionary
-
property
run_cls
¶ The
BaseRun
class associated with this config.
-
serialize
(*args, **kwargs)¶ Serializes the object into a dictionary.
Serialization is applied recursively to all attributes in the object, including element-wise serialization of lists and dictionary values.
- Parameters
reflective – whether to include reflective attributes when serializing the object. By default, this is False
- Returns
a JSON dictionary representation of the object
-
to_str
(pretty_print=True, **kwargs)¶ Returns a string representation of this object.
- Parameters
pretty_print – whether to render the JSON in human readable format with newlines and indentations. By default, this is True
**kwargs – optional keyword arguments for self.serialize()
- Returns
a string representation of the object
-
property
type
¶ The type of run.
-
static
validate_all_or_nothing_fields
(fields)¶ Validates a dictionary of pre-parsed fields checking that either all or none of the fields have a truthy value.
- Parameters
fields – a dictionary of pre-parsed fields
- Raises
ConfigError – if some values are truth and some are not
-
write_json
(path, pretty_print=False, **kwargs)¶ Serializes the object and writes it to disk.
- Parameters
path – the output path
pretty_print – whether to render the JSON in human readable format with newlines and indentations. By default, this is False
**kwargs – optional keyword arguments for self.serialize()
-
class
fiftyone.utils.cvat.
CVATBackend
(*args, **kwargs)¶ Bases:
fiftyone.utils.annotations.AnnotationBackend
Class for interacting with the CVAT annotation backend.
Attributes:
The list of media types that this backend supports.
The list of label types supported by the backend.
The list of scalar field types supported by the backend.
The list of attribute types supported by the backend.
Whether this backend supports annotating clips views.
Whether this backend supports uploading only keyframes when editing existing video track annotations.
Whether this backend supports annotating video labels at a sample-level.
Whether this backend requires a pre-defined label schema for its annotation runs.
Methods:
recommend_attr_tool
(name, value)Recommends an attribute tool for an attribute with the given name and value.
requires_attr_values
(attr_type)Determines whether the list of possible values are required for attributes of the given type.
upload_annotations
(samples, anno_key[, …])Uploads the samples and relevant existing labels from the label schema to the annotation backend.
download_annotations
(results)Downloads the annotations from the annotation backend for the given results.
cleanup
(samples, key)Cleans up the results of the run with the given key from the collection.
Returns an API instance connected to the annotation backend.
delete_run
(samples, key[, cleanup])Deletes the results associated with the given run key from the collection.
delete_runs
(samples[, cleanup])Deletes all runs from the collection.
Ensures that any necessary packages to execute this run are installed.
Ensures that any necessary packages to use existing results for this run are installed.
from_config
(config)Instantiates a Configurable class from a <cls>Config instance.
from_dict
(d)Instantiates a Configurable class from a <cls>Config dict.
from_json
(json_path)Instantiates a Configurable class from a <cls>Config JSON file.
from_kwargs
(**kwargs)Instantiates a Configurable class from keyword arguments defining the attributes of a <cls>Config.
get_fields
(samples, anno_key)Gets the fields that were involved in the given run.
get_run_info
(samples, key)Gets the
BaseRunInfo
for the given key on the collection.has_cached_run_results
(samples, key)Determines whether
BaseRunResults
for the given key are cached on the collection.list_runs
(samples[, type, method])Returns the list of run keys on the given collection.
load_run_results
(samples, key[, cache, …])Loads the
BaseRunResults
for the given key on the collection.load_run_view
(samples, key[, select_fields])Loads the
fiftyone.core.view.DatasetView
on which the specified run was performed.parse
(class_name[, module_name])Parses a Configurable subclass name string.
register_run
(samples, key[, overwrite, cleanup])Registers a run of this method under the given key on the given collection.
rename
(samples, key, new_key)Performs any necessary operations required to rename this run’s key.
The
BaseRunInfo
class associated with this class.save_run_info
(samples, run_info[, …])Saves the run information on the collection.
save_run_results
(samples, key, run_results)Saves the run results on the collection.
update_run_config
(samples, key, config)Updates the
BaseRunConfig
for the given run on the collection.update_run_key
(samples, key, new_key)Replaces the key for the given run with a new key.
use_api
(api)Registers an API instance to use for subsequent operations.
validate
(config)Validates that the given config is an instance of <cls>Config.
validate_run
(samples, key[, overwrite])Validates that the collection can accept this run.
-
property
supported_media_types
¶ The list of media types that this backend supports.
For example, CVAT supports
["image", "video"]
.
-
property
supported_label_types
¶ The list of label types supported by the backend.
Backends may support any subset of the following label types:
"classification"
"classifications"
"detection"
"detections"
"instance"
"instances"
"polyline"
"polylines"
"polygon"
"polygons"
"keypoint"
"keypoints"
"segmentation"
"scalar"
-
property
supported_scalar_types
¶ The list of scalar field types supported by the backend.
For example, CVAT supports the following types:
-
property
supported_attr_types
¶ The list of attribute types supported by the backend.
This list defines the valid string values for the
type
field of an attributes dict of the label schema provided to the backend.For example, CVAT supports
["text", "select", "radio", "checkbox"]
.
-
property
supports_clips_views
¶ Whether this backend supports annotating clips views.
-
property
supports_keyframes
¶ Whether this backend supports uploading only keyframes when editing existing video track annotations.
-
property
supports_video_sample_fields
¶ Whether this backend supports annotating video labels at a sample-level.
-
property
requires_label_schema
¶ Whether this backend requires a pre-defined label schema for its annotation runs.
-
recommend_attr_tool
(name, value)¶ Recommends an attribute tool for an attribute with the given name and value.
For example, a backend may recommend a tool as follows for a boolean value:
{ "type": "radio", "values": [False, True], }
or a tool as follows for a generic value:
{"type": "text"}
- Parameters
name – the name of the attribute
value – the attribute value, which may be
None
- Returns
an attribute type dict
-
requires_attr_values
(attr_type)¶ Determines whether the list of possible values are required for attributes of the given type.
- Parameters
attr_type – the attribute type string
- Returns
True/False
-
upload_annotations
(samples, anno_key, launch_editor=False)¶ Uploads the samples and relevant existing labels from the label schema to the annotation backend.
- Parameters
samples – a
fiftyone.core.collections.SampleCollection
anno_key – the annotation key
launch_editor (False) – whether to launch the annotation backend’s editor after uploading the samples
- Returns
an
AnnotationResults
-
download_annotations
(results)¶ Downloads the annotations from the annotation backend for the given results.
The returned labels should be represented as either scalar values or
fiftyone.core.labels.Label
instances.For image datasets, the return dictionary should have the following nested structure:
# Scalar fields results[label_type][sample_id] = scalar # Label fields results[label_type][sample_id][label_id] = label
For video datasets, the returned labels dictionary should have the following nested structure:
# Scalar fields results[label_type][sample_id][frame_id] = scalar # Label fields results[label_type][sample_id][frame_id][label_id] = label
The valid values for
label_type
are:“classifications”: single or multilabel classifications
“detections”: detections or instance segmentations
“polylines”: polygons or polylines
“segmentation”: semantic segmentations
“scalar”: scalar values
- Parameters
results – an
AnnotationResults
- Returns
the labels results dict
-
cleanup
(samples, key)¶ Cleans up the results of the run with the given key from the collection.
- Parameters
samples – a
fiftyone.core.collections.SampleCollection
key – a run key
-
connect_to_api
()¶ Returns an API instance connected to the annotation backend.
Existing API instances are reused, if available.
Some annotation backends may not expose this functionality.
- Returns
an
AnnotationAPI
, orNone
if the backend does not expose an API
-
classmethod
delete_run
(samples, key, cleanup=True)¶ Deletes the results associated with the given run key from the collection.
- Parameters
samples – a
fiftyone.core.collections.SampleCollection
key – a run key
cleanup (True) – whether to execute the run’s
BaseRun.cleanup()
method
-
classmethod
delete_runs
(samples, cleanup=True)¶ Deletes all runs from the collection.
- Parameters
samples – a
fiftyone.core.collections.SampleCollection
cleanup (True) – whether to execute the run’s
BaseRun.cleanup()
methods
-
ensure_requirements
()¶ Ensures that any necessary packages to execute this run are installed.
Runs should respect
fiftyone.config.requirement_error_level
when handling errors.
-
ensure_usage_requirements
()¶ Ensures that any necessary packages to use existing results for this run are installed.
Runs should respect
fiftyone.config.requirement_error_level
when handling errors.
-
classmethod
from_config
(config)¶ Instantiates a Configurable class from a <cls>Config instance.
-
classmethod
from_dict
(d)¶ Instantiates a Configurable class from a <cls>Config dict.
- Parameters
d – a dict to construct a <cls>Config
- Returns
an instance of cls
-
classmethod
from_json
(json_path)¶ Instantiates a Configurable class from a <cls>Config JSON file.
- Parameters
json_path – path to a JSON file for type <cls>Config
- Returns
an instance of cls
-
classmethod
from_kwargs
(**kwargs)¶ Instantiates a Configurable class from keyword arguments defining the attributes of a <cls>Config.
- Parameters
**kwargs – keyword arguments that define the fields of a <cls>Config dict
- Returns
an instance of cls
-
get_fields
(samples, anno_key)¶ Gets the fields that were involved in the given run.
- Parameters
samples – a
fiftyone.core.collections.SampleCollection
key – a run key
- Returns
a list of fields
-
classmethod
get_run_info
(samples, key)¶ Gets the
BaseRunInfo
for the given key on the collection.- Parameters
samples – a
fiftyone.core.collections.SampleCollection
key – a run key
- Returns
a
BaseRunInfo
-
classmethod
has_cached_run_results
(samples, key)¶ Determines whether
BaseRunResults
for the given key are cached on the collection.- Parameters
samples – a
fiftyone.core.collections.SampleCollection
key – a run key
- Returns
True/False
-
classmethod
list_runs
(samples, type=None, method=None, **kwargs)¶ Returns the list of run keys on the given collection.
- Parameters
samples – a
fiftyone.core.collections.SampleCollection
type (None) –
a specific run type to match, which can be:
a
fiftyone.core.runs.BaseRun
class or its fully-qualified class name string
method (None) – a specific
fiftyone.core.runs.BaseRunConfig.method
string to match**kwargs – optional config parameters to match
- Returns
a list of run keys
-
classmethod
load_run_results
(samples, key, cache=True, load_view=True, **kwargs)¶ Loads the
BaseRunResults
for the given key on the collection.- Parameters
samples – a
fiftyone.core.collections.SampleCollection
key – a run key
cache (True) – whether to cache the results on the collection
load_view (True) – whether to load the run view in the results (True) or the full dataset (False)
**kwargs – keyword arguments for the run’s
BaseRunConfig.load_credentials()
method
- Returns
a
BaseRunResults
, or None if the run did not save results
-
classmethod
load_run_view
(samples, key, select_fields=False)¶ Loads the
fiftyone.core.view.DatasetView
on which the specified run was performed.- Parameters
samples – a
fiftyone.core.collections.SampleCollection
key – a run key
select_fields (False) – whether to exclude fields involved in other runs of the same type
- Returns
-
static
parse
(class_name, module_name=None)¶ Parses a Configurable subclass name string.
Assumes both the Configurable class and the Config class are defined in the same module. The module containing the classes will be loaded if necessary.
- Parameters
class_name – a string containing the name of the Configurable class, e.g. “ClassName”, or a fully-qualified class name, e.g. “eta.core.config.ClassName”
module_name – a string containing the fully-qualified module name, e.g. “eta.core.config”, or None if class_name includes the module name. Set module_name = __name__ to load a class from the calling module
- Returns
the Configurable class config_cls: the Config class associated with cls
- Return type
cls
-
register_run
(samples, key, overwrite=True, cleanup=True)¶ Registers a run of this method under the given key on the given collection.
- Parameters
samples – a
fiftyone.core.collections.SampleCollection
key – a run key
overwrite (True) – whether to allow overwriting an existing run of the same type
cleanup (True) – whether to execute an existing run’s
BaseRun.cleanup()
method when overwriting it
-
rename
(samples, key, new_key)¶ Performs any necessary operations required to rename this run’s key.
- Parameters
samples – a
fiftyone.core.collections.SampleCollection
key – a run key
new_key – a new run key
-
classmethod
run_info_cls
()¶ The
BaseRunInfo
class associated with this class.
-
classmethod
save_run_info
(samples, run_info, overwrite=True, cleanup=True)¶ Saves the run information on the collection.
- Parameters
samples – a
fiftyone.core.collections.SampleCollection
run_info – a
BaseRunInfo
overwrite (True) – whether to overwrite an existing run with the same key
cleanup (True) – whether to execute an existing run’s
BaseRun.cleanup()
method when overwriting it
-
classmethod
save_run_results
(samples, key, run_results, overwrite=True, cache=True)¶ Saves the run results on the collection.
- Parameters
samples – a
fiftyone.core.collections.SampleCollection
key – a run key
run_results – a
BaseRunResults
, or Noneoverwrite (True) – whether to overwrite an existing result with the same key
cache (True) – whether to cache the results on the collection
-
classmethod
update_run_config
(samples, key, config)¶ Updates the
BaseRunConfig
for the given run on the collection.- Parameters
samples – a
fiftyone.core.collections.SampleCollection
key – a run key
config – a
BaseRunConfig
-
classmethod
update_run_key
(samples, key, new_key)¶ Replaces the key for the given run with a new key.
- Parameters
samples – a
fiftyone.core.collections.SampleCollection
key – a run key
new_key – a new run key
-
use_api
(api)¶ Registers an API instance to use for subsequent operations.
- Parameters
api – an
AnnotationAPI
-
classmethod
validate
(config)¶ Validates that the given config is an instance of <cls>Config.
- Raises
ConfigurableError – if config is not an instance of <cls>Config
-
validate_run
(samples, key, overwrite=True)¶ Validates that the collection can accept this run.
The run may be invalid if, for example, a run of a different type has already been run under the same key and thus overwriting it would cause ambiguity on how to cleanup the results.
- Parameters
samples – a
fiftyone.core.collections.SampleCollection
key – a run key
overwrite (True) – whether to allow overwriting an existing run of the same type
- Raises
ValueError – if the run is invalid
-
property
-
class
fiftyone.utils.cvat.
CVATAnnotationResults
(samples, config, anno_key, id_map, server_id_map, project_ids, task_ids, job_ids, frame_id_map, labels_task_map, backend=None)¶ Bases:
fiftyone.utils.annotations.AnnotationResults
Class that stores all relevant information needed to monitor the progress of an annotation run sent to CVAT and download the results.
Methods:
Launches the CVAT editor and loads the first task for this annotation run.
Gets the status of the assigned tasks and jobs.
Prints the status of the assigned tasks and jobs.
delete_tasks
(task_ids)Deletes the given tasks from both the CVAT server and this run.
cleanup
()Deletes all tasks and created projects associated with this run.
Returns the list of class attributes that will be serialized by
serialize()
.base_results_cls
(type)Returns the results class for the given run type.
Returns an API instance connected to the annotation backend.
copy
()Returns a deep copy of the object.
custom_attributes
([dynamic, private])Returns a customizable list of class attributes.
from_dict
(d, samples, config, key)Builds a
BaseRunResults
from a JSON dict representation of it.from_json
(path, *args, **kwargs)Constructs a Serializable object from a JSON file.
from_str
(s, *args, **kwargs)Constructs a Serializable object from a JSON string.
Returns the fully-qualified class name string of this object.
save
()Saves the results to the database.
Saves these results config to the database.
serialize
([reflective])Serializes the object into a dictionary.
to_str
([pretty_print])Returns a string representation of this object.
use_api
(api)Registers an API instance to use for subsequent operations.
write_json
(path[, pretty_print])Serializes the object and writes it to disk.
Attributes:
The
BaseRun
for these results.The fully-qualified name of this
BaseRunResults
class.The
BaseRunConfig
for these results.The run key for these results.
The
fiftyone.core.collections.SampleCollection
associated with these results.-
launch_editor
()¶ Launches the CVAT editor and loads the first task for this annotation run.
-
get_status
()¶ Gets the status of the assigned tasks and jobs.
- Returns
a dict of status information
-
print_status
()¶ Prints the status of the assigned tasks and jobs.
-
delete_tasks
(task_ids)¶ Deletes the given tasks from both the CVAT server and this run.
- Parameters
task_ids – an iterable of task IDs
-
cleanup
()¶ Deletes all tasks and created projects associated with this run.
-
attributes
()¶ Returns the list of class attributes that will be serialized by
serialize()
.- Returns
a list of attributes
-
property
backend
¶ The
BaseRun
for these results.
-
static
base_results_cls
(type)¶ Returns the results class for the given run type.
- Parameters
type – a
BaseRunConfig.type
- Returns
a
BaseRunResults
subclass
-
property
cls
¶ The fully-qualified name of this
BaseRunResults
class.
-
property
config
¶ The
BaseRunConfig
for these results.
-
connect_to_api
()¶ Returns an API instance connected to the annotation backend.
Existing API instances are reused, if available.
Some annotation backends may not expose this functionality.
- Returns
an
AnnotationAPI
, orNone
if the backend does not expose an API
-
copy
()¶ Returns a deep copy of the object.
- Returns
a Serializable instance
-
custom_attributes
(dynamic=False, private=False)¶ Returns a customizable list of class attributes.
By default, all attributes in vars(self) are returned, minus private attributes (those starting with “_”).
- Parameters
dynamic – whether to include dynamic properties, e.g., those defined by getter/setter methods or the @property decorator. By default, this is False
private – whether to include private properties, i.e., those starting with “_”. By default, this is False
- Returns
a list of class attributes
-
classmethod
from_dict
(d, samples, config, key)¶ Builds a
BaseRunResults
from a JSON dict representation of it.- Parameters
d – a JSON dict
samples – the
fiftyone.core.collections.SampleCollection
for the runconfig – the
BaseRunConfig
for the runkey – the run key
- Returns
a
BaseRunResults
-
classmethod
from_json
(path, *args, **kwargs)¶ Constructs a Serializable object from a JSON file.
Subclasses may override this method, but, by default, this method simply reads the JSON and calls from_dict(), which subclasses must implement.
- Parameters
path – the path to the JSON file on disk
*args – optional positional arguments for self.from_dict()
**kwargs – optional keyword arguments for self.from_dict()
- Returns
an instance of the Serializable class
-
classmethod
from_str
(s, *args, **kwargs)¶ Constructs a Serializable object from a JSON string.
Subclasses may override this method, but, by default, this method simply parses the string and calls from_dict(), which subclasses must implement.
- Parameters
s – a JSON string representation of a Serializable object
*args – optional positional arguments for self.from_dict()
**kwargs – optional keyword arguments for self.from_dict()
- Returns
an instance of the Serializable class
-
classmethod
get_class_name
()¶ Returns the fully-qualified class name string of this object.
-
property
key
¶ The run key for these results.
-
property
samples
¶ The
fiftyone.core.collections.SampleCollection
associated with these results.
-
save
()¶ Saves the results to the database.
-
save_config
()¶ Saves these results config to the database.
-
serialize
(reflective=False)¶ Serializes the object into a dictionary.
Serialization is applied recursively to all attributes in the object, including element-wise serialization of lists and dictionary values.
- Parameters
reflective – whether to include reflective attributes when serializing the object. By default, this is False
- Returns
a JSON dictionary representation of the object
-
to_str
(pretty_print=True, **kwargs)¶ Returns a string representation of this object.
- Parameters
pretty_print – whether to render the JSON in human readable format with newlines and indentations. By default, this is True
**kwargs – optional keyword arguments for self.serialize()
- Returns
a string representation of the object
-
use_api
(api)¶ Registers an API instance to use for subsequent operations.
- Parameters
api – an
AnnotationAPI
-
write_json
(path, pretty_print=False, **kwargs)¶ Serializes the object and writes it to disk.
- Parameters
path – the output path
pretty_print – whether to render the JSON in human readable format with newlines and indentations. By default, this is False
**kwargs – optional keyword arguments for self.serialize()
-
-
class
fiftyone.utils.cvat.
CVATAnnotationAPI
(name, url, username=None, email=None, password=None, headers=None, organization=None)¶ Bases:
fiftyone.utils.annotations.AnnotationAPI
A class to facilitate connection to and management of tasks in CVAT.
On initialization, this class constructs a session based on the provided server url and credentials.
This API provides methods to easily get, put, post, patch, and delete tasks and jobs through the formatted urls specified by the CVAT REST API.
Additionally, samples and label schemas can be uploaded and annotations downloaded through this class.
- Parameters
name – the name of the backend
url – url of the CVAT server
username (None) – the CVAT username
email (None) – the CVAT email
password (None) – the CVAT password
headers (None) – an optional dict of headers to add to all requests
organization (None) – the name of the organization to use when sending requests to CVAT
Attributes:
Methods:
projects_page_url
(page_number)project_url
(project_id)tasks_page_url
(page_number)task_url
(task_id)task_status_url
(task_id)task_data_url
(task_id)task_data_download_url
(task_id, frame_id[, …])task_data_meta_url
(task_id)task_annotation_url
(task_id)task_annotation_formatted_url
(task_id, …)labels_url
(task_id)jobs_url
(task_id)job_url
(task_id, job_id)job_annotation_url
(job_id)taskless_job_url
(job_id)base_task_url
(task_id)base_job_url
(task_id, job_id)task_id_search_url
(task_id)user_search_url
(username)project_search_url
(project_name)project_id_search_url
(project_id)close
()Closes the API session.
get
(url, **kwargs)Sends a GET request to the given CVAT API URL.
patch
(url, **kwargs)Sends a PATCH request to the given CVAT API URL.
post
(url, **kwargs)Sends a POST request to the given CVAT API URL.
put
(url, **kwargs)Sends a PUT request to the given CVAT API URL.
delete
(url, **kwargs)Sends a DELETE request to the given CVAT API URL.
get_user_id
(username)Retrieves the CVAT user ID for the given username.
get_project_id
(project_name)Retrieves the CVAT project ID for the first instance of the given project name.
get_project_name
(project_id)Retrieves the CVAT project name for the given project ID.
get_empty_projects
(project_ids)Check all given project ids to determine if they are empty or if they contain at least one task.
create_project
(name[, schema])Creates a project on the CVAT server using the given label schema.
Returns the list of project IDs.
project_exists
(project_id)Checks if the given project exists.
delete_project
(project_id)Deletes the given project from the CVAT server.
delete_projects
(project_ids[, progress])Deletes the given projects from the CVAT server.
get_project_tasks
(project_id)Returns the IDs of the tasks in the given project.
create_task
(name[, schema, segment_size, …])Creates a task on the CVAT server using the given label schema.
Returns the list of task IDs.
task_exists
(task_id)Checks if the given task exists.
delete_task
(task_id)Deletes the given task from the CVAT server.
delete_tasks
(task_ids[, progress])Deletes the given tasks from the CVAT server.
launch_editor
([url])Launches the CVAT editor in your default web browser.
upload_data
(task_id, paths[, image_quality, …])Uploads a list of media to the task with the given ID.
upload_samples
(samples, anno_key, backend)Uploads the given samples to CVAT according to the given backend’s annotation and server configuration.
download_annotations
(results)Download the annotations from the CVAT server for the given results instance and parses them into the appropriate FiftyOne types.
-
property
server_version
¶
-
property
base_url
¶
-
property
base_api_url
¶
-
property
login_url
¶
-
property
about_url
¶
-
property
users_url
¶
-
property
projects_url
¶
-
projects_page_url
(page_number)¶
-
project_url
(project_id)¶
-
property
tasks_url
¶
-
tasks_page_url
(page_number)¶
-
task_url
(task_id)¶
-
task_status_url
(task_id)¶
-
task_data_url
(task_id)¶
-
task_data_download_url
(task_id, frame_id, data_type='frame', quality='original')¶
-
task_data_meta_url
(task_id)¶
-
task_annotation_url
(task_id)¶
-
task_annotation_formatted_url
(task_id, anno_filepath, anno_format='CVAT 1.1')¶
-
labels_url
(task_id)¶
-
jobs_url
(task_id)¶
-
job_url
(task_id, job_id)¶
-
job_annotation_url
(job_id)¶
-
taskless_job_url
(job_id)¶
-
base_task_url
(task_id)¶
-
base_job_url
(task_id, job_id)¶
-
task_id_search_url
(task_id)¶
-
user_search_url
(username)¶
-
project_search_url
(project_name)¶
-
project_id_search_url
(project_id)¶
-
property
assignee_key
¶
-
close
()¶ Closes the API session.
-
get
(url, **kwargs)¶ Sends a GET request to the given CVAT API URL.
- Parameters
url – the url
**kwargs – additional request parameters
- Returns
the request response
-
patch
(url, **kwargs)¶ Sends a PATCH request to the given CVAT API URL.
- Parameters
url – the url
**kwargs – additional request parameters
- Returns
the request response
-
post
(url, **kwargs)¶ Sends a POST request to the given CVAT API URL.
- Parameters
url – the url
**kwargs – additional request parameters
- Returns
the request response
-
put
(url, **kwargs)¶ Sends a PUT request to the given CVAT API URL.
- Parameters
url – the url
**kwargs – additional request parameters
- Returns
the request response
-
delete
(url, **kwargs)¶ Sends a DELETE request to the given CVAT API URL.
- Parameters
url – the url to send the request to
**kwargs – additional request parameters
- Returns
the request response
-
get_user_id
(username)¶ Retrieves the CVAT user ID for the given username.
- Parameters
username – the username
- Returns
the user ID, or None if the user was not found
-
get_project_id
(project_name)¶ Retrieves the CVAT project ID for the first instance of the given project name.
- Parameters
project_name – the name of the project
- Returns
the project ID, or None if no project with the given name was found
-
get_project_name
(project_id)¶ Retrieves the CVAT project name for the given project ID.
- Parameters
project_id – the ID of the project
- Returns
the project name, or None if no project with the given ID was found
-
get_empty_projects
(project_ids)¶ Check all given project ids to determine if they are empty or if they contain at least one task.
- Parameters
project_ids – a list of project ids to check
- Returns
a list of empty project ids
-
create_project
(name, schema=None)¶ Creates a project on the CVAT server using the given label schema.
- Parameters
name – a name for the project
schema (None) – the label schema to use for the created project
- Returns
the ID of the created project in CVAT
-
list_projects
()¶ Returns the list of project IDs.
- Returns
the list of project IDs
-
project_exists
(project_id)¶ Checks if the given project exists.
- Parameters
project_id – the project ID
- Returns
True/False
-
delete_project
(project_id)¶ Deletes the given project from the CVAT server.
- Parameters
project_id – the project ID
-
delete_projects
(project_ids, progress=None)¶ Deletes the given projects from the CVAT server.
- Parameters
project_ids – an iterable of project IDs
progress (None) – whether to render a progress bar (True/False), use the default value
fiftyone.config.show_progress_bars
(None), or a progress callback function to invoke instead
-
get_project_tasks
(project_id)¶ Returns the IDs of the tasks in the given project.
- Parameters
project_id – a project ID
- Returns
the list of task IDs
-
create_task
(name, schema=None, segment_size=None, image_quality=75, task_assignee=None, project_id=None, issue_tracker=None)¶ Creates a task on the CVAT server using the given label schema.
- Parameters
name – a name for the task
schema (None) – the label schema to use for the created task
segment_size (None) – maximum number of images to load into a job. Not applicable to videos
image_quality (75) – an int in
[0, 100]
determining the image quality to upload to CVATtask_assignee (None) – the username to assign the created task(s)
project_id (None) – the ID of a project to which upload the task
issue_tracker (None) – the URL of an issue tracker to link the task
- Returns
a tuple of
task_id: the ID of the created task in CVAT
class_id_map: a dictionary mapping the IDs assigned to classes by CVAT
attr_id_map: a dictionary mapping the IDs assigned to attributes by CVAT for every class
-
list_tasks
()¶ Returns the list of task IDs.
- Returns
the list of task IDs
-
task_exists
(task_id)¶ Checks if the given task exists.
- Parameters
task_id – the task ID
- Returns
True/False
-
delete_task
(task_id)¶ Deletes the given task from the CVAT server.
- Parameters
task_id – the task ID
-
delete_tasks
(task_ids, progress=None)¶ Deletes the given tasks from the CVAT server.
- Parameters
task_ids – an iterable of task IDs
progress (None) – whether to render a progress bar (True/False), use the default value
fiftyone.config.show_progress_bars
(None), or a progress callback function to invoke instead
-
launch_editor
(url=None)¶ Launches the CVAT editor in your default web browser.
- Parameters
url (None) – an optional URL to open. By default, the base URL of the server is opened
-
upload_data
(task_id, paths, image_quality=75, use_cache=True, use_zip_chunks=True, chunk_size=None, job_assignees=None, job_reviewers=None, frame_start=None, frame_stop=None, frame_step=None)¶ Uploads a list of media to the task with the given ID.
- Parameters
task_id – the task ID
paths – a list of media paths to upload
image_quality (75) – an int in
[0, 100]
determining the image quality to upload to CVATuse_cache (True) – whether to use a cache when uploading data. Using a cache reduces task creation time as data will be processed on-the-fly and stored in the cache when requested
use_zip_chunks (True) – when annotating videos, whether to upload video frames in smaller chunks. Setting this option to
False
may result in reduced video quality in CVAT due to size limitations on ZIP files that can be uploaded to CVATchunk_size (None) – the number of frames to upload per ZIP chunk
job_assignees (None) – a list of usernames to assign jobs
job_reviewers (None) – a list of usernames to assign job reviews
frame_start (None) – an optional first frame to start uploading from
frame_stop (None) – an optional last frame to upload
frame_step (None) – an optional positive integer specifying the spacing between frames to upload
- Returns
a list of the job IDs created for the task
-
upload_samples
(samples, anno_key, backend)¶ Uploads the given samples to CVAT according to the given backend’s annotation and server configuration.
- Parameters
samples – a
fiftyone.core.collections.SampleCollection
anno_key – the annotation key
backend – a
CVATBackend
to use to perform the upload
- Returns
-
download_annotations
(results)¶ Download the annotations from the CVAT server for the given results instance and parses them into the appropriate FiftyOne types.
- Parameters
results – a
CVATAnnotationResults
- Returns
the annotations dict
-
class
fiftyone.utils.cvat.
CVATLabel
(label_dict, class_map, attr_id_map, server_id_map, attributes=None)¶ Bases:
object
A label returned by the CVAT API.
- Parameters
label_dict – the dictionary containing the label information loaded from the CVAT API
class_map – a dictionary mapping label IDs to class strings
attr_id_map – a dictionary mapping attribute IDs attribute names for every label
server_id_map – a dictionary mapping server IDs to FiftyOne label IDs
attributes (None) – an optional list of additional attributes
-
class
fiftyone.utils.cvat.
CVATShape
(label_dict, class_map, attr_id_map, server_id_map, metadata, index=None, immutable_attrs=None, occluded_attrs=None, group_id_attrs=None, group_id=None)¶ Bases:
fiftyone.utils.cvat.CVATLabel
A shape returned by the CVAT API.
- Parameters
label_dict – the dictionary containing the label information loaded from the CVAT API
class_map – a dictionary mapping label IDs to class strings
attr_id_map – a dictionary mapping attribute IDs attribute names for every label
server_id_map – a dictionary mapping server IDs to FiftyOne label IDs
metadata – a dictionary containing the width and height of the frame
index (None) – the tracking index of the shape
immutable_attrs (None) – immutable attributes inherited by this shape from its track
occluded_attrs (None) – a dictionary mapping class names to the corresponding attribute linked to the CVAT occlusion widget, if any
group_id_attrs (None) – a dictionary mapping class names to the corresponding attribute linked to the CVAT group id, if any
group_id (None) – an optional group id value for this shape when it cannot be parsed from the label dict
Methods:
Converts this shape to a
fiftyone.core.labels.Detection
.to_polyline
([closed, filled])Converts this shape to a
fiftyone.core.labels.Polyline
.to_polylines
([closed, filled])Converts this shape to a
fiftyone.core.labels.Polylines
.Converts this shape to a
fiftyone.core.labels.Keypoint
.polyline_to_detection
(polyline, frame_size)Converts a
fiftyone.core.labels.Polyline
to afiftyone.core.labels.Detection
with a segmentation mask.polylines_to_segmentation
(polylines, …)Converts a
fiftyone.core.labels.Polylines
to afiftyone.core.labels.Segmentation
.-
to_detection
()¶ Converts this shape to a
fiftyone.core.labels.Detection
.- Returns
-
to_polyline
(closed=False, filled=False)¶ Converts this shape to a
fiftyone.core.labels.Polyline
.- Returns
-
to_polylines
(closed=False, filled=False)¶ Converts this shape to a
fiftyone.core.labels.Polylines
.- Returns
-
to_keypoint
()¶ Converts this shape to a
fiftyone.core.labels.Keypoint
.- Returns
-
classmethod
polyline_to_detection
(polyline, frame_size)¶ Converts a
fiftyone.core.labels.Polyline
to afiftyone.core.labels.Detection
with a segmentation mask.- Parameters
polyline – a
fiftyone.core.labels.Polyline
frame_size – the
(width, height)
of the frame
- Returns
-
classmethod
polylines_to_segmentation
(polylines, frame_size, mask_targets)¶ Converts a
fiftyone.core.labels.Polylines
to afiftyone.core.labels.Segmentation
.- Parameters
polylines – a
fiftyone.core.labels.Polylines
mask_targets – a dict mapping integer pixel values to label strings
frame_size – the
(width, height)
of the frame
- Returns
-
class
fiftyone.utils.cvat.
CVATTag
(label_dict, class_map, attr_id_map, server_id_map, attributes=None)¶ Bases:
fiftyone.utils.cvat.CVATLabel
A tag returned by the CVAT API.
- Parameters
label_dict – the dictionary containing the label information loaded from the CVAT API
class_map – a dictionary mapping label IDs to class strings
attr_id_map – a dictionary mapping attribute IDs attribute names for every label
server_id_map – a dictionary mapping server IDs to FiftyOne label IDs
attributes (None) – an optional list of additional attributes
Methods:
Converts the tag to a
fiftyone.core.labels.Classification
.-
to_classification
()¶ Converts the tag to a
fiftyone.core.labels.Classification
.- Returns
-
fiftyone.utils.cvat.
load_cvat_image_annotations
(xml_path)¶ Loads the CVAT image annotations from the given XML file.
See this page for format details.
- Parameters
xml_path – the path to the annotations XML file
- Returns
a tuple of
info: a dict of dataset info
cvat_task_labels: a
CVATTaskLabels
instancecvat_images: a list of
CVATImage
instances
-
fiftyone.utils.cvat.
load_cvat_video_annotations
(xml_path)¶ Loads the CVAT video annotations from the given XML file.
See this page for format details.
- Parameters
xml_path – the path to the annotations XML file
- Returns
a tuple of
info: a dict of dataset info
cvat_task_labels: a
CVATTaskLabels
instancecvat_tracks: a list of
CVATTrack
instances