1次遅れと2次遅れ,ノッチフィルターを実装
Fork of Filter by
Filter.cpp@2:a842c1a33e4f, 2018-01-11 (annotated)
- Committer:
- uenono
- Date:
- Thu Jan 11 07:00:44 2018 +0000
- Revision:
- 2:a842c1a33e4f
- Parent:
- 1:637f9a61b133
- Child:
- 3:987d5d78f863
??????
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
uenono | 0:17706252d1ed | 1 | #include "Filter.h" |
uenono | 0:17706252d1ed | 2 | |
uenono | 1:637f9a61b133 | 3 | Filter::Filter(double xint_time) |
uenono | 0:17706252d1ed | 4 | { |
uenono | 1:637f9a61b133 | 5 | int_time = xint_time; |
uenono | 0:17706252d1ed | 6 | } |
uenono | 0:17706252d1ed | 7 | |
uenono | 0:17706252d1ed | 8 | void Filter::setLowPassPara(double T) |
uenono | 0:17706252d1ed | 9 | { |
uenono | 0:17706252d1ed | 10 | T_LPF = T; |
uenono | 0:17706252d1ed | 11 | } |
uenono | 0:17706252d1ed | 12 | |
uenono | 0:17706252d1ed | 13 | double Filter::LowPassFilter(double input) |
uenono | 0:17706252d1ed | 14 | { |
uenono | 0:17706252d1ed | 15 | static double preOutput = 0.0; |
uenono | 0:17706252d1ed | 16 | |
uenono | 2:a842c1a33e4f | 17 | double Output = (int_time * input + T_LPF * preOutput)/(T_LPF + int_time); |
uenono | 0:17706252d1ed | 18 | |
uenono | 0:17706252d1ed | 19 | preOutput = Output; |
uenono | 0:17706252d1ed | 20 | |
uenono | 0:17706252d1ed | 21 | return Output; |
uenono | 0:17706252d1ed | 22 | } |
uenono | 0:17706252d1ed | 23 | |
uenono | 0:17706252d1ed | 24 | void Filter::setNotchPara(double Omega) |
uenono | 0:17706252d1ed | 25 | { |
uenono | 0:17706252d1ed | 26 | // 落としたい角周波数[rad/s]をOm_nに入れる |
uenono | 0:17706252d1ed | 27 | Om_n = Omega; |
uenono | 0:17706252d1ed | 28 | sq_Om = pow(Om_n, 2.0); // Om_nの2乗 |
uenono | 2:a842c1a33e4f | 29 | sq_dt = pow(int_time, 2.0); // dtの2乗 |
uenono | 0:17706252d1ed | 30 | |
uenono | 0:17706252d1ed | 31 | } |
uenono | 0:17706252d1ed | 32 | |
uenono | 0:17706252d1ed | 33 | double Filter::NotchFilter(double input) |
uenono | 0:17706252d1ed | 34 | { |
uenono | 0:17706252d1ed | 35 | static double preOutput[2] = {0.0, 0.0}; |
uenono | 0:17706252d1ed | 36 | static double preInput[2] = {0.0, 0.0}; |
uenono | 0:17706252d1ed | 37 | |
uenono | 2:a842c1a33e4f | 38 | double Output = (2*(1 + Om_n * int_time) * preOutput[0]-preOutput[1] + (1 + sq_Om * sq_dt) * input -2 * preInput[0] + preInput[1]) / (1 + 2 * Om_n * int_time + sq_Om * sq_dt); |
uenono | 0:17706252d1ed | 39 | |
uenono | 0:17706252d1ed | 40 | preInput[1] = preInput[0]; |
uenono | 0:17706252d1ed | 41 | preInput[0] = input; |
uenono | 0:17706252d1ed | 42 | |
uenono | 0:17706252d1ed | 43 | preOutput[1] = preOutput[0]; |
uenono | 0:17706252d1ed | 44 | preOutput[0] = Output; |
uenono | 0:17706252d1ed | 45 | |
uenono | 0:17706252d1ed | 46 | return Output; |
uenono | 0:17706252d1ed | 47 | } |