ノイズを付加した正弦波発生器 Sinusoidal wave generator with noise.
Dependencies: F746_GUI F746_SAI_IO Random mbed
main.cpp
- Committer:
- MikamiUitOpen
- Date:
- 2018-11-04
- Revision:
- 0:31361b0fcdad
File content as of revision 0:31361b0fcdad:
//----------------------------------------------------------------- // 正弦波+ノイズの発生器(標本化周波数:48 kHz) // ノイズの大きさは SeekBar で変えられる // // 使用しているライブラリのリビジョン: // F746_GUI Rev.33 // F746_SAI_IO Rev.12 // mbed Rev.170 // // 2018/11/04, Copyright (c) 2018 MIKAMI, Naoki //----------------------------------------------------------------- #include "SAI_InOut.hpp" #include "LcdPanelFrq.hpp" #include "GaussRand.hpp" int main() { const int FS = I2S_AUDIOFREQ_48K; // 標本化周波数:48 kHz SaiIO mySai(SaiIO::OUTPUT, 2048, FS); // オーディオ信号出力用 LcdPanel myPanel(1.0f/(float)FS); // LCD パネル表示用 GaussRand rnd(0.5f, 0); // ガウス性ノイズ発生器 mySai.PlayOut(); // オーディオ信号出力開始 const float MAX_AMP = 8192.0f; while (true) // 無限ループ { // 出力バッファへの転送が完了したら以下の処理を行う if (mySai.IsXferred()) { for (int n=0; n<mySai.GetLength(); n++) { // 入力信号の生成 float phi = myPanel.GetPhi(); float sn = sinf(phi); // 入力信号となる正弦波を発生 float noize = myPanel.GetNoiseLevel()*rnd.Next(); int16_t xn = (int16_t)(MAX_AMP*sn); int16_t yn = (int16_t)(MAX_AMP*(sn + noize)); mySai.Output(xn, yn); // xn:ノイズなし(左チャンネル) // yn:ノイズ付加(右チャンネル) myPanel.Store(yn, n); // 表示用として格納 } myPanel.Display(); // 入出力信号の波形表示 } myPanel.Update(); // パネルの状態を読み取り必要なパラメータなどを更新する } }