⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 div_32.cpp

📁 实现3GPP的GSM中AMR语音的CODECS。
💻 CPP
字号:
/* ------------------------------------------------------------------ * Copyright (C) 2008 PacketVideo * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * *      http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either * express or implied. * See the License for the specific language governing permissions * and limitations under the License. * ------------------------------------------------------------------- *//****************************************************************************************Portions of this file are derived from the following 3GPP standard:    3GPP TS 26.073    ANSI-C code for the Adaptive Multi-Rate (AMR) speech codec    Available from http://www.3gpp.org(C) 2004, 3GPP Organizational Partners (ARIB, ATIS, CCSA, ETSI, TTA, TTC)Permission to distribute, modify and use this file under the standard licenseterms listed above has been obtained from the copyright holder.****************************************************************************************//* Filename: /audio/gsm_amr/c/src/div_32.c     Date: 09/07/2000------------------------------------------------------------------------------ REVISION HISTORY Description: Updated template. Changed function interface to pass in a              pointer to overflow flag into the function instead of using a              global flag. Removed inclusion of unwanted header files. Changed              the name of input and output variables for clarity. Description:              1. Eliminated unused include files.              2. Replaced l_extract functionality, code size and speed                 do not justify calling this function              3. Eliminated sub() function call, replace by (-), this knowing                 that the result will not saturate. Description:  Added casting to eliminate warnings Description:------------------------------------------------------------------------------*//*----------------------------------------------------------------------------; INCLUDES----------------------------------------------------------------------------*/#include    "basic_op.h"/*----------------------------------------------------------------------------; MACROS; [Define module specific macros here]----------------------------------------------------------------------------*//*----------------------------------------------------------------------------; DEFINES; [Include all pre-processor statements here. Include conditional; compile variables also.]----------------------------------------------------------------------------*//*----------------------------------------------------------------------------; LOCAL FUNCTION DEFINITIONS; [List function prototypes here]----------------------------------------------------------------------------*//*----------------------------------------------------------------------------; LOCAL VARIABLE DEFINITIONS; [Variable declaration - defined here and used outside this module]----------------------------------------------------------------------------*//*------------------------------------------------------------------------------ FUNCTION NAME: div_32------------------------------------------------------------------------------ INPUT AND OUTPUT DEFINITIONS Inputs:    L_num = 32 bit signed integer (Word32) whose value falls in the                range : 0x0000 0000 < L_num < L_denom    L_denom_hi = 16 bit positive normalized integer whose value falls in               the range : 0x4000 < hi < 0x7fff    L_denom_lo = 16 bit positive integer whose value falls in the range :               0 < lo < 0x7fff    pOverflow = pointer to overflow (Flag) Outputs:    pOverflow -> 1 if the 32 bit divide operation resulted in overflow Returns:    result = 32-bit quotient of of the division of two 32 bit integers                L_num / L_denom (Word32) Global Variables Used:    None Local Variables Needed:    None------------------------------------------------------------------------------ FUNCTION DESCRIPTION This function is a fractional integer division of two 32 bit numbers, the numerator L_num and the denominator L_denom. The denominator is formed by combining denom_hi and denom_lo. Note that denom_hi is a normalized numbers. The numerator and denominator must be positive and the numerator must be less than the denominator. The division is done as follows: 1. Find 1/L_denom by first approximating: approx = 1 / denom_hi. 2. 1/L_denom = approx * (2.0 - L_denom * approx ). 3. result = L_num * (1/L_denom).------------------------------------------------------------------------------ REQUIREMENTS None------------------------------------------------------------------------------ REFERENCES [1] div_32() function in oper_32b.c,  UMTS GSM AMR speech codec, R99 - Version 3.2.0, March 2, 2001------------------------------------------------------------------------------ PSEUDO-CODE------------------------------------------------------------------------------ RESOURCES USED [optional] When the code is written for a specific target processor the the resources used should be documented below. HEAP MEMORY USED: x bytes STACK MEMORY USED: x bytes CLOCK CYCLES: (cycle count equation for this function) + (variable                used to represent cycle count for each subroutine                called)     where: (cycle count variable) = cycle count for [subroutine                                     name]------------------------------------------------------------------------------ CAUTION [optional] [State any special notes, constraints or cautions for users of this function]------------------------------------------------------------------------------*//*----------------------------------------------------------------------------; FUNCTION CODE----------------------------------------------------------------------------*/Word32 Div_32(Word32 L_num,              Word16 L_denom_hi,              Word16 L_denom_lo,              Flag   *pOverflow){    Word16 approx;    Word16 hi;    Word16 lo;    Word16 n_hi;    Word16 n_lo;    Word32 result;    /* First approximation: 1 / L_denom = 1/L_denom_hi */    approx = div_s((Word16) 0x3fff, L_denom_hi);    /* 1/L_denom = approx * (2.0 - L_denom * approx) */    result = Mpy_32_16(L_denom_hi, L_denom_lo, approx, pOverflow);    /* result is > 0 , and less than 1.0 */    result =  0x7fffffffL - result;    hi = (Word16)(result >> 16);    lo = (result >> 1) - (hi << 15);    result = Mpy_32_16(hi, lo, approx, pOverflow);    /* L_num * (1/L_denom) */    hi = (Word16)(result >> 16);    lo = (result >> 1) - (hi << 15);    n_hi = (Word16)(L_num >> 16);    n_lo = (L_num >> 1) - (n_hi << 15);    result = Mpy_32(n_hi, n_lo, hi, lo, pOverflow);    result = L_shl(result, 2, pOverflow);    return (result);}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -