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

牽著老婆滿街逛

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

CELT編碼解碼

轉載自:https://gist.github.com/haxar/2402477


解碼:

 
#include 
<stdio.h>
#include 
<stdlib.h>
#include 
<stdint.h>
#include 
<string.h>
#include 
<unistd.h>
#include 
<errno.h>
 
#include 
"celt.h"
 
int
main(
int argc, char **argv) {
    
char data[2048= { };
    
short pcm[2048= { };
    
int rate        = 48000;
    
int framesize   = 960;
    
int channels    = 1;
    
int tmp;
    
int rem;
    
void *mode;
    
void *state;
    uint16_t len;
 
    
while ((tmp = getopt(argc, argv, "r:f:c:")) != -1{
        
switch (tmp) {
          
case 'r':
            rate 
= atoi(optarg);
            
break;
          
case 'f':
            framesize 
= atoi(optarg);
            
break;
          
case 'c':
            channels 
= atoi(optarg);
            
break;
        }

    }

    
if (!(mode = celt_mode_create(rate, framesize, &tmp))) {
        fprintf(stderr, 
"error: celt_mode_create: %s\n", celt_strerror(tmp));
        
return 1;
    }

    
if (!(state = celt_decoder_create_custom(mode, channels, &tmp))) {
        fprintf(stderr, 
"error: celt_decoder_create_custom: %s\n", celt_strerror(tmp));
        celt_mode_destroy(mode);
        
return 1;
    }

 
    
for (len = 0;;) {
        
if (!len) {
            
if (read(STDIN_FILENO, &len, sizeof(len)) != sizeof(len)) {
                
break;
            }

            
if (len > sizeof(data)) {
                fprintf(stderr, 
"error: celt packet larger than buffer\n");
                celt_decoder_destroy(state);
                celt_mode_destroy(mode);
                
return 1;
            }

            rem 
= len;
        }

        
if ((tmp = read(STDIN_FILENO, data + (len - rem), rem)) < 0{
            fprintf(stderr, 
"error: read: %s\n", strerror(errno));
            celt_decoder_destroy(state);
            celt_mode_destroy(mode);
            
return 1;
        }

        
if (!tmp) {
            
break;
        }

        
if (tmp != rem) {
            rem 
-= tmp;
            
continue;
        }

        
if ((tmp = celt_decode(state, (void *)data, len, pcm, framesize)) < 0{
            fprintf(stderr, 
"error: celt_decode: %s\n", celt_strerror(tmp));
            celt_decoder_destroy(state);
            celt_mode_destroy(mode);
            
return 1;
        }

        len 
= 0;
        
if (write(STDOUT_FILENO, pcm, sizeof(*pcm) * framesize * channels) < 0{
            fprintf(stderr, 
"error: write: %s\n", strerror(errno));
            celt_decoder_destroy(state);
            celt_mode_destroy(mode);
            
return 1;
        }

    }

 
    celt_decoder_destroy(state);
    celt_mode_destroy(mode);
 
    
return 0;
}



編碼:
#include <stdio.h>
#include 
<stdlib.h>
#include 
<stdint.h>
#include 
<string.h>
#include 
<unistd.h>
#include 
<errno.h>
 
#include 
"celt.h"
 
int
main(
int argc, char **argv) {
    
short pcm[2048= { };
    
char data[2048= { };
    
int rate        = 48000;
    
int framesize   = 960;
    
int channels    = 1;
    
int bitrate     = 0;
    
int variable    = 0;
    
int prediction  = 2;
    
int complexity  = 10;
    
int tmp;
    
int rem;
    
void *mode;
    
void *state;
    uint16_t len;
 
    
while ((tmp = getopt(argc, argv, "r:f:c:b:vp:x:")) != -1{
        
switch (tmp) {
          
case 'r':
            rate 
= atoi(optarg);
            
break;
          
case 'f':
            framesize 
= atoi(optarg);
            
break;
          
case 'c':
            channels 
= atoi(optarg);
            
break;
          
case 'b':
            bitrate 
= atoi(optarg);
            
break;
          
case 'v':
            variable 
= 1;
            
break;
          
case 'p':
            prediction 
= atoi(optarg);
            
break;
          
case 'x':
            complexity 
= atoi(optarg);
            
break;
        }

    }

    
if (!(mode = celt_mode_create(rate, framesize, &tmp))) {
        fprintf(stderr, 
"error: celt_mode_create: %s\n", celt_strerror(tmp));
        
return 1;
    }

    
if (!(state = celt_encoder_create_custom(mode, channels, &tmp))) {
        fprintf(stderr, 
"error: celt_encoder_create_custom: %s\n", celt_strerror(tmp));
        celt_mode_destroy(mode);
        
return 1;
    }

    
if (bitrate && celt_encoder_ctl(state, CELT_SET_BITRATE(bitrate)) != CELT_OK) {
        fprintf(stderr, 
"error: celt_encoder_ctl: CELT_SET_BITRATE: bitrate request failed\n");
        celt_encoder_destroy(state);
        celt_mode_destroy(mode);
        
return 1;
    }

    
if (variable && celt_encoder_ctl(state, CELT_SET_VBR(variable)) != CELT_OK) {
        fprintf(stderr, 
"error: celt_encoder_ctl: CELT_SET_VBR: vbr request failed\n");
        celt_encoder_destroy(state);
        celt_mode_destroy(mode);
        
return 1;
    }

    
if (celt_encoder_ctl(state, CELT_SET_PREDICTION(prediction)) != CELT_OK) {
        fprintf(stderr, 
"error: celt_encoder_ctl: CELT_SET_PREDICTION: prediction request failed\n");
        celt_encoder_destroy(state);
        celt_mode_destroy(mode);
        
return 1;
    }

    
if (celt_encoder_ctl(state, CELT_SET_COMPLEXITY(complexity)) != CELT_OK) {
        fprintf(stderr, 
"error: celt_encoder_ctl: CELT_SET_COMPLEXITY: complexity 0 through 10 is only supported\n");
        celt_encoder_destroy(state);
        celt_mode_destroy(mode);
        
return 1;
    }

 
    
for (len = 0;;) {
        
if (!len) {
            len 
= sizeof(*pcm) * framesize * channels;
            
if (len > sizeof(pcm)) {
                fprintf(stderr, 
"error: pcm frame larger than buffer\n");
                celt_encoder_destroy(state);
                celt_mode_destroy(mode);
                
return 1;
            }

            rem 
= len;
        }

        
if ((tmp = read(STDIN_FILENO, (void *)pcm + (len - rem), rem)) < 0{
            fprintf(stderr, 
"error: read: %s\n", strerror(errno));
            celt_encoder_destroy(state);
            celt_mode_destroy(mode);
            
return 1;
        }

        
if (!tmp) {
            
break;
        }

        
if (tmp != rem) {
            rem 
-= tmp;
            
continue;
        }

        
if ((tmp = celt_encode(state, pcm, framesize, (void *)data, sizeof(data))) < 0{
            fprintf(stderr, 
"error: celt_encode: %s\n", celt_strerror(tmp));
            celt_encoder_destroy(state);
            celt_mode_destroy(mode);
            
return 1;
        }

        len 
= tmp;
        
if (write(STDOUT_FILENO, &len, sizeof(len)) < 0 || write(STDOUT_FILENO, data, len) < 0{
            fprintf(stderr, 
"error: write: %s\n", strerror(errno));
            celt_encoder_destroy(state);
            celt_mode_destroy(mode);
            
return 1;
        }

        len 
= 0;
    }

 
    celt_encoder_destroy(state);
    celt_mode_destroy(mode);
 
    
return 0;
}


posted on 2013-02-10 13:09 楊粼波 閱讀(1778) 評論(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>
            国产精品久久久久一区二区三区 | 日韩视频国产视频| 国产精品成人午夜| 国产精品久久久久久久久| 欧美视频在线观看 亚洲欧| 欧美日韩国产综合在线| 国产精品草莓在线免费观看| 国产精品每日更新| 国内揄拍国内精品少妇国语| 一区二区三区在线观看国产| 91久久精品美女高潮| 日韩视频一区二区| 午夜视频在线观看一区二区三区| 欧美在线综合| 亚洲国产一区视频| 亚洲国产精品va在线观看黑人| 亚洲欧洲精品成人久久奇米网| 99这里只有精品| 欧美亚洲在线观看| 欧美成人免费在线观看| 国产精品久久一卡二卡| 一色屋精品亚洲香蕉网站| 99v久久综合狠狠综合久久| 欧美在线视频日韩| 亚洲日本激情| 欧美一区二区三区啪啪| 久久九九精品99国产精品| 欧美 日韩 国产一区二区在线视频| 亚洲精品偷拍| 久久久一二三| 国产乱子伦一区二区三区国色天香| 亚洲电影在线免费观看| 亚洲免费在线| 亚洲高清精品中出| 欧美一级专区| 国产精品视频久久| 一个色综合av| 欧美成人自拍| 欧美在线网站| 国产精品男gay被猛男狂揉视频| 亚洲电影中文字幕| 久久久久久久成人| 亚洲专区一区| 欧美视频免费看| 日韩视频在线观看免费| 欧美成人在线影院| 久久久久久久久久久久久9999| 国产精品稀缺呦系列在线| 亚洲精品美女91| 欧美风情在线观看| 久久久精品动漫| 精品电影一区| 久久综合久久久久88| 欧美一站二站| 国产一区二区三区在线观看视频| 性色av一区二区三区| 一区二区三区成人| 国产精品久久激情| 亚洲综合国产| 亚洲一区二区三区四区中文| 国产精品成人一区二区网站软件| 亚洲视频日本| 亚洲一级一区| 国产日韩精品入口| 久久精彩免费视频| 欧美一区二区视频观看视频| 国产农村妇女毛片精品久久麻豆 | 欧美在线一区二区三区| 亚洲欧美另类在线| 国产亚洲精品一区二555| 欧美专区18| 久久精品亚洲一区二区三区浴池 | 欧美一区二区三区久久精品| 亚洲免费在线电影| 韩日成人av| 亚洲高清影视| 欧美日韩国产美女| 欧美一区二区三区视频在线观看| 午夜精品美女自拍福到在线| 国产自产v一区二区三区c| 老司机一区二区| 欧美韩日一区| 国产精品嫩草99av在线| 久久国产福利国产秒拍| 久久国产色av| 日韩视频免费| 亚洲免费一在线| 91久久久久久久久| 亚洲午夜精品17c| 狠狠色噜噜狠狠色综合久 | 亚洲国产婷婷香蕉久久久久久99| 欧美日韩a区| 欧美一区亚洲一区| 六月婷婷久久| 午夜精品久久久久久久久| 久久女同精品一区二区| 亚洲午夜激情| 久久久人成影片一区二区三区| 亚洲另类视频| 久久精品首页| 亚洲欧美在线高清| 欧美大秀在线观看| 久久九九99视频| 欧美日韩理论| 欧美激情一区二区三区在线 | 欧美www视频| 久久久99国产精品免费| 欧美精品一区二区三区很污很色的 | 91久久精品国产91性色tv| 亚洲一区二区三区久久| 亚洲片区在线| 久久精品欧洲| 欧美一区二区三区男人的天堂| 欧美激情一区二区三区在线| 久久人人爽爽爽人久久久| 国产精品久久久久一区二区三区| 亚洲电影自拍| 国内精品视频在线观看| 亚洲永久免费| 另类尿喷潮videofree | 午夜亚洲性色视频| 亚洲一级黄色片| 欧美理论在线| 亚洲国产成人久久综合一区| 狠狠干成人综合网| 亚洲欧美在线观看| 欧美亚洲一区二区在线| 国产精品乱子久久久久| 日韩天堂av| 99国内精品久久| 国产欧美日韩视频在线观看 | 一区在线影院| 羞羞色国产精品| 亚洲欧美国产制服动漫| 亚洲精品国产日韩| 在线观看欧美激情| 久久精品人人做人人爽电影蜜月| 欧美在线影院在线视频| 国产欧美另类| 久久精品一本| 免费亚洲电影| 亚洲美女视频| 欧美日韩综合视频| 亚洲一区二区三区高清| 久久精品视频网| 亚洲成色999久久网站| 欧美插天视频在线播放| 亚洲激情啪啪| 亚洲综合欧美日韩| 国产欧美综合在线| 久久精品最新地址| 亚洲福利在线看| 亚洲午夜国产成人av电影男同| 国产精品国产一区二区| 亚洲欧美国产高清| 嫩草成人www欧美| 亚洲精选国产| 国产九色精品成人porny| 欧美一级艳片视频免费观看| 男女视频一区二区| 在线视频你懂得一区| 国产精品一区免费观看| 久久精品欧洲| 亚洲精品视频在线播放| 性色av香蕉一区二区| 1024精品一区二区三区| 欧美日韩成人在线视频| 亚洲影院色无极综合| 欧美成人三级在线| 亚洲一区二区三区四区视频| 国产综合色在线| 欧美人在线观看| 欧美亚洲综合网| 亚洲日本精品国产第一区| 久久精品国产一区二区三区| 亚洲日本免费电影| 国产亚洲精品aa午夜观看| 欧美激情综合亚洲一二区| 欧美一区二区三区免费看| 亚洲成人自拍视频| 欧美在线播放视频| 99精品视频免费| 在线日韩电影| 国产亚洲一区二区在线观看 | 久久精品国产999大香线蕉| 亚洲激情网站| 国产在线播精品第三| 欧美日韩中文字幕在线| 老司机成人网| 欧美在线高清| 亚洲图片欧美日产| 91久久在线| 欧美电影打屁股sp| 久久久综合激的五月天| 欧美一级午夜免费电影| 99人久久精品视频最新地址| 一色屋精品亚洲香蕉网站| 国产午夜精品一区二区三区欧美| 欧美日韩中文在线观看| 欧美国产1区2区|