Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Diff: cmsis_dsp/StatisticsFunctions/arm_rms_q15.c
- Revision:
- 3:7a284390b0ce
- Parent:
- 2:da51fb522205
- Child:
- 5:3762170b6d4d
--- a/cmsis_dsp/StatisticsFunctions/arm_rms_q15.c Thu May 30 17:10:11 2013 +0100
+++ b/cmsis_dsp/StatisticsFunctions/arm_rms_q15.c Fri Nov 08 13:45:10 2013 +0000
@@ -1,8 +1,8 @@
/* ----------------------------------------------------------------------
-* Copyright (C) 2010 ARM Limited. All rights reserved.
+* Copyright (C) 2010-2013 ARM Limited. All rights reserved.
*
-* $Date: 15. February 2012
-* $Revision: V1.1.0
+* $Date: 17. January 2013
+* $Revision: V1.4.1
*
* Project: CMSIS DSP Library
* Title: arm_rms_q15.c
@@ -11,23 +11,31 @@
*
* Target Processor: Cortex-M4/Cortex-M3/Cortex-M0
*
-* Version 1.1.0 2012/02/15
-* Updated with more optimizations, bug fixes and minor API changes.
-*
-* Version 1.0.10 2011/7/15
-* Big Endian support added and Merged M0 and M3/M4 Source code.
-*
-* Version 1.0.3 2010/11/29
-* Re-organized the CMSIS folders and updated documentation.
-*
-* 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.
+* Redistribution and use in source and binary forms, with or without
+* modification, are permitted provided that the following conditions
+* are met:
+* - Redistributions of source code must retain the above copyright
+* notice, this list of conditions and the following disclaimer.
+* - Redistributions in binary form must reproduce the above copyright
+* notice, this list of conditions and the following disclaimer in
+* the documentation and/or other materials provided with the
+* distribution.
+* - Neither the name of ARM LIMITED nor the names of its contributors
+* may be used to endorse or promote products derived from this
+* software without specific prior written permission.
+*
+* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
+* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
+* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
+* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
+* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
+* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
+* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
+* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
+* POSSIBILITY OF SUCH DAMAGE.
* ---------------------------------------------------------------------------- */
#include "arm_math.h"
@@ -66,7 +74,7 @@
{
q63_t sum = 0; /* accumulator */
-#ifndef ARM_MATH_CM0
+#ifndef ARM_MATH_CM0_FAMILY
/* Run the below code for Cortex-M4 and Cortex-M3 */
@@ -108,9 +116,9 @@
}
/* Truncating and saturating the accumulator to 1.15 format */
- sum = __SSAT((q31_t) (sum >> 15), 16);
+ in = (q31_t)(sum >> 15);
- in1 = (q15_t) (sum / blockSize);
+ in1 = __SSAT(in / blockSize, 16);
/* Store the result in the destination */
arm_sqrt_q15(in1, pResult);
@@ -120,6 +128,7 @@
/* Run the below code for Cortex-M0 */
q15_t in; /* temporary variable to store the input value */
+ q31_t tmp; /* temporary variable to store the input value */
uint32_t blkCnt; /* loop counter */
/* Loop over blockSize number of values */
@@ -137,14 +146,14 @@
}
/* Truncating and saturating the accumulator to 1.15 format */
- sum = __SSAT((q31_t) (sum >> 15), 16);
+ tmp = (q31_t)(sum >> 15);
- in = (q15_t) (sum / blockSize);
+ in = __SSAT(tmp / blockSize, 16);
/* Store the result in the destination */
arm_sqrt_q15(in, pResult);
-#endif /* #ifndef ARM_MATH_CM0 */
+#endif /* #ifndef ARM_MATH_CM0_FAMILY */
}