source: roaraudio/libroardsp/rms.c @ 3541:1e63ce5b7951

Last change on this file since 3541:1e63ce5b7951 was 3517:1a3218a3fc5b, checked in by phi, 14 years ago

updated license headers, FSF moved office

File size: 1.5 KB
Line 
1//rms.c:
2
3/*
4 *      Copyright (C) Philipp 'ph3-der-loewe' Schafft - 2009
5 *
6 *  This file is part of libroardsp a part of RoarAudio,
7 *  a cross-platform sound system for both, home and professional use.
8 *  See README for details.
9 *
10 *  This file is free software; you can redistribute it and/or modify
11 *  it under the terms of the GNU General Public License version 3
12 *  as published by the Free Software Foundation.
13 *
14 *  libroardsp is distributed in the hope that it will be useful,
15 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
16 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17 *  GNU General Public License for more details.
18 *
19 *  You should have received a copy of the GNU General Public License
20 *  along with this software; see the file COPYING.  If not, write to
21 *  the Free Software Foundation, 51 Franklin Street, Fifth Floor,
22 *  Boston, MA 02110-1301, USA.
23 *
24 */
25
26#include "libroardsp.h"
27
28int64_t roar_rms2_1_8  (int8_t  * data, size_t samples) {
29 register int64_t s = 0;
30 register size_t  i;
31
32 for (i = 0; i < samples; i++)
33  s += data[i] * data[i];
34
35 s /= samples;
36
37 return s;
38}
39
40int64_t roar_rms2_1_16 (int16_t * data, size_t samples) {
41 register int64_t s = 0;
42 register size_t  i;
43
44 for (i = 0; i < samples; i++)
45  s += data[i] * data[i];
46
47 s /= samples;
48
49 return s;
50}
51
52int64_t roar_rms2_1_32 (int32_t * data, size_t samples) {
53 register int64_t s = 0;
54 register size_t  i;
55
56 for (i = 0; i < samples; i++)
57  s += data[i] * data[i];
58
59 s /= samples;
60
61 return s;
62}
63
64
65//ll
Note: See TracBrowser for help on using the repository browser.