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

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

?? testfilterdlg.cpp

?? 主要功能是任意波段的濾波計算
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
// TestFilterDlg.cpp : implementation file
//

#include "stdafx.h"
#include "TestFilter.h"
#include "TestFilterDlg.h"
#include	<math.h>

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

#define		N		1024


void FFT(float xreal [], float ximag [], int n);
void  IFFT (float xreal [], float ximag [], int n);

/////////////////////////////////////////////////////////////////////////////
// CAboutDlg dialog used for App About

class CAboutDlg : public CDialog
{
public:
	CAboutDlg();

// Dialog Data
	//{{AFX_DATA(CAboutDlg)
	enum { IDD = IDD_ABOUTBOX };
	//}}AFX_DATA

	// ClassWizard generated virtual function overrides
	//{{AFX_VIRTUAL(CAboutDlg)
	protected:
	virtual void DoDataExchange(CDataExchange* pDX);    // DDX/DDV support
	//}}AFX_VIRTUAL

// Implementation
protected:
	//{{AFX_MSG(CAboutDlg)
	//}}AFX_MSG
	DECLARE_MESSAGE_MAP()
};

CAboutDlg::CAboutDlg() : CDialog(CAboutDlg::IDD)
{
	//{{AFX_DATA_INIT(CAboutDlg)
	//}}AFX_DATA_INIT
}

void CAboutDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CAboutDlg)
	//}}AFX_DATA_MAP
}

BEGIN_MESSAGE_MAP(CAboutDlg, CDialog)
	//{{AFX_MSG_MAP(CAboutDlg)
		// No message handlers
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CTestFilterDlg dialog

CTestFilterDlg::CTestFilterDlg(CWnd* pParent /*=NULL*/)
	: CDialog(CTestFilterDlg::IDD, pParent)
{
	//{{AFX_DATA_INIT(CTestFilterDlg)
	m_fFreqLow = 0.0f;
	m_fFreqHigh = 0.0f;
	m_fScope = 0.5f;
	m_bFilter = FALSE;
	m_fDT = 0.0f;
	m_fFsamp = 3976.9f;
	m_fPower = 0.0f;
	//}}AFX_DATA_INIT
	// Note that LoadIcon does not require a subsequent DestroyIcon in Win32
	m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
}

void CTestFilterDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CTestFilterDlg)
	DDX_Text(pDX, IDC_EDIT_LOW, m_fFreqLow);
	DDX_Text(pDX, IDC_EDIT_HIGH, m_fFreqHigh);
	DDX_Text(pDX, IDC_EDIT_SCOPE, m_fScope);
	DDX_Check(pDX, IDC_CHECK_FILTER, m_bFilter);
	DDX_Text(pDX, IDC_EDIT_DT, m_fDT);
	DDX_Text(pDX, IDC_EDIT_FSAMP, m_fFsamp);
	DDX_Text(pDX, IDC_EDIT_FPOWER, m_fPower);
	//}}AFX_DATA_MAP
}

BEGIN_MESSAGE_MAP(CTestFilterDlg, CDialog)
	//{{AFX_MSG_MAP(CTestFilterDlg)
	ON_WM_SYSCOMMAND()
	ON_WM_PAINT()
	ON_WM_QUERYDRAGICON()
	ON_BN_CLICKED(IDC_BTN_DRAWWAVE, OnBtnDrawwave)
	ON_BN_CLICKED(IDC_BTN_GENWAVE, OnBtnGenwave)
	ON_BN_CLICKED(IDC_BTN_FFT, OnBtnFft)
	ON_BN_CLICKED(IDC_BTN_READDATA, OnBtnReaddata)
	ON_BN_CLICKED(IDC_BTN_JIFEN, OnBtnJifen)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CTestFilterDlg message handlers

BOOL CTestFilterDlg::OnInitDialog()
{
	CDialog::OnInitDialog();

	// Add "About..." menu item to system menu.

	// IDM_ABOUTBOX must be in the system command range.
	ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX);
	ASSERT(IDM_ABOUTBOX < 0xF000);

	CMenu* pSysMenu = GetSystemMenu(FALSE);
	if (pSysMenu != NULL)
	{
		CString strAboutMenu;
		strAboutMenu.LoadString(IDS_ABOUTBOX);
		if (!strAboutMenu.IsEmpty())
		{
			pSysMenu->AppendMenu(MF_SEPARATOR);
			pSysMenu->AppendMenu(MF_STRING, IDM_ABOUTBOX, strAboutMenu);
		}
	}

	// Set the icon for this dialog.  The framework does this automatically
	//  when the application's main window is not a dialog
	SetIcon(m_hIcon, TRUE);			// Set big icon
	SetIcon(m_hIcon, FALSE);		// Set small icon
	
	// TODO: Add extra initialization here
	
	return TRUE;  // return TRUE  unless you set the focus to a control
}

void CTestFilterDlg::OnSysCommand(UINT nID, LPARAM lParam)
{
	if ((nID & 0xFFF0) == IDM_ABOUTBOX)
	{
		CAboutDlg dlgAbout;
		dlgAbout.DoModal();
	}
	else
	{
		CDialog::OnSysCommand(nID, lParam);
	}
}

// If you add a minimize button to your dialog, you will need the code below
//  to draw the icon.  For MFC applications using the document/view model,
//  this is automatically done for you by the framework.

void CTestFilterDlg::OnPaint() 
{
	if (IsIconic())
	{
		CPaintDC dc(this); // device context for painting

		SendMessage(WM_ICONERASEBKGND, (WPARAM) dc.GetSafeHdc(), 0);

		// Center icon in client rectangle
		int cxIcon = GetSystemMetrics(SM_CXICON);
		int cyIcon = GetSystemMetrics(SM_CYICON);
		CRect rect;
		GetClientRect(&rect);
		int x = (rect.Width() - cxIcon + 1) / 2;
		int y = (rect.Height() - cyIcon + 1) / 2;

		// Draw the icon
		dc.DrawIcon(x, y, m_hIcon);
	}
	else
	{
		//// 在這里做圖形繪制


		CRect waveRect;
		GetDlgItem(IDC_STATIC_WAVE)->GetWindowRect(&waveRect); 
		ScreenToClient(&waveRect); 
		//繪制頻譜
		CRect FreqRect;
		GetDlgItem(IDC_STATIC_FREQ)->GetWindowRect(&FreqRect); 
		ScreenToClient(&FreqRect);

		UpdateData(TRUE);

		DrawWaveData( waveRect,FreqRect, fAccWave, fFreqData,1024,  m_fScope,  m_fScope);
//		DrawWaveData( waveRect,FreqRect, fAccWave, fVocWave,1024,  m_fScope,  m_fScope);

		CDialog::OnPaint();
	}
}

// The system calls this to obtain the cursor to display while the user drags
//  the minimized window.
HCURSOR CTestFilterDlg::OnQueryDragIcon()
{
	return (HCURSOR) m_hIcon;
}

void CTestFilterDlg::OnBtnDrawwave() 
{
	// TODO: Add your control notification handler code here
	
	// 計算 電壓有效值
	float	fPower;
	GetWavePower(fAccWave,1024, &fPower);
	m_fPower = fPower;
	UpdateData(FALSE);

	//繪制波形
	CRect	waveRect;
	GetDlgItem( IDC_STATIC_WAVE )->GetWindowRect( &waveRect ); 
	ScreenToClient( &waveRect ); 
	InvalidateRect(waveRect,TRUE);
	// 繪制頻譜
	CRect	FreqRect;
	GetDlgItem( IDC_STATIC_FREQ )->GetWindowRect( &FreqRect ); 
	ScreenToClient( &FreqRect ); 
	InvalidateRect(FreqRect,TRUE);
}


// 繪制波形數據
void CTestFilterDlg::DrawWaveData( CRect waveRect, CRect FreqRect,FLOAT Wave[],FLOAT Freq[] , INT ptNum, FLOAT fWaveMax,FLOAT fFreqMax)
{
	CPaintDC dc(this);

	CPen	GrayPen;
	CPen	RedPen;
	CPen	* pOldPen;
	INT		nIndex;
	FLOAT	fX0,fY0,fW,fH;
	FLOAT	fTemp;
	INT		nTemp;
	INT		i;
	
	GrayPen.CreatePen(PS_SOLID,1,RGB(128,128,128));
	RedPen.CreatePen(PS_SOLID,1,RGB(255,0,0));
	/////////////////////繪制波形部分////////////////////////////////	
	pOldPen = dc.SelectObject(&GrayPen);
	dc.Rectangle(waveRect);
	dc.FillSolidRect(waveRect, RGB(50,50,50));
	
	fX0 = (FLOAT)waveRect.left;
	fY0 = (FLOAT)(waveRect.top+waveRect.bottom) / 2.0f;
	fW	= (FLOAT)waveRect.Width();
	fH	= (FLOAT)waveRect.Height() / 2.0f;

	// 垂直線
	for (nIndex=0;nIndex<10;nIndex++)
	{
		fTemp = fX0 + fW * nIndex / 10.0f;
		nTemp = (INT)fTemp;
		dc.MoveTo(nTemp, waveRect.top);
		dc.LineTo(nTemp, waveRect.bottom) ;
	}

	// 水平線
	for (nIndex=0;nIndex<4 ;nIndex++)
	{
		fTemp = fH * 2.0f * nIndex / 4.0f;
		nTemp = waveRect.top + (INT)fTemp;
		dc.MoveTo(waveRect.left, nTemp);
		dc.LineTo(waveRect.right, nTemp);
	}

	// 繪制曲線
	pOldPen = dc.SelectObject(&RedPen);
	fTemp = SetWaveDataInScope(Wave[0], fWaveMax);
	dc.MoveTo((INT)(fX0+fW*0/ptNum), (INT)(fY0-fTemp/fWaveMax*fH)); 

	for(i=1;i<=ptNum-1 ;i++)
	{
		// 限制波形范圍
		fTemp = SetWaveDataInScope(Wave[i],fWaveMax);
		dc.LineTo((INT)(fX0+fW*i/ptNum), (INT)(fY0-fTemp/fWaveMax*fH)); 
	}
	dc.SelectObject(pOldPen);
	/////////////繪制頻譜部分////////////////////////////////////////////
	pOldPen = dc.SelectObject(&GrayPen);
	dc.Rectangle(FreqRect);
	dc.FillSolidRect(FreqRect, RGB(50,50,50));
	
	fX0 = (FLOAT)FreqRect.left;
	fY0 = (FLOAT)FreqRect.bottom - FreqRect.Height()/2 ;
	fW	= (FLOAT)FreqRect.Width();
	fH	= (FLOAT)FreqRect.Height()/2.0;

	// 垂直線
	for (nIndex=0;nIndex<10;nIndex++)
	{
		fTemp = fX0 + fW * nIndex / 10.0f;
		nTemp = (INT)fTemp;
		dc.MoveTo(nTemp, FreqRect.top);
		dc.LineTo(nTemp, FreqRect.bottom) ;
	}

	// 水平線
	for (nIndex=0;nIndex<4 ;nIndex++)
	{
		fTemp = fH *2.0* nIndex / 4.0f;
		nTemp = FreqRect.top + (INT)fTemp;
		dc.MoveTo(FreqRect.left, nTemp);
		dc.LineTo(FreqRect.right, nTemp);
	}

	// 繪制曲線
	pOldPen = dc.SelectObject(&RedPen);
	fTemp   = SetFreqDataInScope(Freq[0 ],fFreqMax);
	dc.MoveTo((INT)(fX0 + fW * 0 / ptNum), (INT)(fY0 - fTemp / fFreqMax * fH)); 

	for(i=1;i<=ptNum-1 ;i++)
	{
		// 限制范圍
		fTemp = SetFreqDataInScope(Freq[i], fFreqMax);
		
		//繪制曲線
		dc.LineTo((INT)(fX0+ fW*i/ptNum), (INT)(fY0- fTemp /fFreqMax*fH)); 
	}

	//////////////////
	dc.SelectObject(pOldPen);



	
	RedPen.DeleteObject();
	GrayPen.DeleteObject();
}

// 設置在波形的范圍內
float	 CTestFilterDlg::SetWaveDataInScope(FLOAT fValue, FLOAT fMax)
{
	FLOAT fTemp = 0.0f;

	if ((fValue<fMax)&&(fValue>(-1.0f)*fMax ))
	{
		fTemp= fValue;
	}
	else if(fValue>=fMax)
	{
		fTemp=fMax;
	}
	else if(fValue<=(-1.0f)*fMax)
	{
		fTemp=fMax*(-1.0f);
	}

	return  fTemp;
}

void CTestFilterDlg::OnBtnGenwave() 
{
	// TODO: Add your control notification handler code here
	int		i;
	float	fA1,fA2,fA3,fA4,fA5;
	fA1=1.20;
	fA2=0.30;
	fA3=0.4;
	fA4=0.2;
	fA5=0.6;
	for(i=0;i<1024;i++)
	{
		fAccWave[i]=fA1* cos( 2*PI *i/128  )+
					fA2* cos(2*PI *i/128 * 2 )
					+fA3*cos(2*PI *i/128 * 3   )
					+fA4*cos(2*PI *i/128 * 4  )
					+fA5*cos(2*PI *i/128 * 5   );
//					+rand()/(256*64);   ////  白噪聲不能這么加上去。
	}

}

/*
// 繪制頻譜數據
VOID CTestFilterDlg::DrawFreqData(  CRect FreqRect, FLOAT Freq[], INT ptNum, FLOAT fFreqMax)
{
	CPaintDC	dc(this);

	CPen	GrayPen;
	CPen	RedPen;
	CPen	* pOldPen;
	INT		nIndex;
	FLOAT	fX0,fY0,fW,fH;
	FLOAT	fTemp;
	INT		nTemp;
	INT		i;
	
	GrayPen.CreatePen(PS_SOLID, 1, RGB(128,128,128));
	RedPen.CreatePen(PS_SOLID, 1, RGB(255,0,0));
	
	pOldPen = dc.SelectObject(&GrayPen);
	dc.Rectangle(FreqRect);
	dc.FillSolidRect(FreqRect, RGB(50,50,50));
	
	fX0 = (FLOAT)FreqRect.left;
	fY0 = (FLOAT)FreqRect.bottom;
	fW	= (FLOAT)FreqRect.Width();
	fH	= (FLOAT)FreqRect.Height();

	// 垂直線
	for (nIndex=0;nIndex<10;nIndex++)
	{
		fTemp = fX0 + fW * nIndex / 10.0f;
		nTemp = (INT)fTemp;
		dc.MoveTo(nTemp, FreqRect.top);
		dc.LineTo(nTemp, FreqRect.bottom) ;
	}

	// 水平線
	for (nIndex=0;nIndex<4 ;nIndex++)
	{
		fTemp = fH * nIndex / 4.0f;
		nTemp = FreqRect.top + (INT)fTemp;
		dc.MoveTo(FreqRect.left, nTemp);
		dc.LineTo(FreqRect.right, nTemp);
	}

	// 繪制曲線
	pOldPen = dc.SelectObject(&RedPen);
	fTemp   = SetFreqDataInScope(Freq[0 ],fFreqMax);
	dc.MoveTo((INT)(fX0 + fW * 0 / ptNum), (INT)(fY0 - fTemp / fFreqMax * fH)); 

	for(i=1;i<=ptNum-1 ;i++)
	{
		// 限制范圍
		fTemp = SetFreqDataInScope(Freq[i], fFreqMax);
		
		//繪制曲線
		dc.LineTo((INT)(fX0+ fW*i/ptNum), (INT)(fY0- fTemp /fFreqMax*fH)); 
	}

	//////////////////
	dc.SelectObject(pOldPen);
	
	RedPen.DeleteObject();
	GrayPen.DeleteObject();
}
*/


// 設置在頻譜的范圍內
FLOAT	CTestFilterDlg::SetFreqDataInScope(FLOAT fValue, FLOAT fMax)
{
	FLOAT fTemp = 0.0f;

	// 限制范圍
	if ((fValue<fMax)&&(fValue> (-1*fMax )))
	{
		fTemp = fValue ;
	}
	else
	{
		fTemp =0.0f;
	}

	return  fTemp;
}


// 應用FFT計算
VOID CTestFilterDlg::AppFFT(INT ptNum , float  Wave[])
{
    float pr[1024],pi[1024],fr[1024],fi[1024];
	int	nJieCi;
	int	i,nT;
	nJieCi = -1;  // 表示不是2的整數次冪
	nT=1;
	
	for(i=1;i<=10;i++)
	{
		nT=nT*2;
		if  (nT==ptNum)
		{
			nJieCi=i;
		}
	}
	// 歸整的 冪整數
	if( (nJieCi>=1)&&(nJieCi<=10) )
	{
		// 前期準備數據
		for(i=0;i<=ptNum-1;i++)
		{
			pr[i]= Wave[i];
			pi[i]=0.0;
		}

		// FFT計算
		kkfft(pr,pi,ptNum, nJieCi ,fr,fi,0,1);
		
		// 后期整理數據
		// 0,1====fr 為幅值 fi為角度,按照角度表達
		for(i=0;i<=ptNum-1;i++)
		{
			fFreqData[i]= fr[i];
		}

		UpdateData(FALSE);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人免费小视频| 欧美人与禽zozo性伦| 蜜桃精品视频在线观看| 亚洲最快最全在线视频| 一区二区三区四区在线| 亚洲猫色日本管| 亚洲美女屁股眼交3| 亚洲资源中文字幕| 亚洲国产视频a| 亚洲v精品v日韩v欧美v专区| 日韩精品91亚洲二区在线观看| 亚洲一区二区五区| 亚洲h动漫在线| 久久精品国产一区二区| 精品一区二区三区欧美| 国产成人免费网站| 国产91露脸合集magnet| 国产大陆亚洲精品国产| 成人免费三级在线| 在线一区二区三区| 欧美理论电影在线| 日韩美女视频一区二区在线观看| 精品国产免费人成在线观看| 国产欧美日韩在线视频| 亚洲欧美在线aaa| 亚洲在线成人精品| 精品影视av免费| 岛国精品在线播放| 欧美日韩一区二区欧美激情| 欧美大片一区二区| 依依成人综合视频| 国产在线精品一区二区夜色 | 中文字幕国产一区| 亚洲女女做受ⅹxx高潮| 日本在线不卡视频| 国产91丝袜在线观看| 欧美亚洲综合色| 久久免费国产精品| 亚洲成av人片| 成人av资源在线| 日韩欧美一区在线| 亚洲男人的天堂网| 久久99国内精品| 欧美午夜精品免费| 国产精品卡一卡二| 美国毛片一区二区三区| 91日韩精品一区| 久久久久久久久一| 午夜不卡av在线| 99久久久无码国产精品| 精品国产一区a| 性感美女极品91精品| 成人午夜精品在线| 精品乱人伦小说| 亚洲va国产天堂va久久en| 91网站在线播放| 国产女人18毛片水真多成人如厕 | 1024亚洲合集| 国产麻豆91精品| 在线播放中文字幕一区| 中文字幕一区二区三区不卡 | 欧美乱妇一区二区三区不卡视频| 国产日韩精品一区| 免费观看成人av| 欧美日韩精品欧美日韩精品一 | 天堂av在线一区| 色综合av在线| 亚洲一区在线观看视频| 91麻豆国产香蕉久久精品| 国产欧美日韩精品一区| 国产乱码一区二区三区| 精品国产第一区二区三区观看体验| 亚洲一二三四在线| 欧美优质美女网站| 亚洲精品视频在线| 91丝袜呻吟高潮美腿白嫩在线观看| 久久婷婷一区二区三区| 国产综合久久久久久久久久久久 | 色婷婷久久久久swag精品| 亚洲免费av高清| 欧洲亚洲国产日韩| 一区2区3区在线看| 欧美日韩在线直播| 性欧美疯狂xxxxbbbb| 4438x亚洲最大成人网| 日本午夜精品一区二区三区电影| 日韩一区二区三| 国产一区二区免费视频| 国产欧美精品区一区二区三区 | 日韩免费高清视频| 久久99日本精品| 久久久蜜桃精品| 99国产精品视频免费观看| 亚洲精品乱码久久久久久久久| 色婷婷狠狠综合| 日韩高清中文字幕一区| xfplay精品久久| 成人黄色在线视频| 亚洲国产精品一区二区久久恐怖片| 欧美群妇大交群的观看方式| 日韩av一区二区在线影视| 精品国产a毛片| 91丝袜美腿高跟国产极品老师| 亚洲宅男天堂在线观看无病毒| 欧美一级爆毛片| 高清在线不卡av| 亚洲一区在线观看免费| 精品国产免费人成在线观看| 99久久精品免费看| 秋霞午夜av一区二区三区| 亚洲国产成人在线| 欧美日韩国产综合一区二区| 国产精品一区二区无线| 亚洲激情网站免费观看| 日韩色在线观看| 色综合久久中文字幕| 免费不卡在线观看| 亚洲制服欧美中文字幕中文字幕| 久久毛片高清国产| 欧美疯狂性受xxxxx喷水图片| 国产成人精品1024| 天天综合色天天综合| 国产精品久久夜| 91精品国产91综合久久蜜臀| 成人av资源在线观看| 精品一区二区在线播放| 亚洲成人动漫在线观看| 国产精品女上位| 精品国内二区三区| 欧美三级视频在线观看| 99久久精品国产麻豆演员表| 国产一区二区精品久久91| 日韩精品一区第一页| 伊人婷婷欧美激情| 中文字幕av一区二区三区免费看| 日韩精品一区在线| 欧美男女性生活在线直播观看| a4yy欧美一区二区三区| 国产91丝袜在线观看| 麻豆国产91在线播放| 亚洲电影视频在线| 《视频一区视频二区| 欧美高清在线一区| 久久久久国产精品厨房| www国产精品av| 欧美tk—视频vk| 日韩一级免费一区| 欧美精品一区二区三区蜜桃 | 国产欧美日韩在线| 亚洲三级在线免费| 久久亚洲二区三区| 久久免费电影网| 久久久www成人免费毛片麻豆 | 99精品视频一区二区| www.日韩av| 成人av网在线| 99久久综合色| 色婷婷亚洲精品| 欧美日韩美女一区二区| 欧美老女人第四色| 91精品婷婷国产综合久久| 91精品国产高清一区二区三区| 欧美绝品在线观看成人午夜影视| 欧美日韩在线一区二区| 欧美一区二区国产| 久久久久亚洲蜜桃| 一区二区中文字幕在线| 亚洲精品写真福利| 五月天视频一区| 麻豆精品视频在线观看| 国产一区二区三区香蕉| 国产成人精品在线看| av不卡免费电影| 91.xcao| 欧美精品一区视频| 亚洲精品中文在线影院| 午夜一区二区三区在线观看| 秋霞成人午夜伦在线观看| 国产伦精品一区二区三区免费| 成人福利视频网站| 欧美性大战久久| 精品福利一二区| 一区二区在线观看免费| 日本欧美一区二区三区乱码 | 91麻豆免费在线观看| 久久久国际精品| 日韩伦理av电影| 日韩影院免费视频| 国产福利91精品| 欧美乱妇一区二区三区不卡视频 | 色婷婷国产精品综合在线观看| 宅男在线国产精品| 国产精品你懂的| 男人的j进女人的j一区| 91麻豆.com| 精品成a人在线观看| 亚洲电影第三页| 成人免费黄色在线| 日韩午夜精品电影| 夜夜操天天操亚洲|