mirror of
https://gitee.com/Lyon1998/pikapython.git
synced 2025-01-22 17:12:55 +08:00
190 lines
4.9 KiB
C
190 lines
4.9 KiB
C
|
/******************************************************************************
|
||
|
* @file arm_2d_math.h
|
||
|
* @brief Public header file for Arm-2D Library
|
||
|
* @version V1.0.0
|
||
|
* @date 16. June 2021
|
||
|
******************************************************************************/
|
||
|
/*
|
||
|
* Copyright (c) 2010-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.
|
||
|
*/
|
||
|
|
||
|
#ifndef __ARM_2D_MATH_H__
|
||
|
#define __ARM_2D_MATH_H__
|
||
|
|
||
|
/*============================ INCLUDES ======================================*/
|
||
|
|
||
|
|
||
|
/*! \note this header file is not standalone, and please always use it after
|
||
|
*! #include "arm_2d_features.h"
|
||
|
*! #include "arm_2d_utils.h"
|
||
|
*! in your c source file if you insist to use it explicity.
|
||
|
*/
|
||
|
|
||
|
#if defined(__clang__)
|
||
|
# pragma clang diagnostic push
|
||
|
# pragma clang diagnostic ignored "-Wunknown-warning-option"
|
||
|
# pragma clang diagnostic ignored "-Wreserved-identifier"
|
||
|
# pragma clang diagnostic ignored "-Wgnu-zero-variadic-macro-arguments"
|
||
|
# pragma clang diagnostic ignored "-Wpadded"
|
||
|
# pragma clang diagnostic ignored "-Wsign-conversion"
|
||
|
# pragma clang diagnostic ignored "-Wimplicit-int-conversion"
|
||
|
# pragma clang diagnostic ignored "-Wundef"
|
||
|
#elif __IS_COMPILER_GCC__
|
||
|
# pragma GCC diagnostic push
|
||
|
# pragma GCC diagnostic ignored "-Wpedantic"
|
||
|
#endif
|
||
|
|
||
|
#if defined(__IS_COMPILER_ARM_COMPILER_5__) \
|
||
|
&& defined(__ARM_2D_HAS_HELIUM__) && __ARM_2D_HAS_HELIUM__
|
||
|
# warning 'Arm Compiler 5 doesn\'t support Armv8.1-M architecture, please use \
|
||
|
Arm Compiler 5 instead. If you insist using Arm Compiler 5,\
|
||
|
__ARM_2D_HAS_HELIUM__ is forced to 0.'
|
||
|
# undef __ARM_2D_HAS_HELIUM__
|
||
|
# define __ARM_2D_HAS_HELIUM__ 0
|
||
|
#endif
|
||
|
|
||
|
|
||
|
#if defined(__ARM_2D_HAS_HELIUM__) && __ARM_2D_HAS_HELIUM__
|
||
|
#include <arm_mve.h>
|
||
|
#else
|
||
|
// if MVE is not defined, use float type for bilinear interpolation
|
||
|
typedef float float16_t;
|
||
|
#endif
|
||
|
|
||
|
#if __ARM_2D_HAS_DSP__
|
||
|
|
||
|
#if defined(__IS_COMPILER_ARM_COMPILER_5__)
|
||
|
# include "armdsp.h"
|
||
|
#else
|
||
|
# include <arm_acle.h>
|
||
|
#endif
|
||
|
|
||
|
#endif
|
||
|
|
||
|
#include "arm_math.h"
|
||
|
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
extern "C" {
|
||
|
#endif
|
||
|
|
||
|
/*============================ MACROS ========================================*/
|
||
|
|
||
|
/*----------------------------------------------------------------------------*
|
||
|
* Math *
|
||
|
*----------------------------------------------------------------------------*/
|
||
|
#ifndef MAX
|
||
|
# define MAX(a,b) ((a) > (b) ? (a) : (b))
|
||
|
#endif
|
||
|
|
||
|
#ifndef MIN
|
||
|
# define MIN(a,b) ((a) < (b) ? (a) : (b))
|
||
|
#endif
|
||
|
|
||
|
#ifndef _BV
|
||
|
# define _BV(__BIT) (1 << (__BIT))
|
||
|
#endif
|
||
|
|
||
|
#ifndef ABS
|
||
|
# define ABS(x) ((x) > 0 ? (x) : -(x))
|
||
|
#endif
|
||
|
|
||
|
#undef MULTFX
|
||
|
/* 32 bit multiplication with high part extraction */
|
||
|
#define MULTFX(x,y) (q31_t)((q63_t)((q63_t) (x) * (q63_t)(y)) >> 32)
|
||
|
|
||
|
/* Q16 multiplication */
|
||
|
#undef MUL_Q16
|
||
|
#define MUL_Q16(x,y) (q31_t)((q63_t)((q63_t) (x) * (q63_t)(y)) >> 16)
|
||
|
|
||
|
|
||
|
#define ARM_PIX_SCLTYP(sz) ARM_CONNECT2(ARM_CONNECT2(uint, sz), _t)
|
||
|
|
||
|
#define ARM_2D_ANGLE(__ANGLE) ((float)((float)(__ANGLE) * 3.1415926f / 180.0f))
|
||
|
|
||
|
#if __ARM_2D_HAS_DSP__
|
||
|
|
||
|
#undef __QDADD
|
||
|
#undef __QDSUB
|
||
|
#define __QDADD(X, Y) __qadd(X, __qdbl(Y))
|
||
|
#define __QDSUB(X, Y) __qsub(X, __qdbl(Y))
|
||
|
|
||
|
#define __LARGEINVF32 100.0f
|
||
|
|
||
|
/*============================ TYPES =========================================*/
|
||
|
/*============================ GLOBAL VARIABLES ==============================*/
|
||
|
/*============================ PROTOTYPES ====================================*/
|
||
|
|
||
|
#elif defined(__ARM_2D_CFG_UNSAFE_NO_SATURATION_IN_FIXED_POINT__)
|
||
|
/*
|
||
|
* @brief C custom defined QDADD
|
||
|
*/
|
||
|
__STATIC_FORCEINLINE int32_t __QDADD(
|
||
|
int32_t x,
|
||
|
int32_t y)
|
||
|
{
|
||
|
return x + y * 2;
|
||
|
}
|
||
|
/*
|
||
|
* @brief C custom defined QDSUB
|
||
|
*/
|
||
|
__STATIC_FORCEINLINE int32_t __QDSUB(
|
||
|
int32_t x,
|
||
|
int32_t y)
|
||
|
{
|
||
|
return x - y * 2;
|
||
|
}
|
||
|
#else
|
||
|
|
||
|
/*
|
||
|
* @brief C custom defined QDADD
|
||
|
*/
|
||
|
__STATIC_FORCEINLINE int32_t __QDADD(
|
||
|
int32_t x,
|
||
|
int32_t y)
|
||
|
{
|
||
|
return ((int32_t)(clip_q63_to_q31((q63_t)x + (q63_t)y*2)));
|
||
|
}
|
||
|
/*
|
||
|
* @brief C custom defined QDSUB
|
||
|
*/
|
||
|
__STATIC_FORCEINLINE int32_t __QDSUB(
|
||
|
int32_t x,
|
||
|
int32_t y)
|
||
|
{
|
||
|
return ((int32_t)(clip_q63_to_q31((q63_t)x - (q63_t)2*y)));
|
||
|
}
|
||
|
|
||
|
#endif
|
||
|
|
||
|
|
||
|
|
||
|
#if defined(__clang__)
|
||
|
# pragma clang diagnostic pop
|
||
|
#elif __IS_COMPILER_ARM_COMPILER_5__
|
||
|
#elif __IS_COMPILER_GCC__
|
||
|
# pragma GCC diagnostic pop
|
||
|
#endif
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
}
|
||
|
#endif
|
||
|
|
||
|
|
||
|
#endif /* end of __ARM_2D_MATH_H__ */
|
||
|
|