Skip to content

Commit

Permalink
allow for disabling the dynamic notch
Browse files Browse the repository at this point in the history
  • Loading branch information
bkleiner committed Nov 5, 2023
1 parent 7e8b9f9 commit a81d638
Show file tree
Hide file tree
Showing 3 changed files with 20 additions and 13 deletions.
1 change: 1 addition & 0 deletions src/core/profile.c
Original file line number Diff line number Diff line change
Expand Up @@ -258,6 +258,7 @@ const profile_t default_profile = {
#ifdef DTERM_DYNAMIC_FREQ_MAX
.dterm_dynamic_max = DTERM_DYNAMIC_FREQ_MAX,
#endif
.gyro_dynamic_notch_enable = 0,
},

.rate = {
Expand Down
4 changes: 3 additions & 1 deletion src/core/profile.h
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@

#define OSD_NUMBER_ELEMENTS 32

#define PROFILE_VERSION MAKE_SEMVER(0, 2, 2)
#define PROFILE_VERSION MAKE_SEMVER(0, 2, 3)

// Rates
typedef enum {
Expand Down Expand Up @@ -312,6 +312,7 @@ typedef struct {
uint8_t dterm_dynamic_enable;
float dterm_dynamic_min;
float dterm_dynamic_max;
uint8_t gyro_dynamic_notch_enable;
} profile_filter_t;

#define FILTER_MEMBERS \
Expand All @@ -321,6 +322,7 @@ typedef struct {
MEMBER(dterm_dynamic_enable, uint8_t) \
MEMBER(dterm_dynamic_min, float) \
MEMBER(dterm_dynamic_max, float) \
MEMBER(gyro_dynamic_notch_enable, uint8_t) \
END_STRUCT()

typedef struct {
Expand Down
28 changes: 16 additions & 12 deletions src/flight/sixaxis.c
Original file line number Diff line number Diff line change
Expand Up @@ -143,26 +143,30 @@ void sixaxis_read() {
state.gyro.axis[2] = state.gyro_raw.axis[2] = -state.gyro_raw.axis[2] * GYRO_RANGE * DEGTORAD;

for (uint32_t i = 0; i < 3; i++) {
static uint8_t axis_needs_update = 0;
if (sdft_push(&gyro_sdft[i], state.gyro.axis[i]) && axis_needs_update == 0) {
axis_needs_update = 3;
}
if (profile.filter.gyro_dynamic_notch_enable) {
static uint8_t axis_needs_update = 0;
if (sdft_push(&gyro_sdft[i], state.gyro.axis[i]) && axis_needs_update == 0) {
axis_needs_update = 3;
}

if ((axis_needs_update - 1) == i && sdft_update(&gyro_sdft[i])) {
for (uint32_t p = 0; p < SDFT_PEAKS; p++) {
filter_biquad_notch_coeff(&notch_filter[i][p], gyro_sdft[i].notch_hz[p]);
if ((axis_needs_update - 1) == i && sdft_update(&gyro_sdft[i])) {
for (uint32_t p = 0; p < SDFT_PEAKS; p++) {
filter_biquad_notch_coeff(&notch_filter[i][p], gyro_sdft[i].notch_hz[p]);
}
axis_needs_update--;
}
axis_needs_update--;
}

state.gyro.axis[i] = filter_step(profile.filter.gyro[0].type, &filter[0], &filter_state[0][i], state.gyro.axis[i]);
state.gyro.axis[i] = filter_step(profile.filter.gyro[1].type, &filter[1], &filter_state[1][i], state.gyro.axis[i]);

for (uint32_t p = 0; p < SDFT_PEAKS; p++) {
if (i == 0) {
blackbox_set_debug(p, gyro_sdft[i].notch_hz[p]);
if (profile.filter.gyro_dynamic_notch_enable) {
for (uint32_t p = 0; p < SDFT_PEAKS; p++) {
if (i == 0) {
blackbox_set_debug(p, gyro_sdft[i].notch_hz[p]);
}
state.gyro.axis[i] = filter_biquad_notch_step(&notch_filter[i][p], &notch_filter_state[i][p], state.gyro.axis[i]);
}
state.gyro.axis[i] = filter_biquad_notch_step(&notch_filter[i][p], &notch_filter_state[i][p], state.gyro.axis[i]);
}
}

Expand Down

0 comments on commit a81d638

Please sign in to comment.