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

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

?? player.c

?? G.711,G.723.1,G.726,G.729,GSM CODEC C/C++ code
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*////////////////////////////////////////////////////////////////////////
//
// 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 speech codec sample
//
// By downloading and installing this sample, 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: Speech sample. Main program file.
//
////////////////////////////////////////////////////////////////////////*/
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include "ippcore.h"
#include "ipps.h"
#include "ippsc.h"

#ifdef USE_PLUGINS
#include "vm_shared_object.h"
#endif /*USE_PLUGINS*/

#include "usc.h"

#include "util.h"
#include "loadcodec.h"
#include "wavfile.h"
#include "usccodec.h"
#include "platform.h"

#define LOAD_CODEC_FAIL     1
#define FOPEN_FAIL          2
#define MEMORY_FAIL         3
#define UNKNOWN_FORMAT      4
#define USC_CALL_FAIL       5


#define COPYRIGHT_STRING "Copyright (c) 2005 Intel Corporation. All Rights Reserved."
MeasureIt measure;
int ProcessOneFrameOneChannel(USCParams *uscPrms, char *inputBuffer,
                              char *outputBuffer, int *pSrcLenUsed, int *pDstLenUsed, int channel)
{
   int frmlen, infrmLen, FrmDataLen;
   USC_PCMStream PCMStream;
   USC_Bitstream Bitstream;
   if(uscPrms->pInfo.params.direction==0) {
      /*Do the pre-procession of the frame*/
      infrmLen = USCEncoderPreProcessFrame(uscPrms, inputBuffer,
                                             outputBuffer,&PCMStream,&Bitstream);
      /*Encode one frame*/
      measure_start(&measure);
      FrmDataLen = USCCodecEncode(uscPrms, &PCMStream,&Bitstream,channel);
      measure_pause(&measure);
      if(FrmDataLen < 0) return USC_CALL_FAIL;
      infrmLen += FrmDataLen;
      /*Do the post-procession of the frame*/
      frmlen = USCEncoderPostProcessFrame(uscPrms, inputBuffer,
                                             outputBuffer,&PCMStream,&Bitstream);
      *pSrcLenUsed = infrmLen;
      *pDstLenUsed = frmlen;
   } else {
      /*Do the pre-procession of the frame*/
      infrmLen = USCDecoderPreProcessFrame(uscPrms, inputBuffer,
                                             outputBuffer,&Bitstream,&PCMStream);
      /*Decode one frame*/
      measure_start(&measure);
      FrmDataLen = USCCodecDecode(uscPrms, &Bitstream,&PCMStream,channel);
      measure_pause(&measure);
      if(FrmDataLen < 0) return USC_CALL_FAIL;
      infrmLen += FrmDataLen;
      /*Do the post-procession of the frame*/
      frmlen = USCDecoderPostProcessFrame(uscPrms, inputBuffer,
                                             outputBuffer,&Bitstream,&PCMStream);
      *pSrcLenUsed = infrmLen;
      *pDstLenUsed = frmlen;
   }
   return 0;
}
#define MAX_LEN(a,b) ((a)>(b))? (a):(b)
int ProcessOneChannel(LoadedCodec *codec, WaveFileParams *wfOutputParams, char *inputBuffer,
                              int inputLen, char *outputBuffer, int *pDuration, int *dstLen)
{
   int duration=0, outLen = 0, currLen;
   char *pInputBuffPtr = inputBuffer;
   int frmlen, infrmLen, cvtLen;
   int lLowBound;
   currLen = inputLen;

   USCCodecGetTerminationCondition(&codec->uscParams, &lLowBound);

   while(currLen > lLowBound) {
      ProcessOneFrameOneChannel(&codec->uscParams, pInputBuffPtr,
                              outputBuffer, &infrmLen, &frmlen,SINGLE_CHANNEL);
      /* Write encoded data to the output file*/
      cvtLen = frmlen;
      if((wfOutputParams->waveFmt.nFormatTag==ALAW_PCM)||(wfOutputParams->waveFmt.nFormatTag==MULAW_PCM)) {
         USC_CvtToLaw(&codec->uscParams, wfOutputParams->waveFmt.nFormatTag, outputBuffer, &cvtLen);
      }
      WavFileWrite(wfOutputParams, outputBuffer, cvtLen);
      /* Move pointer to the next position*/
      currLen -= infrmLen;
      pInputBuffPtr += infrmLen;
      duration += MAX_LEN(infrmLen,frmlen);
      outLen += frmlen;
   }

   *pDuration = duration;
   *dstLen = outLen;
   return 0;
}

#if defined( _WIN32_WCE )
#define WINCE_CMDLINE_SIZE 512
#define WINCE_EXENAME_SIZE 128
#define WINCE_NCMD_PARAMS   16
int parseCmndLine( char* exename, const char* cmndline, char* line, int linelen, char** argv, int argvlen ) {
   int i;
   char* token;
   char* seps = " ,";                     /* argement separators */
   int argc = 1;                          /* number of parameters */
   for (i=0; i<argvlen; i++) argv[i] = NULL;
   argv[0] = exename;                     /* the first standard argument */
   memset( line, 0, linelen );
   strncpy( line, cmndline, linelen-1 );
   token = strtok( line, seps );          /* the first true argument */
   while( token != NULL && argc <= argvlen ) {
      argv[argc++] = token;
      token = strtok( NULL, seps );
   }
   return argc;
}

int WINAPI WinMain( HINSTANCE hinst, HINSTANCE xxx, LPWSTR lpCmdLine, int yyy )
{
   char line[WINCE_CMDLINE_SIZE];                     /* to copy command line */
   char* argvv[WINCE_NCMD_PARAMS];
   char** argv=argvv;

   wchar_t wexename[WINCE_EXENAME_SIZE];
   char exename[WINCE_EXENAME_SIZE];
   char cmdline[WINCE_CMDLINE_SIZE];

   /* simulate argc and argv parameters */
   int argc;
#else /*Other OS*/
int main(int argc, char *argv[])
{
#endif /*_WIN32_WCE*/
   int lCallResult, encode;
   int PCMType = -1;
   LoadedCodec codec;
   WaveFileParams wfInputParams;
   WaveFileParams wfOutputParams;
   CommandLineParams clParams;
   char *inputBuffer=NULL;
   char *outputBuffer=NULL;
   int currLen, duration;
   const  IppLibraryVersion *verIppSC;
   float spSeconds;
   FILE *f_log=NULL;

#if defined( _WIN32_WCE )

   GetModuleFileName( hinst, wexename, WINCE_EXENAME_SIZE );
   sprintf( exename, "%ls", wexename );
   sprintf( cmdline, "%ls", lpCmdLine );
   argc = parseCmndLine( exename, cmdline, line, WINCE_CMDLINE_SIZE, argv, WINCE_NCMD_PARAMS );

#endif
   /*
      Dynamic re-linkage from PX to target IPP library,
      need only if codec was linked with ippmerged lib
   */

   ippStaticInit();

#ifdef USE_PLUGINS
   codec.handleCodecDLL = NULL;
   codec.handleFormatDLL = NULL;
#endif /*USE_PLUGINS*/

   SetCommandLineByDefault(&clParams);
   /*Get params from comman line.*/
   ReadCommandLine(&clParams, argc, argv);
   if(clParams.puttologfile) {
      f_log=fopen(clParams.logFileName,"a");
      if(f_log==NULL) {
         printf("Cannot open %s log file for writing\n",clParams.logFileName);
         printf("Log file ignored.\n");
         clParams.puttologfile = 0;
      }
   }

   if(clParams.optionReport) {
      verIppSC = ippscGetLibVersion();
      if(clParams.puttologfile) {
         fprintf(f_log,"%s\n",COPYRIGHT_STRING);
         fprintf(f_log,"Intel Unified Speech Codec interface based console player\n");
         fprintf(f_log,"The Intel(R) IPPSC library used:  %d.%d.%d Build %d, name %s\n",
             verIppSC->major,verIppSC->minor,verIppSC->majorBuild,verIppSC->build,verIppSC->Name);
      } else {
         printf("%s\n",COPYRIGHT_STRING);
         printf("Intel Unified Speech Codec interface based console player\n");
         printf("The Intel(R) IPPSC library used:  %d.%d.%d Build %d, name %s\n",
             verIppSC->major,verIppSC->minor,verIppSC->majorBuild,verIppSC->build,verIppSC->Name);
      }
   }

   if(clParams.enumerate) {
      EnumerateStaticLinkedCodecs(f_log);
      if(f_log) fclose(f_log);
      return 0;
   }

   if((!clParams.inputFileName[0]) ||(!clParams.outputFileName[0])) {
      PrintUsage();
      return 0;
   }
   /*Open inpuit file and read header*/
   InitWavFile(&wfInputParams);
   lCallResult = OpenWavFile(&wfInputParams, clParams.inputFileName, FILE_READ);
   if(lCallResult==-1) {
      if(clParams.puttologfile) {
         fprintf(f_log,"Cannot open %s file for reading\n",clParams.inputFileName);
      } else {
         printf("Cannot open %s file for reading\n",clParams.inputFileName);
      }
      if(f_log) fclose(f_log);
      return FOPEN_FAIL;
   }
   /*Read WAVE file header*/
   lCallResult = WavFileReadHeader(&wfInputParams);
   if(lCallResult<0) {
      if(clParams.puttologfile) {
         if(lCallResult==-1) fprintf(f_log,"Couldn't read from the %s file\n",clParams.inputFileName);
         if(lCallResult==-2) fprintf(f_log,"File %s isn't in RIFF format\n",clParams.inputFileName);
         if(lCallResult==-3) fprintf(f_log,"File %s is in RIFF format but not in a WAVE foramt\n",
                                       clParams.inputFileName);
      } else {
         if(lCallResult==-1) printf("Couldn't read from the %s file\n",clParams.inputFileName);
         if(lCallResult==-2) printf("File %s isn't in RIFF format\n",clParams.inputFileName);
         if(lCallResult==-3) printf("File %s is in RIFF format but not in a WAVE foramt\n",
                                       clParams.inputFileName);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品一区二区久久精品爱涩| 国产日韩精品一区| av一区二区三区| 成人午夜视频网站| 国产91丝袜在线18| eeuss国产一区二区三区| 国产成人免费高清| 成人午夜私人影院| 精品一二三四区| 日韩福利视频网| 久色婷婷小香蕉久久| 麻豆成人91精品二区三区| 激情文学综合网| 国产精品一线二线三线| 成人高清免费在线播放| av亚洲产国偷v产偷v自拍| 91欧美一区二区| 欧洲人成人精品| 日韩一卡二卡三卡四卡| 国产婷婷色一区二区三区四区 | 欧美自拍偷拍午夜视频| 欧美色爱综合网| 欧美不卡在线视频| 国产精品久久久久久久第一福利| 国产精品国产自产拍在线| 夜夜揉揉日日人人青青一国产精品 | 精品久久人人做人人爰| 国产精品久久久久一区二区三区 | 亚洲第一会所有码转帖| 久久99精品网久久| 91国偷自产一区二区使用方法| 欧美日韩国产一区二区三区地区| 欧美成人激情免费网| 国产精品福利一区二区| 美女视频一区在线观看| a4yy欧美一区二区三区| 91精品国产入口在线| 国产精品乱码妇女bbbb| 日本中文一区二区三区| av成人老司机| 久久蜜桃av一区二区天堂| 亚洲综合一区二区三区| 国产麻豆精品95视频| 91成人看片片| 国产精品久久久久aaaa| 午夜国产精品一区| aaa亚洲精品一二三区| 91精品国产免费| 亚洲国产成人午夜在线一区| 亚洲国产综合91精品麻豆| 三级影片在线观看欧美日韩一区二区| 日韩av电影一区| 99久久久国产精品| 日韩美女视频在线| 1区2区3区国产精品| 亚洲欧美一区二区三区国产精品 | 亚洲三级免费观看| 日日夜夜精品视频免费| 久久99精品久久久久久| 91福利视频网站| 欧美激情在线观看视频免费| 午夜激情一区二区| 国产成人免费xxxxxxxx| 欧美精品在线观看一区二区| 成人免费在线观看入口| 国内精品久久久久影院一蜜桃| 欧美性三三影院| 中文字幕中文字幕一区| 国产一区在线视频| 日韩欧美在线观看一区二区三区| 亚洲伦理在线免费看| 成人精品视频一区| 国产人久久人人人人爽| 蜜臀av一区二区在线观看| 91性感美女视频| 国产精品国产三级国产有无不卡| 久久99九九99精品| 欧美日韩免费观看一区二区三区| 中文字幕欧美区| 国产一区二区精品久久99| 7878成人国产在线观看| 午夜久久久久久久久| 色婷婷久久久亚洲一区二区三区| ...xxx性欧美| av不卡在线播放| 日韩视频一区二区三区在线播放 | 亚洲精品一区在线观看| 日韩电影在线观看网站| 制服丝袜一区二区三区| 亚洲电影一区二区三区| 欧美日韩大陆在线| 亚洲va国产va欧美va观看| 日韩av电影天堂| 亚洲欧美二区三区| 欧美大肚乱孕交hd孕妇| 丁香亚洲综合激情啪啪综合| 久久99精品久久久久久国产越南| 蜜臀久久99精品久久久久久9| 国产精品国产三级国产普通话三级| 一本大道综合伊人精品热热 | 韩国毛片一区二区三区| 最新中文字幕一区二区三区| 日韩精品中午字幕| 欧美四级电影在线观看| 高清免费成人av| 人禽交欧美网站| 精品91自产拍在线观看一区| 欧美一级免费大片| 欧美性色欧美a在线播放| 99久久综合精品| 国产乱子伦视频一区二区三区| 天堂午夜影视日韩欧美一区二区| 亚洲日本丝袜连裤袜办公室| 欧美精品一区二区三区高清aⅴ| 欧美精品一级二级三级| 在线国产亚洲欧美| 色狠狠一区二区| 不卡影院免费观看| 国产高清在线精品| 国产综合色视频| 狠狠色丁香婷综合久久| 日本成人在线一区| 蜜臀av性久久久久av蜜臀妖精| 亚洲一区二区成人在线观看| 亚洲激情中文1区| 亚洲精品亚洲人成人网| 亚洲日穴在线视频| 亚洲欧美日韩国产手机在线| 中文字幕日韩一区| 亚洲丝袜精品丝袜在线| 综合av第一页| 亚洲人成在线观看一区二区| 国产精品美女视频| 一区二区三区国产精华| 亚洲与欧洲av电影| 午夜免费久久看| 美脚の诱脚舐め脚责91| 国内精品伊人久久久久av影院| 国产激情一区二区三区桃花岛亚洲| 国产精品亚洲第一区在线暖暖韩国| 国产一区二区福利| 91热门视频在线观看| 欧美日韩国产欧美日美国产精品| 欧美日本在线播放| 91精品国产日韩91久久久久久| 精品欧美一区二区在线观看| 久久久国产精华| 18成人在线观看| 天天综合色天天| 九九九久久久精品| 日韩二区三区四区| 久久9热精品视频| 国产成人高清视频| 91视频xxxx| 日韩欧美在线一区二区三区| 国产区在线观看成人精品| 亚洲精品视频在线看| 人妖欧美一区二区| 成人免费三级在线| 国产91精品精华液一区二区三区 | 精品少妇一区二区三区免费观看| 精品国产污网站| 26uuu精品一区二区| 亚洲欧洲一区二区在线播放| 国产精品福利在线播放| 亚瑟在线精品视频| 成人免费黄色大片| 欧美性生活一区| 精品人在线二区三区| 国产精品看片你懂得| 麻豆传媒一区二区三区| www.亚洲免费av| 91精品国产高清一区二区三区蜜臀| 国产欧美一区二区三区在线看蜜臀| 日韩毛片精品高清免费| 国产伦精一区二区三区| 欧美亚洲免费在线一区| 亚洲国产精品av| 免费成人在线影院| 在线视频你懂得一区二区三区| 精品成人佐山爱一区二区| 亚洲韩国精品一区| 国产美女在线观看一区| 欧美日韩国产在线观看| 亚洲区小说区图片区qvod| 国产在线精品国自产拍免费| 欧美精品在线观看播放| 亚洲精品欧美综合四区| 国产99久久精品| 精品国产人成亚洲区| 日韩电影在线免费| 成人h精品动漫一区二区三区| 99久久精品99国产精品| 国产日韩欧美综合一区| 美国精品在线观看| 555www色欧美视频| 亚洲成av人影院| 欧美亚洲一区二区三区四区| 亚洲视频一区在线观看| 另类专区欧美蜜桃臀第一页|