FFmpeg
Main Page
Related Pages
Modules
Namespaces
Data Structures
Files
Examples
File List
Globals
•
All
Data Structures
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Enumerator
Macros
Groups
Pages
libavcodec
dcadsp.c
Go to the documentation of this file.
1
/*
2
* Copyright (c) 2004 Gildas Bazin
3
* Copyright (c) 2010 Mans Rullgard <mans@mansr.com>
4
*
5
* This file is part of FFmpeg.
6
*
7
* FFmpeg is free software; you can redistribute it and/or
8
* modify it under the terms of the GNU Lesser General Public
9
* License as published by the Free Software Foundation; either
10
* version 2.1 of the License, or (at your option) any later version.
11
*
12
* FFmpeg is distributed in the hope that it will be useful,
13
* but WITHOUT ANY WARRANTY; without even the implied warranty of
14
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15
* Lesser General Public License for more details.
16
*
17
* You should have received a copy of the GNU Lesser General Public
18
* License along with FFmpeg; if not, write to the Free Software
19
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20
*/
21
22
#include "config.h"
23
#include "
libavutil/attributes.h
"
24
#include "
dcadsp.h
"
25
26
static
void
dca_lfe_fir_c
(
float
*
out
,
const
float
*
in
,
const
float
*coefs,
27
int
decifactor,
float
scale
)
28
{
29
float
*out2 = out + decifactor;
30
const
float
*cf0 = coefs;
31
const
float
*cf1 = coefs + 256;
32
int
j, k;
33
34
/* One decimated sample generates 2*decifactor interpolated ones */
35
for
(k = 0; k < decifactor; k++) {
36
float
v0
= 0.0;
37
float
v1 = 0.0;
38
for
(j = 0; j < 256 / decifactor; j++) {
39
float
s
= in[-j];
40
v0 += s * *cf0++;
41
v1 += s * *--cf1;
42
}
43
*out++ = v0 *
scale
;
44
*out2++ = v1 *
scale
;
45
}
46
}
47
48
av_cold
void
ff_dcadsp_init
(
DCADSPContext
*
s
)
49
{
50
s->
lfe_fir
=
dca_lfe_fir_c
;
51
if
(ARCH_ARM)
ff_dcadsp_init_arm
(s);
52
}
Generated on Wed Jul 10 2013 23:47:56 for FFmpeg by
1.8.2