create_dl_model
— Create a deep learning model.
create_dl_model( : : OutputLayers : DLModelHandle)
The operator create_dl_model
creates a deep learning model from a
graph and returns its handle in DLModelHandle
.
A deep learning model in HALCON mainly consists of a directed acyclic
graph that defines the networks architecture.
Further components of a deep learning model in HALCON are parameters as
'class_names' , 'class_ids' , and many others,
or hyperparameters that are needed to train a model, as for example the
'learning_rate' .
While parameters and hyperparameters can be set after creation of the model
using set_dl_model_param
, the model itself can only be created
using create_dl_model
if its network architecture is given in form of
a graph.
To build a graph that defines the models network architecture, one needs to
put together the networks layers. In general, a graph starts with an input
layer. A subsequent layer that follows after the input layer uses the
input layer as feeding layer, and the new layer itself might be used as
a feeding layer for the next layer, and so on. This is repeated until
the graphs output layers (e.g., softmax or loss layers) are
appended to the graph.
To create a layer, use its specified creation operator, e.g., an input
layer is created using create_dl_layer_input
, a convolution layer
is created using create_dl_layer_convolution
, and so on.
When the graph is defined, a model can be created using
create_dl_model
by passing over the graphs output layer handles in
OutputLayers
.
Note that the output layer handles save all other layers that directly or
indirectly serve as feeding input layers for the output layers during
their creation. This means that the output layer handles keep the
whole network architecture necessary for the creation of the model
using create_dl_model
.
The type of the created model, hence the task the model is designed for
(classification, object detection, segmentation), is only given by the
networks architecture.
However, if the networks architecture allows it, the type of the model,
'type' , can be set using set_dl_model_param
.
A specified model type allows a more user friendly usage in the HALCON
deep learning workflow.
Supported types are:
This is the default model type. The task the
model's neuronal network can solve is defined by its architecture.
When apply_dl_model
is applied for inference, the operator
returns the activations of the output layers. To train the model
using train_dl_model_batch
, the underlying graph requires
loss layers.
The model is specified for
classification and all layers required for training the model
are adapted to the model.
When apply_dl_model
is applied for inference,
the output is adapted according to the type, see apply_dl_model
for more details.
See Deep Learning / Classification for further information.
In addition, the operator gen_dl_model_heatmap
can be used to
display the models heatmap.
The model is specified for object detection
and instance segmentation and all layers and anchors required for
training the model are adapted to the model.
When apply_dl_model
is applied for inference,
the output is adapted according to the type, see apply_dl_model
for more details.
See Deep Learning / Object Detection, Instance Segmentation for further information.
The model is specified for semantic
segmentation or edge extraction respectively and all layers required for
training the model are adapted to the model.
When apply_dl_model
is applied for inference,
the output is adapted according to the type, see apply_dl_model
for more details.
See Deep Learning / Semantic Segmentation, Edge Extraction for further information.
Furthermore, many deep learning procedures provide more functionality for the
model if its type is set. As an example, dev_display_dl_data
can be used to display the inferred results more nicely.
Note that setting a model type requires that the graph fulfills certain structure conditions. We recommend to follow the architecture of our delivered neuronal networks if the model type should be set to one of these types.
This operator returns a handle. Note that the state of an instance of this handle type may be changed by specific operators even though the handle is used as an input parameter by those operators.
OutputLayers
(input_control) dl_layer(-array) →
(handle)
Output layers of the graph.
DLModelHandle
(output_control) dl_model →
(handle)
Handle of the deep learning model.
If the parameters are valid, the operator create_dl_model
returns the value 2 (H_MSG_TRUE). If necessary, an exception is raised.
create_dl_layer_softmax
,
create_dl_layer_loss_cross_entropy
,
create_dl_layer_loss_focal
,
create_dl_layer_loss_huber
Deep Learning Training