Realtime spectrum analyzer. Using FFT, linear prediction, or cepstrum smoothing. Version using MEMS microphone and CODEC, named "F746_RealtimeSpectrumAnalyzer_MEMS_Mic" is registered. リアルタイム スペクトル解析器.解析の手法:FFT,線形予測法,ケプストラムによる平滑化の3種類.このプログラムの説明は,CQ出版社のインターフェース誌,2016年4月号に掲載.外付けのマイクまたは他の信号源等を A0 に接続する.線形予測法,ケプストラムは,スペクトル解析の対象を音声信号に想定してパラメータを設定している.MEMS マイクと CODEC を使ったバージョンを "F746_RealtimeSpectrumAnalyzer_MEMS_Mic" として登録.

Dependencies:   BSP_DISCO_F746NG BUTTON_GROUP LCD_DISCO_F746NG TS_DISCO_F746NG UIT_FFT_Real mbed

Revision:
13:92ac49e48697
Parent:
11:a8420871920e
Child:
14:cd4534fb34e7
--- a/main.cpp	Thu Dec 31 12:03:06 2015 +0000
+++ b/main.cpp	Thu Dec 31 12:47:28 2015 +0000
@@ -13,7 +13,6 @@
 
 int main()
 {
-    printf("\r\n20:12");
     const int N_DATA = 260; // Number of data to be analyzed
     const int N_FFT = 512;  // Number of date for FFT
     const int X_WAV = 44;   // Origin for x axis of waveform
@@ -79,11 +78,9 @@
     int inv = 0;    // 0: "NORM", 1: "INV"
     int select = -1;
     int stop = 0;
-//    input.Start(inv == 1);
     
     while (true)
     {
-//        runStop.GetTouchedNumber(stop, TOUCHED_COLOR);
         if (runStop.GetTouchedNumber(stop, TOUCHED_COLOR))
             if (stop == 0) input.Start(inv == 1);
         if (stop == 0)
@@ -107,10 +104,9 @@
         }            
         else
         {
-            input.Stop();
-            // Check "STOP" button touched
-////            if (runStop.Touched(1, TOUCHED_COLOR))
-            normInv.DrawAll(INACTIVE_COLOR, INACTIVE_TEXT_COLOR);
+            input.Stop();   // Stop timer interrupt
+            if (runStop.Touched(1))
+                normInv.DrawAll(INACTIVE_COLOR, INACTIVE_TEXT_COLOR);
             if (method.GetTouchedNumber(select, TOUCHED_COLOR))
                 analyzer.Execute(sn, select);
         }