亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? libmp3dec.c

?? 能解壓幾乎所有mp3
?? C
?? 第 1 頁 / 共 5 頁
字號:
/*
* This source code is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
* Lesser General Public License for more details.
*       
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
*
* File Name: libmp3dec.c							
*
* Reference:
*
* Author: Li Feng,  fli_linux@yahoo.com.cn                                                 
*
* Description:
*
* 	
* 
* History:
* 02/23/2005  Li Feng    Created
*  
*
*CodeReview Log:
* 
*/
#include <stdlib.h>
#include <string.h>
#include <math.h>
#include "typedef.h"
#include "libmp3dec.h"
#include "mp3dec.h"
#include "mp3dectab.h"
#include "bits.h"
#include "vlc.h"

static void compute_antialias_integer(MPADecodeContext *s, GranuleDef *g);
static void compute_antialias_float(MPADecodeContext *s, GranuleDef *g);

/* vlc structure for decoding layer 3 huffman tables */
static VLC huff_vlc[16]; 
static uint8_t *huff_code_table[16];
static VLC huff_quad_vlc[2];
/* computed from band_size_long */
static uint16_t band_index_long[9][23];
/* XXX: free when all decoders are closed */
#define TABLE_4_3_SIZE (8191 + 16)
static int8_t  *table_4_3_exp;
#if FRAC_BITS <= 15
static uint16_t *table_4_3_value;
#else
static uint32_t *table_4_3_value;
#endif
/* intensity stereo coef table */
static int32_t is_table[2][16];
static int32_t is_table_lsf[2][2][16];
static int32_t csa_table[8][4];
static float csa_table_float[8][4];
static int32_t mdct_win[8][36];

/* lower 2 bits: modulo 3, higher bits: shift */
static uint16_t scale_factor_modshift[64];
/* [i][j]:  2^(-j/3) * FRAC_ONE * 2^(i+2) / (2^(i+2) - 1) */
static int32_t scale_factor_mult[15][3];
/* mult table for layer 2 group quantization */

#define SCALE_GEN(v) \
{ FIXR(1.0 * (v)), FIXR(0.7937005259 * (v)), FIXR(0.6299605249 * (v)) }

static int32_t scale_factor_mult2[3][3] = {
    SCALE_GEN(4.0 / 3.0), /* 3 steps */
    SCALE_GEN(4.0 / 5.0), /* 5 steps */
    SCALE_GEN(4.0 / 9.0), /* 9 steps */
};

/* 2^(n/4) */
static uint32_t scale_factor_mult3[4] = 
{
    FIXR(1.0),
    FIXR(1.18920711500272106671),
    FIXR(1.41421356237309504880),
    FIXR(1.68179283050742908605),
};

static MPA_INT window[512];
    
/* layer 1 unscaling */
/* n = number of bits of the mantissa minus 1 */
static int l1_unscale(int n, int mant, int scale_factor)
{
    int shift, mod;
    int64_t val;

    shift = scale_factor_modshift[scale_factor];
    mod = shift & 3;
    shift >>= 2;
    val = MUL64(mant + (-1 << n) + 1, scale_factor_mult[n-1][mod]);
    shift += n;
    /* NOTE: at this point, 1 <= shift >= 21 + 15 */
    return (int)((val + (1L << (shift - 1))) >> shift);
}

static int l2_unscale_group(int steps, int mant, int scale_factor)
{
    int shift, mod, val;

    shift = scale_factor_modshift[scale_factor];
    mod = shift & 3;
    shift >>= 2;

    val = (mant - (steps >> 1)) * scale_factor_mult2[steps >> 2][mod];
    /* NOTE: at this point, 0 <= shift <= 21 */
    if (shift > 0)
        val = (val + (1 << (shift - 1))) >> shift;
    return val;
}

/* compute value^(4/3) * 2^(exponent/4). It normalized to FRAC_BITS */
static int l3_unscale(int value, int exponent)
{
#if FRAC_BITS <= 15    
    unsigned int m;
#else
    uint64_t m;
#endif
    int e;

    e = table_4_3_exp[value];
    e += (exponent >> 2);
    e = FRAC_BITS - e;
#if FRAC_BITS <= 15    
    if (e > 31)
        e = 31;
#endif
    m = table_4_3_value[value];
#if FRAC_BITS <= 15    
    m = (m * scale_factor_mult3[exponent & 3]);
    m = (m + (1 << (e-1))) >> e;
    return m;
#else
    m = MUL64(m, scale_factor_mult3[exponent & 3]);
    m = (m + (uint64_t_C(1) << (e-1))) >> e;
    return m;
#endif
}

/* all integer n^(4/3) computation code */
#define DEV_ORDER 13

#define POW_FRAC_BITS 24
#define POW_FRAC_ONE    (1 << POW_FRAC_BITS)
#define POW_FIX(a)   ((int)((a) * POW_FRAC_ONE))
#define POW_MULL(a,b) (((int64_t)(a) * (int64_t)(b)) >> POW_FRAC_BITS)

static int dev_4_3_coefs[DEV_ORDER];

static int pow_mult3[3] = {
    POW_FIX(1.0),
    POW_FIX(1.25992104989487316476),
    POW_FIX(1.58740105196819947474),
};

static void int_pow_init(void)
{
    int i, a;

    a = POW_FIX(1.0);
    for(i=0;i<DEV_ORDER;i++) {
        a = POW_MULL(a, POW_FIX(4.0 / 3.0) - i * POW_FIX(1.0)) / (i + 1);
        dev_4_3_coefs[i] = a;
    }
}

/* return the mantissa and the binary exponent */
static int int_pow(int i, int *exp_ptr)
{
    int e, er, eq, j;
    int a, a1;
    
    /* renormalize */
    a = i;
    e = POW_FRAC_BITS;
    while (a < (1 << (POW_FRAC_BITS - 1))) {
        a = a << 1;
        e--;
    }
    a -= (1 << POW_FRAC_BITS);
    a1 = 0;
    for(j = DEV_ORDER - 1; j >= 0; j--)
        a1 = POW_MULL(a, dev_4_3_coefs[j] + a1);
    a = (1 << POW_FRAC_BITS) + a1;
    /* exponent compute (exact) */
    e = e * 4;
    er = e % 3;
    eq = e / 3;
    a = POW_MULL(a, pow_mult3[er]);
    while (a >= 2 * POW_FRAC_ONE) {
        a = a >> 1;
        eq++;
    }
    /* convert to float */
    while (a < POW_FRAC_ONE) {
        a = a << 1;
        eq--;
    }
    /* now POW_FRAC_ONE <= a < 2 * POW_FRAC_ONE */
#if POW_FRAC_BITS > FRAC_BITS
    a = (a + (1 << (POW_FRAC_BITS - FRAC_BITS - 1))) >> (POW_FRAC_BITS - FRAC_BITS);
    /* correct overflow */
    if (a >= 2 * (1 << FRAC_BITS)) {
        a = a >> 1;
        eq++;
    }
#endif
    *exp_ptr = eq;
    return a;
}

/* tab[i][j] = 1.0 / (2.0 * cos(pi*(2*k+1) / 2^(6 - j))) */

/* cos(i*pi/64) */

#define COS0_0  FIXR(0.50060299823519630134)
#define COS0_1  FIXR(0.50547095989754365998)
#define COS0_2  FIXR(0.51544730992262454697)
#define COS0_3  FIXR(0.53104259108978417447)
#define COS0_4  FIXR(0.55310389603444452782)
#define COS0_5  FIXR(0.58293496820613387367)
#define COS0_6  FIXR(0.62250412303566481615)
#define COS0_7  FIXR(0.67480834145500574602)
#define COS0_8  FIXR(0.74453627100229844977)
#define COS0_9  FIXR(0.83934964541552703873)
#define COS0_10 FIXR(0.97256823786196069369)
#define COS0_11 FIXR(1.16943993343288495515)
#define COS0_12 FIXR(1.48416461631416627724)
#define COS0_13 FIXR(2.05778100995341155085)
#define COS0_14 FIXR(3.40760841846871878570)
#define COS0_15 FIXR(10.19000812354805681150)

#define COS1_0 FIXR(0.50241928618815570551)
#define COS1_1 FIXR(0.52249861493968888062)
#define COS1_2 FIXR(0.56694403481635770368)
#define COS1_3 FIXR(0.64682178335999012954)
#define COS1_4 FIXR(0.78815462345125022473)
#define COS1_5 FIXR(1.06067768599034747134)
#define COS1_6 FIXR(1.72244709823833392782)
#define COS1_7 FIXR(5.10114861868916385802)

#define COS2_0 FIXR(0.50979557910415916894)
#define COS2_1 FIXR(0.60134488693504528054)
#define COS2_2 FIXR(0.89997622313641570463)
#define COS2_3 FIXR(2.56291544774150617881)

#define COS3_0 FIXR(0.54119610014619698439)
#define COS3_1 FIXR(1.30656296487637652785)

#define COS4_0 FIXR(0.70710678118654752439)

/* butterfly operator */
#define BF(a, b, c)\
{\
    tmp0 = tab[a] + tab[b];\
    tmp1 = tab[a] - tab[b];\
    tab[a] = tmp0;\
    tab[b] = MULL(tmp1, c);\
}

#define BF1(a, b, c, d)\
{\
    BF(a, b, COS4_0);\
    BF(c, d, -COS4_0);\
    tab[c] += tab[d];\
}

#define BF2(a, b, c, d)\
{\
    BF(a, b, COS4_0);\
    BF(c, d, -COS4_0);\
    tab[c] += tab[d];\
    tab[a] += tab[c];\
    tab[c] += tab[b];\
    tab[b] += tab[d];\
}

#define ADD(a, b) tab[a] += tab[b]

/* DCT32 without 1/sqrt(2) coef zero scaling. */
static void dct32(int32_t *out, int32_t *tab)
{
    int tmp0, tmp1;

    /* pass 1 */
    BF(0, 31, COS0_0);
    BF(1, 30, COS0_1);
    BF(2, 29, COS0_2);
    BF(3, 28, COS0_3);
    BF(4, 27, COS0_4);
    BF(5, 26, COS0_5);
    BF(6, 25, COS0_6);
    BF(7, 24, COS0_7);
    BF(8, 23, COS0_8);
    BF(9, 22, COS0_9);
    BF(10, 21, COS0_10);
    BF(11, 20, COS0_11);
    BF(12, 19, COS0_12);
    BF(13, 18, COS0_13);
    BF(14, 17, COS0_14);
    BF(15, 16, COS0_15);

    /* pass 2 */
    BF(0, 15, COS1_0);
    BF(1, 14, COS1_1);
    BF(2, 13, COS1_2);
    BF(3, 12, COS1_3);
    BF(4, 11, COS1_4);
    BF(5, 10, COS1_5);
    BF(6,  9, COS1_6);
    BF(7,  8, COS1_7);
    
    BF(16, 31, -COS1_0);
    BF(17, 30, -COS1_1);
    BF(18, 29, -COS1_2);
    BF(19, 28, -COS1_3);
    BF(20, 27, -COS1_4);
    BF(21, 26, -COS1_5);
    BF(22, 25, -COS1_6);
    BF(23, 24, -COS1_7);
    
    /* pass 3 */
    BF(0, 7, COS2_0);
    BF(1, 6, COS2_1);
    BF(2, 5, COS2_2);
    BF(3, 4, COS2_3);
    
    BF(8, 15, -COS2_0);
    BF(9, 14, -COS2_1);
    BF(10, 13, -COS2_2);
    BF(11, 12, -COS2_3);
    
    BF(16, 23, COS2_0);
    BF(17, 22, COS2_1);
    BF(18, 21, COS2_2);
    BF(19, 20, COS2_3);
    
    BF(24, 31, -COS2_0);
    BF(25, 30, -COS2_1);
    BF(26, 29, -COS2_2);
    BF(27, 28, -COS2_3);

    /* pass 4 */
    BF(0, 3, COS3_0);
    BF(1, 2, COS3_1);
    
    BF(4, 7, -COS3_0);
    BF(5, 6, -COS3_1);
    
    BF(8, 11, COS3_0);
    BF(9, 10, COS3_1);
    
    BF(12, 15, -COS3_0);
    BF(13, 14, -COS3_1);
    
    BF(16, 19, COS3_0);
    BF(17, 18, COS3_1);
    
    BF(20, 23, -COS3_0);
    BF(21, 22, -COS3_1);
    
    BF(24, 27, COS3_0);
    BF(25, 26, COS3_1);
    
    BF(28, 31, -COS3_0);
    BF(29, 30, -COS3_1);
    
    /* pass 5 */
    BF1(0, 1, 2, 3);
    BF2(4, 5, 6, 7);
    BF1(8, 9, 10, 11);
    BF2(12, 13, 14, 15);
    BF1(16, 17, 18, 19);
    BF2(20, 21, 22, 23);
    BF1(24, 25, 26, 27);
    BF2(28, 29, 30, 31);
    
    /* pass 6 */
    
    ADD( 8, 12);
    ADD(12, 10);
    ADD(10, 14);
    ADD(14,  9);
    ADD( 9, 13);
    ADD(13, 11);
    ADD(11, 15);

    out[ 0] = tab[0];
    out[16] = tab[1];
    out[ 8] = tab[2];
    out[24] = tab[3];
    out[ 4] = tab[4];
    out[20] = tab[5];
    out[12] = tab[6];
    out[28] = tab[7];
    out[ 2] = tab[8];
    out[18] = tab[9];
    out[10] = tab[10];
    out[26] = tab[11];
    out[ 6] = tab[12];
    out[22] = tab[13];
    out[14] = tab[14];
    out[30] = tab[15];
    
    ADD(24, 28);
    ADD(28, 26);
    ADD(26, 30);
    ADD(30, 25);
    ADD(25, 29);
    ADD(29, 27);
    ADD(27, 31);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
狠狠色丁香久久婷婷综| 欧美人狂配大交3d怪物一区| 91麻豆蜜桃一区二区三区| 欧美日韩一区二区三区高清| 欧美经典一区二区三区| 午夜一区二区三区视频| 成人网页在线观看| 精品美女在线观看| 亚洲激情五月婷婷| 成人毛片老司机大片| 在线观看91av| 亚洲综合成人在线| 9久草视频在线视频精品| 欧美成人精品福利| 青草av.久久免费一区| 欧美丝袜第三区| 亚洲精品国产无天堂网2021| 成人精品在线视频观看| 久久综合九色综合97_久久久| 午夜日韩在线电影| 欧美影院一区二区三区| 亚洲美女在线国产| 不卡一区二区在线| 国产日产欧美一区二区三区| 麻豆视频观看网址久久| 久久嫩草精品久久久久| 蜜桃视频第一区免费观看| 欧美日韩高清一区二区三区| 亚洲已满18点击进入久久| 99国产精品国产精品久久| 国产精品国产三级国产三级人妇 | 有坂深雪av一区二区精品| 懂色av一区二区三区免费观看| 日韩精品中文字幕在线一区| 日本最新不卡在线| 69av一区二区三区| 日本中文字幕不卡| 精品成人一区二区三区四区| 精品制服美女久久| 精品久久久久久久久久久久久久久| 热久久一区二区| 欧美精品一区二区三区在线播放| 黄色日韩网站视频| 精品国产乱码久久久久久浪潮 | 中文字幕精品三区| 成人天堂资源www在线| 中文字幕一区二区三区四区 | 国产毛片精品国产一区二区三区| 精品国产91久久久久久久妲己 | 午夜精品免费在线| 这里是久久伊人| 国产精品一二三四| 中文字幕一区二区三区精华液| 99精品视频在线免费观看| 亚洲欧美日韩小说| 日韩一区二区精品葵司在线 | 日韩欧美你懂的| 国产高清成人在线| 一区二区三区产品免费精品久久75| 欧美日韩久久一区| 国产黄色成人av| 亚洲一区中文日韩| 久久这里只精品最新地址| 99re这里只有精品首页| 婷婷开心激情综合| 国产午夜精品理论片a级大结局| 99riav一区二区三区| 奇米影视一区二区三区小说| 中文字幕第一区第二区| 欧美偷拍一区二区| 国产精一品亚洲二区在线视频| 亚洲色图视频免费播放| 日韩一级大片在线| 色天天综合久久久久综合片| 久久er精品视频| 亚洲图片欧美视频| 国产喷白浆一区二区三区| 欧美精品日韩精品| 成年人网站91| 韩国v欧美v日本v亚洲v| 亚洲国产欧美一区二区三区丁香婷| 精品国产乱码久久久久久免费| 一本久久综合亚洲鲁鲁五月天 | 国产宾馆实践打屁股91| 天天操天天干天天综合网| 成人免费一区二区三区在线观看| 7777精品伊人久久久大香线蕉最新版| 成人午夜av在线| 精品一区在线看| 人妖欧美一区二区| 亚洲成人午夜影院| 一区二区三区精密机械公司| 中文字幕精品—区二区四季| 久久久亚洲高清| 日韩欧美国产一区在线观看| 欧美少妇xxx| 在线观看日韩毛片| 一本到不卡免费一区二区| 大胆欧美人体老妇| 国产黄人亚洲片| 国产在线精品一区二区夜色 | 国产精品美女久久福利网站| 欧美成va人片在线观看| 777欧美精品| 777xxx欧美| 91精品国产91综合久久蜜臀| 欧美日韩国产综合久久| 欧美伊人久久久久久午夜久久久久| 成年人国产精品| 成人黄色av网站在线| 成人免费看的视频| 成人免费视频一区二区| 成人免费的视频| 波多野结衣中文字幕一区二区三区 | 国产一区二区三区高清播放| 日韩成人一区二区| 日本不卡的三区四区五区| 日韩av不卡一区二区| 日韩二区三区四区| 美女视频第一区二区三区免费观看网站| 图片区小说区区亚洲影院| 日韩在线a电影| 美洲天堂一区二卡三卡四卡视频| 久久疯狂做爰流白浆xx| 国产精品18久久久久久久网站| 国产精品1区二区.| 不卡在线视频中文字幕| 91毛片在线观看| 欧美久久久久中文字幕| 精品国产乱码久久久久久浪潮| 日本一区二区三区视频视频| 亚洲欧洲www| 亚洲一区二区视频在线观看| 日韩精品视频网站| 精品一区二区综合| 99久久精品国产毛片| 欧美日韩精品系列| 精品国产乱子伦一区| 国产精品女主播av| 亚洲www啪成人一区二区麻豆| 毛片一区二区三区| 不卡高清视频专区| 91精品国产91久久久久久一区二区 | 中文字幕亚洲一区二区av在线| 亚洲乱码国产乱码精品精的特点 | 国产欧美一区二区在线| 亚洲四区在线观看| 日韩av中文在线观看| 东方aⅴ免费观看久久av| 91福利社在线观看| 精品福利一区二区三区免费视频| 国产欧美日韩卡一| 午夜精品福利久久久| 国产成人免费在线视频| 欧美色老头old∨ideo| 国产欧美1区2区3区| 亚洲国产精品精华液网站| 国产麻豆精品视频| 欧美三级韩国三级日本三斤 | 亚洲精品国产无套在线观| 美女爽到高潮91| 91麻豆免费在线观看| 精品第一国产综合精品aⅴ| 亚洲精品国产视频| 国产精品亚洲人在线观看| 欧美日韩一区二区三区在线| 国产女主播视频一区二区| 日日摸夜夜添夜夜添亚洲女人| 风间由美一区二区三区在线观看| 欧美日本精品一区二区三区| 国产精品免费视频观看| 久久成人免费网站| 欧美日韩国产系列| 一区二区三区在线观看网站| 国产mv日韩mv欧美| 日韩欧美国产一二三区| 亚洲一二三专区| 97se狠狠狠综合亚洲狠狠| 国产亚洲一区二区三区四区| 日韩电影一区二区三区| 欧美在线免费视屏| 亚洲精品乱码久久久久久黑人 | 国产精品久久久久久久久快鸭 | aa级大片欧美| 国产精品欧美一区喷水| 国产黄色成人av| 久久精品亚洲精品国产欧美| 免费成人美女在线观看| 欧美美女网站色| 午夜国产精品影院在线观看| 欧美在线观看18| 亚洲女子a中天字幕| av在线这里只有精品| 国产欧美日韩激情| 风间由美一区二区av101| 久久精品欧美一区二区三区麻豆| 国产一区美女在线| 久久影院午夜论| 国产一区二区三区最好精华液| 欧美大片免费久久精品三p|