save progress

This commit is contained in:
vadyschka01
2026-05-06 17:01:03 +03:00
parent 4d694ecf43
commit e5ca7f608a
38 changed files with 773 additions and 552 deletions
+27 -3
View File
@@ -10,18 +10,42 @@ typedef struct {
float d1, d2;
} biquad_t;
// Делаем фильтры видимыми для dsp_manager
extern biquad_t notch1, notch2, notch3;
// Старые фильтры notch1,2,3 удалены (использовалась только FMAC с notch_fmac_coeffs[3])
// extern biquad_t notch1, notch2, notch3;
// Прототипы
void I2C1_Init(void);
void IMU_Init(void);
void IMU_Calibrate(void);
void IMU_ReadRawData(void);
void biquad_init_notch(biquad_t *f, float center_freq, float Q, float fs);
// biquad_init_notch удалена (заменена на Update_FMAC_Coeffs в dsp_manager)
// Данные
extern volatile int16_t raw_gx; // Нам для анализа нужен только GX
extern float filt_gx;
// Добавить в imu.h
typedef struct {
int16_t b0, b1, b2; // Коэффициенты числителя
int16_t a1, a2; // Коэффициенты знаменателя (инвертированные для FMAC)
} fmac_weights_t;
void FMAC_Init(void);
float FMAC_Process_Sample(float input);
void Update_FMAC_Coeffs(int stage, float b0, float b1, float b2, float a1, float a2);
typedef struct {
int16_t b0, b1, b2;
int16_t a1, a2;
} fmac_coeffs_t;
typedef struct {
int16_t x1, x2; // История входов (x[n-1], x[n-2])
int16_t y1, y2; // История выходов (y[n-1], y[n-2])
} fmac_state_t;
// Внешние структуры для 3-х каскадов
extern fmac_coeffs_t notch_fmac_coeffs[3];
extern fmac_state_t notch_fmac_state[3];
#endif