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

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

?? uscec.c

?? G.711,G.723.1,G.726,G.729,GSM CODEC C/C++ code
?? C
字號:
/*/////////////////////////////////////////////////////////////////////////////
//
//                  INTEL CORPORATION PROPRIETARY INFORMATION
//     This software is supplied under the terms of a license agreement or
//     nondisclosure agreement with Intel Corporation and may not be copied
//     or disclosed except in accordance with the terms of that agreement.
//          Copyright(c) 2005 Intel Corporation. All Rights Reserved.
//
//     Intel(R) Integrated Performance Primitives
//     USC - Unified Speech Codec interface library
//
// By downloading and installing USC codec, you hereby agree that the
// accompanying Materials are being provided to you under the terms and
// conditions of the End User License Agreement for the Intel(R) Integrated
// Performance Primitives product previously accepted by you. Please refer
// to the file ipplic.htm located in the root directory of your Intel(R) IPP
// product installation for more information.
//
//
//
// Purpose: Echo Canceller [float point]: USC funtions.
//
*/

#include "ipps.h"
#include "ippsc.h"
#include "ec_api.h"
#include <string.h>
#include "ecusc.h"

#define  SUBBAND_FRAME_SIZE    64
#define  FULLBAND_FRAME_SIZE    8
#define  FASTSBBAND_FRAME_SIZE 44
#define  SB_MAX_LEN_TAIL      200
#define  FB_MAX_LEN_TAIL       16
#define  FREQ_SHIFT_EC         10
#define  MAX_BLOCK_SIZE       128

static USC_Status GetInfo(USC_Handle handle, USC_EC_Info *pInfo);
static USC_Status NumAlloc(const USC_EC_Option *options, int *nbanks);
static USC_Status MemAlloc(const USC_EC_Option *options, USC_MemBank *pBanks);
static USC_Status Init(const USC_EC_Option *options, const USC_MemBank *pBanks, USC_Handle *handle);
static USC_Status Reinit(const USC_EC_Modes *modes, USC_Handle handle );
static USC_Status Control(const USC_EC_Modes *modes, USC_Handle handle );
static USC_Status CancelEcho(USC_Handle handle, short *pSin, short *pRin, short *pSout);

typedef struct {
   ec_GetFrameSize_ptr ec_GetFrameSize;
   ec_GetSize_ptr ec_GetSize;
   ec_Init_ptr ec_Init;
   ec_ModeOp_ptr ec_ModeOp;
   ec_ProcessFrame_ptr ec_ProcessFrame;
} ecfp_fun;

typedef struct {
   USC_EC_Algs   algType;
   USC_PCMType   pcmType;
   int           echotail;
   USC_AdaptType adapt;
   int           zeroCoeff;
   int           nlp;
   int           td;
   int           reserve1;
   ecfp_fun      fun;
} ECFP_Handle_Header;


/* global usc vector table */
USCFUN USC_EC_Fxns USC_ECFP_Fxns=
{
    {
        USC_AEC,
        GetInfo,
        NumAlloc,
        MemAlloc,
        Init,
        Reinit,
        Control
    },
    CancelEcho

};


static USC_Status GetInfo(USC_Handle handle, USC_EC_Info *pInfo)
{
    ECFP_Handle_Header *ecfp_header;

    pInfo->name = "EchoCanceller_FP";
    if (handle == NULL) {
      pInfo->framesize = SUBBAND_FRAME_SIZE*sizeof(short);
      pInfo->params.algType = EC_SUBBAND;
      pInfo->params.pcmType.sample_frequency = 8000;
      pInfo->params.pcmType.bitPerSample = 16;
      pInfo->params.echotail = 16;
      pInfo->params.modes.adapt = AD_FULLADAPT;
      pInfo->params.modes.zeroCoeff = 0;
      pInfo->params.modes.nlp = 0;
      pInfo->params.modes.td = 1;
    } else {
      ecfp_header = (ECFP_Handle_Header*)handle;
      if(ecfp_header->algType == EC_SUBBAND) {
        pInfo->params.algType = EC_SUBBAND;
        pInfo->framesize = SUBBAND_FRAME_SIZE*sizeof(short);
      } else if(ecfp_header->algType == EC_FULLBAND) {
        pInfo->params.algType = EC_FULLBAND;
        pInfo->framesize = FULLBAND_FRAME_SIZE*sizeof(short);
      } else {
        pInfo->params.algType = EC_FASTSUBBAND;
        pInfo->framesize = FASTSBBAND_FRAME_SIZE*sizeof(short);
      }
      pInfo->params.pcmType.sample_frequency = ecfp_header->pcmType.sample_frequency;
      pInfo->params.pcmType.bitPerSample = ecfp_header->pcmType.bitPerSample;
      pInfo->params.echotail = ecfp_header->echotail;
      pInfo->params.modes.adapt = ecfp_header->adapt;
      pInfo->params.modes.zeroCoeff = ecfp_header->zeroCoeff;
      pInfo->params.modes.nlp = ecfp_header->nlp;
      pInfo->params.modes.td = ecfp_header->td;
    }
    return USC_NoError;
}

static USC_Status NumAlloc(const USC_EC_Option *options, int *nbanks)
{
   if(options==NULL) return USC_BadDataPointer;
   if(nbanks==NULL) return USC_BadDataPointer;
   *nbanks = 1;
   return USC_NoError;
}

static USC_Status MemAlloc(const USC_EC_Option *options, USC_MemBank *pBanks)
{
   unsigned int nbytes;
   IppPCMFrequency freq;
   int taptime_ms;

   if(options==NULL) return USC_BadDataPointer;
   if(pBanks==NULL) return USC_BadDataPointer;
   if(options->pcmType.bitPerSample != 16) return USC_InvalidHandler;
   switch(options->pcmType.sample_frequency) {
     case 8000:  freq = IPP_PCM_FREQ_8000;  break;
     case 16000: freq = IPP_PCM_FREQ_16000; break;
     default: return USC_InvalidHandler;
   }

   pBanks->pMem = NULL;
   if(options->algType == EC_SUBBAND) {
     if((options->echotail > 0) && (options->echotail <= SB_MAX_LEN_TAIL)) taptime_ms = options->echotail;
     else return USC_InvalidHandler;
     ec_sb_GetSize(freq, taptime_ms, &nbytes);
   } else if(options->algType == EC_FULLBAND) {
     if((options->echotail > 0) && (options->echotail <= FB_MAX_LEN_TAIL)) taptime_ms = options->echotail;
     else return USC_InvalidHandler;
     ec_fb_GetSize(freq, taptime_ms, &nbytes);
   } else {
     if((options->echotail > 0) && (options->echotail <= SB_MAX_LEN_TAIL)) taptime_ms = options->echotail;
     else return USC_InvalidHandler;
     ec_sbf_GetSize(freq, taptime_ms, &nbytes);
   }
   pBanks->nbytes = nbytes + sizeof(ECFP_Handle_Header); /* room for USC header */
   return USC_NoError;
}

static USC_Status Init(const USC_EC_Option *options, const USC_MemBank *pBanks, USC_Handle *handle)
{
   ECFP_Handle_Header *ecfp_header;
   IppPCMFrequency freq;
   int taptime_ms;
   USC_Handle *obj_ec;

   if(options==NULL) return USC_BadDataPointer;
   if(pBanks==NULL) return USC_BadDataPointer;
   if(pBanks->pMem==NULL) return USC_NotInitialized;
   if(pBanks->nbytes<=0) return USC_NotInitialized;
   if(handle==NULL) return USC_InvalidHandler;
   if(options->pcmType.bitPerSample != 16) return USC_InvalidHandler;
   switch(options->pcmType.sample_frequency) {
     case 8000:  freq = IPP_PCM_FREQ_8000;  break;
     case 16000: freq = IPP_PCM_FREQ_16000; break;
     default: return USC_InvalidHandler;
   }

   *handle = (USC_Handle*)pBanks->pMem;
   ecfp_header = (ECFP_Handle_Header*)*handle;

   ecfp_header->algType = options->algType;
   ecfp_header->pcmType.sample_frequency = options->pcmType.sample_frequency;
   ecfp_header->pcmType.bitPerSample = options->pcmType.bitPerSample;
   if(ecfp_header->algType == EC_SUBBAND) {
     taptime_ms = options->echotail;
     if(options->echotail < 1) taptime_ms = 1;
     if(options->echotail > SB_MAX_LEN_TAIL) taptime_ms = SB_MAX_LEN_TAIL;
     ecfp_header->fun.ec_GetFrameSize = (ec_GetFrameSize_ptr)ec_sb_GetFrameSize;
     ecfp_header->fun.ec_GetSize = (ec_GetSize_ptr)ec_sb_GetSize;
     ecfp_header->fun.ec_Init = (ec_Init_ptr)ec_sb_Init;
     ecfp_header->fun.ec_ModeOp = (ec_ModeOp_ptr)ec_sb_ModeOp;
     ecfp_header->fun.ec_ProcessFrame = (ec_ProcessFrame_ptr)ec_sb_ProcessFrame;

   } else if(ecfp_header->algType == EC_FULLBAND) {
     taptime_ms = options->echotail;
     if(options->echotail < 1) taptime_ms = 1;
     if(options->echotail > FB_MAX_LEN_TAIL) taptime_ms = FB_MAX_LEN_TAIL;
     ecfp_header->fun.ec_GetFrameSize = (ec_GetFrameSize_ptr)ec_fb_GetFrameSize;
     ecfp_header->fun.ec_GetSize = (ec_GetSize_ptr)ec_fb_GetSize;
     ecfp_header->fun.ec_Init = (ec_Init_ptr)ec_fb_Init;
     ecfp_header->fun.ec_ModeOp = (ec_ModeOp_ptr)ec_fb_ModeOp;
     ecfp_header->fun.ec_ProcessFrame = (ec_ProcessFrame_ptr)ec_fb_ProcessFrame;

   } else {
     taptime_ms = options->echotail;
     if(options->echotail < 1) taptime_ms = 1;
     if(options->echotail > SB_MAX_LEN_TAIL) taptime_ms = SB_MAX_LEN_TAIL;
     ecfp_header->fun.ec_GetFrameSize = (ec_GetFrameSize_ptr)ec_sbf_GetFrameSize;
     ecfp_header->fun.ec_GetSize = (ec_GetSize_ptr)ec_sbf_GetSize;
     ecfp_header->fun.ec_Init = (ec_Init_ptr)ec_sbf_Init;
     ecfp_header->fun.ec_ModeOp = (ec_ModeOp_ptr)ec_sbf_ModeOp;
     ecfp_header->fun.ec_ProcessFrame = (ec_ProcessFrame_ptr)ec_sbf_ProcessFrame;

   }
   ecfp_header->echotail = taptime_ms;
   ecfp_header->adapt = options->modes.adapt;
   ecfp_header->zeroCoeff = options->modes.zeroCoeff;
   ecfp_header->nlp = options->modes.nlp;
   ecfp_header->td = options->modes.td;

   obj_ec = (USC_Handle*)((char*)*handle + sizeof(ECFP_Handle_Header));
   ecfp_header->fun.ec_Init(obj_ec, freq, ecfp_header->echotail);

   if(ecfp_header->zeroCoeff) ecfp_header->fun.ec_ModeOp(obj_ec, EC_COEFFS_ZERO);
   if((ecfp_header->adapt == AD_FULLADAPT) || (ecfp_header->adapt == AD_LITEADAPT)) ecfp_header->fun.ec_ModeOp(obj_ec, EC_ADAPTATION_ENABLE);
   else ecfp_header->fun.ec_ModeOp(obj_ec, EC_ADAPTATION_DISABLE);
   if(ecfp_header->nlp) ecfp_header->fun.ec_ModeOp(obj_ec, EC_NLP_ENABLE);
   else ecfp_header->fun.ec_ModeOp(obj_ec, EC_NLP_DISABLE);
   if(ecfp_header->td) ecfp_header->fun.ec_ModeOp(obj_ec, EC_TD_ENABLE);
   else ecfp_header->fun.ec_ModeOp(obj_ec, EC_TD_DISABLE);


   return USC_NoError;
}

static USC_Status Reinit(const USC_EC_Modes *modes, USC_Handle handle )
{
    ECFP_Handle_Header *ecfp_header;
    USC_Handle *obj_ec;

    if(modes==NULL) return USC_BadDataPointer;
    if(handle==NULL) return USC_InvalidHandler;

    ecfp_header = (ECFP_Handle_Header*)handle;
    obj_ec = (USC_Handle*)((char*)handle + sizeof(ECFP_Handle_Header));

    ecfp_header->adapt = modes->adapt;
    ecfp_header->zeroCoeff = modes->zeroCoeff;
    ecfp_header->nlp = modes->nlp;
    ecfp_header->td = modes->td;

    if(ecfp_header->zeroCoeff) ecfp_header->fun.ec_ModeOp(obj_ec, EC_COEFFS_ZERO);
    if((ecfp_header->adapt == AD_FULLADAPT) || (ecfp_header->adapt == AD_LITEADAPT)) ecfp_header->fun.ec_ModeOp(obj_ec, EC_ADAPTATION_ENABLE);
    else ecfp_header->fun.ec_ModeOp(obj_ec, EC_ADAPTATION_DISABLE);
    if(ecfp_header->nlp) ecfp_header->fun.ec_ModeOp(obj_ec, EC_NLP_ENABLE);
    else ecfp_header->fun.ec_ModeOp(obj_ec, EC_NLP_DISABLE);
    if(ecfp_header->td) ecfp_header->fun.ec_ModeOp(obj_ec, EC_TD_ENABLE);
    else ecfp_header->fun.ec_ModeOp(obj_ec, EC_TD_DISABLE);

    return USC_NoError;
}

static USC_Status Control(const USC_EC_Modes *modes, USC_Handle handle )
{

    ECFP_Handle_Header *ecfp_header;
    USC_Handle *obj_ec;

    if(modes==NULL) return USC_BadDataPointer;
    if(handle==NULL) return USC_InvalidHandler;

    ecfp_header = (ECFP_Handle_Header*)handle;
    obj_ec = (USC_Handle*)((char*)handle + sizeof(ECFP_Handle_Header));

    ecfp_header->zeroCoeff = modes->zeroCoeff;
    if(ecfp_header->zeroCoeff) ecfp_header->fun.ec_ModeOp(obj_ec, EC_COEFFS_ZERO);
    if(ecfp_header->adapt != modes->adapt) {
      ecfp_header->adapt = modes->adapt;
      if((ecfp_header->adapt == AD_FULLADAPT) || (ecfp_header->adapt == AD_LITEADAPT)) ecfp_header->fun.ec_ModeOp(obj_ec, EC_ADAPTATION_ENABLE);
      else ecfp_header->fun.ec_ModeOp(obj_ec, EC_ADAPTATION_DISABLE);
    }
    if(ecfp_header->nlp != modes->nlp) {
      ecfp_header->nlp = modes->nlp;
      if(ecfp_header->nlp) ecfp_header->fun.ec_ModeOp(obj_ec, EC_NLP_ENABLE);
      else ecfp_header->fun.ec_ModeOp(obj_ec, EC_NLP_DISABLE);
    }
    if(ecfp_header->td != modes->td) {
      ecfp_header->td = modes->td;
      if(ecfp_header->td) ecfp_header->fun.ec_ModeOp(obj_ec, EC_TD_ENABLE);
      else ecfp_header->fun.ec_ModeOp(obj_ec, EC_TD_DISABLE);
    }

    return USC_NoError;
}

static USC_Status CancelEcho(USC_Handle handle, short *pSin, short *pRin, short *pSout)
{
   ECFP_Handle_Header *ecfp_header;
   USC_Handle *obj_ec;
   int framesize;
   Ipp32f r_in_32f_cur[MAX_BLOCK_SIZE];
   Ipp32f s_in_32f_cur[MAX_BLOCK_SIZE];
   Ipp32f s_out_32f_cur[MAX_BLOCK_SIZE];

   if(handle==NULL) return USC_InvalidHandler;
   if(pSin==NULL) return USC_BadDataPointer;
   if(pRin==NULL) return USC_BadDataPointer;
   if(pSout==NULL) return USC_BadDataPointer;

   ecfp_header = (ECFP_Handle_Header*)handle;
   obj_ec = (USC_Handle*)((char*)handle + sizeof(ECFP_Handle_Header));
   if(ecfp_header->algType == EC_SUBBAND) framesize = SUBBAND_FRAME_SIZE;
   else if(ecfp_header->algType == EC_FULLBAND) framesize = FULLBAND_FRAME_SIZE;
   else framesize = FASTSBBAND_FRAME_SIZE;

   ippsConvert_16s32f_Sfs((Ipp16s *)pRin, r_in_32f_cur, framesize, 0);
   ippsConvert_16s32f_Sfs((Ipp16s *)pSin, s_in_32f_cur, framesize, 0);
   ecfp_header->fun.ec_ProcessFrame(obj_ec, r_in_32f_cur, s_in_32f_cur, s_out_32f_cur);
   ippsConvert_32f16s_Sfs(s_out_32f_cur, (Ipp16s *)pSout, framesize, ippRndZero, 0);

   return USC_NoError;

}


?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久精品一区二区三区av| 亚洲手机成人高清视频| 国产精品免费人成网站| 婷婷综合久久一区二区三区| 成人小视频在线观看| 欧美日韩亚洲丝袜制服| 综合激情网...| 国产麻豆一精品一av一免费| 欧美久久免费观看| 中文字幕字幕中文在线中不卡视频| 久久精品国产色蜜蜜麻豆| 欧美丝袜第三区| 亚洲资源在线观看| 日韩免费电影网站| 激情六月婷婷久久| 日韩一区二区在线播放| 一区二区视频在线| 成人av影院在线| 国产三级一区二区| 国产一区二区福利视频| 91精品国产乱码| 天堂av在线一区| 色综合一区二区| ...av二区三区久久精品| 国产69精品久久久久777| 久久久精品天堂| 国产尤物一区二区在线| 亚洲精品在线观看网站| 久88久久88久久久| 亚洲精品一区二区三区在线观看 | 91精品国产综合久久久久久久| 亚洲日本在线观看| 色偷偷久久一区二区三区| 国产精品素人视频| av在线不卡电影| 亚洲裸体xxx| 在线观看视频一区二区| 亚洲国产视频一区二区| 欧美日韩日日摸| 日韩在线一区二区三区| 精品美女被调教视频大全网站| 国产乱国产乱300精品| 国产人妖乱国产精品人妖| 不卡一区中文字幕| 依依成人精品视频| 欧美日韩成人综合在线一区二区| 日韩专区一卡二卡| 精品少妇一区二区| 成年人网站91| 亚洲国产一区视频| 日韩免费高清av| 国产成人久久精品77777最新版本| 国产精品美女久久久久久2018 | 亚洲精品国产一区二区精华液 | 91免费观看国产| 亚洲成a人片在线不卡一二三区| 欧美一区二区大片| 国产91精品精华液一区二区三区 | 26uuu国产一区二区三区| 成人污污视频在线观看| 亚洲综合一区二区精品导航| 91精品在线观看入口| 国产成人av电影| 一区二区三区欧美久久| 日韩一级黄色大片| 成人免费视频一区| 三级亚洲高清视频| 亚洲国产成人自拍| 欧美体内she精高潮| 精品制服美女丁香| 有码一区二区三区| 欧美成人一区二区三区| 91色九色蝌蚪| 国产在线精品免费av| 亚洲高清免费在线| 中日韩免费视频中文字幕| 欧美剧情片在线观看| 成人短视频下载| 日韩国产欧美在线视频| 亚洲精品欧美在线| 久久精品视频网| 337p亚洲精品色噜噜狠狠| 99国产精品一区| 国产精品资源网| 免费观看在线综合色| 亚洲视频电影在线| 久久蜜桃一区二区| 国产婷婷一区二区| 欧美电影一区二区三区| 99九九99九九九视频精品| 国内精品伊人久久久久av影院 | 最新成人av在线| 久久综合九色综合97婷婷| 欧美日韩成人综合在线一区二区 | 亚洲愉拍自拍另类高清精品| 精品盗摄一区二区三区| 欧美精品第1页| 在线看日韩精品电影| 99re这里只有精品首页| 国产一区二区三区久久悠悠色av| 秋霞电影一区二区| 日韩专区中文字幕一区二区| 午夜伊人狠狠久久| 亚洲一区视频在线| 亚洲午夜私人影院| 一区二区三区四区中文字幕| 亚洲视频一区二区在线观看| 亚洲欧美在线视频观看| 国产精品久久久久婷婷二区次| 国产精品网友自拍| 国产精品视频一二三区| 国产精品视频你懂的| 中文字幕乱码日本亚洲一区二区| 久久久精品天堂| 精品国产91亚洲一区二区三区婷婷 | 国产精品美女久久久久高潮| 国产蜜臀av在线一区二区三区| 久久久精品黄色| 国产欧美日本一区视频| 中文字幕一区二区不卡| 亚洲欧美日韩久久精品| 亚洲小说欧美激情另类| 亚洲成人激情综合网| 日韩av一区二| 国产乱国产乱300精品| 9人人澡人人爽人人精品| 色播五月激情综合网| 欧美精品 国产精品| 精品国产一区久久| 国产精品免费久久久久| 亚洲女人****多毛耸耸8| 亚洲一区二区影院| 日本中文字幕一区二区视频| 麻豆91在线观看| 国产精品66部| av电影天堂一区二区在线观看| 色老汉一区二区三区| 欧美一级理论片| 日本一区二区电影| 国产一区二区三区在线观看免费视频| 国产一区在线精品| 99久久久免费精品国产一区二区| 91福利资源站| 欧美成人激情免费网| 中文字幕不卡三区| 婷婷六月综合亚洲| 国产白丝网站精品污在线入口| 欧美亚洲免费在线一区| 久久综合色综合88| 亚洲乱码一区二区三区在线观看| 蜜臀av在线播放一区二区三区| 成人免费黄色大片| 制服丝袜av成人在线看| 欧美极品少妇xxxxⅹ高跟鞋| 亚洲国产日韩综合久久精品| 国产一区二区三区免费观看| 欧美在线啊v一区| 国产三级精品在线| 亚洲高清视频中文字幕| 成人免费高清视频| 日韩久久精品一区| 一区二区三区中文字幕电影| 国产专区综合网| 欧美福利视频一区| 亚洲精品综合在线| 国产精品一区一区三区| 欧美疯狂性受xxxxx喷水图片| ㊣最新国产の精品bt伙计久久| 久久精品国产免费| 欧美日韩免费一区二区三区视频| 精品剧情在线观看| 偷偷要91色婷婷| 一本久久a久久免费精品不卡| 精品sm捆绑视频| 美脚の诱脚舐め脚责91| 欧美亚洲综合在线| 亚洲欧美自拍偷拍色图| 国产白丝精品91爽爽久久| 日韩美女一区二区三区四区| 五月激情六月综合| 日本黄色一区二区| 亚洲日本电影在线| 成人毛片在线观看| 国产午夜精品一区二区三区嫩草| 日日摸夜夜添夜夜添精品视频| 555www色欧美视频| 亚洲v中文字幕| 在线精品观看国产| 亚洲精品伦理在线| 99精品在线免费| 亚洲欧美色图小说| 99精品视频在线观看| 国产欧美一区二区三区在线老狼| 狠狠色丁香婷婷综合久久片| 精品区一区二区| 国产在线乱码一区二区三区| 精品国产99国产精品| 精品无人码麻豆乱码1区2区| 精品国产伦一区二区三区观看方式| 美女一区二区视频|