CQエレクトロニクス・セミナ「実習・マイコンを動かしながら学ぶディジタル・フィルタ」で使うプログラム.雛形として使う. http://seminar.cqpub.co.jp/ccm/ES18-0020
Dependencies: F746_GUI F746_SAI_IO mbed
Diff: main.cpp
- Revision:
- 0:b6d17af0f47a
- Child:
- 1:d9fdd52ea43a
diff -r 000000000000 -r b6d17af0f47a main.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/main.cpp Fri Sep 29 12:50:44 2017 +0000 @@ -0,0 +1,67 @@ +//----------------------------------------------------------------- +// ディジタルフィルタ実験のためのプラットフォーム(標本化周波数:48 kHz) +// ---- 入出力信号の波形表示付き ---- +// +// このプログラムでは,例として定数乗算器を実装している +// +// 使用しているライブラリのリビジョン: +// mbed Rev.151 +// BSP_DISCO_F746NG Rev.9 +// +// 2017/09/29, Copyright (c) 2017 MIKAMI, Naoki +//----------------------------------------------------------------- + +#include "SAI_InOut.hpp" +#include "LcdPanelFrq.hpp" + +//----------------------------------------------------------------- +// 実行するフィルタに応じて以下のインクルードファイルを変更する +#include "Multiplier.hpp" // 入力を定数倍して出力する処理 +//----------------------------------------------------------------- + +int main() +{ + const int FS = I2S_AUDIOFREQ_48K; // 標本化周波数:48 kHz + // オーディオ信号出力用 + SaiIO mySai(SaiIO::OUTPUT, 2048, FS); + + // LCD パネル表示用 + LcdPanel myPanel(1.0f/(float)FS); + + //----------------------------------------------------------------- + // ここでディジタルフィルタのオブジェクト生成や初期化などを行う + Multiplier df(-0.5f); // 定数乗算の処理 + //----------------------------------------------------------------- + + mySai.PlayOut(); // オーディオ信号出力開始 + + const float MAX_AMP = 10000.0f; + float phi = 0; + + while (true) // 無限ループ + { + // 出力バッファへの転送が完了したら以下の処理を行う + if (mySai.IsXferred()) + { + for (int n=0; n<mySai.GetLength(); n++) + { + // 入力信号の生成 + float sn = sinf(phi); // 入力信号となる正弦波を発生 + + int16_t xn = (int16_t)(MAX_AMP*sn); + //------------------------------------------------------ + // ディジタルフィルタなどの信号処理の実行 + int16_t yn = df.Execute(xn); + //------------------------------------------------------ + mySai.Output(xn, yn); // xn:入力(左チャンネル) + // yn:出力(右チャンネル) + + phi = myPanel.GetPhi(); // phi の更新 + myPanel.Store(xn, yn, n); // 表示用として格納 + } + + myPanel.Display(); // 入出力信号の波形表示 + } + myPanel.Update(); // パネルの状態を読み取り必要なパラメータなどを更新する + } +}