Vega decomposes the entire AutoML process from data to models into multiple steps, including network architecture search, hyperparameter optimization, data augmentation, and model training. Vega can combine these steps into a complete pipeline through configuration files and execute these steps in sequence, complete the entire process from data to model.
In addition, Vega designs a network and hyperparameter search space independent of the search algorithm for algorithms such as network architecture search, hyperparameter optimization, and data augmentation. You can adjust the configuration file to implement personalized search.
The following is an example of running the CARS algorithm:
cd examples
vega ./nas/cars/cars.yml
The following describes each item in the configuration file.
The configuration of the vega can be divided into two parts:
- General configuration. The configuration item name is
general
. It is used to set common and common configuration items, such as Backend, output path, and log level. - Pipeline configuration, including the following two parts:
- Pipeline definition. The configuration item name is pipeline, which is a list that contains all steps in the pipeline.
- Defines each step in Pipeline. The configuration item name is the name of each step defined in Pipeline.
general:
# general configuration
# Defining a Pipeline.
pipeline: [my_nas, my_hpo, my_data_augmentation, my_fully_train]
# defines each step. Refer to the following sections for details about
my_nas:
# NAS configuration
my_hpo:
# HPO configuration
my_data_augmentation:
# Data augmentation configuration
my_fully_train:
# fully train configuration
The following describes each configuration item in detail.
The following public configuration items can be configured:
Configuration item | Optional | Default value | Description |
---|---|---|---|
backend | pytorch | tensorflow | mindspore | pytorch | Backend. |
local_base_path | - | ./tasks/ | Working path. Each time when the system is running, a subfolder with time information (task id) is generated in the path. In this way, the output of multiple running is not overwritten. The task id subfolder contains two subfolders: output and worker. The output folder stores the output data of each step in the pipeline, and the worker folder stores temporary information. In the clustered scenario, this path needs to be set to an EFS path that can be accessed by each computing node, and is used by different nodes to share data. |
timeout | - | 10 | Worker timeout interval, in hours. If the task is not completed within the interval, the worker is forcibly terminated. |
parallel_search | True | False | False | Whether to search multiple models in parallel. |
parallel_fully_train | True | False | False | Whether to train multiple models in parallel. |
devices_per_trainer | 1..N (Tthe maximum number of GPUs or NPUs on a single node) | 1 | In parallel search and training, the number of devices (GPU | NPU) allocated by each trainer, when parallel_search or parallel_fully_train is true. The default is 1, and each trainer is assigned one (gpu | npu). |
logger / level | debug | info | warn | error | critical | info | Log level |
cluster / master_ip | - | ~ | In the cluster scenario, this parameter needs to be set to the IP address of the master node. |
cluster / slaves | - | [] | In the cluster scenario, this parameter needs to be set to the IP address of other nodes except the master node. |
quota | - | ~ | Models filter. Set maximum value or range of the floating-point calculation amount of the sampling model (MB), the parameters of the sampling model (KB), the latency of the sampling model (ms), max pipeline estimated running time set by user (hour). The options are "<", ">", "in", and "and". eg: "flops < 10 and params in [100, 1000]" |
general:
backend: pytorch
parallel_search: False
parallel_fully_train: False
devices_per_trainer: 1
task:
local_base_path: "./tasks"
logger:
level: info
cluster:
master_ip: ~
slaves: []
quota: "flops < 10 and params in [100, 1000]"
During NAS/HPO search, one trainer corresponds to one GPU/NPU. If one trainer corresponds to multiple GPUs/NPUs, you can modify the general.device_per_trainer
parameter.
Currently, this configuration works on PyTorch/GPU, as shown in the following:
general:
parallel_search: True
parallel_fully_train: False
devices_per_trainer: 2
pipeline: [nas, fully_train]
nas:
pipe_step:
type: SearchPipeStep
search_algorithm:
type: BackboneNas
codec: BackboneNasCodec
search_space:
hyperparameters:
- key: network.backbone.depth
type: CATEGORY
range: [18, 34, 50]
- key: network.backbone.base_channel
type: CATEGORY
range: [32, 48, 56]
- key: network.backbone.doublechannel
type: CATEGORY
range: [3, 4]
- key: network.backbone.downsample
type: CATEGORY
range: [3, 4]
model:
model_desc:
modules: ['backbone']
backbone:
type: ResNet
num_class: 10
trainer:
type: Trainer
dataset:
type: Cifar10
fully_train:
pipe_step:
type: TrainPipeStep
models_folder: "{local_base_path}/output/nas/"
trainer:
epochs: 160
distributed: True
dataset:
type: Cifar10
In the fully training phase, Horovod (GPU) or HCCL (NPU) can be used to provide distributed data model training.
This is as follows:
pipeline: [fully_train]
fully_train:
pipe_step:
type: HorovodTrainStep # HorovodTrainStep(GPU), HcclTrainStep(NPU)
trainer:
epochs: 160
model:
model_desc:
modules: ['backbone']
backbone:
type: ResNet
num_class: 10
dataset:
type: Cifar10
common:
data_path: /cache/datasets/cifar10/
HPO and NAS configuration items include:
Configuration Item | Description |
---|---|
pipe_step / type | Set this parameter to SearchPipeStep , indicating that this step is a search step. |
search_algorithm | Search algorithm configuration. For details, see the search algorithm section in this document. |
search_space | Search space configuration. For details, see section "Search Space Configuration." |
model | Model configuration. For details, see the search space section in this document. |
dataset | Dataset configuration. For details, see the dataset section in this document. |
trainer | Model training parameter configuration. For details, see the trainer section in this document. |
evaluator | evaluator parameter configuration. For details, see the evaluator section in this document. |
The configuration:
my_nas:
pipe_step:
type: SearchPipeStep
search_algorithm:
<search algorithm parameters>
search_space:
<search space parameters>
model:
<model parameters>
dataset:
<dataset parameters>
trainer:
<trainer parameters>
evaluator:
<evaluator parameters>
The following describes the search_algorithm and search_space configuration items.
Common search algorithms include the following configuration items:
Configuration item | Description | Example |
---|---|---|
type | Search algorithm name. For details, see the configuration item in the example file of each algorithm. | type: BackboneNas |
codec | Search algorithm encoder. Generally, an encoder is used with a search algorithm. | codec: BackboneNasCodec |
policy | Search policy, which is a search algorithm parameter. | For example, if the BackboneNas uses the evolution algorithm, the policy is set to num_mutate: 10 random_ratio: 0.2 |
range | Search range | For example, the search range of BackboneNas can be min_sample: 10 max_sample: 300 |
The search algorithm examples in the preceding table are as follows in the configuration file:
search_algorithm:
type: BackboneNas
codec: BackboneNasCodec
policy:
num_mutate: 10
random_ratio: 0.2
range:
max_sample: 300
min_sample: 10
The search algorithm BackboneNas is used as an example. Configuration items vary according to search algorithms. For details, see the related chapters in the document of each search algorithm.
Task | categorize | Algorithms |
---|---|---|
Image Classification | Network Architecture Search | CARS, NAGO, BackboneNas, DartsCNN, GDAS, EfficientNet |
Hyperparameter Optimization | ASHA, BOHB, BOSS, PBT, Random | |
Data Augmentation | PBA | |
Model Compression | Model Pruning | Prune-EA |
Model Quantization | Quant-EA | |
Image Super-Resolution | Network Architecture Search | SR-EA, ESR-EA |
Data Augmentation | CycleSR | |
Image Segmentation | Network Architecture Search | Adelaide-EA |
Object Detection | Network Architecture Search | SP-NAS |
Lane Detection | Network Architecture Search | Auto-Lane |
Recommender System | Feature Selection | AutoFIS |
Feature Interactions Selection | AutoGroup |
Common configuration items for search algorithms such as Random, ASHA, BOHB, BOSS, and PBT are as follows:
Configuration Item | Description | Example |
---|---|---|
type | Search algorithm name, including RandomSearch, AshaHpo, BohbHpo, BossHpo, and PBTHpo | type: RandomSearch |
objective_keys | Optimization objective | objective_keys:'accuracy' |
policy.total_epochs | Quota of epochs. Vega simplifies the configuration policy, you only need to set this parameter. For details about other parameter settings, see the examples of the HPO and NAGO algorithms. | total_epochs: 2430 |
tuner | Tuner type, used for the BOHB algorithm, including gp (default), rf, and hebo | tuner: "gp" |
Note: If the tuner parameter is set to hebo, the "HEBO" needs to be installed. Note that the gpytorch version is 1.1.1, the torch version is 1.5.0, and the torch version is 0.5.0.
Example:
search_algorithm:
type: BohbHpo
policy:
total_epochs: 2430
The types of hyperparameters that make up the search space are as follows:
Hyperparameter type | Example | Description |
---|---|---|
CATEGORY | [18, 34, 50, 101] [0.3, 0.7, 0.9] ["red", "yellow"] [[1, 0, 1], [0, 0, 1]] |
group type. Its elements can be any data type. |
BOOL | [True, False] |
Boolean type |
INT | [10, 100] |
Integer type. Set the minimum and maximum values for even sampling. |
INT_EXP | [1, 100000] |
Integer type, minimum and maximum values, exponential sampling |
FLOAT | [0.1, 0.9] |
floating-point number type. Set the minimum and maximum values to sample evenly. |
FLOAT_EXP | [0.1, 100000.0] |
floating point number type. Sets the minimum and maximum values, and performs exponential sampling. |
Constraints between hyperparameters are classified into condition and forbidden, as shown in the following figure.
Category | Constraint Type | Example | Description |
---|---|---|---|
condition | EQUAL | parent: trainer.optimizer.type child: trainer.optimizer.params.momentum type: EQUAL range: ["SGD"] |
indicates the relationship between two hyperparameters. The child parameter takes effect only when the parent parameter is equal to a certain value. In the example, when the value of trainer.optimizer.type is ["SGD"] , the trainer.optimizer.params.momentum parameter takes effect. |
condition | NOT_EQUAL | - | Indicates the relationship between two nodes. The child node takes effect only when the value of parent is different from a value. |
condition | IN | - | Indicates the relationship between two nodes. The child node takes effect only when the parent value is within a certain range. |
forbidden | - | - | indicates the exclusive relationship between two hyperparameter values. The two hyperparameter values cannot be used at the same time. |
The following is an example:
hyperparameters:
- key: dataset.batch_size
type: CATEGORY
range: [8, 16, 32, 64, 128, 256]
- key: trainer.optimizer.params.lr
type: FLOAT_EXP
range: [0.00001, 0.1]
- key: trainer.optimizer.type
type: CATEGORY
range: ['Adam', 'SGD']
- key: trainer.optimizer.params.momentum
type: FLOAT
range: [0.0, 0.99]
condition:
- key: condition_for_sgd_momentum
child: trainer.optimizer.params.momentum
parent: trainer.optimizer.type
type: EQUAL
range: ["SGD"]
forbidden:
- trainer.optimizer.params.lr: 0.025
trainer.optimizer.params.momentum: 0.35
In the preceding example, the forbidden configuration item is used to display the format of the forbidden configuration item.
The search items in the network search space are as follows:
Network | module | Hyperparameter | Description |
---|---|---|---|
ResNet | backbone | network.backbone.depth |
Network Depth |
ResNet | backbone | network.backbone.base_channel |
Input Channels |
ResNet | backbone | network.backbone.doublechannel |
Upgrade Channel Position |
ResNet | backbone | network.backbone.downsample |
Downsampling Position |
The following figure shows the network configuration information, corresponding to the model
section in the example.
module | network | Description | Reference |
---|---|---|---|
backbone | ResNet | ResNet network, which consists of RestNetGeneral and LinearClassificationHead. | |
backbone | ResNetGeneral | ResNet Backbone. | |
head | LinearClassificationHead | Network classification layer used for classification tasks. |
The following is an example in the configuration file:
search_space:
hyperparameters:
- key: network.backbone.depth
type: CATEGORY
range: [18, 34, 50, 101]
- key: network.backbone.base_channel
type: CATEGORY
range: [32, 48, 56, 64]
- key: network.backbone.doublechannel
type: CATEGORY
range: [3, 4]
- key: network.backbone.downsample
type: CATEGORY
range: [3, 4]
model:
model_desc:
modules: ['backbone']
backbone:
type: ResNet
Other network search space configurations are determined by each algorithm. For details, see the following algorithm documents:
Task | categorize | Algorithms |
---|---|---|
Image Classification | Network Architecture Search | CARS, NAGO, BackboneNas, DartsCNN, GDAS, EfficientNet |
Hyperparameter Optimization | ASHA, BOHB, BOSS, BO, TPE, Random, Random-Pareto | |
Data Augmentation | PBA | |
Model Compression | Model Pruning | Prune-EA |
Model Quantization | Quant-EA | |
Image Super-Resolution | Network Architecture Search | SR-EA, ESR-EA |
Data Augmentation | CycleSR | |
Image Segmentation | Network Architecture Search | Adelaide-EA |
Object Detection | Network Architecture Search | SP-NAS |
Lane Detection | Network Architecture Search | Auto-Lane |
Recommender System | Feature Selection | AutoFIS |
Feature Interactions Selection | AutoGroup |
Network training hyperparameters include the following:
- Dataset parameters.
- Model trainer parameters, including:
- Optimizationer and parameters.
- Learning rate scheduler and its parameters.
- Loss function and its parameters.
Configuration item description:
Hyperparameter | Example | Description |
---|---|---|
dataset.<dataset param> | dataset.batch_size |
Dataset parameter |
trainer.optimizer.type | trainer.optimizer.type |
Optimizer type |
trainer.optimizer.params.<optimizer param> | trainer.optimizer.params.lr trainer.optimizer.params.momentum |
Optimizer parameter |
trainer.lr_scheduler.type | trainer.lr_scheduler.type |
LR-Schecduler type |
trainer.lr_scheduler.params.<lr_scheduler param> | trainer.lr_scheduler.params.gamma |
LR-Scheduler parameter |
trainer.loss.type | trainer.loss.type |
Loss function type |
trainer.loss.params.<loss function param> | trainer.loss.params.aux_weight |
Loss function parameter |
The configuration in the preceding table is in the following format in the configuration file:
hyperparameters:
- key: dataset.batch_size
type: CATEGORY
range: [8, 16, 32, 64, 128, 256]
- key: trainer.optimizer.type
type: CATEGORY
range: ["Adam", "SGD"]
- key: trainer.optimizer.params.lr
type: FLOAT_EXP
range: [0.00001, 0.1]
- key: trainer.optimizer.params.momentum
type: FLOAT
range: [0.0, 0.99]
- key: trainer.lr_scheduler.type
type: CATEGORY
range: ["MultiStepLR", "StepLR"]
- key: trainer.lr_scheduler.params.gamma
type: FLOAT
range: [0.1, 0.5]
- key: trainer.loss.type
type: CATEGORY
range: ["CrossEntropyLoss", "MixAuxiliaryLoss"]
- key: trainer.loss.params.aux_weight
type: FLOAT
range: [0, 1]
condition:
- key: condition_for_sgd_momentum
child: trainer.optimizer.params.momentum
parent: trainer.optimizer.type
type: EQUAL
range: ["SGD"]
- key: condition_for_MixAuxiliaryLoss_aux_weight
child: trainer.loss.params.aux_weight
parent: trainer.loss.type
type: EQUAL
range: ["MixAuxiliaryLoss"]
NAS and HPO configuration items can be configured at the same time. The network structure and training parameters can be searched at the same time. In the following example, the model training hyperparameters are batch_size, optimizer, and ResNet network parameters depth, base_channel, doublechannel, and downsample.
search_algorithm:
type: BohbHpo
policy:
total_epochs: 100
repeat_times: 2
search_space:
hyperparameters:
- key: dataset.batch_size
type: CATEGORY
range: [8, 16, 32, 64, 128, 256]
- key: trainer.optimizer.type
type: CATEGORY
range: ["Adam", "SGD"]
- key: trainer.optimizer.params.lr
type: FLOAT_EXP
range: [0.00001, 0.1]
- key: trainer.optimizer.params.momentum
type: FLOAT
range: [0.0, 0.99]
- key: network.backbone.depth
type: CATEGORY
range: [18, 34, 50, 101]
- key: network.backbone.base_channel
type: CATEGORY
range: [32, 48, 56, 64]
- key: network.backbone.doublechannel
type: CATEGORY
range: [3, 4]
- key: network.backbone.downsample
type: CATEGORY
range: [3, 4]
condition:
- key: condition_for_sgd_momentum
child: trainer.optimizer.params.momentum
parent: trainer.optimizer.type
type: EQUAL
range: ["SGD"]
model:
model_desc:
modules: ['backbone']
backbone:
type: ResNet
Similar to HPO, data augmentation configuration items include pipe_step, search_algorithm, search_space, dataset, trainer, and evaluator. Vega provides two data augmentation algorithms: PBA and CycleSR, for details, see PBA and CycleSR .
The network model and training hyperparameter obtained after the NAS and HPO are used as the input of the Fully Train step. The fully trained model is obtained after the Fully Train step. The configuration items are as follows:
The HPO/NAS configuration items are as follows:
Configuration item | Description |
---|---|
pipe_step / type | Set this parameter to TrainPipeStep , indicating that this step is a search step. |
pipe_step / models_folder | Specify the location of the model description file. Read the model description files named desc_<ID>.json (ID indicates a number) in the folder and train these models in sequence. This option takes precedence over the model option. |
model / model_desc_file | Location of the model description file. The priority of this configuration item is lower than that of pipe_step/models_folder and higher than that of model/model_desc . |
model / model_desc | Model description. For details, see the model-related section in the search space. This configuration has a lower priority than pipe_step/models_folder and model/model_desc . |
dataset | Dataset configuration. For details, see the dataset section in this document. |
trainer | Model training parameter configuration. For details, see the trainer section in this document. |
evaluator | evaluator parameter configuration. For details, see the evaluator section in this document. |
my_fully_train:
pipe_step:
type: TrainPipeStep
models_folder: "{local_base_path}/output/nas/"
trainer:
<trainer params>
model:
<model desc params>
model_desc_file: "./desc_0.json"
dataset:
<dataset params>
trainer:
<trainer params>
evaluator:
<evaluator params>
The configuration items of the Trainer are as follows:
Configuration item | Default value | Description |
---|---|---|
type | "Trainer" | Type |
epochs | 1 | Number of epochs |
distributed | False | Whether to enable horovod. To enable Horovod, set shuffle of the dataset to False. |
syncbn | False | Whether to enable SyncBN |
amp | False | Whether to enable the AMP |
optimizer/type | "Adam" | Optimizer name |
optimizer/params | {"lr": 0.1} | Optimizer Parameter |
lr_scheduler/type | "MultiStepLR" | lr scheduler and Parameters |
lr_scheduler/params | {"milestones": [75, 150], "gamma": 0.5} | lr scheduler and Parameters |
loss/type | "CrossEntropyLoss" | loss and Parameters |
loss/params | {} | loss and parameters |
metric/type | "accuracy" | metric and parameter |
metric/params | {"topk": [1, 5]} | metric and Parameters |
report_freq | 10 | Frequency for printing epoch information |
Complete configuration example:
my_fullytrain:
pipe_step:
type: TrainPipeStep
# models_folder: "{local_base_path}/output/nas/"
trainer:
ref: nas.trainer
epochs: 160
optimizer:
type: SGD
params:
lr: 0.1
momentum: 0.9
weight_decay: 0.0001
lr_scheduler:
type: MultiStepLR
params:
milestones: [60, 120]
gamma: 0.5
model:
model_desc:
modules: ['backbone']
backbone:
type: ResNet
# model_desc_file: "./desc_0.json"
dataset:
type: Cifar10
common:
data_path: /cache/datasets/cifar10/
In addition, Vega provides the ScriptRunner for running user scripts.
Configuration Item | Value | Example |
---|---|---|
type | "ScriptRunner" | type: "ScriptRunner" |
script | Script file name | "./train.py" |
For details, see the example of the trainer.
Vega provides multiple dataset classes for reading common research datasets and provides common dataset operation methods. The dataset classes provided by Vega can be configured separately for train, val, and test. You can also configure the configuration items on the common node to take effect on the three types of data. The following is a configuration example of the Cifar10 dataset:
dataset:
type: Cifar10
common:
data_path: /cache/datasets/cifar10
batch_size: 256
train:
shuffle: True
val:
shuffle: False
test:
shuffle: False
The following describes the configuration of common data classes:
The configuration items are as follows:
Configuration item | Default value | Description |
---|---|---|
data_path | ~ | Directory generated after the dataset is downloaded and decompressed. |
batch_size | 256 | batch size |
shuffle | False | shuffle |
num_workers | 8 | Number of read threads |
pin_memory | True | Pin memeory |
drop_laster | True | Drop last |
distributed | False | Data distribution |
train_portion | 1 | Division ratio of the training set in the dataset |
transforms | train: [RandomCrop, RandomHorizontalFlip, ToTensor, Normalize] val: [ToTensor, Normalize] test: [ToTensor, Normalize] |
缺省transforms |
The configuration items are as follows:
Configuration item | Default value | Description |
---|---|---|
data_path | ~ | Directory generated after the dataset is downloaded and decompressed. |
batch_size | 64 | batch size |
shuffle | train: True val: False test: False |
shuffle |
n_class | 1000 | Category |
num_workers | 8 | Number of read threads |
pin_memory | True | Pin memeory |
drop_laster | True | Drop last |
distributed | False | Data distribution |
train_portion | 1 | Division ratio of the training set in the dataset |
transforms | train: [RandomResizedCrop, RandomHorizontalFlip, ColorJitter, ToTensor, Normalize] val: [Resize, CenterCrop, ToTensor, Normalize] test: [Resize, CenterCrop, ToTensor, Normalize] |
缺省transforms |
The configuration items are as follows:
Configuration item | Default value | Description |
---|---|---|
root_path | ~ | Directory generated after the dataset is downloaded and decompressed. |
list_file | train: train.txt val: val.txt test: test.txt |
Index File |
batch_size | 1 | batch size |
num_workers | 8 | Number of read threads |
shuffle | False | shuffle |
The configuration items are as follows:
Configuration item | Default value | Description |
---|---|---|
root_HR | ~ | Directory where the HR image is located. |
root_LR | ~ | Directory where LR images are stored. |
batch_size | 1 | batch size |
shuffle | False | shuffle |
num_workers | 4 | Number of read threads |
pin_memory | True | Pin memeory |
value_div | 1.0 | Value div |
upscale | 2 | Up scale |
crop | ~ | crop size of lr image |
hflip | False | flip image horizontally |
vflip | False | flip image vertically |
rot90 | False | flip image diagonally |
The configuration items are as follows:
Configuration item | Default value | Description |
---|---|---|
data_path | ~ | Directory generated after the dataset is downloaded and decompressed. |
batch_size | 24 | batch size |
shuffle | False | shuffle |
num_workers | 8 | Number of read threads |
network_input_width | 512 | Network inpurt width |
network_input_height | 288 | Network input height |
gt_len | 145 | - |
gt_num | 576 | - |
random_sample | True | Random sample |
transforms | [ToTensor, Normalize] | transforms |
The configuration items are as follows:
Configuration item | Default value | Description |
---|---|---|
data_path | ~ | Directory generated after the dataset is downloaded and decompressed. |
batch_size | 2000 | batch size |
This dataset is used to read user classification data. The user dataset directory contains three subfolders: train, val, and test. The three subfolders contain the image classification tag folder, which stores images belonging to the category.
The configuration items are as follows:
Configuration item | Default value | Description |
---|---|---|
data_path | ~ | Directory generated after the dataset is downloaded and decompressed. |
batch_size | 1 | batch size |
shuffle | train: True val: True test: False |
shuffle |
num_workers | 8 | Number of read threads |
pin_memory | True | Pin memeory |
drop_laster | True | Drop last |
distributed | False | Data distribution |
train_portion | 1 | Division ratio of the training set in the dataset |
n_class | - | number of clases |
cached | True | Whether to cache all data to the memory. |
transforms | [] | transforms |