FFT アナライザ このプログラムの説明は,CQ出版社「トランジスタ技術」の2021年10月号から開始された連載記事「STM32マイコンではじめるPC計測」の中にあります.このプログラムといっしょに使うPC側のプログラムについても同誌を参照してください.
Dependencies: Array_Matrix mbed SerialTxRxIntr DSP_ADDA UIT_FFT_Real Window
MyFFT_Analyzer/FFT_Analyzer.cpp
- Committer:
- MikamiUitOpen
- Date:
- 2021-11-03
- Revision:
- 1:d9dbfbe95c8d
- Parent:
- 0:e5fc70976c00
File content as of revision 1:d9dbfbe95c8d:
//------------------------------------------------------- // FFT を使ってスペクトル解析を行うクラス // // 2021/05/22, Copyright (c) 2021 MIKAMI, Naoki //------------------------------------------------------- #include "FFT_Analyzer.hpp" namespace Mikami { FftAnalyzer::FftAnalyzer(int nFft) : N_FFT_(nFft), fft_(nFft), wBlk_(nFft), xData_(nFft), wData_(nFft), yFft_(nFft/2+1) {} void FftAnalyzer::Execute(const Array<float> &xn, Array<float> &absFt) { xData_ = xn; // データを作業領域にコピー // 直流分を除去 float sum = 0; for (int n=0; n<N_FFT_; n++) sum = sum + xData_[n]; float ave = sum/N_FFT_; for (int n=0; n<N_FFT_; n++) xData_[n] = xData_[n] - ave; wData_ = wBlk_.Execute(xData_); // 窓掛け fft_.Execute(wData_, yFft_); // FFT の実行 for (int n=0; n<=N_FFT_/2; n++) // 絶対値に変換 absFt[n] = 100.0f*abs(yFft_[n]); } }