FFT アナライザ このプログラムの説明は,CQ出版社「トランジスタ技術」の2021年10月号から開始された連載記事「STM32マイコンではじめるPC計測」の中にあります.このプログラムといっしょに使うPC側のプログラムについても同誌を参照してください.
Dependencies: Array_Matrix mbed SerialTxRxIntr DSP_ADDA UIT_FFT_Real Window
MSeq16.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 | 1:d9dbfbe95c8d | 2 | // M 系列信号発生器(N = 16) |
MikamiUitOpen | 0:e5fc70976c00 | 3 | // |
MikamiUitOpen | 1:d9dbfbe95c8d | 4 | // 2021/09/28, Copyright (c) 2021 MIKAMI, Naoki |
MikamiUitOpen | 0:e5fc70976c00 | 5 | //--------------------------------------------------------- |
MikamiUitOpen | 0:e5fc70976c00 | 6 | |
MikamiUitOpen | 0:e5fc70976c00 | 7 | #include "mbed.h" |
MikamiUitOpen | 0:e5fc70976c00 | 8 | |
MikamiUitOpen | 0:e5fc70976c00 | 9 | #ifndef MSEQ16_HPP |
MikamiUitOpen | 0:e5fc70976c00 | 10 | #define MSEQ16_HPP |
MikamiUitOpen | 0:e5fc70976c00 | 11 | |
MikamiUitOpen | 0:e5fc70976c00 | 12 | namespace Mikami |
MikamiUitOpen | 0:e5fc70976c00 | 13 | { |
MikamiUitOpen | 1:d9dbfbe95c8d | 14 | class MSeq16 |
MikamiUitOpen | 1:d9dbfbe95c8d | 15 | { |
MikamiUitOpen | 1:d9dbfbe95c8d | 16 | public: |
MikamiUitOpen | 1:d9dbfbe95c8d | 17 | MSeq16() : reg_(1) {} |
MikamiUitOpen | 0:e5fc70976c00 | 18 | |
MikamiUitOpen | 1:d9dbfbe95c8d | 19 | // 戻り値: 0 => -0.5, 1 => 0.5 |
MikamiUitOpen | 1:d9dbfbe95c8d | 20 | float Execute() |
MikamiUitOpen | 1:d9dbfbe95c8d | 21 | { |
MikamiUitOpen | 1:d9dbfbe95c8d | 22 | msb_ = reg_ >> 15; |
MikamiUitOpen | 1:d9dbfbe95c8d | 23 | reg_ = ((reg_ ^ XOR_[msb_]) << 1) | msb_; |
MikamiUitOpen | 1:d9dbfbe95c8d | 24 | return RET_[msb_]; |
MikamiUitOpen | 1:d9dbfbe95c8d | 25 | } |
MikamiUitOpen | 1:d9dbfbe95c8d | 26 | private: |
MikamiUitOpen | 1:d9dbfbe95c8d | 27 | static const uint16_t XOR_[2]; // XOR の一方の入力 |
MikamiUitOpen | 1:d9dbfbe95c8d | 28 | static const float RET_[2]; // 戻り値として使用 |
MikamiUitOpen | 1:d9dbfbe95c8d | 29 | uint16_t reg_; // 16 段の D フリップ・フロップに対応 |
MikamiUitOpen | 1:d9dbfbe95c8d | 30 | uint16_t msb_; // 16 段目に相当するビット |
MikamiUitOpen | 1:d9dbfbe95c8d | 31 | }; |
MikamiUitOpen | 1:d9dbfbe95c8d | 32 | const uint16_t MSeq16::XOR_[2] = { 0, 0x16 }; |
MikamiUitOpen | 1:d9dbfbe95c8d | 33 | const float MSeq16::RET_[2] = { -0.5f, 0.5f }; |
MikamiUitOpen | 0:e5fc70976c00 | 34 | } |
MikamiUitOpen | 1:d9dbfbe95c8d | 35 | #endif // MSEQ16_HPP |