FFT アナライザ このプログラムの説明は,CQ出版社「トランジスタ技術」の2021年10月号から開始された連載記事「STM32マイコンではじめるPC計測」の中にあります.このプログラムといっしょに使うPC側のプログラムについても同誌を参照してください.
Dependencies: Array_Matrix mbed SerialTxRxIntr DSP_ADDA UIT_FFT_Real Window
XferSpectrum.hpp@1:d9dbfbe95c8d, 2021-11-03 (annotated)
- Committer:
- MikamiUitOpen
- Date:
- Wed Nov 03 01:29:16 2021 +0000
- Revision:
- 1:d9dbfbe95c8d
- Parent:
- 0:e5fc70976c00
2
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
MikamiUitOpen | 0:e5fc70976c00 | 1 | //--------------------------------------------------------------------- |
MikamiUitOpen | 0:e5fc70976c00 | 2 | // スペクトル解析の結果を PC へ転送するための XferBase の派生クラス |
MikamiUitOpen | 0:e5fc70976c00 | 3 | // |
MikamiUitOpen | 0:e5fc70976c00 | 4 | // 2021/07/11, Copyright (c) 2021 MIKAMI, Naoki |
MikamiUitOpen | 0:e5fc70976c00 | 5 | //--------------------------------------------------------------------- |
MikamiUitOpen | 0:e5fc70976c00 | 6 | |
MikamiUitOpen | 0:e5fc70976c00 | 7 | #include "XferBase.hpp" |
MikamiUitOpen | 0:e5fc70976c00 | 8 | |
MikamiUitOpen | 0:e5fc70976c00 | 9 | #ifndef XFER_SPECTRUM_DERIVED_HPP |
MikamiUitOpen | 0:e5fc70976c00 | 10 | #define XFER_SPECTRUM_DERIVED_HPP |
MikamiUitOpen | 0:e5fc70976c00 | 11 | |
MikamiUitOpen | 0:e5fc70976c00 | 12 | class XferSpectrum : public XferBase |
MikamiUitOpen | 0:e5fc70976c00 | 13 | { |
MikamiUitOpen | 0:e5fc70976c00 | 14 | public: |
MikamiUitOpen | 0:e5fc70976c00 | 15 | // コンストラクタ |
MikamiUitOpen | 0:e5fc70976c00 | 16 | XferSpectrum(SerialRxTxIntr& rxTx, int size) |
MikamiUitOpen | 0:e5fc70976c00 | 17 | : XferBase(rxTx, size) {} |
MikamiUitOpen | 0:e5fc70976c00 | 18 | |
MikamiUitOpen | 0:e5fc70976c00 | 19 | private: |
MikamiUitOpen | 0:e5fc70976c00 | 20 | // スペクトル解析の結果を転送する形式に変換 |
MikamiUitOpen | 0:e5fc70976c00 | 21 | // yAbs FFT の結果の絶対値 |
MikamiUitOpen | 0:e5fc70976c00 | 22 | virtual void Convert(const float yAbs[]) |
MikamiUitOpen | 0:e5fc70976c00 | 23 | { |
MikamiUitOpen | 0:e5fc70976c00 | 24 | const float MAX = 10000; |
MikamiUitOpen | 0:e5fc70976c00 | 25 | for (int n=0; n<SIZE_; n++) |
MikamiUitOpen | 0:e5fc70976c00 | 26 | { |
MikamiUitOpen | 0:e5fc70976c00 | 27 | float x = yAbs[n]; |
MikamiUitOpen | 0:e5fc70976c00 | 28 | xn_[n] = (x > MAX) ? (uint16_t)MAX : (uint16_t)x; |
MikamiUitOpen | 0:e5fc70976c00 | 29 | } |
MikamiUitOpen | 0:e5fc70976c00 | 30 | } |
MikamiUitOpen | 0:e5fc70976c00 | 31 | |
MikamiUitOpen | 0:e5fc70976c00 | 32 | // コピー・コンストラクタおよび代入演算子の禁止のため |
MikamiUitOpen | 0:e5fc70976c00 | 33 | XferSpectrum(const XferSpectrum&); |
MikamiUitOpen | 0:e5fc70976c00 | 34 | XferSpectrum& operator=(const XferSpectrum&); |
MikamiUitOpen | 0:e5fc70976c00 | 35 | }; |
MikamiUitOpen | 0:e5fc70976c00 | 36 | #endif // XFER_SPECTRUM_DERIVED_HPP |