16cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK/* ----------------------------------------------------------------------------- 22228e360595641dd906bf1773307f43d304f5b2The Android Open Source ProjectSoftware License for The Fraunhofer FDK AAC Codec Library for Android 32228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project 46cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK© Copyright 1995 - 2018 Fraunhofer-Gesellschaft zur Förderung der angewandten 56cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKForschung e.V. All rights reserved. 62228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project 72228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project 1. INTRODUCTION 86cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKThe Fraunhofer FDK AAC Codec Library for Android ("FDK AAC Codec") is software 96cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKthat implements the MPEG Advanced Audio Coding ("AAC") encoding and decoding 106cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKscheme for digital audio. This FDK AAC Codec software is intended to be used on 116cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKa wide variety of Android devices. 126cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK 136cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKAAC's HE-AAC and HE-AAC v2 versions are regarded as today's most efficient 146cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKgeneral perceptual audio codecs. AAC-ELD is considered the best-performing 156cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKfull-bandwidth communications codec by independent studies and is widely 166cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKdeployed. AAC has been standardized by ISO and IEC as part of the MPEG 176cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKspecifications. 186cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK 196cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKPatent licenses for necessary patent claims for the FDK AAC Codec (including 206cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKthose of Fraunhofer) may be obtained through Via Licensing 216cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK(www.vialicensing.com) or through the respective patent owners individually for 226cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKthe purpose of encoding or decoding bit streams in products that are compliant 236cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKwith the ISO/IEC MPEG audio standards. Please note that most manufacturers of 246cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKAndroid devices already license these patent claims through Via Licensing or 256cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKdirectly from the patent owners, and therefore FDK AAC Codec software may 266cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKalready be covered under those patent licenses when it is used for those 276cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKlicensed purposes only. 286cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK 296cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKCommercially-licensed AAC software libraries, including floating-point versions 306cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKwith enhanced sound quality, are also available from Fraunhofer. Users are 316cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKencouraged to check the Fraunhofer website for additional applications 326cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKinformation and documentation. 332228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project 342228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project2. COPYRIGHT LICENSE 352228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project 366cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKRedistribution and use in source and binary forms, with or without modification, 376cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKare permitted without payment of copyright license fees provided that you 386cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKsatisfy the following conditions: 392228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project 406cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKYou must retain the complete text of this software license in redistributions of 416cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKthe FDK AAC Codec or your modifications thereto in source code form. 422228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project 436cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKYou must retain the complete text of this software license in the documentation 446cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKand/or other materials provided with redistributions of the FDK AAC Codec or 456cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKyour modifications thereto in binary form. You must make available free of 466cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKcharge copies of the complete source code of the FDK AAC Codec and your 472228e360595641dd906bf1773307f43d304f5b2The Android Open Source Projectmodifications thereto to recipients of copies in binary form. 482228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project 496cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKThe name of Fraunhofer may not be used to endorse or promote products derived 506cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKfrom this library without prior written permission. 512228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project 526cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKYou may not charge copyright license fees for anyone to use, copy or distribute 536cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKthe FDK AAC Codec software or your modifications thereto. 542228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project 556cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKYour modified versions of the FDK AAC Codec must carry prominent notices stating 566cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKthat you changed the software and the date of any change. For modified versions 576cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKof the FDK AAC Codec, the term "Fraunhofer FDK AAC Codec Library for Android" 586cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKmust be replaced by the term "Third-Party Modified Version of the Fraunhofer FDK 596cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKAAC Codec Library for Android." 602228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project 612228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project3. NO PATENT LICENSE 622228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project 636cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKNO EXPRESS OR IMPLIED LICENSES TO ANY PATENT CLAIMS, including without 646cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKlimitation the patents of Fraunhofer, ARE GRANTED BY THIS SOFTWARE LICENSE. 656cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKFraunhofer provides no warranty of patent non-infringement with respect to this 666cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKsoftware. 672228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project 686cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKYou may use this FDK AAC Codec software or modifications thereto only for 696cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKpurposes that are authorized by appropriate patent licenses. 702228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project 712228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project4. DISCLAIMER 722228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project 736cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKThis FDK AAC Codec software is provided by Fraunhofer on behalf of the copyright 746cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKholders and contributors "AS IS" and WITHOUT ANY EXPRESS OR IMPLIED WARRANTIES, 756cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKincluding but not limited to the implied warranties of merchantability and 766cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKfitness for a particular purpose. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR 776cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKCONTRIBUTORS BE LIABLE for any direct, indirect, incidental, special, exemplary, 786cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKor consequential damages, including but not limited to procurement of substitute 796cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKgoods or services; loss of use, data, or profits, or business interruption, 806cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKhowever caused and on any theory of liability, whether in contract, strict 816cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKliability, or tort (including negligence), arising in any way out of the use of 826cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKthis software, even if advised of the possibility of such damage. 832228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project 842228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project5. CONTACT INFORMATION 852228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project 862228e360595641dd906bf1773307f43d304f5b2The Android Open Source ProjectFraunhofer Institute for Integrated Circuits IIS 872228e360595641dd906bf1773307f43d304f5b2The Android Open Source ProjectAttention: Audio and Multimedia Departments - FDK AAC LL 882228e360595641dd906bf1773307f43d304f5b2The Android Open Source ProjectAm Wolfsmantel 33 892228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project91058 Erlangen, Germany 902228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project 912228e360595641dd906bf1773307f43d304f5b2The Android Open Source Projectwww.iis.fraunhofer.de/amm 922228e360595641dd906bf1773307f43d304f5b2The Android Open Source Projectamm-info@iis.fraunhofer.de 936cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK----------------------------------------------------------------------------- */ 946cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK 956cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK/**************************** AAC encoder library ****************************** 962228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project 976cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK Author(s): M. Werner 982228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project 996cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK Description: Convert chaos measure to the tonality index 1002228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project 1016cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK*******************************************************************************/ 1022228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project 1032228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project#include "tonality.h" 1046cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK 1052228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project#include "chaosmeasure.h" 1062228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project 1076cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK#if defined(__arm__) 1082228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project#endif 1096cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK 1106cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKstatic const FIXP_DBL normlog = 1116cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK (FIXP_DBL)0xd977d949; /*FL2FXCONST_DBL(-0.4342944819f * 1126cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK FDKlog(2.0)/FDKlog(2.7182818)); */ 1136cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK 1146cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKstatic void FDKaacEnc_CalcSfbTonality(FIXP_DBL *RESTRICT spectrum, 1156cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK INT *RESTRICT sfbMaxScaleSpec, 1166cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK FIXP_DBL *RESTRICT chaosMeasure, 1176cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK FIXP_SGL *RESTRICT sfbTonality, 1186cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK INT sfbCnt, const INT *RESTRICT sfbOffset, 1196cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK FIXP_DBL *RESTRICT sfbEnergyLD64); 1206cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK 1216cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKvoid FDKaacEnc_CalculateFullTonality(FIXP_DBL *RESTRICT spectrum, 1226cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK INT *RESTRICT sfbMaxScaleSpec, 1236cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK FIXP_DBL *RESTRICT sfbEnergyLD64, 1246cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK FIXP_SGL *RESTRICT sfbTonality, INT sfbCnt, 1256cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK const INT *sfbOffset, INT usePns) { 1266cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK INT j; 1272228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project INT numberOfLines = sfbOffset[sfbCnt]; 1282228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project 1296cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK if (usePns) { 1306cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK C_ALLOC_SCRATCH_START(chaosMeasurePerLine, FIXP_DBL, (1024)) 1316cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK 1326cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK /* calculate chaos measure */ 1336cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK FDKaacEnc_CalculateChaosMeasure(spectrum, numberOfLines, 1346cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK chaosMeasurePerLine); 1356cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK 1366cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK /* smooth ChaosMeasure */ 1376cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK FIXP_DBL left = chaosMeasurePerLine[0]; 1386cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK FIXP_DBL right; 1396cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK for (j = 1; j < (numberOfLines - 1); j += 2) { 1406cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK right = chaosMeasurePerLine[j]; 1416cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK right = right - (right >> 2); 1426cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK left = right + (left >> 2); 1436cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK chaosMeasurePerLine[j] = left; /* 0.25 left + 0.75 right */ 1446cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK 1456cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK right = chaosMeasurePerLine[j + 1]; 1466cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK right = right - (right >> 2); 1476cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK left = right + (left >> 2); 1486cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK chaosMeasurePerLine[j + 1] = left; 1496cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK } 1506cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK if (j == (numberOfLines - 1)) { 1516cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK right = chaosMeasurePerLine[j]; 1526cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK right = right - (right >> 2); 1536cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK left = right + (left >> 2); 1546cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK chaosMeasurePerLine[j] = left; 1556cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK } 1562228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project 1576cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK FDKaacEnc_CalcSfbTonality(spectrum, sfbMaxScaleSpec, chaosMeasurePerLine, 1586cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK sfbTonality, sfbCnt, sfbOffset, sfbEnergyLD64); 1592228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project 1606cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK C_ALLOC_SCRATCH_END(chaosMeasurePerLine, FIXP_DBL, (1024)) 1612228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project } 1622228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project} 1632228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project 1642228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project/***************************************************************************** 1652228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project 1662228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project functionname: CalculateTonalityIndex 1672228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project description: computes tonality values out of unpredictability values 1682228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project limits range and computes log() 1692228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project returns: 1702228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project input: ptr to energies, ptr to chaos measure values, 1712228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project number of sfb 1722228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project output: sfb wise tonality values 1732228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project 1742228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project*****************************************************************************/ 1756cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDKstatic void FDKaacEnc_CalcSfbTonality(FIXP_DBL *RESTRICT spectrum, 1766cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK INT *RESTRICT sfbMaxScaleSpec, 1776cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK FIXP_DBL *RESTRICT chaosMeasure, 1786cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK FIXP_SGL *RESTRICT sfbTonality, 1796cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK INT sfbCnt, const INT *RESTRICT sfbOffset, 1806cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK FIXP_DBL *RESTRICT sfbEnergyLD64) { 1816cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK INT i; 1826cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK 1836cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK for (i = 0; i < sfbCnt; i++) { 1846cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK FIXP_DBL chaosMeasureSfbLD64; 1856cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK INT shiftBits = 1866cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK fixMax(0, sfbMaxScaleSpec[i] - 1876cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK 4); /* max sfbWidth = 96 ; 2^7=128 => 7/2 = 4 (spc*spc) */ 1886cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK 1896cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK INT j; 1906cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK FIXP_DBL chaosMeasureSfb = FL2FXCONST_DBL(0.0); 1916cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK 1926cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK /* calc chaosMeasurePerSfb */ 1936cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK for (j = (sfbOffset[i + 1] - sfbOffset[i]) - 1; j >= 0; j--) { 1946cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK FIXP_DBL tmp = (*spectrum++) << shiftBits; 1956cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK FIXP_DBL lineNrg = fMultDiv2(tmp, tmp); 1966cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK chaosMeasureSfb = fMultAddDiv2(chaosMeasureSfb, lineNrg, *chaosMeasure++); 1976cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK } 1986cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK 1996cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK /* calc tonalityPerSfb */ 2006cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK if (chaosMeasureSfb != FL2FXCONST_DBL(0.0)) { 2016cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK /* add ld(convtone)/64 and 2/64 bec.fMultDiv2 */ 2026cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK chaosMeasureSfbLD64 = CalcLdData((chaosMeasureSfb)) - sfbEnergyLD64[i]; 2036cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK chaosMeasureSfbLD64 += FL2FXCONST_DBL(3.0f / 64) - 2046cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK ((FIXP_DBL)(shiftBits) << (DFRACT_BITS - 6)); 2056cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK 2066cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK if (chaosMeasureSfbLD64 > 2076cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK FL2FXCONST_DBL(-0.0519051)) /* > ld(0.05)+ld(2) */ 2082228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project { 2096cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK if (chaosMeasureSfbLD64 <= FL2FXCONST_DBL(0.0)) 2106cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK sfbTonality[i] = 2116cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK FX_DBL2FX_SGL(fMultDiv2(chaosMeasureSfbLD64, normlog) << 7); 2122228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project else 2136cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK sfbTonality[i] = FL2FXCONST_SGL(0.0); 2146cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK } else 2152228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project sfbTonality[i] = (FIXP_SGL)MAXVAL_SGL; 2166cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK } else 2176cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK sfbTonality[i] = (FIXP_SGL)MAXVAL_SGL; 2186cfabd35363c3ef5e3b209b867169a500b3ccc3cFraunhofer IIS FDK } 2192228e360595641dd906bf1773307f43d304f5b2The Android Open Source Project} 220