Version using MEMS microphone and CODEC for the program "F746_RealtimeSpectrumAnalyzer". "F746_RealtimeSpectrumAnalyzer" の入力を MEMS のマイクと CODEC に変更.このプログラムは Tomona Nanase さんが作成し DISCO-F746NG_Oscilloscope の名前で登録しているプログラムで, CODEC を使って入力する部分を参考にして作成.このプログラムの説明は,CQ出版社のインターフェース誌,2016年4月号に掲載.

Dependencies:   BSP_DISCO_F746NG BUTTON_GROUP LCD_DISCO_F746NG TS_DISCO_F746NG UIT_FFT_Real mbed

Embed: (wiki syntax)

« Back to documentation index

Show/hide line numbers FFT_Analysis.cpp Source File

FFT_Analysis.cpp

00001 //-------------------------------------------------------
00002 //  Class for spectrum analysis using FFT
00003 //
00004 //  2015/12/15, Copyright (c) 2015 MIKAMI, Naoki
00005 //-------------------------------------------------------
00006 
00007 #include "FFT_Analysis.hpp"
00008 
00009 namespace Mikami
00010 {
00011     FftAnalyzer::FftAnalyzer(int nData, int nFft)
00012         : AnalyzerBase(nData, nFft, nFft),
00013           yFft_(new Complex[nFft/2+1]) {}
00014 
00015     FftAnalyzer::~FftAnalyzer()
00016     {
00017         delete[] yFft_;
00018     }
00019 
00020     void FftAnalyzer::Analyze(const float xn[], float yn[])
00021     {
00022         fft_.Execute(xn, yFft_);    // Execute FFT
00023         
00024         // Translate to dB
00025         for (int n=0; n<=N_FFT_/2; n++)
00026             yn[n] = 10.0f*log10f(Norm(yFft_[n]));
00027     }
00028 }