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

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? adpcm.c.svn-base

?? ffmpeg最新源碼
?? SVN-BASE
?? 第 1 頁(yè) / 共 5 頁(yè)
字號(hào):
    }    return dst - frame;}#endif //CONFIG_ENCODERSstatic av_cold int adpcm_decode_init(AVCodecContext * avctx){    ADPCMContext *c = avctx->priv_data;    unsigned int max_channels = 2;    switch(avctx->codec->id) {    case CODEC_ID_ADPCM_EA_R1:    case CODEC_ID_ADPCM_EA_R2:    case CODEC_ID_ADPCM_EA_R3:        max_channels = 6;        break;    }    if(avctx->channels > max_channels){        return -1;    }    switch(avctx->codec->id) {    case CODEC_ID_ADPCM_CT:        c->status[0].step = c->status[1].step = 511;        break;    case CODEC_ID_ADPCM_IMA_WS:        if (avctx->extradata && avctx->extradata_size == 2 * 4) {            c->status[0].predictor = AV_RL32(avctx->extradata);            c->status[1].predictor = AV_RL32(avctx->extradata + 4);        }        break;    default:        break;    }    return 0;}static inline short adpcm_ima_expand_nibble(ADPCMChannelStatus *c, char nibble, int shift){    int step_index;    int predictor;    int sign, delta, diff, step;    step = step_table[c->step_index];    step_index = c->step_index + index_table[(unsigned)nibble];    if (step_index < 0) step_index = 0;    else if (step_index > 88) step_index = 88;    sign = nibble & 8;    delta = nibble & 7;    /* perform direct multiplication instead of series of jumps proposed by     * the reference ADPCM implementation since modern CPUs can do the mults     * quickly enough */    diff = ((2 * delta + 1) * step) >> shift;    predictor = c->predictor;    if (sign) predictor -= diff;    else predictor += diff;    c->predictor = av_clip_int16(predictor);    c->step_index = step_index;    return (short)c->predictor;}static inline short adpcm_ms_expand_nibble(ADPCMChannelStatus *c, char nibble){    int predictor;    predictor = (((c->sample1) * (c->coeff1)) + ((c->sample2) * (c->coeff2))) / 256;    predictor += (signed)((nibble & 0x08)?(nibble - 0x10):(nibble)) * c->idelta;    c->sample2 = c->sample1;    c->sample1 = av_clip_int16(predictor);    c->idelta = (AdaptationTable[(int)nibble] * c->idelta) >> 8;    if (c->idelta < 16) c->idelta = 16;    return c->sample1;}static inline short adpcm_ct_expand_nibble(ADPCMChannelStatus *c, char nibble){    int sign, delta, diff;    int new_step;    sign = nibble & 8;    delta = nibble & 7;    /* perform direct multiplication instead of series of jumps proposed by     * the reference ADPCM implementation since modern CPUs can do the mults     * quickly enough */    diff = ((2 * delta + 1) * c->step) >> 3;    /* predictor update is not so trivial: predictor is multiplied on 254/256 before updating */    c->predictor = ((c->predictor * 254) >> 8) + (sign ? -diff : diff);    c->predictor = av_clip_int16(c->predictor);    /* calculate new step and clamp it to range 511..32767 */    new_step = (ct_adpcm_table[nibble & 7] * c->step) >> 8;    c->step = av_clip(new_step, 511, 32767);    return (short)c->predictor;}static inline short adpcm_sbpro_expand_nibble(ADPCMChannelStatus *c, char nibble, int size, int shift){    int sign, delta, diff;    sign = nibble & (1<<(size-1));    delta = nibble & ((1<<(size-1))-1);    diff = delta << (7 + c->step + shift);    /* clamp result */    c->predictor = av_clip(c->predictor + (sign ? -diff : diff), -16384,16256);    /* calculate new step */    if (delta >= (2*size - 3) && c->step < 3)        c->step++;    else if (delta == 0 && c->step > 0)        c->step--;    return (short) c->predictor;}static inline short adpcm_yamaha_expand_nibble(ADPCMChannelStatus *c, unsigned char nibble){    if(!c->step) {        c->predictor = 0;        c->step = 127;    }    c->predictor += (c->step * yamaha_difflookup[nibble]) / 8;    c->predictor = av_clip_int16(c->predictor);    c->step = (c->step * yamaha_indexscale[nibble]) >> 8;    c->step = av_clip(c->step, 127, 24567);    return c->predictor;}static void xa_decode(short *out, const unsigned char *in,    ADPCMChannelStatus *left, ADPCMChannelStatus *right, int inc){    int i, j;    int shift,filter,f0,f1;    int s_1,s_2;    int d,s,t;    for(i=0;i<4;i++) {        shift  = 12 - (in[4+i*2] & 15);        filter = in[4+i*2] >> 4;        f0 = xa_adpcm_table[filter][0];        f1 = xa_adpcm_table[filter][1];        s_1 = left->sample1;        s_2 = left->sample2;        for(j=0;j<28;j++) {            d = in[16+i+j*4];            t = (signed char)(d<<4)>>4;            s = ( t<<shift ) + ((s_1*f0 + s_2*f1+32)>>6);            s_2 = s_1;            s_1 = av_clip_int16(s);            *out = s_1;            out += inc;        }        if (inc==2) { /* stereo */            left->sample1 = s_1;            left->sample2 = s_2;            s_1 = right->sample1;            s_2 = right->sample2;            out = out + 1 - 28*2;        }        shift  = 12 - (in[5+i*2] & 15);        filter = in[5+i*2] >> 4;        f0 = xa_adpcm_table[filter][0];        f1 = xa_adpcm_table[filter][1];        for(j=0;j<28;j++) {            d = in[16+i+j*4];            t = (signed char)d >> 4;            s = ( t<<shift ) + ((s_1*f0 + s_2*f1+32)>>6);            s_2 = s_1;            s_1 = av_clip_int16(s);            *out = s_1;            out += inc;        }        if (inc==2) { /* stereo */            right->sample1 = s_1;            right->sample2 = s_2;            out -= 1;        } else {            left->sample1 = s_1;            left->sample2 = s_2;        }    }}/* DK3 ADPCM support macro */#define DK3_GET_NEXT_NIBBLE() \    if (decode_top_nibble_next) \    { \        nibble = last_byte >> 4; \        decode_top_nibble_next = 0; \    } \    else \    { \        last_byte = *src++; \        if (src >= buf + buf_size) break; \        nibble = last_byte & 0x0F; \        decode_top_nibble_next = 1; \    }static int adpcm_decode_frame(AVCodecContext *avctx,                            void *data, int *data_size,                            const uint8_t *buf, int buf_size){    ADPCMContext *c = avctx->priv_data;    ADPCMChannelStatus *cs;    int n, m, channel, i;    int block_predictor[2];    short *samples;    short *samples_end;    const uint8_t *src;    int st; /* stereo */    /* DK3 ADPCM accounting variables */    unsigned char last_byte = 0;    unsigned char nibble;    int decode_top_nibble_next = 0;    int diff_channel;    /* EA ADPCM state variables */    uint32_t samples_in_chunk;    int32_t previous_left_sample, previous_right_sample;    int32_t current_left_sample, current_right_sample;    int32_t next_left_sample, next_right_sample;    int32_t coeff1l, coeff2l, coeff1r, coeff2r;    uint8_t shift_left, shift_right;    int count1, count2;    int coeff[2][2], shift[2];//used in EA MAXIS ADPCM    if (!buf_size)        return 0;    //should protect all 4bit ADPCM variants    //8 is needed for CODEC_ID_ADPCM_IMA_WAV with 2 channels    //    if(*data_size/4 < buf_size + 8)        return -1;    samples = data;    samples_end= samples + *data_size/2;    *data_size= 0;    src = buf;    st = avctx->channels == 2 ? 1 : 0;    switch(avctx->codec->id) {    case CODEC_ID_ADPCM_IMA_QT:        n = buf_size - 2*avctx->channels;        for (channel = 0; channel < avctx->channels; channel++) {            cs = &(c->status[channel]);            /* (pppppp) (piiiiiii) */            /* Bits 15-7 are the _top_ 9 bits of the 16-bit initial predictor value */            cs->predictor = (*src++) << 8;            cs->predictor |= (*src & 0x80);            cs->predictor &= 0xFF80;            /* sign extension */            if(cs->predictor & 0x8000)                cs->predictor -= 0x10000;            cs->predictor = av_clip_int16(cs->predictor);            cs->step_index = (*src++) & 0x7F;            if (cs->step_index > 88){                av_log(avctx, AV_LOG_ERROR, "ERROR: step_index = %i\n", cs->step_index);                cs->step_index = 88;            }            cs->step = step_table[cs->step_index];            samples = (short*)data + channel;            for(m=32; n>0 && m>0; n--, m--) { /* in QuickTime, IMA is encoded by chuncks of 34 bytes (=64 samples) */                *samples = adpcm_ima_expand_nibble(cs, src[0] & 0x0F, 3);                samples += avctx->channels;                *samples = adpcm_ima_expand_nibble(cs, src[0] >> 4  , 3);                samples += avctx->channels;                src ++;            }        }        if (st)            samples--;        break;    case CODEC_ID_ADPCM_IMA_WAV:        if (avctx->block_align != 0 && buf_size > avctx->block_align)            buf_size = avctx->block_align;//        samples_per_block= (block_align-4*chanels)*8 / (bits_per_sample * chanels) + 1;        for(i=0; i<avctx->channels; i++){            cs = &(c->status[i]);            cs->predictor = *samples++ = (int16_t)(src[0] + (src[1]<<8));            src+=2;            cs->step_index = *src++;            if (cs->step_index > 88){                av_log(avctx, AV_LOG_ERROR, "ERROR: step_index = %i\n", cs->step_index);                cs->step_index = 88;            }            if (*src++) av_log(avctx, AV_LOG_ERROR, "unused byte should be null but is %d!!\n", src[-1]); /* unused */        }        while(src < buf + buf_size){            for(m=0; m<4; m++){                for(i=0; i<=st; i++)                    *samples++ = adpcm_ima_expand_nibble(&c->status[i], src[4*i] & 0x0F, 3);                for(i=0; i<=st; i++)                    *samples++ = adpcm_ima_expand_nibble(&c->status[i], src[4*i] >> 4  , 3);                src++;            }            src += 4*st;        }        break;    case CODEC_ID_ADPCM_4XM:        cs = &(c->status[0]);        c->status[0].predictor= (int16_t)(src[0] + (src[1]<<8)); src+=2;

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲一区二区不卡免费| 亚洲老司机在线| 亚洲va天堂va国产va久| 国产91精品精华液一区二区三区| 欧美日韩一区二区在线观看| 日本一区二区三区免费乱视频 | 欧美videos中文字幕| 亚洲精品国产成人久久av盗摄| 国产资源精品在线观看| 欧美人狂配大交3d怪物一区| 国产精品成人免费精品自在线观看| 欧美aa在线视频| 欧美日韩亚洲高清一区二区| 最新高清无码专区| 国产成人av一区| 精品88久久久久88久久久| 午夜国产不卡在线观看视频| 91蜜桃网址入口| 中文字幕中文在线不卡住| 国产精品一区二区在线观看不卡| 日韩欧美视频在线| 视频一区国产视频| 欧美色图激情小说| 亚洲午夜久久久久| 色婷婷av一区二区| 亚洲人成精品久久久久久| 成人黄色大片在线观看| 国产欧美一区在线| 粉嫩蜜臀av国产精品网站| 久久久久久久久岛国免费| 国产呦精品一区二区三区网站| 欧美成人a视频| 久久99精品久久久久久动态图| 日韩欧美综合一区| 蜜桃在线一区二区三区| 日韩欧美在线网站| 日本午夜一区二区| 日韩免费视频一区二区| 久久国产尿小便嘘嘘尿| 日韩精品一区二区三区在线| 久久99精品国产91久久来源| 亚洲精品一线二线三线| 国产在线麻豆精品观看| 久久久一区二区| 国产乱对白刺激视频不卡| 国产日韩av一区| 成人国产精品免费观看| 成人免费小视频| 日本韩国一区二区| 亚洲午夜精品在线| 91精品婷婷国产综合久久| 日本一区中文字幕| 精品久久久久av影院| 国产一区中文字幕| 国产精品丝袜在线| 色综合网站在线| 性做久久久久久| 欧美一区二区久久| 国产成人一区二区精品非洲| 国产精品污www在线观看| 91蜜桃网址入口| 亚洲v日本v欧美v久久精品| 欧美一区二区三级| 国产激情视频一区二区三区欧美 | 欧美激情一区三区| 99久久精品国产导航| 亚洲中国最大av网站| 5858s免费视频成人| 久久精品国产99| 国产精品欧美久久久久无广告| 91黄色免费网站| 免费久久99精品国产| 久久网这里都是精品| 99精品一区二区三区| 亚洲福利一二三区| 久久丝袜美腿综合| 91丨porny丨首页| 日韩精品一卡二卡三卡四卡无卡| 日韩免费福利电影在线观看| 国产成人午夜精品5599| 一区二区不卡在线播放| 91精品国产综合久久香蕉麻豆| 国产一区二区在线观看免费 | 7777精品伊人久久久大香线蕉完整版| 久久成人免费日本黄色| 国产精品久线观看视频| 欧美视频自拍偷拍| 国产精品一级在线| 亚洲国产日韩在线一区模特| 精品国产不卡一区二区三区| 99久久精品一区二区| 奇米精品一区二区三区在线观看一 | 国产高清不卡一区| 亚洲小说欧美激情另类| 久久综合给合久久狠狠狠97色69| 色婷婷久久综合| 美女视频黄免费的久久| 中文字幕一区二区三区不卡 | 欧美日韩欧美一区二区| 国产精品综合一区二区三区| 亚洲午夜精品在线| 国产精品网曝门| 欧美一级片在线看| 一本大道久久a久久精品综合| 精品一区中文字幕| 亚洲国产精品久久久久婷婷884 | 久久综合久色欧美综合狠狠| 色国产综合视频| 久久激情五月婷婷| 亚洲在线免费播放| 日韩成人一级大片| 国产精品午夜在线观看| 日韩三级视频在线看| 欧洲色大大久久| www.激情成人| 国产精品99久久久久久久vr | 亚洲欧美自拍偷拍色图| 日韩美女主播在线视频一区二区三区 | 亚洲国产一区二区在线播放| 国产欧美一区二区三区鸳鸯浴| 欧美一区二区三区思思人| 色综合天天综合网天天看片| 国产成人av电影免费在线观看| 日本中文字幕一区二区视频| 一区二区久久久久久| 国产精品国产三级国产有无不卡 | 欧美精品丝袜中出| 色综合久久88色综合天天6 | 麻豆精品视频在线观看视频| 一区二区三区欧美日韩| 中文成人综合网| 久久中文娱乐网| 日韩欧美电影在线| 91精品午夜视频| 欧美日韩你懂得| 欧美午夜片在线看| 91福利在线免费观看| 成人免费视频caoporn| 国产麻豆视频一区二区| 麻豆精品在线观看| 日本美女一区二区三区视频| 亚洲大尺度视频在线观看| 亚洲综合区在线| 一级做a爱片久久| 亚洲欧美一区二区不卡| 日韩一区在线看| 综合欧美一区二区三区| 亚洲人精品一区| 亚洲免费伊人电影| 一区二区三区久久| 一区二区三区美女视频| 亚洲激情图片小说视频| 亚洲码国产岛国毛片在线| 亚洲日本一区二区| 亚洲欧美偷拍卡通变态| 一区二区三区中文在线观看| 一区二区三区日韩精品视频| 一区二区三区免费| 亚洲大片一区二区三区| 视频一区视频二区中文| 蜜桃精品在线观看| 久久99热这里只有精品| 激情欧美一区二区| 国产一区二区三区美女| 国产激情一区二区三区| 不卡一区二区在线| 91香蕉视频污| 欧美日韩一级黄| 亚洲影院免费观看| 亚洲男人的天堂网| 亚洲一区二区三区四区在线免费观看| 亚洲最新在线观看| 亚洲一级在线观看| 日本欧美一区二区三区乱码| 久久精品国产亚洲高清剧情介绍| 精品亚洲国产成人av制服丝袜| 国产乱码精品一区二区三区五月婷| 国产91精品一区二区麻豆网站 | av在线不卡电影| 日本韩国视频一区二区| 欧美日韩性生活| 精品少妇一区二区三区视频免付费| 国产日韩高清在线| 亚洲伦理在线免费看| 亚洲国产日韩综合久久精品| 美女一区二区三区在线观看| 国产精品白丝jk白祙喷水网站 | 卡一卡二国产精品| 国产aⅴ精品一区二区三区色成熟| av电影一区二区| 欧美色视频在线| 久久久蜜桃精品| 亚洲男女毛片无遮挡| 秋霞午夜鲁丝一区二区老狼| 国产在线麻豆精品观看| 99国产欧美久久久精品| 91精品免费在线| 欧美高清在线精品一区| 性做久久久久久久免费看| 国产麻豆精品视频|