Nucleo-F446RE 内蔵の AD/DA を使うためのライブラリ.DA からの出力は,標本化周波数の4倍のレートで行う.  このライブラリを登録した際のプログラム: Demo_F446_AD_DA_Multirate. Library for built-in ADC and DAC in Nucleo-F446RE. Sampling rate for DAC is four times of that for ADC.

Dependencies:   Array_Matrix

Dependents:   F446_UpSampling_GraphicEqualizer F446_UpSampling_ReverbSystem F446_UpSampling_FrqShifter_Weaver Demo_F446_AD_DA_Multirate ... more

Committer:
MikamiUitOpen
Date:
Wed May 30 09:09:04 2018 +0000
Revision:
3:285cebe5823c
Parent:
2:b55ae17ffd92
Child:
4:c853feefa216
4

Who changed what in which revision?

UserRevisionLine numberNew contents of line
MikamiUitOpen 0:2447a7d225b1 1 //---------------------------------------------------
MikamiUitOpen 0:2447a7d225b1 2 // 出力を 4 倍にアップサンプリングするクラス(ヘッダ)
MikamiUitOpen 0:2447a7d225b1 3 // Nucleo-F446RE 専用
MikamiUitOpen 0:2447a7d225b1 4 //
MikamiUitOpen 0:2447a7d225b1 5 // 入力端子: A0 (PA_0)
MikamiUitOpen 0:2447a7d225b1 6 // 出力端子: A2 (PA_4)
MikamiUitOpen 0:2447a7d225b1 7 //
MikamiUitOpen 3:285cebe5823c 8 // 2018/05/30, Copyright (c) 2018 MIKAMI, Naoki
MikamiUitOpen 0:2447a7d225b1 9 //---------------------------------------------------
MikamiUitOpen 0:2447a7d225b1 10
MikamiUitOpen 0:2447a7d225b1 11 #include "mbed.h"
MikamiUitOpen 0:2447a7d225b1 12 #include "F446_ADC.hpp"
MikamiUitOpen 0:2447a7d225b1 13 #include "F446_DAC.hpp"
MikamiUitOpen 0:2447a7d225b1 14 #include "IIR_Cascade.hpp"
MikamiUitOpen 0:2447a7d225b1 15
MikamiUitOpen 0:2447a7d225b1 16 #ifndef F446_MULTIRATE_HPP
MikamiUitOpen 0:2447a7d225b1 17 #define F446_MULTIRATE_HPP
MikamiUitOpen 0:2447a7d225b1 18
MikamiUitOpen 0:2447a7d225b1 19 namespace Mikami
MikamiUitOpen 0:2447a7d225b1 20 {
MikamiUitOpen 0:2447a7d225b1 21 class F446_Multirate
MikamiUitOpen 0:2447a7d225b1 22 {
MikamiUitOpen 0:2447a7d225b1 23 public:
MikamiUitOpen 0:2447a7d225b1 24 // コンストラクタ
MikamiUitOpen 3:285cebe5823c 25 // コンストラクタの引数を与えない場合はデフォルトのフィルタを使用
MikamiUitOpen 3:285cebe5823c 26 // order = 0 にすると,補間フィルタなしの状態になる
MikamiUitOpen 3:285cebe5823c 27 F446_Multirate(int order = -1, const Biquad::Coefs ck[] = NULL,
MikamiUitOpen 3:285cebe5823c 28 float g0 = 1);
MikamiUitOpen 0:2447a7d225b1 29
MikamiUitOpen 0:2447a7d225b1 30 virtual ~F446_Multirate()
MikamiUitOpen 0:2447a7d225b1 31 {
MikamiUitOpen 0:2447a7d225b1 32 delete adc_;
MikamiUitOpen 0:2447a7d225b1 33 delete interpolator_;
MikamiUitOpen 0:2447a7d225b1 34 }
MikamiUitOpen 0:2447a7d225b1 35
MikamiUitOpen 2:b55ae17ffd92 36 // 標本化の実行開始
MikamiUitOpen 0:2447a7d225b1 37 // frequency: 入力の標本化周波数
MikamiUitOpen 2:b55ae17ffd92 38 void Start(int frequency);
MikamiUitOpen 0:2447a7d225b1 39
MikamiUitOpen 0:2447a7d225b1 40 // AD変換の結果を取り出す
MikamiUitOpen 0:2447a7d225b1 41 float Input();
MikamiUitOpen 0:2447a7d225b1 42
MikamiUitOpen 0:2447a7d225b1 43 // 補間用フィルタを実行し,処理結果を出力用バッファへ書き込む
MikamiUitOpen 0:2447a7d225b1 44 void Output(float yn);
MikamiUitOpen 0:2447a7d225b1 45
MikamiUitOpen 0:2447a7d225b1 46 private:
MikamiUitOpen 0:2447a7d225b1 47 static const int FACTOR_ = 4; // アップサンプリング倍率:4 倍
MikamiUitOpen 0:2447a7d225b1 48 // この倍率は 2 のべき乗にすること
MikamiUitOpen 0:2447a7d225b1 49 static const int MASK_FACTOR_ = FACTOR_ - 1;
MikamiUitOpen 0:2447a7d225b1 50 static const int MASK_BUF_ = 2*FACTOR_ - 1;
MikamiUitOpen 0:2447a7d225b1 51
MikamiUitOpen 0:2447a7d225b1 52 static AdcF446 *adc_; // AD変換器のオブジェクトのポインタ
MikamiUitOpen 0:2447a7d225b1 53 static DacF446 dac_; // DA変換器のオブジェクト
MikamiUitOpen 0:2447a7d225b1 54
MikamiUitOpen 0:2447a7d225b1 55 static Array<float> buf_; // DA変換器に出力するデータ用バッファ
MikamiUitOpen 0:2447a7d225b1 56 int indexW_; // buf_ へ書き込む際のインデックス
MikamiUitOpen 0:2447a7d225b1 57 static int indexR_; // buf_ から読み出す際のインデックス
MikamiUitOpen 0:2447a7d225b1 58 static float xn_; // AD変換器から入力されたデータ
MikamiUitOpen 0:2447a7d225b1 59 static __IO bool okIn_; // AD変換されたデータが使える場合に true となる
MikamiUitOpen 0:2447a7d225b1 60
MikamiUitOpen 3:285cebe5823c 61 // 補間用フィルタ用のメンバ
MikamiUitOpen 3:285cebe5823c 62 static const Biquad::Coefs HK_[]; // biquad 部の係数
MikamiUitOpen 3:285cebe5823c 63 static const float G0_; // 利得定数
MikamiUitOpen 3:285cebe5823c 64 IirCascade *interpolator_; // 補間用フィルタのポインタ
MikamiUitOpen 3:285cebe5823c 65
MikamiUitOpen 0:2447a7d225b1 66 // 引数を 0 ~ (アップサンプリング倍率-1) の間でカウントアップ
MikamiUitOpen 0:2447a7d225b1 67 static inline int ModCounter(int &index)
MikamiUitOpen 0:2447a7d225b1 68 {
MikamiUitOpen 0:2447a7d225b1 69 index = ++index & MASK_BUF_;
MikamiUitOpen 0:2447a7d225b1 70 return index;
MikamiUitOpen 0:2447a7d225b1 71 }
MikamiUitOpen 0:2447a7d225b1 72 // ADC 変換終了割り込みに対する割り込みサービス・ルーチン
MikamiUitOpen 0:2447a7d225b1 73 static void AdcIsr();
MikamiUitOpen 0:2447a7d225b1 74 };
MikamiUitOpen 0:2447a7d225b1 75 }
MikamiUitOpen 0:2447a7d225b1 76 #endif // F446_MULTIRATE_HPP