1*e5436536SAndroid Build Coastguard Worker /* -----------------------------------------------------------------------------
2*e5436536SAndroid Build Coastguard Worker Software License for The Fraunhofer FDK AAC Codec Library for Android
3*e5436536SAndroid Build Coastguard Worker
4*e5436536SAndroid Build Coastguard Worker © Copyright 1995 - 2018 Fraunhofer-Gesellschaft zur Förderung der angewandten
5*e5436536SAndroid Build Coastguard Worker Forschung e.V. All rights reserved.
6*e5436536SAndroid Build Coastguard Worker
7*e5436536SAndroid Build Coastguard Worker 1. INTRODUCTION
8*e5436536SAndroid Build Coastguard Worker The Fraunhofer FDK AAC Codec Library for Android ("FDK AAC Codec") is software
9*e5436536SAndroid Build Coastguard Worker that implements the MPEG Advanced Audio Coding ("AAC") encoding and decoding
10*e5436536SAndroid Build Coastguard Worker scheme for digital audio. This FDK AAC Codec software is intended to be used on
11*e5436536SAndroid Build Coastguard Worker a wide variety of Android devices.
12*e5436536SAndroid Build Coastguard Worker
13*e5436536SAndroid Build Coastguard Worker AAC's HE-AAC and HE-AAC v2 versions are regarded as today's most efficient
14*e5436536SAndroid Build Coastguard Worker general perceptual audio codecs. AAC-ELD is considered the best-performing
15*e5436536SAndroid Build Coastguard Worker full-bandwidth communications codec by independent studies and is widely
16*e5436536SAndroid Build Coastguard Worker deployed. AAC has been standardized by ISO and IEC as part of the MPEG
17*e5436536SAndroid Build Coastguard Worker specifications.
18*e5436536SAndroid Build Coastguard Worker
19*e5436536SAndroid Build Coastguard Worker Patent licenses for necessary patent claims for the FDK AAC Codec (including
20*e5436536SAndroid Build Coastguard Worker those of Fraunhofer) may be obtained through Via Licensing
21*e5436536SAndroid Build Coastguard Worker (www.vialicensing.com) or through the respective patent owners individually for
22*e5436536SAndroid Build Coastguard Worker the purpose of encoding or decoding bit streams in products that are compliant
23*e5436536SAndroid Build Coastguard Worker with the ISO/IEC MPEG audio standards. Please note that most manufacturers of
24*e5436536SAndroid Build Coastguard Worker Android devices already license these patent claims through Via Licensing or
25*e5436536SAndroid Build Coastguard Worker directly from the patent owners, and therefore FDK AAC Codec software may
26*e5436536SAndroid Build Coastguard Worker already be covered under those patent licenses when it is used for those
27*e5436536SAndroid Build Coastguard Worker licensed purposes only.
28*e5436536SAndroid Build Coastguard Worker
29*e5436536SAndroid Build Coastguard Worker Commercially-licensed AAC software libraries, including floating-point versions
30*e5436536SAndroid Build Coastguard Worker with enhanced sound quality, are also available from Fraunhofer. Users are
31*e5436536SAndroid Build Coastguard Worker encouraged to check the Fraunhofer website for additional applications
32*e5436536SAndroid Build Coastguard Worker information and documentation.
33*e5436536SAndroid Build Coastguard Worker
34*e5436536SAndroid Build Coastguard Worker 2. COPYRIGHT LICENSE
35*e5436536SAndroid Build Coastguard Worker
36*e5436536SAndroid Build Coastguard Worker Redistribution and use in source and binary forms, with or without modification,
37*e5436536SAndroid Build Coastguard Worker are permitted without payment of copyright license fees provided that you
38*e5436536SAndroid Build Coastguard Worker satisfy the following conditions:
39*e5436536SAndroid Build Coastguard Worker
40*e5436536SAndroid Build Coastguard Worker You must retain the complete text of this software license in redistributions of
41*e5436536SAndroid Build Coastguard Worker the FDK AAC Codec or your modifications thereto in source code form.
42*e5436536SAndroid Build Coastguard Worker
43*e5436536SAndroid Build Coastguard Worker You must retain the complete text of this software license in the documentation
44*e5436536SAndroid Build Coastguard Worker and/or other materials provided with redistributions of the FDK AAC Codec or
45*e5436536SAndroid Build Coastguard Worker your modifications thereto in binary form. You must make available free of
46*e5436536SAndroid Build Coastguard Worker charge copies of the complete source code of the FDK AAC Codec and your
47*e5436536SAndroid Build Coastguard Worker modifications thereto to recipients of copies in binary form.
48*e5436536SAndroid Build Coastguard Worker
49*e5436536SAndroid Build Coastguard Worker The name of Fraunhofer may not be used to endorse or promote products derived
50*e5436536SAndroid Build Coastguard Worker from this library without prior written permission.
51*e5436536SAndroid Build Coastguard Worker
52*e5436536SAndroid Build Coastguard Worker You may not charge copyright license fees for anyone to use, copy or distribute
53*e5436536SAndroid Build Coastguard Worker the FDK AAC Codec software or your modifications thereto.
54*e5436536SAndroid Build Coastguard Worker
55*e5436536SAndroid Build Coastguard Worker Your modified versions of the FDK AAC Codec must carry prominent notices stating
56*e5436536SAndroid Build Coastguard Worker that you changed the software and the date of any change. For modified versions
57*e5436536SAndroid Build Coastguard Worker of the FDK AAC Codec, the term "Fraunhofer FDK AAC Codec Library for Android"
58*e5436536SAndroid Build Coastguard Worker must be replaced by the term "Third-Party Modified Version of the Fraunhofer FDK
59*e5436536SAndroid Build Coastguard Worker AAC Codec Library for Android."
60*e5436536SAndroid Build Coastguard Worker
61*e5436536SAndroid Build Coastguard Worker 3. NO PATENT LICENSE
62*e5436536SAndroid Build Coastguard Worker
63*e5436536SAndroid Build Coastguard Worker NO EXPRESS OR IMPLIED LICENSES TO ANY PATENT CLAIMS, including without
64*e5436536SAndroid Build Coastguard Worker limitation the patents of Fraunhofer, ARE GRANTED BY THIS SOFTWARE LICENSE.
65*e5436536SAndroid Build Coastguard Worker Fraunhofer provides no warranty of patent non-infringement with respect to this
66*e5436536SAndroid Build Coastguard Worker software.
67*e5436536SAndroid Build Coastguard Worker
68*e5436536SAndroid Build Coastguard Worker You may use this FDK AAC Codec software or modifications thereto only for
69*e5436536SAndroid Build Coastguard Worker purposes that are authorized by appropriate patent licenses.
70*e5436536SAndroid Build Coastguard Worker
71*e5436536SAndroid Build Coastguard Worker 4. DISCLAIMER
72*e5436536SAndroid Build Coastguard Worker
73*e5436536SAndroid Build Coastguard Worker This FDK AAC Codec software is provided by Fraunhofer on behalf of the copyright
74*e5436536SAndroid Build Coastguard Worker holders and contributors "AS IS" and WITHOUT ANY EXPRESS OR IMPLIED WARRANTIES,
75*e5436536SAndroid Build Coastguard Worker including but not limited to the implied warranties of merchantability and
76*e5436536SAndroid Build Coastguard Worker fitness for a particular purpose. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
77*e5436536SAndroid Build Coastguard Worker CONTRIBUTORS BE LIABLE for any direct, indirect, incidental, special, exemplary,
78*e5436536SAndroid Build Coastguard Worker or consequential damages, including but not limited to procurement of substitute
79*e5436536SAndroid Build Coastguard Worker goods or services; loss of use, data, or profits, or business interruption,
80*e5436536SAndroid Build Coastguard Worker however caused and on any theory of liability, whether in contract, strict
81*e5436536SAndroid Build Coastguard Worker liability, or tort (including negligence), arising in any way out of the use of
82*e5436536SAndroid Build Coastguard Worker this software, even if advised of the possibility of such damage.
83*e5436536SAndroid Build Coastguard Worker
84*e5436536SAndroid Build Coastguard Worker 5. CONTACT INFORMATION
85*e5436536SAndroid Build Coastguard Worker
86*e5436536SAndroid Build Coastguard Worker Fraunhofer Institute for Integrated Circuits IIS
87*e5436536SAndroid Build Coastguard Worker Attention: Audio and Multimedia Departments - FDK AAC LL
88*e5436536SAndroid Build Coastguard Worker Am Wolfsmantel 33
89*e5436536SAndroid Build Coastguard Worker 91058 Erlangen, Germany
90*e5436536SAndroid Build Coastguard Worker
91*e5436536SAndroid Build Coastguard Worker www.iis.fraunhofer.de/amm
92*e5436536SAndroid Build Coastguard Worker [email protected]
93*e5436536SAndroid Build Coastguard Worker ----------------------------------------------------------------------------- */
94*e5436536SAndroid Build Coastguard Worker
95*e5436536SAndroid Build Coastguard Worker /**************************** AAC encoder library ******************************
96*e5436536SAndroid Build Coastguard Worker
97*e5436536SAndroid Build Coastguard Worker Author(s): M. Werner
98*e5436536SAndroid Build Coastguard Worker
99*e5436536SAndroid Build Coastguard Worker Description: Perceptual entropie module
100*e5436536SAndroid Build Coastguard Worker
101*e5436536SAndroid Build Coastguard Worker *******************************************************************************/
102*e5436536SAndroid Build Coastguard Worker
103*e5436536SAndroid Build Coastguard Worker #include "line_pe.h"
104*e5436536SAndroid Build Coastguard Worker #include "sf_estim.h"
105*e5436536SAndroid Build Coastguard Worker #include "bit_cnt.h"
106*e5436536SAndroid Build Coastguard Worker
107*e5436536SAndroid Build Coastguard Worker #include "genericStds.h"
108*e5436536SAndroid Build Coastguard Worker
109*e5436536SAndroid Build Coastguard Worker static const FIXP_DBL C1LdData =
110*e5436536SAndroid Build Coastguard Worker FL2FXCONST_DBL(3.0 / LD_DATA_SCALING); /* C1 = 3.0 = log(8.0)/log(2) */
111*e5436536SAndroid Build Coastguard Worker static const FIXP_DBL C2LdData = FL2FXCONST_DBL(
112*e5436536SAndroid Build Coastguard Worker 1.3219281 / LD_DATA_SCALING); /* C2 = 1.3219281 = log(2.5)/log(2) */
113*e5436536SAndroid Build Coastguard Worker static const FIXP_DBL C3LdData = FL2FXCONST_DBL(0.5593573); /* 1-C2/C1 */
114*e5436536SAndroid Build Coastguard Worker
115*e5436536SAndroid Build Coastguard Worker /* constants that do not change during successive pe calculations */
FDKaacEnc_prepareSfbPe(PE_CHANNEL_DATA * RESTRICT const peChanData,const FIXP_DBL * RESTRICT const sfbEnergyLdData,const FIXP_DBL * RESTRICT const sfbThresholdLdData,const FIXP_DBL * RESTRICT const sfbFormFactorLdData,const INT * RESTRICT const sfbOffset,const INT sfbCnt,const INT sfbPerGroup,const INT maxSfbPerGroup)116*e5436536SAndroid Build Coastguard Worker void FDKaacEnc_prepareSfbPe(PE_CHANNEL_DATA *RESTRICT const peChanData,
117*e5436536SAndroid Build Coastguard Worker const FIXP_DBL *RESTRICT const sfbEnergyLdData,
118*e5436536SAndroid Build Coastguard Worker const FIXP_DBL *RESTRICT const sfbThresholdLdData,
119*e5436536SAndroid Build Coastguard Worker const FIXP_DBL *RESTRICT const sfbFormFactorLdData,
120*e5436536SAndroid Build Coastguard Worker const INT *RESTRICT const sfbOffset,
121*e5436536SAndroid Build Coastguard Worker const INT sfbCnt, const INT sfbPerGroup,
122*e5436536SAndroid Build Coastguard Worker const INT maxSfbPerGroup) {
123*e5436536SAndroid Build Coastguard Worker INT sfbGrp, sfb;
124*e5436536SAndroid Build Coastguard Worker INT sfbWidth;
125*e5436536SAndroid Build Coastguard Worker FIXP_DBL avgFormFactorLdData;
126*e5436536SAndroid Build Coastguard Worker const FIXP_DBL formFacScaling =
127*e5436536SAndroid Build Coastguard Worker FL2FXCONST_DBL((float)FORM_FAC_SHIFT / LD_DATA_SCALING);
128*e5436536SAndroid Build Coastguard Worker
129*e5436536SAndroid Build Coastguard Worker for (sfbGrp = 0; sfbGrp < sfbCnt; sfbGrp += sfbPerGroup) {
130*e5436536SAndroid Build Coastguard Worker for (sfb = 0; sfb < maxSfbPerGroup; sfb++) {
131*e5436536SAndroid Build Coastguard Worker if ((FIXP_DBL)sfbEnergyLdData[sfbGrp + sfb] >
132*e5436536SAndroid Build Coastguard Worker (FIXP_DBL)sfbThresholdLdData[sfbGrp + sfb]) {
133*e5436536SAndroid Build Coastguard Worker sfbWidth = sfbOffset[sfbGrp + sfb + 1] - sfbOffset[sfbGrp + sfb];
134*e5436536SAndroid Build Coastguard Worker /* estimate number of active lines */
135*e5436536SAndroid Build Coastguard Worker avgFormFactorLdData = ((-sfbEnergyLdData[sfbGrp + sfb] >> 1) +
136*e5436536SAndroid Build Coastguard Worker (CalcLdInt(sfbWidth) >> 1)) >>
137*e5436536SAndroid Build Coastguard Worker 1;
138*e5436536SAndroid Build Coastguard Worker peChanData->sfbNLines[sfbGrp + sfb] = (INT)CalcInvLdData(
139*e5436536SAndroid Build Coastguard Worker (sfbFormFactorLdData[sfbGrp + sfb] + formFacScaling) +
140*e5436536SAndroid Build Coastguard Worker avgFormFactorLdData);
141*e5436536SAndroid Build Coastguard Worker /* Make sure sfbNLines is never greater than sfbWidth due to
142*e5436536SAndroid Build Coastguard Worker * unaccuracies (e.g. sfbEnergyLdData[sfbGrp+sfb] = 0x80000000) */
143*e5436536SAndroid Build Coastguard Worker peChanData->sfbNLines[sfbGrp + sfb] =
144*e5436536SAndroid Build Coastguard Worker fMin(sfbWidth, peChanData->sfbNLines[sfbGrp + sfb]);
145*e5436536SAndroid Build Coastguard Worker } else {
146*e5436536SAndroid Build Coastguard Worker peChanData->sfbNLines[sfbGrp + sfb] = 0;
147*e5436536SAndroid Build Coastguard Worker }
148*e5436536SAndroid Build Coastguard Worker }
149*e5436536SAndroid Build Coastguard Worker }
150*e5436536SAndroid Build Coastguard Worker }
151*e5436536SAndroid Build Coastguard Worker
152*e5436536SAndroid Build Coastguard Worker /*
153*e5436536SAndroid Build Coastguard Worker formula for one sfb:
154*e5436536SAndroid Build Coastguard Worker pe = n * ld(en/thr), if ld(en/thr) >= C1
155*e5436536SAndroid Build Coastguard Worker pe = n * (C2 + C3 * ld(en/thr)), if ld(en/thr) < C1
156*e5436536SAndroid Build Coastguard Worker n: estimated number of lines in sfb,
157*e5436536SAndroid Build Coastguard Worker ld(x) = log(x)/log(2)
158*e5436536SAndroid Build Coastguard Worker
159*e5436536SAndroid Build Coastguard Worker constPart is sfbPe without the threshold part n*ld(thr) or n*C3*ld(thr)
160*e5436536SAndroid Build Coastguard Worker */
FDKaacEnc_calcSfbPe(PE_CHANNEL_DATA * RESTRICT const peChanData,const FIXP_DBL * RESTRICT const sfbEnergyLdData,const FIXP_DBL * RESTRICT const sfbThresholdLdData,const INT sfbCnt,const INT sfbPerGroup,const INT maxSfbPerGroup,const INT * RESTRICT const isBook,const INT * RESTRICT const isScale)161*e5436536SAndroid Build Coastguard Worker void FDKaacEnc_calcSfbPe(PE_CHANNEL_DATA *RESTRICT const peChanData,
162*e5436536SAndroid Build Coastguard Worker const FIXP_DBL *RESTRICT const sfbEnergyLdData,
163*e5436536SAndroid Build Coastguard Worker const FIXP_DBL *RESTRICT const sfbThresholdLdData,
164*e5436536SAndroid Build Coastguard Worker const INT sfbCnt, const INT sfbPerGroup,
165*e5436536SAndroid Build Coastguard Worker const INT maxSfbPerGroup,
166*e5436536SAndroid Build Coastguard Worker const INT *RESTRICT const isBook,
167*e5436536SAndroid Build Coastguard Worker const INT *RESTRICT const isScale) {
168*e5436536SAndroid Build Coastguard Worker INT sfbGrp, sfb, thisSfb;
169*e5436536SAndroid Build Coastguard Worker INT nLines;
170*e5436536SAndroid Build Coastguard Worker FIXP_DBL logDataRatio;
171*e5436536SAndroid Build Coastguard Worker FIXP_DBL scaleLd = (FIXP_DBL)0;
172*e5436536SAndroid Build Coastguard Worker INT lastValIs = 0;
173*e5436536SAndroid Build Coastguard Worker
174*e5436536SAndroid Build Coastguard Worker FIXP_DBL pe = 0;
175*e5436536SAndroid Build Coastguard Worker FIXP_DBL constPart = 0;
176*e5436536SAndroid Build Coastguard Worker FIXP_DBL nActiveLines = 0;
177*e5436536SAndroid Build Coastguard Worker
178*e5436536SAndroid Build Coastguard Worker FIXP_DBL tmpPe, tmpConstPart, tmpNActiveLines;
179*e5436536SAndroid Build Coastguard Worker
180*e5436536SAndroid Build Coastguard Worker for (sfbGrp = 0; sfbGrp < sfbCnt; sfbGrp += sfbPerGroup) {
181*e5436536SAndroid Build Coastguard Worker for (sfb = 0; sfb < maxSfbPerGroup; sfb++) {
182*e5436536SAndroid Build Coastguard Worker tmpPe = (FIXP_DBL)0;
183*e5436536SAndroid Build Coastguard Worker tmpConstPart = (FIXP_DBL)0;
184*e5436536SAndroid Build Coastguard Worker tmpNActiveLines = (FIXP_DBL)0;
185*e5436536SAndroid Build Coastguard Worker
186*e5436536SAndroid Build Coastguard Worker thisSfb = sfbGrp + sfb;
187*e5436536SAndroid Build Coastguard Worker
188*e5436536SAndroid Build Coastguard Worker if (sfbEnergyLdData[thisSfb] > sfbThresholdLdData[thisSfb]) {
189*e5436536SAndroid Build Coastguard Worker logDataRatio = sfbEnergyLdData[thisSfb] - sfbThresholdLdData[thisSfb];
190*e5436536SAndroid Build Coastguard Worker nLines = peChanData->sfbNLines[thisSfb];
191*e5436536SAndroid Build Coastguard Worker
192*e5436536SAndroid Build Coastguard Worker FIXP_DBL factor = nLines << (LD_DATA_SHIFT + PE_CONSTPART_SHIFT + 1);
193*e5436536SAndroid Build Coastguard Worker if (logDataRatio >= C1LdData) {
194*e5436536SAndroid Build Coastguard Worker /* scale sfbPe and sfbConstPart with PE_CONSTPART_SHIFT */
195*e5436536SAndroid Build Coastguard Worker tmpPe = fMultDiv2(logDataRatio, factor);
196*e5436536SAndroid Build Coastguard Worker tmpConstPart = fMultDiv2(sfbEnergyLdData[thisSfb] + scaleLd, factor);
197*e5436536SAndroid Build Coastguard Worker } else {
198*e5436536SAndroid Build Coastguard Worker /* scale sfbPe and sfbConstPart with PE_CONSTPART_SHIFT */
199*e5436536SAndroid Build Coastguard Worker tmpPe = fMultDiv2(
200*e5436536SAndroid Build Coastguard Worker ((FIXP_DBL)C2LdData + fMult(C3LdData, logDataRatio)), factor);
201*e5436536SAndroid Build Coastguard Worker tmpConstPart =
202*e5436536SAndroid Build Coastguard Worker fMultDiv2(((FIXP_DBL)C2LdData +
203*e5436536SAndroid Build Coastguard Worker fMult(C3LdData, sfbEnergyLdData[thisSfb] + scaleLd)),
204*e5436536SAndroid Build Coastguard Worker factor);
205*e5436536SAndroid Build Coastguard Worker
206*e5436536SAndroid Build Coastguard Worker nLines = fMultI(C3LdData, nLines);
207*e5436536SAndroid Build Coastguard Worker }
208*e5436536SAndroid Build Coastguard Worker tmpNActiveLines = (FIXP_DBL)nLines;
209*e5436536SAndroid Build Coastguard Worker } else if (isBook[thisSfb]) {
210*e5436536SAndroid Build Coastguard Worker /* provide for cost of scale factor for Intensity */
211*e5436536SAndroid Build Coastguard Worker INT delta = isScale[thisSfb] - lastValIs;
212*e5436536SAndroid Build Coastguard Worker lastValIs = isScale[thisSfb];
213*e5436536SAndroid Build Coastguard Worker peChanData->sfbPe[thisSfb] = FDKaacEnc_bitCountScalefactorDelta(delta)
214*e5436536SAndroid Build Coastguard Worker << PE_CONSTPART_SHIFT;
215*e5436536SAndroid Build Coastguard Worker peChanData->sfbConstPart[thisSfb] = 0;
216*e5436536SAndroid Build Coastguard Worker peChanData->sfbNActiveLines[thisSfb] = 0;
217*e5436536SAndroid Build Coastguard Worker }
218*e5436536SAndroid Build Coastguard Worker peChanData->sfbPe[thisSfb] = tmpPe;
219*e5436536SAndroid Build Coastguard Worker peChanData->sfbConstPart[thisSfb] = tmpConstPart;
220*e5436536SAndroid Build Coastguard Worker peChanData->sfbNActiveLines[thisSfb] = tmpNActiveLines;
221*e5436536SAndroid Build Coastguard Worker
222*e5436536SAndroid Build Coastguard Worker /* sum up peChanData values */
223*e5436536SAndroid Build Coastguard Worker pe += tmpPe;
224*e5436536SAndroid Build Coastguard Worker constPart += tmpConstPart;
225*e5436536SAndroid Build Coastguard Worker nActiveLines += tmpNActiveLines;
226*e5436536SAndroid Build Coastguard Worker }
227*e5436536SAndroid Build Coastguard Worker }
228*e5436536SAndroid Build Coastguard Worker
229*e5436536SAndroid Build Coastguard Worker /* correct scaled pe and constPart values */
230*e5436536SAndroid Build Coastguard Worker peChanData->pe = pe >> PE_CONSTPART_SHIFT;
231*e5436536SAndroid Build Coastguard Worker peChanData->constPart = constPart >> PE_CONSTPART_SHIFT;
232*e5436536SAndroid Build Coastguard Worker
233*e5436536SAndroid Build Coastguard Worker peChanData->nActiveLines = nActiveLines;
234*e5436536SAndroid Build Coastguard Worker }
235