mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-10 09:58:28 -04:00
Tools: support triple notch in FilterTool
This commit is contained in:
parent
c29b390e7b
commit
6eb406b2d6
@ -161,8 +161,14 @@ function HarmonicNotchFilter(sample_freq,enable,mode,freq,bw,att,ref,fm_rat,hmnc
|
|||||||
this.notches = []
|
this.notches = []
|
||||||
var chained = 1;
|
var chained = 1;
|
||||||
var dbl = false;
|
var dbl = false;
|
||||||
|
var triple = false;
|
||||||
|
var composite_notches = 1;
|
||||||
if (opts & 1) {
|
if (opts & 1) {
|
||||||
dbl = true;
|
dbl = true;
|
||||||
|
composite_notches = 2;
|
||||||
|
} else if (opts & 16) {
|
||||||
|
triple = true;
|
||||||
|
composite_notches = 3;
|
||||||
}
|
}
|
||||||
|
|
||||||
this.reset = function(sample) {
|
this.reset = function(sample) {
|
||||||
@ -204,22 +210,36 @@ function HarmonicNotchFilter(sample_freq,enable,mode,freq,bw,att,ref,fm_rat,hmnc
|
|||||||
for (var n=0;n<8;n++) {
|
for (var n=0;n<8;n++) {
|
||||||
var fmul = n+1;
|
var fmul = n+1;
|
||||||
if (hmncs & (1<<n)) {
|
if (hmncs & (1<<n)) {
|
||||||
var center_freq_hz = freq * fmul;
|
var notch_center = freq * fmul;
|
||||||
var bandwidth_hz = bw * fmul;
|
var bandwidth_hz = bw * fmul;
|
||||||
for (var c=0; c<chained; c++) {
|
for (var c=0; c<chained; c++) {
|
||||||
var nyquist_limit = sample_freq * 0.48;
|
var nyquist_limit = sample_freq * 0.48;
|
||||||
var bandwidth_limit = bandwidth_hz * 0.52;
|
var bandwidth_limit = bandwidth_hz * 0.52;
|
||||||
// adjust the fundamental center frequency to be in the allowable range
|
|
||||||
center_freq_hz = constrain_float(center_freq_hz, bandwidth_limit, nyquist_limit);
|
|
||||||
// Calculate spread required to achieve an equivalent single notch using two notches with Bandwidth/2
|
// Calculate spread required to achieve an equivalent single notch using two notches with Bandwidth/2
|
||||||
if (dbl) {
|
var notch_spread = bandwidth_hz / (32.0 * notch_center);
|
||||||
var notch_spread = bandwidth_hz / (32.0 * center_freq_hz);
|
|
||||||
var notch_center1 = center_freq_hz * (1.0 - notch_spread);
|
// adjust the fundamental center frequency to be in the allowable range
|
||||||
var notch_center2 = center_freq_hz * (1.0 + notch_spread);
|
notch_center = constrain_float(notch_center, bandwidth_limit, nyquist_limit);
|
||||||
this.notches.push(new NotchFilter(sample_freq,notch_center1,bandwidth_hz*0.5,att));
|
|
||||||
this.notches.push(new NotchFilter(sample_freq,notch_center2,bandwidth_hz*0.5,att));
|
if (composite_notches != 2) {
|
||||||
} else {
|
// only enable the filter if its center frequency is below the nyquist frequency
|
||||||
this.notches.push(new NotchFilter(sample_freq,center_freq_hz,bandwidth_hz,att));
|
if (notch_center < nyquist_limit) {
|
||||||
|
this.notches.push(new NotchFilter(sample_freq,notch_center,bandwidth_hz/composite_notches,att));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (composite_notches > 1) {
|
||||||
|
var notch_center_double;
|
||||||
|
// only enable the filter if its center frequency is below the nyquist frequency
|
||||||
|
notch_center_double = notch_center * (1.0 - notch_spread);
|
||||||
|
if (notch_center_double < nyquist_limit) {
|
||||||
|
this.notches.push(new NotchFilter(sample_freq,notch_center_double,bandwidth_hz/composite_notches,att));
|
||||||
|
}
|
||||||
|
// only enable the filter if its center frequency is below the nyquist frequency
|
||||||
|
notch_center_double = notch_center * (1.0 + notch_spread);
|
||||||
|
if (notch_center_double < nyquist_limit) {
|
||||||
|
this.notches.push(new NotchFilter(sample_freq,notch_center_double,bandwidth_hz/composite_notches,att));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -572,6 +592,9 @@ function fill_docs()
|
|||||||
if (ival & 8) {
|
if (ival & 8) {
|
||||||
bits.push("All IMUs Rate");
|
bits.push("All IMUs Rate");
|
||||||
}
|
}
|
||||||
|
if ((ival & 16) && (ival & 1) == 0) {
|
||||||
|
bits.push("Triple Notch");
|
||||||
|
}
|
||||||
doc.innerHTML = bits.join(", ");
|
doc.innerHTML = bits.join(", ");
|
||||||
} else if (name.endsWith("_HMNCS")) {
|
} else if (name.endsWith("_HMNCS")) {
|
||||||
var ival = Math.floor(value);
|
var ival = Math.floor(value);
|
||||||
|
Loading…
Reference in New Issue
Block a user