CMSIS-NN  Version 3.1.0
CMSIS NN Software Library
 All Data Structures Files Functions Variables Enumerations Enumerator Macros Groups Pages
Basic math functions

Functions

arm_status arm_elementwise_add_s16 (const int16_t *input_1_vect, const int16_t *input_2_vect, const int32_t input_1_offset, const int32_t input_1_mult, const int32_t input_1_shift, const int32_t input_2_offset, const int32_t input_2_mult, const int32_t input_2_shift, const int32_t left_shift, int16_t *output, const int32_t out_offset, const int32_t out_mult, const int32_t out_shift, const int32_t out_activation_min, const int32_t out_activation_max, const int32_t block_size)
 s16 elementwise add of two vectors More...
 
arm_status arm_elementwise_add_s8 (const int8_t *input_1_vect, const int8_t *input_2_vect, const int32_t input_1_offset, const int32_t input_1_mult, const int32_t input_1_shift, const int32_t input_2_offset, const int32_t input_2_mult, const int32_t input_2_shift, const int32_t left_shift, int8_t *output, const int32_t out_offset, const int32_t out_mult, const int32_t out_shift, const int32_t out_activation_min, const int32_t out_activation_max, const int32_t block_size)
 s8 elementwise add of two vectors More...
 
arm_status arm_elementwise_mul_s16 (const int16_t *input_1_vect, const int16_t *input_2_vect, const int32_t input_1_offset, const int32_t input_2_offset, int16_t *output, const int32_t out_offset, const int32_t out_mult, const int32_t out_shift, const int32_t out_activation_min, const int32_t out_activation_max, const int32_t block_size)
 s16 element wise multiplication of two vectors More...
 
arm_status arm_elementwise_mul_s8 (const int8_t *input_1_vect, const int8_t *input_2_vect, const int32_t input_1_offset, const int32_t input_2_offset, int8_t *output, const int32_t out_offset, const int32_t out_mult, const int32_t out_shift, const int32_t out_activation_min, const int32_t out_activation_max, const int32_t block_size)
 s8 element wise multiplication of two vectors More...
 

Description

Elementwise add and multiplication functions.

Function Documentation

arm_status arm_elementwise_add_s16 ( const int16_t *  input_1_vect,
const int16_t *  input_2_vect,
const int32_t  input_1_offset,
const int32_t  input_1_mult,
const int32_t  input_1_shift,
const int32_t  input_2_offset,
const int32_t  input_2_mult,
const int32_t  input_2_shift,
const int32_t  left_shift,
int16_t *  output,
const int32_t  out_offset,
const int32_t  out_mult,
const int32_t  out_shift,
const int32_t  out_activation_min,
const int32_t  out_activation_max,
const int32_t  block_size 
)
Parameters
[in]input_1_vectpointer to input vector 1
[in]input_2_vectpointer to input vector 2
[in]input_1_offsetoffset for input 1. Not used.
[in]input_1_multmultiplier for input 1
[in]input_1_shiftshift for input 1
[in]input_2_offsetoffset for input 2. Not used.
[in]input_2_multmultiplier for input 2
[in]input_2_shiftshift for input 2
[in]left_shiftinput left shift
[in,out]outputpointer to output vector
[in]out_offsetoutput offset. Not used.
[in]out_multoutput multiplier
[in]out_shiftoutput shift
[in]out_activation_minminimum value to clamp output to. Min: -32768
[in]out_activation_maxmaximum value to clamp output to. Max: 32767
[in]block_sizenumber of samples
Returns
The function returns ARM_MATH_SUCCESS

References arm_nn_requantize(), MAX, and MIN.

arm_status arm_elementwise_add_s8 ( const int8_t *  input_1_vect,
const int8_t *  input_2_vect,
const int32_t  input_1_offset,
const int32_t  input_1_mult,
const int32_t  input_1_shift,
const int32_t  input_2_offset,
const int32_t  input_2_mult,
const int32_t  input_2_shift,
const int32_t  left_shift,
int8_t *  output,
const int32_t  out_offset,
const int32_t  out_mult,
const int32_t  out_shift,
const int32_t  out_activation_min,
const int32_t  out_activation_max,
const int32_t  block_size 
)
Parameters
[in]input_1_vectpointer to input vector 1
[in]input_2_vectpointer to input vector 2
[in]input_1_offsetoffset for input 1. Range: -127 to 128
[in]input_1_multmultiplier for input 1
[in]input_1_shiftshift for input 1
[in]input_2_offsetoffset for input 2. Range: -127 to 128
[in]input_2_multmultiplier for input 2
[in]input_2_shiftshift for input 2
[in]left_shiftinput left shift
[in,out]outputpointer to output vector
[in]out_offsetoutput offset. Range: -128 to 127
[in]out_multoutput multiplier
[in]out_shiftoutput shift
[in]out_activation_minminimum value to clamp output to. Min: -128
[in]out_activation_maxmaximum value to clamp output to. Max: 127
[in]block_sizenumber of samples
Returns
The function returns ARM_MATH_SUCCESS

References arm_nn_requantize(), arm_nn_write_q7x4_ia(), MAX, MIN, and PACK_Q7x4_32x1.

arm_status arm_elementwise_mul_s16 ( const int16_t *  input_1_vect,
const int16_t *  input_2_vect,
const int32_t  input_1_offset,
const int32_t  input_2_offset,
int16_t *  output,
const int32_t  out_offset,
const int32_t  out_mult,
const int32_t  out_shift,
const int32_t  out_activation_min,
const int32_t  out_activation_max,
const int32_t  block_size 
)

s16 elementwise multiplication

Note
Refer header file for details.

References arm_nn_requantize(), MAX, and MIN.

arm_status arm_elementwise_mul_s8 ( const int8_t *  input_1_vect,
const int8_t *  input_2_vect,
const int32_t  input_1_offset,
const int32_t  input_2_offset,
int8_t *  output,
const int32_t  out_offset,
const int32_t  out_mult,
const int32_t  out_shift,
const int32_t  out_activation_min,
const int32_t  out_activation_max,
const int32_t  block_size 
)

s8 elementwise multiplication

Note
Refer header file for details.

References arm_nn_requantize(), arm_nn_write_q7x4_ia(), MAX, MIN, and PACK_Q7x4_32x1.