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

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

?? smpg.c

?? this the source code of addio compression standard CELP. Also, it is optimizied for the execution sp
?? C
字號:
/**************************************************************************
*
* ROUTINE
*               smoothpgain
*
* FUNCTION
*
*               smooth pgain values when two errors detected in
*		Hamming block
*
* SYNOPSIS
*               smoothpgain(pgain,twoerror,syndavg,pgains,subframe)
*
*   formal
*
*                       data    I/O
*       name            type    type    function
*       -------------------------------------------------------------------
*       pgain		float	i/o	input pgain
*	twoerror	int	i	two error flag
*	syndavg		float	i	error rate estimation parameter
*	pgains		float	i	vector of pgains to calculate variance
*	subframe	int	i	subframe number
*
*   external
*                       data    I/O
*       name            type    type    function
*       -------------------------------------------------------------------
*       frame           int     i
*
***************************************************************************
*
* DESCRIPTION
*
*	Smoothing routine to smooth pgain (alpha) when errors are detected:
*
*	Due to the range of PGAIN, statistical variance is not appropriate.
*	Pseudovariance is used and calculated as: 
*		sum of delta oldpgains/# of deltas
*
*	If this variance of past pgain values is within the range VARLIMIT, 
*	the validity of the current pgain value is tested.  If the current 
*	value of pgain is within the range PGAINLIMIT, PGAIN is passed.  
*	If PGAIN is not within that range it is reset to the average
*	value of surrounding pgain values.
*
*	The array OLDPGAIN contains past values of pgain.  The array
*	PGAINS contains current and future values of pgain.  The array 
*	VECTOR is constructed from the arrays OLDPGAIN and PGAINS 
*	depending on the current subframe.  PGAIN is smoothed based on 
*	the statistics of VECTOR, which contains the nearest four 
*	surrounding pgain values, both past and future values, except 
*	where future values are not available (subframes 3 and 4).
*
*	Absolute values of pgain are used in averaging and reassigning
*	pgain.  All reassigned pgains are limited to the range 0.0-1.0.
*
*	Note:  The smoothing parameters should be capable of adapting
*	to various bit error rate estimates. For example, different
*	values of SYNDAVG should select different levels of PGAINLIMIT,
*	VARLIMIT, and SYNDLIMIT.
*
*
***************************************************************************
*
* CALLED BY
*
*       celp
*
* CALLS
*
*
*
**************************************************************************/
#define PGAINHISTORY	4
#define PGAINLIMIT	0.9
#define VARLIMIT	0.2
#define SYNDLIMIT	0.04
#define TRUE		1
#define FALSE		0
#include <math.h>
extern int frame;
smoothpgain(pgain, twoerror, syndavg, pgains, subframe)
int twoerror, subframe;
float *pgain, syndavg, pgains[];

{
  int i;
  static int enable;
  float abspgain, avg, var, sum1, sum2, vector[4];
  static float oldpgain[PGAINHISTORY];

  abspgain = fabs(*pgain);
  if (subframe != 4)
    enable = TRUE;
  if ((twoerror || syndavg > SYNDLIMIT) && enable)
  {
    if (subframe == 1)
    {
      vector[0] = oldpgain[0];
      vector[1] = oldpgain[1];
      vector[2] = fabs(pgains[1]);
      vector[3] = fabs(pgains[2]);
    }
    else if (subframe == 2)
    {
      vector[0] = oldpgain[0];
      vector[1] = oldpgain[1];
      vector[2] = fabs(pgains[2]);
      vector[3] = fabs(pgains[3]);
    }
    else if (subframe == 3)
    {
      vector[0] = oldpgain[0];
      vector[1] = oldpgain[1];
      vector[2] = oldpgain[2];
      vector[3] = fabs(pgains[3]);
    }
    else if (subframe == 4)
    {
      vector[0] = oldpgain[0];
      vector[1] = oldpgain[1];
      vector[2] = oldpgain[2];
      vector[3] = oldpgain[3];
    }
    else
      printf("smoothpgain: Error in subframe number\n");

    for (sum1 = 0.0, i = 0; i < PGAINHISTORY; i++)
    {
      sum1 += vector[i];
    }
    avg = sum1 / PGAINHISTORY;
    for (sum2 = 0.0, i = 0; i < PGAINHISTORY - 1; i++)
      sum2 += fabs(vector[i] - vector[i + 1]);
    var = sum2 / (PGAINHISTORY - 1);
    if (var < VARLIMIT && enable &&
	(abspgain > avg + PGAINLIMIT || abspgain < avg - PGAINLIMIT))
    {
      *pgain = avg;
      if (*pgain > 1.0)
	*pgain = 1.0;
      if (*pgain < -1.0)
	*pgain = -1.0;
      printf("smoothpgain:  pgain value reset to avg at frame %d subframe %d\n",
	      frame, subframe);
      if (subframe == 3)
      {
	enable = FALSE;
	printf("smoothpgain:  smoothing disabled for subframe 4\n");
      }
    }
  }

  for (i = PGAINHISTORY - 1; i > 0; i--)
    oldpgain[i] = oldpgain[i - 1];
  oldpgain[0] = abspgain;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美三区免费完整视频在线观看| 久久尤物电影视频在线观看| 精品久久久久久久人人人人传媒 | 欧美色网站导航| 亚洲精品一区二区三区香蕉| 一区二区三区不卡在线观看 | 亚洲18色成人| av中文字幕在线不卡| 亚洲婷婷在线视频| 亚洲图片另类小说| 日本午夜精品视频在线观看| 成人国产视频在线观看| 欧美成人精精品一区二区频| 亚洲国产欧美一区二区三区丁香婷| 国产福利不卡视频| 日韩视频免费观看高清完整版在线观看 | 国产精品一区二区在线看| 欧美精品一卡两卡| 亚洲影院在线观看| 91亚洲永久精品| 中文在线免费一区三区高中清不卡| 麻豆成人在线观看| 欧美一区二区在线看| 亚洲成av人影院在线观看网| 色八戒一区二区三区| 国产精品二区一区二区aⅴ污介绍| 激情另类小说区图片区视频区| 在线观看免费一区| 中文字幕日韩欧美一区二区三区| 国产一区二区按摩在线观看| www激情久久| 韩国精品免费视频| 久久久久久久综合狠狠综合| 国产剧情一区在线| 久久久久久一二三区| 国产一区二区三区高清播放| 久久夜色精品一区| 国产福利91精品一区二区三区| 国产日韩精品一区二区三区在线| 精品一区二区在线看| 久久久五月婷婷| 国产91精品精华液一区二区三区| 欧美国产精品v| 99精品视频一区二区三区| 亚洲免费在线播放| 在线免费观看日本欧美| 亚洲成av人片一区二区梦乃| 91精品国产综合久久久久久久久久| 午夜av区久久| 日韩一二三四区| 国产一区二区视频在线播放| 国产欧美日韩不卡| 91性感美女视频| 亚洲精品日韩一| 在线电影院国产精品| 老司机精品视频一区二区三区| 久久久久久久免费视频了| av在线不卡免费看| 婷婷夜色潮精品综合在线| 欧美第一区第二区| 成人av网址在线| 亚洲高清视频的网址| 精品国产不卡一区二区三区| 不卡的电视剧免费网站有什么| 亚洲线精品一区二区三区| 欧美mv日韩mv亚洲| 99v久久综合狠狠综合久久| 五月开心婷婷久久| 国产三级精品在线| 欧美三级电影网| 国产成人高清在线| 天天影视涩香欲综合网| 国产亚洲欧美一区在线观看| 欧美日韩一区二区在线观看| 国产精品一区二区视频| 一区二区三区自拍| 国产人成亚洲第一网站在线播放| 精品视频免费看| jlzzjlzz欧美大全| 久久国产精品色婷婷| 亚洲视频1区2区| 精品日本一线二线三线不卡| 91小宝寻花一区二区三区| 久久66热偷产精品| 亚洲在线观看免费视频| 国产精品日产欧美久久久久| 欧美一卡2卡3卡4卡| 色婷婷香蕉在线一区二区| 国产综合色精品一区二区三区| 亚洲线精品一区二区三区八戒| 国产欧美一区二区三区在线老狼 | 亚洲成人动漫一区| 亚洲欧洲色图综合| 久久婷婷色综合| 欧美区在线观看| 在线精品亚洲一区二区不卡| 精品一区精品二区高清| 亚洲女人****多毛耸耸8| 国产亚洲精品aa午夜观看| 91精品国产欧美日韩| 欧美特级限制片免费在线观看| 成人av午夜电影| 国产乱色国产精品免费视频| 青青国产91久久久久久| 亚洲国产精品久久人人爱| 亚洲欧美日韩一区| 国产精品欧美极品| 国产精品久久久久久一区二区三区| 欧美mv和日韩mv的网站| 日韩欧美二区三区| 日韩一区二区在线观看视频播放| 91成人在线观看喷潮| 欧美影院一区二区| 欧美综合久久久| 在线观看亚洲专区| 欧美特级限制片免费在线观看| 欧美在线短视频| 精品视频在线免费看| 欧美乱妇20p| 欧美一区二区在线免费播放| 欧美大片在线观看| 久久女同精品一区二区| 国产亚洲综合在线| 久久久91精品国产一区二区精品| 2021久久国产精品不只是精品 | 在线免费视频一区二区| 欧美午夜在线一二页| 欧美日韩午夜在线视频| 欧美色倩网站大全免费| 69久久夜色精品国产69蝌蚪网| 欧美日韩美少妇| 欧美一区二区性放荡片| 亚洲精品在线网站| 中文字幕久久午夜不卡| 亚洲伦在线观看| 亚洲sss视频在线视频| 日韩中文字幕91| 国内成人精品2018免费看| av亚洲精华国产精华精华| 色94色欧美sute亚洲线路二| 欧美日韩国产免费一区二区| 91精品综合久久久久久| 日韩一区二区三区三四区视频在线观看 | 94-欧美-setu| 777色狠狠一区二区三区| 欧美一区二区在线免费观看| 久久精品夜色噜噜亚洲aⅴ| 国产精品久久久久久久第一福利| 一区二区三区日本| 精品在线一区二区| 99久久婷婷国产精品综合| 欧美精品久久99| 久久精品网站免费观看| 亚洲午夜在线电影| 国产精品白丝jk白祙喷水网站 | 国产成人a级片| 欧洲精品在线观看| 欧美mv和日韩mv国产网站| 亚洲天堂av老司机| 精品一区二区三区蜜桃| 成人a区在线观看| 欧美videofree性高清杂交| 亚洲柠檬福利资源导航| 韩国v欧美v日本v亚洲v| 欧美三级视频在线| 亚洲国产成人91porn| 国产激情一区二区三区桃花岛亚洲| 欧美午夜一区二区三区 | 高清在线观看日韩| 欧美日韩大陆一区二区| 欧美国产精品久久| 久久精品噜噜噜成人av农村| 色综合色狠狠天天综合色| 精品美女在线播放| 午夜精品福利一区二区三区av| 成人一区二区三区在线观看| 欧美一卡二卡在线| 亚洲成人www| 91官网在线免费观看| 久久精品一区四区| 精品一区二区综合| 91精品国产综合久久久久久久| 亚洲欧美日韩国产手机在线 | 经典三级一区二区| 欧美日韩大陆一区二区| 亚洲精品自拍动漫在线| 成人动漫视频在线| 欧美激情在线一区二区| 国产美女av一区二区三区| 日韩一区二区三区视频| 日本最新不卡在线| 欧美久久久一区| 亚洲午夜久久久久久久久电影院 | 欧美精选午夜久久久乱码6080| 亚洲精品videosex极品| av电影天堂一区二区在线观看| 日本一区二区三区国色天香| 国产精品香蕉一区二区三区| 国产校园另类小说区| 国产毛片精品一区|