AIfES 2  2.0.0
ailayer_softsign.h File Reference

Base layer implementation of the Softsign activation layer. More...

Go to the source code of this file.

Data Structures

struct  ailayer_softsign
 General Softsign layer struct. More...
 

Typedefs

typedef struct ailayer_softsign ailayer_softsign_t
 

Functions

ailayer_tailayer_softsign (ailayer_softsign_t *layer, ailayer_t *input_layer)
 Initialize and connect the given Softsign layer. More...
 
void ailayer_softsign_forward (ailayer_t *self)
 Calculate the forward pass for given Tanh layer. More...
 
void ailayer_softsign_backward (ailayer_t *self)
 Calculate the backward pass for the given Softsign layer. More...
 
void ailayer_softsign_calc_result_shape (ailayer_t *self)
 Calculate the shape of the result tensor. More...
 
void ailayer_softsign_print_specs (const ailayer_t *self)
 Print the layer specification. More...
 

Variables

const aicore_layertype_tailayer_softsign_type
 Softsign layer type. More...
 

Detailed Description

Base layer implementation of the Softsign activation layer.

Version
2.2.0

This is an "abstract" data-type independent implementation. To use the layer use one of the provided implementations for a specific hardware and data-type (for example from ailayer_softsign_default.h) or set the required math functions on your own.

The Softsign layer is used as an activation function layer right after a dense layer. It calculates

\[ y = \frac {x} {1 + |x|} \]

for every element of the input tensor.

The results of the forward pass of this layer are written to the result tensor of the base ailayer_t struct.

Function Documentation

◆ ailayer_softsign()

ailayer_t* ailayer_softsign ( ailayer_softsign_t layer,
ailayer_t input_layer 
)

Initialize and connect the given Softsign layer.

This function represents the "constructor" of the abstract Softsign layer. It initializes the layer structure and connects it to the previous layer.
This function is not intended to call it directly. Instead use one of the data type specific implementations (like for example ailayer_softsign_f32_default()).

Parameters
*layerThe layer to initialize.
*input_layerThe previous layer that provides the inputs to the layer.
Returns
Pointer to the (successfully) initialized general layer structure (ailayer_softsign.base).

◆ ailayer_softsign_backward()

void ailayer_softsign_backward ( ailayer_t self)

Calculate the backward pass for the given Softsign layer.

Implementation of ailayer.backward.

It uses the deltas tensor of the next layer as input and writes the result of the backward pass to the deltas tensor (ailayer.deltas) of the given layer.

Calculation of the errors for the previous layer:

\[ \delta_{in} \leftarrow \delta_{out} \circ Softsign'(x_{in}) \]

\( x_{in} \): Result of the forward pass of the previous layer
\( \delta_{in} \): Result of the backward pass of this layer
\( \delta_{out} \): Result of the backward pass of the next layer

Used math functions:

Parameters
*selfLayer to calculate the backward path for.

◆ ailayer_softsign_calc_result_shape()

void ailayer_softsign_calc_result_shape ( ailayer_t self)

Calculate the shape of the result tensor.

Implementation of ailayer.calc_result_shape.

As the result tensor shape is shared with the result tensor shape of the previous layer (no change in shape is needed), this function returns without doing anything.

Parameters
*selfLayer to calculate the resulting shape for.

◆ ailayer_softsign_forward()

void ailayer_softsign_forward ( ailayer_t self)

Calculate the forward pass for given Tanh layer.

Implementation of ailayer.forward.

It uses the result tensor of the previous layer as input and writes the result of the forward pass to the result tensor (ailayer.result) of the given layer.

Calculation of the forward pass result:

\[ x_{out} \leftarrow Softsign(x_{in}) \]

\( x_{in} \): Result of the forward pass of the previous layer
\( x_{out} \): Result of the forward pass of this layer

Used math functions:

Parameters
*selfLayer to calculate the forward pass for.

◆ ailayer_softsign_print_specs()

void ailayer_softsign_print_specs ( const ailayer_t self)

Print the layer specification.

Parameters
*selfThe layer to print the specification for

Variable Documentation

◆ ailayer_softsign_type

const aicore_layertype_t* ailayer_softsign_type
extern

Softsign layer type.

Defines the type of the layer (for example for type checks and debug prints). See aicore_layertype for more information about the layer type.