青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

牽著老婆滿街逛

嚴(yán)以律己,寬以待人. 三思而后行.
GMail/GTalk: yanglinbo#google.com;
MSN/Email: tx7do#yahoo.com.cn;
QQ: 3 0 3 3 9 6 9 2 0 .

speex 的一個(gè)例子, 使用了SPEEX抖動(dòng)緩存.

轉(zhuǎn)載自:http://blog.163.com/yuan_zhch/blog/static/193790046201172743047588/

http://svn.xiph.org/trunk/speex/speexclient/
/***************************************************************************
   Copyright (C) 2004-2006 by Jean-Marc Valin
   Copyright (C) 2006 Commonwealth Scientific and Industrial Research
                      Organisation (CSIRO) Australia

   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 
<stdlib.h>
#include 
<sys/types.h>
#include 
<sys/socket.h>
#include 
<netinet/in.h>
#include 
<arpa/inet.h>
#include 
<netdb.h>
#include 
<stdio.h>
#include 
<unistd.h> /* close() */
#include 
<string.h> /* memset() */

#include 
"alsa_device.h"
#include 
<speex/speex.h>
#include 
<speex/speex_jitter.h>
#include 
<speex/speex_preprocess.h>
#include 
<speex/speex_echo.h>
#include 
"speex_jitter_buffer.h"

#include 
<sched.h>

#define MAX_MSG 1500

#define SAMPLING_RATE 16000
#define FRAME_SIZE 320

int main(int argc, char *argv[])
{
   
   
int sd, rc, n;
   
int i;
   
struct sockaddr_in cliAddr, remoteAddr;
   
char msg[MAX_MSG];
   
struct hostent *h;
   
int local_port, remote_port;
   
int nfds;
   
struct pollfd *pfds;
   SpeexPreprocessState 
*preprocess;
   AlsaDevice 
*audio_dev;
   
int tmp;

   
if (argc != 5)
   
{
      fprintf(stderr, 
"wrong options\n");
      exit(
1);
   }

  
   h 
= gethostbyname(argv[2]);
   
if(h==NULL) {
      fprintf(stderr, 
"%s: unknown host '%s' \n", argv[0], argv[1]);
      exit(
1);
   }


   local_port 
= atoi(argv[3]);
   remote_port 
= atoi(argv[4]);
   
   printf(
"%s: sending data to '%s' (IP : %s) \n", argv[0], h->h_name,
          inet_ntoa(
*(struct in_addr *)h->h_addr_list[0]));

   
{
      remoteAddr.sin_family 
= h->h_addrtype;
      memcpy((
char *&remoteAddr.sin_addr.s_addr,
            h
->h_addr_list[0], h->h_length);
      remoteAddr.sin_port 
= htons(remote_port);
   }

   
/* socket creation */
   sd
=socket(AF_INET, SOCK_DGRAM, 0);
   
if(sd<0{
      printf(
"%s: cannot open socket \n",argv[0]);
      exit(
1);
   }


   
/* bind any port */
   cliAddr.sin_family 
= AF_INET;
   cliAddr.sin_addr.s_addr 
= htonl(INADDR_ANY);
   cliAddr.sin_port 
= htons(local_port);

   rc 
= bind(sd, (struct sockaddr *&cliAddr, sizeof(cliAddr));
   
if(rc<0{
      printf(
"%s: cannot bind port\n", argv[0]);
      exit(
1);
   }


   
/* Setup audio device */
   audio_dev 
= alsa_device_open(argv[1], SAMPLING_RATE, 1, FRAME_SIZE);
   
   
/* Setup the encoder and decoder in wideband */
   
void *enc_state, *dec_state;
   enc_state 
= speex_encoder_init(&speex_wb_mode);
   tmp 
= 8;
   speex_encoder_ctl(enc_state, SPEEX_SET_QUALITY, 
&tmp);
   tmp 
= 2;
   speex_encoder_ctl(enc_state, SPEEX_SET_COMPLEXITY, 
&tmp);
   dec_state 
= speex_decoder_init(&speex_wb_mode);
   tmp 
= 1;
   speex_decoder_ctl(dec_state, SPEEX_SET_ENH, 
&tmp);
   SpeexBits enc_bits, dec_bits;
   speex_bits_init(
&enc_bits);
   speex_bits_init(
&dec_bits);
   
   
   
struct sched_param param;
   
/*param.sched_priority = 40; */
   param.sched_priority 
= sched_get_priority_min(SCHED_FIFO);
   
if (sched_setscheduler(0,SCHED_FIFO,&param))
      perror(
"sched_setscheduler");

   
int send_timestamp = 0;
   
int recv_started=0;
   
   
/* Setup all file descriptors for poll()ing */
   nfds 
= alsa_device_nfds(audio_dev);
   pfds 
= malloc(sizeof(*pfds)*(nfds+1));
   alsa_device_getfds(audio_dev, pfds, nfds);
   pfds[nfds].fd 
= sd;
   pfds[nfds].events 
= POLLIN;

   
/* Setup jitter buffer using decoder */
   SpeexJitter jitter;
   speex_jitter_init(
&jitter, dec_state, SAMPLING_RATE);
   
   
/* Echo canceller with 200 ms tail length */
   SpeexEchoState 
*echo_state = speex_echo_state_init(FRAME_SIZE, 10*FRAME_SIZE);
   tmp 
= SAMPLING_RATE;
   speex_echo_ctl(echo_state, SPEEX_ECHO_SET_SAMPLING_RATE, 
&tmp);

   
/* Setup preprocessor and associate with echo canceller for residual echo suppression */
   preprocess 
= speex_preprocess_state_init(FRAME_SIZE, SAMPLING_RATE);
   speex_preprocess_ctl(preprocess, SPEEX_PREPROCESS_SET_ECHO_STATE, echo_state);
   
   alsa_device_start(audio_dev);
   
   
/* Infinite loop on capture, playback and receiving packets */
   
while (1)
   
{
      
/* Wait for either 1) capture 2) playback 3) socket data */
      poll(pfds, nfds
+1-1);
      
/* Received packets */
      
if (pfds[nfds].revents & POLLIN)
      
{
         
/*fprintf (stderr, "x");*/
         n 
= recv(sd, msg, MAX_MSG, 0);
         
int recv_timestamp = ((int*)msg)[1];
         
int payload = ((int*)msg)[0];
   
         
if ((payload & 0x80000000== 0
         
{
            
/* Put content of the packet into the jitter buffer, except for the pseudo-header */
            speex_jitter_put(
&jitter, msg+8, n-8, recv_timestamp);
            recv_started 
= 1;
         }


      }

      
/* Ready to play a frame (playback) */
      
if (alsa_device_playback_ready(audio_dev, pfds, nfds))
      
{
         
short pcm[FRAME_SIZE];
         
if (recv_started)
         
{
            
/* Get audio from the jitter buffer */
            speex_jitter_get(
&jitter, pcm, NULL);
         }
 else {
            
for (i=0;i<FRAME_SIZE;i++)
               pcm[i] 
= 0;
         }

         
/* Playback the audio and reset the echo canceller if we got an underrun */
         
if (alsa_device_write(audio_dev, pcm, FRAME_SIZE))
            speex_echo_state_reset(echo_state);
         
/* Put frame into playback buffer */
         speex_echo_playback(echo_state, pcm);
      }

      
/* Audio available from the soundcard (capture) */
      
if (alsa_device_capture_ready(audio_dev, pfds, nfds))
      
{
         
short pcm[FRAME_SIZE], pcm2[FRAME_SIZE];
         
char outpacket[MAX_MSG];
         
/* Get audio from the soundcard */
         alsa_device_read(audio_dev, pcm, FRAME_SIZE);
         
         
/* Perform echo cancellation */
         speex_echo_capture(echo_state, pcm, pcm2);
         
for (i=0;i<FRAME_SIZE;i++)
            pcm[i] 
= pcm2[i];
         
         speex_bits_reset(
&enc_bits);
         
         
/* Apply noise/echo suppression */
         speex_preprocess_run(preprocess, pcm);
         
         
/* Encode */
         speex_encode_int(enc_state, pcm, 
&enc_bits);
         
int packetSize = speex_bits_write(&enc_bits, outpacket+8, MAX_MSG);
         
         
/* Pseudo header: four null bytes and a 32-bit timestamp */
         ((
int*)outpacket)[0= htonl(0);
         ((
int*)outpacket)[1= send_timestamp;
         send_timestamp 
+= FRAME_SIZE;
         rc 
= sendto(sd, outpacket, packetSize+80,
                (
struct sockaddr *&remoteAddr,
                
sizeof(remoteAddr));
         
         
if(rc<0{
            printf(
"cannot send audio data\n");
            close(sd);
            exit(
1);
         }

      }

      

   }



   
return 0;
}

posted on 2012-11-23 16:56 楊粼波 閱讀(4764) 評(píng)論(0)  編輯 收藏 引用 所屬分類: 文章收藏

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            久久久国产一区二区| 中文精品在线| 欧美成人自拍视频| 久久久久久久国产| 一区二区三区在线高清| 久久久另类综合| 久久久久久亚洲精品杨幂换脸| 亚洲欧美日韩综合国产aⅴ| 国产精品超碰97尤物18| 亚洲尤物影院| 亚洲一区二区在线看| 国产精品99免视看9| 亚洲一区二区三区三| 亚洲视频在线看| 国产免费成人av| 久久久久久999| 久久亚洲免费| 亚洲乱码国产乱码精品精天堂| 欧美在线首页| 久久不见久久见免费视频1| 狠狠色狠狠色综合系列| 欧美不卡一卡二卡免费版| 欧美成人精品| 中文亚洲欧美| 亚洲欧美电影在线观看| 国产午夜精品久久久| 免费成人av在线看| 欧美激情在线免费观看| 亚洲午夜激情网站| 午夜欧美精品| 一区二区在线观看视频| 欧美国产三区| 欧美日韩一区三区| 久久国产手机看片| 久久综合九色综合欧美狠狠| 亚洲精品在线免费观看视频| 一本色道久久88综合亚洲精品ⅰ| 欧美电影免费观看网站| 中文精品在线| 性欧美激情精品| 亚洲国产精品毛片| 99这里只有精品| 国产欧美日韩精品a在线观看| 亚洲一区二区毛片| 欧美一级久久久久久久大片| 亚洲国产精品一区| 亚洲视频一二区| 激情校园亚洲| 日韩午夜免费视频| 国产一级一区二区| 亚洲国内在线| 国产精品久久久久久模特| 久久综合久久久| 欧美日韩国产不卡| 欧美在线视频网站| 免费永久网站黄欧美| 午夜精品一区二区三区四区| 久久夜色精品一区| 亚洲欧美另类国产| 久久综合久久综合这里只有精品| 在线看国产日韩| 一区二区高清视频| 国产综合欧美| 亚洲美女在线观看| 精品动漫3d一区二区三区免费版| 久久先锋影音| 欧美婷婷在线| 欧美+亚洲+精品+三区| 欧美天堂亚洲电影院在线播放| 亚洲欧美日韩电影| 欧美/亚洲一区| 久久电影一区| 欧美日韩国产色综合一二三四| 一区二区三区四区精品| 欧美一级淫片aaaaaaa视频| 亚洲精品欧美| 久久久国产精品一区二区中文 | 久久精品日产第一区二区| 欧美成人自拍视频| 久久精品一区中文字幕| 欧美色中文字幕| 欧美大秀在线观看| 国产午夜精品久久久| 日韩视频精品在线| 亚洲国产精品免费| 香蕉免费一区二区三区在线观看 | 国产精品午夜国产小视频| 亚洲第一精品夜夜躁人人爽| 国产欧美精品一区二区三区介绍| 免费高清在线一区| 国产视频一区免费看| 一区二区三区日韩在线观看| 亚洲精品看片| 另类欧美日韩国产在线| 久久久噜噜噜久久人人看| 欧美性猛交99久久久久99按摩 | 亚洲精品乱码久久久久久久久 | 国产精品一区免费视频| 亚洲国产午夜| 精品成人国产| 日韩视频二区| 91久久久亚洲精品| 久久超碰97人人做人人爱| 亚洲一区日韩在线| 欧美激情一区二区三级高清视频 | 亚洲成人直播| 亚洲欧美电影在线观看| 一区二区三区在线观看欧美| 性做久久久久久免费观看欧美| 伊人久久亚洲热| 亚洲一区二区三区高清 | 亚洲视频每日更新| 亚洲精品系列| 久久九九精品| 久久久久国产精品一区| 国产精品美女| 99精品视频免费观看视频| 亚洲欧洲一二三| 老色批av在线精品| 欧美成人免费播放| 韩国v欧美v日本v亚洲v| 亚洲女同在线| 欧美亚洲综合网| 国产精品三上| 一区二区三区黄色| 亚洲欧美精品suv| 欧美午夜不卡视频| 一本大道久久精品懂色aⅴ| 日韩小视频在线观看专区| 久久久久久久久综合| 牛牛精品成人免费视频| 激情亚洲成人| 久久婷婷蜜乳一本欲蜜臀| 久久亚洲午夜电影| 狠狠色狠色综合曰曰| 久久精品综合一区| 久久久精彩视频| 亚洲第一免费播放区| 久久频这里精品99香蕉| 女人香蕉久久**毛片精品| 亚洲成色777777在线观看影院| 亚洲日本va午夜在线影院| 亚洲国产日韩欧美| 欧美极品欧美精品欧美视频| 亚洲高清精品中出| 日韩视频亚洲视频| 欧美日韩免费一区| 一区二区三区视频观看| 西瓜成人精品人成网站| 国产美女一区二区| 欧美影院一区| 免费人成精品欧美精品| 亚洲激情欧美| 欧美日韩视频在线观看一区二区三区 | 在线综合亚洲欧美在线视频| 亚洲视频精选| 国产精品v片在线观看不卡| 亚洲性夜色噜噜噜7777| 欧美亚洲综合久久| 国产综合久久久久久鬼色| 免费在线一区二区| 亚洲区一区二区三区| 亚洲午夜伦理| 国产欧美一区二区三区久久| 午夜久久久久久| 葵司免费一区二区三区四区五区| 国产欧美精品日韩区二区麻豆天美| 亚洲乱码国产乱码精品精可以看| 亚洲第一区色| 欧美人在线观看| 亚洲精选国产| 久久久久久久一区二区| 亚洲丁香婷深爱综合| 欧美日韩成人精品| 亚洲天堂视频在线观看| 久热精品视频在线| 亚洲区中文字幕| 国产精品护士白丝一区av| 欧美在线视频不卡| 欧美激情国产高清| 欧美亚洲一区二区三区| 在线观看成人网| 欧美日韩免费观看一区三区| 亚洲男人影院| 久久综合狠狠综合久久综合88| 一区二区三区在线不卡| 欧美成人一区二区三区在线观看| 欧美~级网站不卡| 一区二区国产在线观看| 国产日韩欧美黄色| 久久一区二区三区超碰国产精品| 免费试看一区| 亚洲午夜电影| 在线播放精品| 欧美色播在线播放| 午夜精品久久久久久久99水蜜桃 | 亚洲人成在线播放网站岛国| 亚洲欧美中文日韩在线| 狠狠色狠狠色综合日日tαg| 欧美区一区二|