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

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

?? stereo.c

?? 語音濾波源代碼
?? C
字號:
/* Copyright (C) 2002 Jean-Marc Valin    File: stereo.c   Redistribution and use in source and binary forms, with or without   modification, are permitted provided that the following conditions   are met:      - Redistributions of source code must retain the above copyright   notice, this list of conditions and the following disclaimer.      - Redistributions in binary form must reproduce the above copyright   notice, this list of conditions and the following disclaimer in the   documentation and/or other materials provided with the distribution.      - Neither the name of the Xiph.org Foundation nor the names of its   contributors may be used to endorse or promote products derived from   this software without specific prior written permission.      THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS   ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT   LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR   A PARTICULAR PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR   CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,   EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,   PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR   PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF   LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING   NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS   SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.*/#ifdef HAVE_CONFIG_H#include "config.h"#endif#include "speex_stereo.h"#include "speex_callbacks.h"#include "vq.h"#include <math.h>/*float e_ratio_quant[4] = {1, 1.26, 1.587, 2};*/static const float e_ratio_quant[4] = {.25f, .315f, .397f, .5f};void speex_encode_stereo(float *data, int frame_size, SpeexBits *bits){   int i, tmp;   float e_left=0, e_right=0, e_tot=0;   float balance, e_ratio;   for (i=0;i<frame_size;i++)   {      e_left  += ((float)data[2*i])*data[2*i];      e_right += ((float)data[2*i+1])*data[2*i+1];      data[i] =  .5*(((float)data[2*i])+data[2*i+1]);      e_tot   += ((float)data[i])*data[i];   }   balance=(e_left+1)/(e_right+1);   e_ratio = e_tot/(1+e_left+e_right);   /*Quantization*/   speex_bits_pack(bits, 14, 5);   speex_bits_pack(bits, SPEEX_INBAND_STEREO, 4);      balance=4*log(balance);   /*Pack sign*/   if (balance>0)      speex_bits_pack(bits, 0, 1);   else      speex_bits_pack(bits, 1, 1);   balance=floor(.5+fabs(balance));   if (balance>30)      balance=31;      speex_bits_pack(bits, (int)balance, 5);      /*Quantize energy ratio*/   tmp=vq_index(&e_ratio, e_ratio_quant, 1, 4);   speex_bits_pack(bits, tmp, 2);}void speex_encode_stereo_int(spx_int16_t *data, int frame_size, SpeexBits *bits){   int i, tmp;   float e_left=0, e_right=0, e_tot=0;   float balance, e_ratio;   for (i=0;i<frame_size;i++)   {      e_left  += ((float)data[2*i])*data[2*i];      e_right += ((float)data[2*i+1])*data[2*i+1];      data[i] =  .5*(((float)data[2*i])+data[2*i+1]);      e_tot   += ((float)data[i])*data[i];   }   balance=(e_left+1)/(e_right+1);   e_ratio = e_tot/(1+e_left+e_right);   /*Quantization*/   speex_bits_pack(bits, 14, 5);   speex_bits_pack(bits, SPEEX_INBAND_STEREO, 4);      balance=4*log(balance);   /*Pack sign*/   if (balance>0)      speex_bits_pack(bits, 0, 1);   else      speex_bits_pack(bits, 1, 1);   balance=floor(.5+fabs(balance));   if (balance>30)      balance=31;      speex_bits_pack(bits, (int)balance, 5);      /*Quantize energy ratio*/   tmp=vq_index(&e_ratio, e_ratio_quant, 1, 4);   speex_bits_pack(bits, tmp, 2);}void speex_decode_stereo(float *data, int frame_size, SpeexStereoState *stereo){   float balance, e_ratio;   int i;   float e_tot=0, e_left, e_right, e_sum;   balance=stereo->balance;   e_ratio=stereo->e_ratio;   for (i=frame_size-1;i>=0;i--)   {      e_tot += ((float)data[i])*data[i];   }   e_sum=e_tot/e_ratio;   e_left  = e_sum*balance / (1+balance);   e_right = e_sum-e_left;   e_left  = sqrt(e_left/(e_tot+.01));   e_right = sqrt(e_right/(e_tot+.01));   for (i=frame_size-1;i>=0;i--)   {      float ftmp=data[i];      stereo->smooth_left  = .98*stereo->smooth_left  + .02*e_left;      stereo->smooth_right = .98*stereo->smooth_right + .02*e_right;      data[2*i] = stereo->smooth_left*ftmp;      data[2*i+1] = stereo->smooth_right*ftmp;   }}void speex_decode_stereo_int(spx_int16_t *data, int frame_size, SpeexStereoState *stereo){   float balance, e_ratio;   int i;   float e_tot=0, e_left, e_right, e_sum;   balance=stereo->balance;   e_ratio=stereo->e_ratio;   for (i=frame_size-1;i>=0;i--)   {      e_tot += ((float)data[i])*data[i];   }   e_sum=e_tot/e_ratio;   e_left  = e_sum*balance / (1+balance);   e_right = e_sum-e_left;   e_left  = sqrt(e_left/(e_tot+.01));   e_right = sqrt(e_right/(e_tot+.01));   for (i=frame_size-1;i>=0;i--)   {      float ftmp=data[i];      stereo->smooth_left  = .98*stereo->smooth_left  + .02*e_left;      stereo->smooth_right = .98*stereo->smooth_right + .02*e_right;      data[2*i] = stereo->smooth_left*ftmp;      data[2*i+1] = stereo->smooth_right*ftmp;   }}int speex_std_stereo_request_handler(SpeexBits *bits, void *state, void *data){   SpeexStereoState *stereo;   float sign=1;   int tmp;   stereo = (SpeexStereoState*)data;   if (speex_bits_unpack_unsigned(bits, 1))      sign=-1;   tmp = speex_bits_unpack_unsigned(bits, 5);   stereo->balance = exp(sign*.25*tmp);   tmp = speex_bits_unpack_unsigned(bits, 2);   stereo->e_ratio = e_ratio_quant[tmp];   return 0;}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美曰成人黄网| 99精品久久久久久| 欧美成人精精品一区二区频| 婷婷久久综合九色国产成人| 91精品国产综合久久久久| 免费在线观看日韩欧美| 久久综合色婷婷| av成人免费在线观看| 亚洲精品国久久99热| 欧美三级日韩三级| 蜜桃av一区二区| 国产精品三级av在线播放| 99re这里只有精品6| 亚洲午夜在线电影| 精品国产一区二区三区四区四| 国内精品伊人久久久久av影院 | 在线亚洲一区二区| 三级欧美在线一区| 精品国产制服丝袜高跟| 成人性生交大片免费看在线播放 | 亚洲一级不卡视频| 日韩一区二区三区视频在线| 国产一区二区三区免费| 亚洲乱码一区二区三区在线观看| 欧美精品三级在线观看| 国产一区二区三区四区五区美女| 亚洲伦在线观看| 久久中文字幕电影| 色8久久精品久久久久久蜜| 日本不卡一二三| 国产精品黄色在线观看| 欧美一区二区三区免费大片| 国产成人在线看| 午夜精品一区二区三区电影天堂| 亚洲精品一区二区三区四区高清| 91在线视频播放地址| 看电影不卡的网站| 亚洲综合成人网| 国产喂奶挤奶一区二区三区| 欧美日韩一区二区在线观看视频| 韩国v欧美v日本v亚洲v| 香蕉成人伊视频在线观看| 欧美激情一区二区三区四区| 欧美精品18+| 99国产精品99久久久久久| 精品一区二区三区在线播放视频 | 喷水一区二区三区| 亚洲女同女同女同女同女同69| 91精品国产免费| 色素色在线综合| 成人h精品动漫一区二区三区| 丝袜美腿亚洲综合| 日韩久久一区二区| 久久精品夜夜夜夜久久| 日韩欧美电影在线| 欧美老肥妇做.爰bbww视频| 99精品国产91久久久久久 | bt欧美亚洲午夜电影天堂| 奇米综合一区二区三区精品视频| 亚洲欧美激情一区二区| 久久亚洲二区三区| 日韩欧美亚洲国产另类| 欧美日韩精品免费观看视频 | 欧美探花视频资源| 99久久99久久久精品齐齐| 国产专区综合网| 国产乱国产乱300精品| 久久精品99久久久| 麻豆成人久久精品二区三区红 | 国产精品久久久久久久久搜平片| 精品国产青草久久久久福利| 欧美日韩国产123区| 色综合av在线| 欧美系列亚洲系列| 欧美影院精品一区| 欧美性三三影院| 精品婷婷伊人一区三区三| 色播五月激情综合网| 色婷婷一区二区| 色婷婷亚洲综合| 欧美日韩一区在线| 欧美日韩成人综合天天影院 | 91亚洲精品久久久蜜桃| 99久久精品国产一区二区三区| 成人妖精视频yjsp地址| 99精品在线免费| 色激情天天射综合网| 欧洲国内综合视频| 欧美精品在欧美一区二区少妇| 在线观看91精品国产麻豆| 日韩一区二区视频| 久久综合五月天婷婷伊人| 日本欧美大码aⅴ在线播放| 亚洲国产aⅴ成人精品无吗| 日韩中文字幕不卡| 精品一区二区免费在线观看| 高清国产一区二区| 色哟哟日韩精品| 欧美精品久久99久久在免费线| 日韩视频一区二区在线观看| 国产肉丝袜一区二区| 亚洲人成网站影音先锋播放| 亚洲成人7777| 国产伦精品一区二区三区免费| 不卡的看片网站| 欧美日韩在线三级| 精品国产免费人成在线观看| 国产精品毛片高清在线完整版| 亚洲精品国产一区二区精华液 | 自拍偷拍国产精品| 视频在线观看一区二区三区| 极品少妇一区二区三区精品视频 | 国内成人免费视频| 97se狠狠狠综合亚洲狠狠| 91精品国产手机| 国产精品久久免费看| 午夜欧美一区二区三区在线播放| 狠狠色综合日日| 91小视频免费看| 精品久久人人做人人爽| 亚洲精品欧美激情| 老鸭窝一区二区久久精品| 91视频观看免费| 26uuu亚洲| 亚洲二区在线视频| 成人免费视频免费观看| 911精品国产一区二区在线| 国产精品区一区二区三| 久久精品国内一区二区三区| 99精品偷自拍| 久久久国际精品| 日本亚洲一区二区| 在线影院国内精品| 国产区在线观看成人精品| 男女男精品视频网| 欧美网站大全在线观看| 国产清纯白嫩初高生在线观看91 | 日韩免费视频一区二区| 亚洲情趣在线观看| 国产成人免费在线观看不卡| 在线综合+亚洲+欧美中文字幕| 亚洲蜜臀av乱码久久精品蜜桃| 国产一区二区三区| 日韩一区二区视频| 午夜精品久久久久久久久久| 成人av在线一区二区| 国产亚洲视频系列| 久久99国产精品久久99果冻传媒| 在线欧美日韩国产| 国产女人水真多18毛片18精品视频 | 99久久久精品免费观看国产蜜| 26uuuu精品一区二区| 天堂蜜桃91精品| 777色狠狠一区二区三区| 亚洲一级在线观看| 在线免费视频一区二区| 中文字幕日韩av资源站| 懂色av中文一区二区三区| 香蕉久久夜色精品国产使用方法 | 亚洲综合色丁香婷婷六月图片| av激情亚洲男人天堂| 国产精品成人免费在线| fc2成人免费人成在线观看播放| 欧美激情综合网| 成人在线视频首页| 亚洲国产成人自拍| 成人动漫一区二区在线| 国产精品免费看片| 91亚洲资源网| 亚洲精选视频在线| 在线观看日产精品| 亚洲成人中文在线| 日韩一区和二区| 国产综合久久久久影院| 久久久久一区二区三区四区| 国产成人在线色| 日韩美女啊v在线免费观看| 99精品视频在线播放观看| 夜夜夜精品看看| 3751色影院一区二区三区| 日韩国产欧美在线播放| 日韩欧美的一区| 成人免费视频app| 亚洲日本在线a| 欧美午夜电影一区| 日本aⅴ免费视频一区二区三区| 日韩欧美黄色影院| 国产馆精品极品| 亚洲人成影院在线观看| 欧美军同video69gay| 久久91精品久久久久久秒播| 国产日韩欧美在线一区| 91在线视频免费91| 日韩精品91亚洲二区在线观看| 精品久久国产97色综合| av电影一区二区| 天堂va蜜桃一区二区三区漫画版| 精品国产髙清在线看国产毛片 | 亚洲美女在线一区| 91精品综合久久久久久|