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

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

?? g72x_test.c

?? SUN的ADPCM壓縮解壓程序,包括G.721,G.723,其中G.723又包括16bit,24bit,40bit的壓縮解壓
?? C
字號:
/*
** Copyright (C) 1999-2004 Erik de Castro Lopo <erikd@mega-nerd.com>
**  
** This program is free software; you can redistribute it and/or modify
** it under the terms of the GNU General Public License as published by
** the Free Software Foundation; either version 2 of the License, or
** (at your option) any later version.
** 
** This program is distributed in the hope that it will be useful,
** but WITHOUT ANY WARRANTY; without even the implied warranty of
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
** GNU General Public License for more details.
** 
** You should have received a copy of the GNU General Public License
** along with this program; if not, write to the Free Software 
** Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*/
 
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <string.h>
#include <math.h>

#include "g72x.h"
#include "g72x_priv.h"

#ifndef		M_PI
#define		M_PI		3.14159265358979323846264338
#endif

#define		BUFFER_SIZE		(1<<14) /* Should be (1<<14) */
#define		SAMPLE_RATE		11025


static void g721_test	(void) ;
static void g723_test	(double margin) ;

static void	gen_signal_double (double *data, double scale, int datalen) ;
static int error_function (double data, double orig, double margin) ;

static int	oct_save_short	(short *a, short *b, int len) ;

int
main (int argc, char *argv [])
{	int		bDoAll = 0 ;
	int		nTests = 0 ;

	if (argc != 2)
	{	printf ("Usage : %s <test>\n", argv [0]) ;
		printf ("    Where <test> is one of the following:\n") ;
		printf ("           g721  - test G721 encoder and decoder\n") ;
		printf ("           g723  - test G721 encoder and decoder\n") ;
		printf ("           all   - perform all tests\n") ;
		exit (1) ;
		} ;

	bDoAll=!strcmp (argv [1], "all");

	if (bDoAll || ! strcmp (argv [1], "g721"))
	{	g721_test	() ;
		nTests++ ;
		} ;

	if (bDoAll || ! strcmp (argv [1], "g723"))
	{	g723_test	(0.53) ;
		nTests++ ;
		} ;

	if (nTests == 0)
	{	printf ("Mono : ************************************\n") ;
		printf ("Mono : *  No '%s' test defined.\n", argv [1]) ;
		printf ("Mono : ************************************\n") ;
		return 1 ;
		} ;

	return 0 ;
} /* main */

static void 
g721_test	(void)
{
	return ;
} /* g721_test */

static void 
g723_test	(double margin)
{	static double	orig_buffer [BUFFER_SIZE] ;
	static short 	orig [BUFFER_SIZE] ;
	static short 	data [BUFFER_SIZE] ;

	G72x_STATE encoder_state, decoder_state ;
	
	long	k ;
	int 	code, position, max_err ;

	private_init_state (&encoder_state) ;
	encoder_state.encoder = g723_24_encoder ;
	encoder_state.codec_bits = 3 ;

	private_init_state (&decoder_state) ;
	decoder_state.decoder = g723_24_decoder ;
	decoder_state.codec_bits = 3 ;

	memset (data, 0, BUFFER_SIZE * sizeof (short)) ;
	memset (orig, 0, BUFFER_SIZE * sizeof (short)) ;
	
	printf ("    g723_test    : ") ;
	fflush (stdout) ;
	
	gen_signal_double (orig_buffer, 32000.0, BUFFER_SIZE) ;
	for (k = 0 ; k < BUFFER_SIZE ; k++)
		orig [k] = (short) orig_buffer [k] ;

	/* Write and read data here. */
	position = 0 ;
	max_err = 0 ;
	for (k = 0 ; k < BUFFER_SIZE ; k++)
	{	code = encoder_state.encoder (orig [k], &encoder_state) ;
		data [k] = decoder_state.decoder (code, &decoder_state) ;
		if (abs (orig [k] - data [k]) > max_err)
		{	position = k ;
			max_err = abs (orig [k] - data [k]) ;
			} ;
		} ;

	printf ("\n\nMax error of %d at postion %d.\n", max_err, position) ;

	for (k = 0 ; k < BUFFER_SIZE ; k++)
	{	if (error_function (data [k], orig [k], margin))
		{	printf ("Line %d: Incorrect sample A (#%ld : %d should be %d).\n", __LINE__, k, data [k], orig [k]) ;
			oct_save_short (orig, data, BUFFER_SIZE) ;
			exit (1) ;
			} ;
		} ;


	printf ("ok\n") ;

	return ;
} /* g723_test */


#define		SIGNAL_MAXVAL	30000.0
#define		DECAY_COUNT		1000

static void	
gen_signal_double (double *gendata, double scale, int gendatalen)
{	int		k, ramplen ;
	double	amp = 0.0 ;
	
	ramplen = DECAY_COUNT ;
	
	for (k = 0 ; k < gendatalen ; k++)
	{	if (k <= ramplen)
			amp = scale * k / ((double) ramplen) ;
		else if (k > gendatalen - ramplen)
			amp = scale * (gendatalen - k) / ((double) ramplen) ;

		gendata [k] = amp * (0.4 * sin (33.3 * 2.0 * M_PI * ((double) (k+1)) / ((double) SAMPLE_RATE))
						+ 0.3 * cos (201.1 * 2.0 * M_PI * ((double) (k+1)) / ((double) SAMPLE_RATE))) ;
		} ;
	
	return ;
} /* gen_signal_double */

static int 
error_function (double data, double orig, double margin)
{	double error ;

	if (fabs (orig) <= 500.0)
		error = fabs (fabs (data) - fabs(orig)) / 2000.0 ;
	else if (fabs (orig) <= 1000.0)
		error = fabs (data - orig) / 3000.0 ;
	else
		error = fabs (data - orig) / fabs (orig) ;
		
	if (error > margin)
	{	printf ("\n\n*******************\nError : %f\n", error) ;
		return 1 ;
		} ;
	return 0 ;
} /* error_function */

static int		
oct_save_short	(short *a, short *b, int len)
{	FILE 	*file ;
	int		k ;

	if (! (file = fopen ("error.dat", "w")))
		return 1 ;
		
	fprintf (file, "# Not created by Octave\n") ;
	
	fprintf (file, "# name: a\n") ;
	fprintf (file, "# type: matrix\n") ;
	fprintf (file, "# rows: %d\n", len) ;
	fprintf (file, "# columns: 1\n") ;
	
	for (k = 0 ; k < len ; k++)
		fprintf (file, "% d\n", a [k]) ;

	fprintf (file, "# name: b\n") ;
	fprintf (file, "# type: matrix\n") ;
	fprintf (file, "# rows: %d\n", len) ;
	fprintf (file, "# columns: 1\n") ;
	
	for (k = 0 ; k < len ; k++)
		fprintf (file, "% d\n", b [k]) ;

	fclose (file) ;
	return 0 ;
} /* oct_save_short */

/*
** Do not edit or modify anything in this comment block.
** The arch-tag line is a file identity tag for the GNU Arch 
** revision control system.
**
** arch-tag: 0597b442-a5b0-4abf-92a4-92f6c24e85a6
*/

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
色婷婷久久久亚洲一区二区三区| av午夜精品一区二区三区| 久久久久99精品一区| 91在线你懂得| 奇米四色…亚洲| 国产欧美日韩激情| 欧美日韩国产综合视频在线观看 | 色狠狠av一区二区三区| 蜜臀久久99精品久久久久宅男| 国产精品沙发午睡系列990531| 在线不卡的av| 一本在线高清不卡dvd| 韩国一区二区三区| 午夜视频久久久久久| 国产精品二三区| 欧美成人vr18sexvr| 一本一本大道香蕉久在线精品| 韩国欧美国产1区| 亚洲欧美怡红院| 精品久久人人做人人爰| 欧美日韩免费电影| 99国产欧美久久久精品| 激情综合五月天| 午夜国产精品一区| 亚洲乱码精品一二三四区日韩在线| 久久久久久久精| 91精品国产综合久久婷婷香蕉| 一本大道久久a久久精品综合| 国产超碰在线一区| 国产一区三区三区| 国内精品视频666| 午夜精品视频一区| 香蕉久久一区二区不卡无毒影院 | 欧美精品一区二区三区在线播放| 欧美日韩在线免费视频| 日本韩国一区二区三区视频| 成人av在线资源网| 99久久免费精品| jlzzjlzz欧美大全| 成人综合在线视频| 国产精品一区在线观看你懂的| 狠狠色综合播放一区二区| 老司机一区二区| 美女被吸乳得到大胸91| 看片网站欧美日韩| 精品一区二区三区在线播放视频 | 欧美日韩一级片网站| 色婷婷激情综合| 色呦呦国产精品| 在线一区二区视频| 欧美性视频一区二区三区| 欧美三片在线视频观看| 欧美日本一区二区三区四区| 欧美日韩不卡一区| 日韩无一区二区| 久久久国产精品午夜一区ai换脸| 中文字幕不卡的av| 日韩美女视频19| 一区二区三区四区av| 亚洲一区二区三区视频在线播放 | 国产尤物一区二区| 国产成人久久精品77777最新版本| 国产成都精品91一区二区三 | 欧美精品1区2区3区| 欧美色倩网站大全免费| 欧美日韩成人激情| 亚洲精品一区在线观看| 久久网这里都是精品| 国产精品视频第一区| 成人99免费视频| 欧美午夜一区二区三区| 丰满亚洲少妇av| 国产一区二区三区四| 国产mv日韩mv欧美| 91麻豆123| 欧美夫妻性生活| 久久先锋影音av鲁色资源| 日韩理论片在线| 五月天激情小说综合| 国产麻豆9l精品三级站| 91在线云播放| 91麻豆精品国产无毒不卡在线观看| 久久综合久久99| 一区二区三区在线视频免费| 日韩成人精品在线| 成人av资源网站| 69久久夜色精品国产69蝌蚪网| 久久精品网站免费观看| 中文字幕在线免费不卡| 日本色综合中文字幕| 国产aⅴ综合色| 欧美日韩国产综合一区二区三区| 国产清纯白嫩初高生在线观看91| 夜夜嗨av一区二区三区网页 | 国产精品69毛片高清亚洲| 99re视频精品| 日韩欧美中文字幕一区| 亚洲欧美自拍偷拍色图| 蜜桃av一区二区三区电影| 99视频精品在线| 精品久久久久久久久久久久包黑料| 亚洲免费在线电影| 国产毛片精品国产一区二区三区| 欧美在线观看一区| 国产精品欧美极品| 久久99这里只有精品| 欧美亚州韩日在线看免费版国语版| 国产视频一区二区三区在线观看| 午夜国产不卡在线观看视频| 91亚洲国产成人精品一区二区三| 久久久久久免费| 午夜视频一区二区| 日本韩国精品在线| 日本一区二区综合亚洲| 久久精品国产99国产精品| 色噜噜狠狠成人中文综合| 日本一区二区免费在线观看视频| 久久福利视频一区二区| 欧美色手机在线观看| 国产精品国产三级国产aⅴ入口| 九九国产精品视频| 欧美精品一级二级| 亚洲一区二区三区四区五区中文| 91污在线观看| 国产精品免费aⅴ片在线观看| 国内精品视频一区二区三区八戒| 日韩三区在线观看| 日韩中文字幕区一区有砖一区| 色噜噜狠狠一区二区三区果冻| 国产精品女人毛片| 成人av免费在线| 国产亲近乱来精品视频| 国产成人在线观看免费网站| 久久久国产精华| 国产精品一区二区三区乱码 | 亚洲欧美日韩在线播放| www.在线欧美| 中文字幕精品一区二区精品绿巨人| 国产一区二区不卡老阿姨| 精品国产91亚洲一区二区三区婷婷| 日韩不卡免费视频| 日韩视频在线永久播放| 美腿丝袜亚洲综合| 欧美一区二区三区人| 免费看精品久久片| xnxx国产精品| 国产精品综合在线视频| 日本一区二区三区dvd视频在线| 国产成人一区二区精品非洲| 久久精品免视看| 成人av动漫网站| 亚洲欧美日韩国产成人精品影院| 色素色在线综合| 亚洲一区二区成人在线观看| 欧美精品一二三区| 极品少妇一区二区| 日本一区二区高清| 91在线视频免费观看| 亚洲午夜视频在线| 337p亚洲精品色噜噜| 久久国产精品露脸对白| 国产日韩精品一区二区浪潮av| av激情亚洲男人天堂| 午夜伦理一区二区| 精品国产99国产精品| 97精品国产露脸对白| 亚洲一区二区三区四区中文字幕| 日韩限制级电影在线观看| 国产成人精品亚洲777人妖| 亚洲天天做日日做天天谢日日欢| 欧美午夜免费电影| 狠狠色丁香婷婷综合| 国产精品久久久久久久久晋中| 欧美性色黄大片| 精品一区二区久久久| 日本一区二区综合亚洲| 欧美午夜精品免费| 国产精品18久久久久久久网站| 亚洲三级小视频| 日韩欧美一区二区三区在线| 国产91在线观看| 五月天亚洲精品| 久久先锋影音av| 欧美视频在线不卡| 国产成人亚洲精品青草天美| 一区二区三区国产| 久久久久久日产精品| 欧美日韩国产成人在线免费| 国产伦精一区二区三区| 亚洲一卡二卡三卡四卡| 欧美白人最猛性xxxxx69交| hitomi一区二区三区精品| 亚洲成av人片一区二区梦乃| 国产午夜精品美女毛片视频| 欧美日韩一级二级三级| a在线播放不卡| 麻豆国产精品官网| 亚洲成人资源网| 中文一区在线播放| 国产一区二区三区四区五区美女|