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

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

?? butterworth.c

?? 巴特沃斯濾波
?? C
字號(hào):
/*********************** self documentation **********************/
/*****************************************************************************
BUTTERWORTH - Functions to design and apply Butterworth filters:

bfdesign	design a Butterworth filter
bfhighpass	apply a high-pass Butterworth filter 
bflowpass	apply a low-pass Butterworth filter 

******************************************************************************
Function Prototypes:
void bfhighpass (int npoles, float f3db, int n, float p[], float q[]);
void bflowpass (int npoles, float f3db, int n, float p[], float q[]);
void bfdesign (float fpass, float apass, float fstop, float astop,
	int *npoles, float *f3db);

******************************************************************************
bfdesign:
Input:
fpass		frequency in pass band at which amplitude is >= apass
apass		amplitude in pass band corresponding to frequency fpass
fstop 		frequency in stop band at which amplitude is <= astop
astop		amplitude in stop band corresponding to frequency fstop

Output:
npoles		number of poles
f3db		frequency at which amplitude is sqrt(0.5) (-3 db)

bfhighpass and bflowpass:
Input:
npoles		number of poles (and zeros); npoles>=0 is required
f3db		3 db frequency; nyquist = 0.5; 0.0<=f3db<=0.5 is required
n		length of p and q
p		array[n] to be filtered

Output:
q		filtered array[n] (may be equivalent to p)

******************************************************************************
Notes:
(1) Nyquist frequency equals 0.5

(2) The following conditions must be true:
	(0.0<fpass && fpass<0.5) &&
	(0.0<fstop && fstop<0.5) &&
	(fpass!=fstop) &&
	(0.0<astop && astop<apass && apass<1.0)

(3) if (fpass<fstop)

bfdesign:
Butterworth filter:  compute number of poles and -3 db frequency
for a low-pass or high-pass filter, given a frequency response
constrained at two frequencies. 

***************** end self doc ********************************/

#ifndef BF_H
#define BF_H

#include "math.h"
#define PI 3.1415926535897

#endif

void bfdesign (float fpass, float apass, float fstop, float astop,
	           int *npoles, float *f3db)
/*****************************************************************************
Butterworth filter:  compute number of poles and -3 db frequency for a low-pass or high-pass filter, given a frequency response
constrained at two frequencies.
******************************************************************************
Input:
fpass		frequency in pass band at which amplitude is >= apass
apass		amplitude in pass band corresponding to frequency fpass
fstop 		frequency in stop band at which amplitude is <= astop
astop		amplitude in stop band corresponding to frequency fstop

Output:
npoles		number of poles
f3db		frequency at which amplitude is sqrt(0.5) (-3 db)
******************************************************************************
Notes:
(1) Nyquist frequency equals 0.5

(2) The following conditions must be true:
	(0.0<fpass && fpass<0.5) &&
	(0.0<fstop && fstop<0.5) &&
	(fpass!=fstop) &&
	(0.0<astop && astop<apass && apass<1.0)

(3) if (fpass<fstop)
		a low-pass filter is assumed
	else
		a high-pass filter is assumed
*****************************************************************************/
{
	float wpass,wstop,fnpoles,w3db;

	/* warp frequencies according to bilinear transform */
	wpass = 2.0*tan(PI*fpass);
	wstop = 2.0*tan(PI*fstop);

	/* if lowpass filter, then */
	if (fstop>fpass) 
	{
		fnpoles = log((1.0/(apass*apass)-1.0)/(1.0/(astop*astop)-1.0)) / log(pow(wpass/wstop,2.0));
		w3db = wpass/pow((1.0/(apass*apass)-1.0),0.5/fnpoles);
	/* else, if highpass filter, then */
	}
	else 
	{
		fnpoles = log((1.0/(apass*apass)-1.0)/(1.0/(astop*astop)-1.0)) / log(pow(wstop/wpass,2.0));
		w3db = wpass*pow((1.0/(apass*apass)-1.0),0.5/fnpoles);
	}

	/* determine integer number of poles */
	*npoles = 1+(int)fnpoles;

	/* determine (unwarped) -3 db frequency */
	*f3db = atan(0.5*w3db)/PI;
}

void bfhighpass (int npoles, float f3db, int n, float p[], float q[])
/*****************************************************************************
Butterworth filter:  high-pass
******************************************************************************
Input:
npoles		number of poles (and zeros); npoles>=0 is required
f3db		3 db frequency; nyquist = 0.5; 0.0<=f3db<=0.5 is required
n		length of p and q
p		array[n] to be filtered

Output:
q		filtered array[n] (may be equivalent to p)
*****************************************************************************/
{
	int jpair,j;
	float r,scale,theta,a,b1,b2,pj,pjm1,pjm2,qjm1,qjm2;

	r = 2.0*tan(PI*fabs(f3db));
	if (npoles%2!=0) 
	{
		scale = r+2.0;
		a = 2.0/scale;
		b1 = (r-2.0)/scale;
		pj = 0.0;
		qjm1 = 0.0;
		for (j=0; j<n; j++)
		{
			pjm1 = pj;
			pj = p[j];
			q[j] = a*(pj-pjm1)-b1*qjm1;
			qjm1 = q[j];
		}
	} 
	else
	{
		for (j=0; j<n; j++)
			q[j] = p[j];
	}
	for (jpair=0; jpair<npoles/2; jpair++) 
	{
		theta = PI*(2*jpair+1)/(2*npoles);
		scale = 4.0+4.0*r*sin(theta)+r*r;
		a = 4.0/scale;
		b1 = (2.0*r*r-8.0)/scale;
		b2 = (4.0-4.0*r*sin(theta)+r*r)/scale;
		pjm1 = 0.0;
		pj = 0.0;
		qjm2 = 0.0;
		qjm1 = 0.0;
		for (j=0; j<n; j++) 
		{
			pjm2 = pjm1;
			pjm1 = pj;
			pj = q[j];
			q[j] = a*(pj-2.0*pjm1+pjm2)-b1*qjm1-b2*qjm2;
			qjm2 = qjm1;
			qjm1 = q[j];
		}
	}
}

void bflowpass (int npoles, float f3db, int n, float p[], float q[])
/*****************************************************************************
Butterworth filter:  low-pass
******************************************************************************
Input:
npoles		number of poles (and zeros); npoles>=0 is required
f3db		3 db frequency; nyquist = 0.5; 0.0<=f3db<=0.5 is required
n		length of p and q
p		array[n] to be filtered

Output:
q		filtered array[n] (may be equivalent to p)

*****************************************************************************/
{
	int jpair,j;
	float r,scale,theta,a,b1,b2,pj,pjm1,pjm2,qjm1,qjm2;

	r = 2.0*tan(PI*fabs(f3db));
	if (npoles%2!=0) 
	{
		scale = r+2.0;
		a = r/scale;
		b1 = (r-2.0)/scale;
		pj = 0.0;
		qjm1 = 0.0;
		for (j=0; j<n; j++) 
		{
			pjm1 = pj;
			pj = p[j];
			q[j] = a*(pj+pjm1)-b1*qjm1;
			qjm1 = q[j];
		}
	} 
	else 
	{
		for (j=0; j<n; j++)
			q[j] = p[j];
	}
	for (jpair=0; jpair<npoles/2; jpair++)
	{
		theta = PI*(2*jpair+1)/(2*npoles);
		scale = 4.0+4.0*r*sin(theta)+r*r;
		a = r*r/scale;
		b1 = (2.0*r*r-8.0)/scale;
		b2 = (4.0-4.0*r*sin(theta)+r*r)/scale;
		pjm1 = 0.0;
		pj = 0.0;
		qjm2 = 0.0;
		qjm1 = 0.0;
		for (j=0; j<n; j++) 
		{
			pjm2 = pjm1;
			pjm1 = pj;
			pj = q[j];
			q[j] = a*(pj+2.0*pjm1+pjm2)-b1*qjm1-b2*qjm2;
			qjm2 = qjm1;
			qjm1 = q[j];
		}
	}
}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一级一级性生活免费录像| 狠狠色狠狠色综合日日91app| 欧美老人xxxx18| 国产一区二区女| 亚洲国产综合91精品麻豆| 久久久.com| 7777精品伊人久久久大香线蕉经典版下载| 国产一区二区三区国产| 亚洲国产精品精华液网站| 亚洲男女一区二区三区| 精品国产制服丝袜高跟| 欧美无人高清视频在线观看| 成人黄色网址在线观看| 精品一区在线看| 亚洲国产精品一区二区久久| 国产精品久久久久久亚洲伦| 欧美第一区第二区| 欧美日韩国产在线播放网站| 91免费精品国自产拍在线不卡| 韩国欧美一区二区| 蜜臀精品一区二区三区在线观看 | 一区二区三区在线视频播放| 久久久久久免费| 日韩亚洲欧美在线观看| 69成人精品免费视频| 欧美自拍偷拍一区| 色天天综合色天天久久| 99国产精品久久久久久久久久久| 成人午夜视频网站| 国产东北露脸精品视频| 国产精品中文字幕欧美| 国产乱人伦精品一区二区在线观看| 久久精品72免费观看| 午夜久久久久久久久| 亚洲国产精品久久久男人的天堂| 亚洲综合成人网| 亚洲一区二区在线免费看| 国产精品久久三区| 久久精品水蜜桃av综合天堂| 91精品国产高清一区二区三区| 久久国产福利国产秒拍| 精品一区二区三区视频在线观看| 亚洲午夜久久久久中文字幕久| 亚洲欧洲精品一区二区精品久久久 | 欧美日韩dvd在线观看| 91色综合久久久久婷婷| 岛国av在线一区| 国产一区999| 久久国产尿小便嘘嘘尿| 免费在线看成人av| 日韩成人伦理电影在线观看| 亚洲成人777| 亚洲一区二区黄色| 亚洲国产欧美日韩另类综合 | 91精品国产综合久久福利软件 | 色婷婷狠狠综合| 国产电影精品久久禁18| 国产一区在线观看视频| 精品亚洲成a人在线观看 | 国产成人激情av| 精品影院一区二区久久久| 精品午夜久久福利影院| 国产麻豆91精品| 国产精品69毛片高清亚洲| 黄一区二区三区| 九色porny丨国产精品| 狂野欧美性猛交blacked| 狠狠色丁香婷婷综合久久片| 韩日精品视频一区| 国产成人福利片| 成人在线综合网站| 成人福利视频在线看| 成人av网址在线观看| 91浏览器入口在线观看| 色www精品视频在线观看| 欧洲在线/亚洲| 欧美丰满少妇xxxxx高潮对白| 日韩欧美中文字幕制服| 久久亚洲综合av| 中文字幕在线观看不卡| 亚洲猫色日本管| 日本伊人色综合网| 国产一区不卡视频| 国产宾馆实践打屁股91| 欧美视频一区在线| 日韩精品一区二区三区中文精品| 久久久国际精品| 亚洲人成人一区二区在线观看| 香港成人在线视频| 日韩电影在线观看网站| 国产黄色精品网站| 91福利国产成人精品照片| 精品视频色一区| 久久久久久一级片| 国产精品国产精品国产专区不片| 亚洲午夜免费视频| 精品亚洲欧美一区| 成人成人成人在线视频| 欧美精品色综合| 中文字幕二三区不卡| 亚洲成av人片一区二区| 激情综合五月天| 97久久超碰精品国产| 欧美一区二区三区婷婷月色| 国产女同互慰高潮91漫画| 亚洲宅男天堂在线观看无病毒| 老司机精品视频一区二区三区| 成人sese在线| 91精品国产色综合久久不卡电影 | 日本一区二区免费在线观看视频| 亚洲一区免费视频| 国产一区二区三区日韩| 欧美三日本三级三级在线播放| 精品999在线播放| 亚洲一区二区三区激情| 欧美中文一区二区三区| 欧美一区二区三区日韩| 国产精品不卡在线| 美女在线视频一区| 在线看日韩精品电影| 日本一区二区三区高清不卡| 日韩电影在线观看网站| 色婷婷久久一区二区三区麻豆| 337p日本欧洲亚洲大胆色噜噜| 亚洲成a人v欧美综合天堂下载 | 精品一二三四在线| 欧美日韩视频专区在线播放| 国产精品色哟哟| 精品午夜一区二区三区在线观看| 在线观看av一区二区| 中文字幕精品—区二区四季| 美脚の诱脚舐め脚责91| 欧美色视频在线观看| 亚洲天堂成人网| 成人黄色777网| 国产丝袜美腿一区二区三区| 蜜臀国产一区二区三区在线播放| 在线观看日韩精品| 亚洲欧美激情小说另类| 国产麻豆视频一区二区| 久久久久国产精品厨房| 久久福利资源站| 91精品国产综合久久蜜臀| 亚洲国产精品自拍| 在线一区二区观看| 亚洲人成小说网站色在线| jizzjizzjizz欧美| 国产精品美女久久久久久久网站| 国产成人免费高清| 日本一区二区三区免费乱视频| 国产一区日韩二区欧美三区| 欧美成人bangbros| 免费在线观看视频一区| 欧美片在线播放| 美女一区二区视频| 欧美zozozo| 精品一二三四在线| 久久久久久一二三区| 欧美日韩午夜在线视频| 亚洲综合在线电影| 欧美日韩成人在线一区| 天天综合色天天综合| 91精品一区二区三区在线观看| 日韩精品91亚洲二区在线观看| 欧美这里有精品| 亚洲成av人综合在线观看| 欧美日韩一区小说| 日韩电影一二三区| 欧美精品一区二区久久婷婷 | 亚洲成人黄色小说| 欧美精品成人一区二区三区四区| 亚洲成人综合网站| 94色蜜桃网一区二区三区| 视频一区在线播放| 日韩一区二区三区三四区视频在线观看| 天天操天天综合网| 精品国精品国产尤物美女| 福利电影一区二区| 一区二区成人在线视频| 欧美日韩不卡一区| 国产一区二区三区电影在线观看 | 国产清纯美女被跳蛋高潮一区二区久久w | 亚洲123区在线观看| 欧美一区二区日韩| 国产精品一区二区三区乱码| 中文字幕日本不卡| 精品视频在线免费看| 狠狠色丁香婷婷综合久久片| 日本一区二区久久| 欧美亚洲动漫精品| 日韩avvvv在线播放| 欧美日韩国产bt| 国产aⅴ精品一区二区三区色成熟| 中文字幕一区不卡| 91精品国产综合久久精品app| 国产裸体歌舞团一区二区| 日韩理论片在线| 51精品秘密在线观看| 国产91色综合久久免费分享| 一区二区三区影院|