FFT アナライザ このプログラムの説明は,CQ出版社「トランジスタ技術」の2021年10月号から開始された連載記事「STM32マイコンではじめるPC計測」の中にあります.このプログラムといっしょに使うPC側のプログラムについても同誌を参照してください.

Dependencies:   Array_Matrix mbed SerialTxRxIntr DSP_ADDA UIT_FFT_Real Window

Committer:
MikamiUitOpen
Date:
Thu Sep 09 08:52:33 2021 +0000
Revision:
0:e5fc70976c00
Child:
1:d9dbfbe95c8d
1

Who changed what in which revision?

UserRevisionLine numberNew contents of line
MikamiUitOpen 0:e5fc70976c00 1 //---------------------------------------------------------
MikamiUitOpen 0:e5fc70976c00 2 // M 系列信号発生器(N = 16)
MikamiUitOpen 0:e5fc70976c00 3 //
MikamiUitOpen 0:e5fc70976c00 4 // 2020/10/17, Copyright (c) 2020 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 0:e5fc70976c00 14 class MSeq16
MikamiUitOpen 0:e5fc70976c00 15 {
MikamiUitOpen 0:e5fc70976c00 16 public:
MikamiUitOpen 0:e5fc70976c00 17 MSeq16() : reg_(1) {}
MikamiUitOpen 0:e5fc70976c00 18
MikamiUitOpen 0:e5fc70976c00 19 // 戻り値: 1 => 1, 0 => -1
MikamiUitOpen 0:e5fc70976c00 20 int Execute()
MikamiUitOpen 0:e5fc70976c00 21 {
MikamiUitOpen 0:e5fc70976c00 22 if ((reg_ & B_M_) == B_M_)
MikamiUitOpen 0:e5fc70976c00 23 {
MikamiUitOpen 0:e5fc70976c00 24 reg_ = ((reg_ ^ XOR_) << 1) | 1; // 1 の場合の処理
MikamiUitOpen 0:e5fc70976c00 25 return 1;
MikamiUitOpen 0:e5fc70976c00 26 }
MikamiUitOpen 0:e5fc70976c00 27 else
MikamiUitOpen 0:e5fc70976c00 28 {
MikamiUitOpen 0:e5fc70976c00 29 reg_ = reg_ << 1; // 0 の場合の処理
MikamiUitOpen 0:e5fc70976c00 30 return -1;
MikamiUitOpen 0:e5fc70976c00 31 }
MikamiUitOpen 0:e5fc70976c00 32 }
MikamiUitOpen 0:e5fc70976c00 33 private:
MikamiUitOpen 0:e5fc70976c00 34 static const uint16_t XOR_ = (1 << (2-1))
MikamiUitOpen 0:e5fc70976c00 35 | (1 << (3-1))
MikamiUitOpen 0:e5fc70976c00 36 | (1 << (5-1)); // XOR の位置に対応する定数
MikamiUitOpen 0:e5fc70976c00 37 static const uint16_t B_M_ = 1 << (16-1); // 16 段目に相当するビットを調べる
MikamiUitOpen 0:e5fc70976c00 38
MikamiUitOpen 0:e5fc70976c00 39 uint16_t reg_;
MikamiUitOpen 0:e5fc70976c00 40 };
MikamiUitOpen 0:e5fc70976c00 41 }
MikamiUitOpen 0:e5fc70976c00 42 #endif // MSEQ16_HPP