-
Notifications
You must be signed in to change notification settings - Fork 130
components image_object_detection_pipeline
github-actions[bot] edited this page Dec 24, 2024
·
23 revisions
Pipeline component for image object detection.
Version: 0.0.25
View in Studio: https://ml.azure.com/registries/azureml/components/image_object_detection_pipeline/version/0.0.25
------------------- Computes -------------------
Name | Description | Type | Default | Optional | Enum |
---|---|---|---|---|---|
compute_model_import | Compute to be used for framework_selector eg. provide 'gpu-cluster' if your compute is named 'gpu-cluster'. | string | False | ||
compute_finetune | Compute to be used for running the selected framework eg. provide 'gpu-cluster' if your compute is named 'gpu-cluster'. | string | False | ||
instance_count | Number of nodes to be used for finetuning (used for distributed training). | integer | 1 | True | |
process_count_per_instance | Number of gpus to be used per node for finetuning, should be equal to number of gpu per node in the compute SKU used for finetune. | integer | 1 | True |
------------------- Model Framework Selector -------------------
Name | Description | Type | Default | Optional | Enum |
---|---|---|---|---|---|
model_name | Name of the model. Based on this model name, a framework will be selected (Hugging Face, MM Detection). | string | True | ||
download_from_source | Download model directly from MMDetection instead of system registry | boolean | False | True |
------------------- Data Inputs ------------------
Name | Description | Type | Default | Optional | Enum |
---|---|---|---|---|---|
training_data | Path to MLTable for training data. | mltable | False | ||
validation_data | Path to MLTable for validation data. | mltable | True |
------------------- Task Type ------------------
Name | Description | Type | Default | Optional | Enum |
---|---|---|---|---|---|
task_type | Type of the task | string | image-object-detection | False | ['image-object-detection'] |
primary_metric | Primary metric for the task | string | mean_average_precision | True | ['mean_average_precision'] |
ams_gradient | Enable ams_gradient when optimizer is adam or adamw. | boolean | True | ||
beta1 | Value of beta1 when optimizer is adam or adamw. Must be a float in the range [0, 1]. | number | True | ||
beta2 | Value of beta2 when optimizer is adam or adamw. Must be a float in the range [0, 1]. | number | True | ||
box_detections_per_image | Maximum number of detections per image, for all classes. Must be a positive integer. | integer | True | ||
box_score_threshold | During inference, only return proposals with a classification score greater than box_score_threshold. Must be a float in the range [0, 1]. | number | True | ||
checkpoint_frequency | Frequency to store model checkpoints. Must be a positive integer. | integer | True | ||
checkpoint_run_id | The run ID of the experiment that has a pretrained checkpoint for incremental training. | string | True | ||
early_stopping | Enable early stopping logic during training. | boolean | True | ||
early_stopping_patience | Minimum number of epochs or validation evaluations with no primary metric improvement before the run is stopped. Must be a positive integer. | integer | True | ||
early_stopping_delay | Minimum number of epochs or validation evaluations to wait before primary metric improvement is tracked for early stopping. Must be a positive integer. | integer | True | ||
evaluation_frequency | Frequency to evaluate validation dataset to get metric scores. Must be a positive integer. | integer | True | ||
gradient_accumulation_step | Number of forward passes without updating the model weights while accumulating the gradients of those steps, and then using the accumulated gradients to compute the weight updates. Must be a positive integer. | integer | True | ||
layers_to_freeze | How many layers to freeze for your model. For instance, passing 2 as value for seresnext means freezing layer0 and layer1 referring to the below supported model layer info. Must be a positive integer. | integer | True | ||
learning_rate | Initial learning rate | number | True | ||
learning_rate_scheduler | Type of learning rate scheduler. Must be warmup_cosine or step. | string | True | ['warmup_cosine', 'step'] | |
max_size | Maximum size of the image to be rescaled before feeding it to the backbone. | integer | True | ||
min_size | Minimum size of the image to be rescaled before feeding it to the backbone. Must be a positive integer. | integer | True | ||
momentum | Value of momentum when optimizer is sgd. Must be a float in the range [0, 1]. | number | True | ||
nesterov | Enable nesterov when optimizer is sgd. | boolean | True | ||
nms_iou_threshold | IOU threshold used during inference in non-maximum suppression post processing. Must be a float in the range [0, 1]. | number | True | ||
number_of_epochs | Number of training epochs | integer | True | ||
number_of_workers | Number of subprocesses to use for data loading (PyTorch only). 0 means that the data will be loaded in the main process. | integer | True | ||
optimizer | Type of optimizer | string | True | ['sgd', 'adam', 'adamw'] | |
random_seed | Random seed that will be set at the beginning of training. | integer | True | ||
step_lr_gamma | Value of gamma when learning rate scheduler is step. Must be a float in the range [0, 1]. | number | True | ||
step_lr_step_size | Value of step size when learning rate scheduler is step. Must be a positive integer. | integer | True | ||
tile_grid_size | The grid size to use for tiling each image. Should be passed as a string in '3x2' format. Example --tile_grid_size '3x2'. For more information please visit https://learn.microsoft.com/en-us/azure/machine-learning/how-to-use-automl-small-object-detect?tabs=CLI-v2. | string | True | ||
tile_overlap_ratio | Overlap ratio between adjacent tiles in each dimension. Must be float in the range of [0, 1). | number | True | ||
tile_predictions_nms_threshold | The IOU threshold to use to perform NMS while merging predictions from tiles and image. Used in validation/ inference. Must be float in the range of [0, 1]. | number | True | ||
training_batch_size | Training batch size. | integer | True | ||
validation_batch_size | Validation batch size. | integer | True | ||
validation_iou_threshold | IOU threshold for box matching when computing validation metrics. Must be a float in the range [0.1, 1]. | number | True | ||
validation_metric_type | Metric computation method to use for validation metrics. Must be none, coco, voc, or coco_voc. | string | voc | True | ['none', 'coco', 'voc', 'coco_voc'] |
warmup_cosine_lr_cycles | Value of cosine cycle when learning rate scheduler is warmup_cosine. Must be a float in the range [0, 1]. | number | True | ||
warmup_cosine_lr_warmup_epochs | Value of warmup epochs when learning rate scheduler is warmup_cosine. Must be a positive integer. | integer | True | ||
weight_decay | Value of weight decay used by the optimizer. | number | True |
------------------- Yolov5 Model Specific Hyperparamters ------------------
Name | Description | Type | Default | Optional | Enum |
---|---|---|---|---|---|
model_size | Model size for yolov5. | string | medium | True | ['small', 'medium', 'large', 'xlarge'] |
multi_scale | Enable multi-scale image by varying image size by +/- 50%. | boolean | True | ||
image_size | Image size for train and validation for yolov5 model. | integer | True |
Name | Description | Type |
---|---|---|
pytorch_model_folder | Trained pytorch model. | custom_model |
mlflow_model_folder | The trained MLFlow model. | mlflow_model |