##// END OF EJS Templates
Added Oplayer BSP, Fixed bug on GPIO library(gpiosetval change all the port...
Added Oplayer BSP, Fixed bug on GPIO library(gpiosetval change all the port instead of the desired bit).

File last commit:

r41:27c5438a4566 dev_alexis
r60:17402611bd25 dev_alexis
Show More
arm_sqrt_q31.c
199 lines | 6.2 KiB | text/x-c | CLexer
jeandet@pc-de-jeandet3.LAB-LPP.LOCAL
Added ARM CMSIS for fast math and circle drawing function for ili9328 driver.
r41 /* ----------------------------------------------------------------------
* Copyright (C) 2010 ARM Limited. All rights reserved.
*
* $Date: 15. July 2011
* $Revision: V1.0.10
*
* Project: CMSIS DSP Library
* Title: arm_sqrt_q31.c
*
* Description: Q31 square root function.
*
* Target Processor: Cortex-M4/Cortex-M3/Cortex-M0
*
* Version 1.0.10 2011/7/15
* Big Endian support added and Merged M0 and M3/M4 Source code.
*
* Version 1.0.2 2010/11/11
* Documentation updated.
*
* Version 1.0.1 2010/10/05
* Production release and review comments incorporated.
*
* Version 1.0.0 2010/09/20
* Production release and review comments incorporated.
* -------------------------------------------------------------------- */
#include "arm_math.h"
#include "arm_common_tables.h"
/**
* @ingroup groupFastMath
*/
/**
* @addtogroup SQRT
* @{
*/
/**
* @brief Q31 square root function.
* @param[in] in input value. The range of the input value is [0 +1) or 0x00000000 to 0x7FFFFFFF.
* @param[out] *pOut square root of input value.
* @return The function returns ARM_MATH_SUCCESS if input value is positive value or ARM_MATH_ARGUMENT_ERROR if
* <code>in</code> is negative value and returns zero output for negative values.
*/
arm_status arm_sqrt_q31(
q31_t in,
q31_t * pOut)
{
q63_t prevOut;
q31_t oneByOut;
uint32_t signBits;
#ifndef ARM_MATH_CM0
/* Run the below code for Cortex-M4 and Cortex-M3 */
q63_t out;
if(in > 0)
{
/* run for ten iterations */
/* Take initial guess as half of the input and first iteration */
out = (in >> 1) + 0x3FFFFFFF;
/* Calculation of reciprocal of out */
/* oneByOut contains reciprocal of out which is in 2.30 format
and oneByOut should be upscaled by signBits */
signBits = arm_recip_q31((q31_t) out, &oneByOut, armRecipTableQ31);
/* 0.5 * (out) */
out = out >> 1u;
/* prevOut = 0.5 * out + (in * (oneByOut << signBits))) */
prevOut = out + (((q31_t) (((q63_t) in * oneByOut) >> 32)) << signBits);
/* Third iteration */
signBits = arm_recip_q31((q31_t) prevOut, &oneByOut, armRecipTableQ31);
prevOut = prevOut >> 1u;
out = prevOut + (((q31_t) (((q63_t) in * oneByOut) >> 32)) << signBits);
signBits = arm_recip_q31((q31_t) out, &oneByOut, armRecipTableQ31);
out = out >> 1u;
prevOut = out + (((q31_t) (((q63_t) in * oneByOut) >> 32)) << signBits);
/* Fifth iteration */
signBits = arm_recip_q31((q31_t) prevOut, &oneByOut, armRecipTableQ31);
prevOut = prevOut >> 1u;
out = prevOut + (((q31_t) (((q63_t) in * oneByOut) >> 32)) << signBits);
signBits = arm_recip_q31((q31_t) out, &oneByOut, armRecipTableQ31);
out = out >> 1u;
prevOut = out + (((q31_t) (((q63_t) in * oneByOut) >> 32)) << signBits);
/* Seventh iteration */
signBits = arm_recip_q31((q31_t) prevOut, &oneByOut, armRecipTableQ31);
prevOut = prevOut >> 1u;
out = prevOut + (((q31_t) (((q63_t) in * oneByOut) >> 32)) << signBits);
signBits = arm_recip_q31((q31_t) out, &oneByOut, armRecipTableQ31);
out = out >> 1u;
prevOut = out + (((q31_t) (((q63_t) in * oneByOut) >> 32)) << signBits);
signBits = arm_recip_q31((q31_t) prevOut, &oneByOut, armRecipTableQ31);
prevOut = prevOut >> 1u;
out = prevOut + (((q31_t) (((q63_t) in * oneByOut) >> 32)) << signBits);
signBits = arm_recip_q31((q31_t) out, &oneByOut, armRecipTableQ31);
out = out >> 1u;
prevOut = out + (((q31_t) (((q63_t) in * oneByOut) >> 32)) << signBits);
signBits = arm_recip_q31((q31_t) prevOut, &oneByOut, armRecipTableQ31);
prevOut = prevOut >> 1u;
out = prevOut + (((q31_t) (((q63_t) in * oneByOut) >> 32)) << signBits);
signBits = arm_recip_q31((q31_t) out, &oneByOut, armRecipTableQ31);
out = out >> 1u;
prevOut = out + (((q31_t) (((q63_t) in * oneByOut) >> 32)) << signBits);
signBits = arm_recip_q31((q31_t) prevOut, &oneByOut, armRecipTableQ31);
prevOut = prevOut >> 1u;
out = prevOut + (((q31_t) (((q63_t) in * oneByOut) >> 32)) << signBits);
signBits = arm_recip_q31((q31_t) out, &oneByOut, armRecipTableQ31);
out = out >> 1u;
prevOut = out + (((q31_t) (((q63_t) in * oneByOut) >> 32)) << signBits);
signBits = arm_recip_q31((q31_t) prevOut, &oneByOut, armRecipTableQ31);
prevOut = prevOut >> 1u;
out = prevOut + (((q31_t) (((q63_t) in * oneByOut) >> 32)) << signBits);
/* tenth iteration */
signBits = arm_recip_q31((q31_t) out, &oneByOut, armRecipTableQ31);
out = out >> 1u;
*pOut = out + (((q31_t) (((q63_t) in * oneByOut) >> 32)) << signBits);
return (ARM_MATH_SUCCESS);
}
#else
/* Run the below code for Cortex-M0 */
q63_t out, loopVar; /* Temporary variable for output, loop variable */
if(in > 0)
{
/* run for ten iterations */
/* Take initial guess as half of the input and first iteration */
out = (in >> 1) + 0x3FFFFFFF;
/* Calculation of reciprocal of out */
/* oneByOut contains reciprocal of out which is in 2.30 format
and oneByOut should be upscaled by sign bits */
signBits = arm_recip_q31((q31_t) out, &oneByOut, armRecipTableQ31);
/* 0.5 * (out) */
out = out >> 1u;
/* prevOut = 0.5 * out + (in * (oneByOut) << signbits) */
prevOut = out + (((q31_t) (((q63_t) in * oneByOut) >> 32)) << signBits);
/* loop for third iteration to tength iteration */
for (loopVar = 1; loopVar <= 14; loopVar++)
{
signBits = arm_recip_q31((q31_t) prevOut, &oneByOut, armRecipTableQ31);
/* 0.5 * (prevOut) */
prevOut = prevOut >> 1u;
/* out = 0.5 * prevOut + (in * oneByOut) << signbits))) */
out = prevOut + (((q31_t) (((q63_t) in * oneByOut) >> 32)) << signBits);
/* prevOut = out */
prevOut = out;
}
/* output is moved to pOut pointer */
*pOut = prevOut;
return (ARM_MATH_SUCCESS);
}
#endif /* #ifndef ARM_MATH_CM0 */
else
{
*pOut = 0;
return (ARM_MATH_ARGUMENT_ERROR);
}
}
/**
* @} end of SQRT group
*/