Module containing implementation of the ReLU activation function
This module implements the Rectified Linear Unit (ReLU) activation, which zeroes negative values while preserving positive values.
Mathematical operation:
Derivative:
Properties: Non-saturating, sparse activation, mitigates vanishing gradients Reference: Nair & Hinton (2010), ICML
Initialise a ReLU activation function
| Type | Intent | Optional | Attributes | Name | ||
|---|---|---|---|---|---|---|
| real(kind=real32), | intent(in), | optional | :: | scale |
Optional scale factor for activation output |
|
| type(onnx_attribute_type), | intent(in), | optional | :: | attributes(:) |
Optional ONNX attributes |
ReLU activation type
Type for ReLU activation function with overloaded procedures
| Type | Visibility | Attributes | Name | Initial | |||
|---|---|---|---|---|---|---|---|
| logical, | public | :: | apply_scaling | = | .false. |
Boolean to apply scaling or not |
|
| character(len=10), | public | :: | name |
Name of the activation function |
|||
| real(kind=real32), | public | :: | scale | = | 1._real32 |
Scale of the activation function |
|
| real(kind=real32), | public | :: | threshold |
Threshold of the activation function |
| private function initialise (scale, attributes) | Initialise a ReLU activation function |
| procedure, public, pass(this) :: apply => apply_relu | |
| procedure, public, pass(this) :: apply_attributes => apply_attributes_relu | |
| procedure, public, pass(this) :: export_attributes => export_attributes_relu | |
| procedure, public, pass(this) :: print_to_unit => print_to_unit_actv | |
| procedure, public, pass(this) :: reset => reset_relu |
Create ReLU activation function from ONNX attributes
| Type | Intent | Optional | Attributes | Name | ||
|---|---|---|---|---|---|---|
| type(onnx_attribute_type), | intent(in), | dimension(:) | :: | attributes |
Array of ONNX attributes |
Instance of activation type
Apply ReLU activation to 1D array
| Type | Intent | Optional | Attributes | Name | ||
|---|---|---|---|---|---|---|
| class(relu_actv_type), | intent(in) | :: | this |
ReLU activation type |
||
| type(array_type), | intent(in) | :: | val |
Input values |
Activated output values
Export ReLU activation function attributes as ONNX attributes
| Type | Intent | Optional | Attributes | Name | ||
|---|---|---|---|---|---|---|
| class(relu_actv_type), | intent(in) | :: | this |
ReLU activation type |
Array of ONNX attributes
Initialise a ReLU activation function
| Type | Intent | Optional | Attributes | Name | ||
|---|---|---|---|---|---|---|
| real(kind=real32), | intent(in), | optional | :: | scale |
Optional scale factor for activation output |
|
| type(onnx_attribute_type), | intent(in), | optional | :: | attributes(:) |
Optional ONNX attributes |
ReLU activation type
Load ONNX attributes into ReLU activation function
| Type | Intent | Optional | Attributes | Name | ||
|---|---|---|---|---|---|---|
| class(relu_actv_type), | intent(inout) | :: | this |
ReLU activation type |
||
| type(onnx_attribute_type), | intent(in), | dimension(:) | :: | attributes |
Array of ONNX attributes |
Reset ReLU activation function attributes and variables
| Type | Intent | Optional | Attributes | Name | ||
|---|---|---|---|---|---|---|
| class(relu_actv_type), | intent(inout) | :: | this |
ReLU activation type |