VolumeProject¶
- class VolumeProject[source]¶
Bases:
supervisely.project.video_project.VideoProject
Methods
Makes a copy of the
VideoProject
.Creates a subdirectory with given name and all intermediate subdirectories for items and annotations in project directory, and also adds created dataset to the collection of all datasets in the project.
Download volume project from Supervisely to the given directory.
get_classes_stats
get_item_paths
- rtype
Not available for VideoProject class.
Not available for VideoProject class.
Not available for VideoProject class.
Get URL to video datasets list in Supervisely.
Read project from given ditectory.
Not available for VideoProject class.
Not available for VideoProject class.
Not available for VideoProject class.
Not available for VideoProject class.
Not available for VideoProject class.
Save given KeyIdMap object to project dir in json format.
Saves given
meta
to project directory in json format.Not available for VideoProject class.
Not available for VideoProject class.
Uploads volume project to Supervisely from the given directory.
validate
Attributes
Project datasets.
Path to the project directory.
key_id_map
Project meta.
Project name.
Project parent directory.
Total number of items in project.
-
copy_data(dst_directory, dst_name=
None
, _validate_item=True
, _use_hardlink=False
)¶ Makes a copy of the
VideoProject
.- Parameters
- Returns
VideoProject object.
- Return type
VideoProject
- Usage example
import supervisely as sly project = sly.VideoProject("/home/admin/work/supervisely/projects/videos_example", sly.OpenMode.READ) print(project.total_items) # Output: 6 new_project = project.copy_data("/home/admin/work/supervisely/projects/", "videos_example_copy") print(new_project.total_items) # Output: 6
- create_dataset(ds_name)¶
Creates a subdirectory with given name and all intermediate subdirectories for items and annotations in project directory, and also adds created dataset to the collection of all datasets in the project.
- Parameters
- ds_name :
str
Dataset name.
- ds_name :
- Returns
Dataset object
- Return type
Dataset
- Usage example
import supervisely as sly project = sly.Project("/home/admin/work/supervisely/projects/lemons_annotated", sly.OpenMode.READ) for dataset in project.datasets: print(dataset.name) # Output: ds1 # ds2 project.create_dataset("ds3") for dataset in project.datasets: print(dataset.name) # Output: ds1 # ds2 # ds3
-
static download(api, project_id, dest_dir, dataset_ids=
None
, download_volumes=True
, log_progress=False
)[source]¶ Download volume project from Supervisely to the given directory.
- Parameters
- api :
Api
Supervisely API address and token.
- project_id :
int
Supervisely downloadable project ID.
- dest_dir :
str
Destination directory.
- dataset_ids :
list
[int
], optional Dataset IDs.
- download_volumes :
bool
, optional Download volume data files or not.
- log_progress :
bool
, optional Show uploading progress bar.
- api :
- Returns
None
- Return type
NoneType
- Usage example
import supervisely as sly # Local destination Volume Project folder save_directory = "/home/admin/work/supervisely/source/vlm_project" # Obtain server address and your api_token from environment variables # Edit those values if you run this notebook on your own PC address = os.environ['SERVER_ADDRESS'] token = os.environ['API_TOKEN'] # Initialize API object api = sly.Api(address, token) project_id = 8888 # Download Project sly.VolumeProject.download(api, project_id, save_directory) project_fs = sly.VolumeProject(save_directory, sly.OpenMode.READ)
- static get_train_val_splits_by_count(project_dir, train_count, val_count)¶
Not available for VideoProject class. :raises:
NotImplementedError
in all cases.- Return type
- static get_train_val_splits_by_dataset(project_dir, train_datasets, val_datasets)¶
Not available for VideoProject class. :raises:
NotImplementedError
in all cases.- Return type
-
static get_train_val_splits_by_tag(project_dir, train_tag_name, val_tag_name, untagged=
'ignore'
)¶ Not available for VideoProject class. :raises:
NotImplementedError
in all cases.- Return type
- static get_url(id)¶
Get URL to video datasets list in Supervisely.
- classmethod read_single(dir)¶
Read project from given ditectory. Generate exception error if given dir contains more than one subdirectory :param dir: str :return: VideoProject class object
-
static remove_classes(project_dir, classes_to_remove=
None
, inplace=False
)¶ Not available for VideoProject class. :raises:
NotImplementedError
in all cases.- Return type
-
static remove_classes_except(project_dir, classes_to_keep=
None
, inplace=False
)¶ Not available for VideoProject class. :raises:
NotImplementedError
in all cases.- Return type
-
static remove_items_without_both_objects_and_tags(project_dir, inplace=
False
)¶ Not available for VideoProject class. :raises:
NotImplementedError
in all cases.- Return type
-
static remove_items_without_objects(project_dir, inplace=
False
)¶ Not available for VideoProject class. :raises:
NotImplementedError
in all cases.- Return type
-
static remove_items_without_tags(project_dir, inplace=
False
)¶ Not available for VideoProject class. :raises:
NotImplementedError
in all cases.- Return type
- set_key_id_map(new_map)¶
Save given KeyIdMap object to project dir in json format. :type new_map:
KeyIdMap
:param new_map: KeyIdMap class object
- set_meta(new_meta)¶
Saves given
meta
to project directory in json format.- Parameters
- new_meta :
ProjectMeta
ProjectMeta object.
- new_meta :
- Returns
None
- Return type
NoneType
- Usage example
import supervisely as sly proj_lemons = sly.Project("/home/admin/work/supervisely/projects/lemons_annotated", sly.OpenMode.READ) proj_kiwi = sly.Project("/home/admin/work/supervisely/projects/kiwi_annotated", sly.OpenMode.READ) proj_lemons.set_meta(proj_kiwi.meta) print(project.proj_lemons) # Output: # +-------+--------+----------------+--------+ # | Name | Shape | Color | Hotkey | # +-------+--------+----------------+--------+ # | kiwi | Bitmap | [255, 0, 0] | | # +-------+--------+----------------+--------+
-
static to_detection_task(src_project_dir, dst_project_dir=
None
, inplace=False
, progress_cb=None
)¶ Not available for VideoProject class. :raises:
NotImplementedError
in all cases.- Return type
-
static to_segmentation_task(src_project_dir, dst_project_dir=
None
, inplace=False
, target_classes=None
, progress_cb=None
, segmentation_type='semantic'
)¶ Not available for VideoProject class. :raises:
NotImplementedError
in all cases.- Return type
-
static upload(directory, api, workspace_id, project_name=
None
, log_progress=False
)[source]¶ Uploads volume project to Supervisely from the given directory.
- Parameters
- directory :
str
Path to project directory.
- api :
Api
Supervisely API address and token.
- workspace_id :
int
Workspace ID, where project will be uploaded.
- project_name :
str
, optional Name of the project in Supervisely. Can be changed if project with the same name is already exists.
- log_progress :
bool
, optional Show uploading progress bar.
- directory :
- Returns
Project ID and name. It is recommended to check that returned project name coincides with provided project name.
- Return type
- Usage example
import supervisely as sly # Local folder with Volume Project project_directory = "/home/admin/work/supervisely/source/vlm_project" # Obtain server address and your api_token from environment variables # Edit those values if you run this notebook on your own PC address = os.environ['SERVER_ADDRESS'] token = os.environ['API_TOKEN'] # Initialize API object api = sly.Api(address, token) # Upload Volume Project project_id, project_name = sly.VolumeProject.upload( project_directory, api, workspace_id=45, project_name="My Volume Project" )
- property datasets¶
Project datasets.
- Returns
Datasets
- Return type
- Usage example
import supervisely as sly project = sly.Project("/home/admin/work/supervisely/projects/lemons_annotated", sly.OpenMode.READ) for dataset in project.datasets: print(dataset.name) # Output: ds1 # ds2
- property directory¶
Path to the project directory.
- Returns
Path to the project directory
- Return type
- Usage example
import supervisely as sly project = sly.Project("/home/admin/work/supervisely/projects/lemons_annotated", sly.OpenMode.READ) print(project.directory) # Output: '/home/admin/work/supervisely/projects/lemons_annotated'
- property meta¶
Project meta.
- Returns
ProjectMeta object
- Return type
- Usage example
import supervisely as sly project = sly.Project("/home/admin/work/supervisely/projects/lemons_annotated", sly.OpenMode.READ) print(project.meta) # Output: # +-------+--------+----------------+--------+ # | Name | Shape | Color | Hotkey | # +-------+--------+----------------+--------+ # | kiwi | Bitmap | [255, 0, 0] | | # | lemon | Bitmap | [81, 198, 170] | | # +-------+--------+----------------+--------+ # Tags # +------+------------+-----------------+--------+---------------+--------------------+ # | Name | Value type | Possible values | Hotkey | Applicable to | Applicable classes | # +------+------------+-----------------+--------+---------------+--------------------+
- property name¶
Project name.
- Returns
Project name.
- Return type
- Usage example
import supervisely as sly project = sly.Project("/home/admin/work/supervisely/projects/lemons_annotated", sly.OpenMode.READ) print(project.name) # Output: 'lemons_annotated'
- property parent_dir¶
Project parent directory.
- Returns
Path to project parent directory
- Return type
- Usage example
import supervisely as sly project = sly.Project("/home/admin/work/supervisely/projects/lemons_annotated", sly.OpenMode.READ) print(project.parent_dir) # Output: '/home/admin/work/supervisely/projects'