/* * Copyright (C) 2020 Arm Limited or its affiliates. All rights reserved. * * SPDX-License-Identifier: Apache-2.0 * * Licensed under the Apache License, Version 2.0 (the License); you may * not use this file except in compliance with the License. * You may obtain a copy of the License at * * www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an AS IS BASIS, WITHOUT * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /* ---------------------------------------------------------------------- * Project: CMSIS NN Library * Title: arm_nn_types.h * Description: Public header file to contain the CMSIS-NN structs for the * TensorFlowLite micro compliant functions * * $Date: April 23, 2020 * $Revision: V.0.5.0 * * Target Processor: Cortex-M cores * -------------------------------------------------------------------- */ #ifndef _ARM_NN_TYPES_H #define _ARM_NN_TYPES_H /** CMSIS-NN object to contain the width and height of a tile */ typedef struct { int32_t w; /**< Width */ int32_t h; /**< Height */ } cmsis_nn_tile; /** CMSIS-NN object used for the function context. */ typedef struct { void *buf; /**< Pointer to a buffer needed for the optimization */ int32_t size; /**< Buffer size */ } cmsis_nn_context; /** CMSIS-NN object to contain the dimensions of the tensors */ typedef struct { int32_t n; /**< Generic dimension to contain either the batch size or output channels. Please refer to the function documentation for more information */ int32_t h; /**< Height */ int32_t w; /**< Width */ int32_t c; /**< Input channels */ } cmsis_nn_dims; /** CMSIS-NN object for the per-channel quantization parameters */ typedef struct { int32_t *multiplier; /**< Multiplier values */ int32_t *shift; /**< Shift values */ } cmsis_nn_per_channel_quant_params; /** CMSIS-NN object for the per-tensor quantization parameters */ typedef struct { int32_t multiplier; /**< Multiplier value */ int32_t shift; /**< Shift value */ } cmsis_nn_per_tensor_quant_params; /** CMSIS-NN object for the quantized Relu activation */ typedef struct { int32_t min; /**< Min value used to clamp the result */ int32_t max; /**< Max value used to clamp the result */ } cmsis_nn_activation; /** CMSIS-NN object for the convolution layer parameters */ typedef struct { int32_t input_offset; /**< Zero value for the input tensor */ int32_t output_offset; /**< Zero value for the output tensor */ cmsis_nn_tile stride; cmsis_nn_tile padding; cmsis_nn_tile dilation; cmsis_nn_activation activation; } cmsis_nn_conv_params; /** CMSIS-NN object for Depthwise convolution layer parameters */ typedef struct { int32_t input_offset; /**< Zero value for the input tensor */ int32_t output_offset; /**< Zero value for the output tensor */ int32_t ch_mult; /**< Channel Multiplier. ch_mult * in_ch = out_ch */ cmsis_nn_tile stride; cmsis_nn_tile padding; cmsis_nn_tile dilation; cmsis_nn_activation activation; } cmsis_nn_dw_conv_params; /** CMSIS-NN object for pooling layer parameters */ typedef struct { cmsis_nn_tile stride; cmsis_nn_tile padding; cmsis_nn_activation activation; } cmsis_nn_pool_params; /** CMSIS-NN object for Fully Connected layer parameters */ typedef struct { int32_t input_offset; /**< Zero value for the input tensor */ int32_t filter_offset; /**< Zero value for the filter tensor */ int32_t output_offset; /**< Zero value for the output tensor */ cmsis_nn_activation activation; } cmsis_nn_fc_params; #endif // _ARM_NN_TYPES_H