2014-04-12 01:11:33 -03:00
|
|
|
// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*-
|
|
|
|
|
|
|
|
#ifndef __AP_AUTOTUNE_H__
|
|
|
|
#define __AP_AUTOTUNE_H__
|
|
|
|
|
|
|
|
#include <AP_HAL.h>
|
|
|
|
#include <AP_Param.h>
|
2014-04-12 05:21:50 -03:00
|
|
|
#include <DataFlash.h>
|
2014-04-12 01:11:33 -03:00
|
|
|
|
|
|
|
class AP_AutoTune {
|
|
|
|
public:
|
|
|
|
struct ATGains {
|
|
|
|
AP_Float tau;
|
|
|
|
AP_Float P;
|
|
|
|
AP_Float I;
|
|
|
|
AP_Float D;
|
|
|
|
AP_Int16 rmax;
|
|
|
|
AP_Int16 imax;
|
|
|
|
};
|
|
|
|
|
2014-04-12 05:21:50 -03:00
|
|
|
enum ATType {
|
|
|
|
AUTOTUNE_ROLL = 0,
|
|
|
|
AUTOTUNE_PITCH = 1
|
|
|
|
};
|
|
|
|
|
2014-04-12 01:11:33 -03:00
|
|
|
// constructor
|
2014-04-12 05:21:50 -03:00
|
|
|
AP_AutoTune(ATGains &_gains, ATType type, DataFlash_Class &_dataflash);
|
2014-04-12 01:11:33 -03:00
|
|
|
|
|
|
|
// called when autotune mode is entered
|
|
|
|
void start(void);
|
|
|
|
|
|
|
|
// called to stop autotune and restore gains when user leaves
|
|
|
|
// autotune
|
|
|
|
void stop(void);
|
|
|
|
|
|
|
|
// update called whenever autotune mode is active. This is
|
|
|
|
// typically at 50Hz
|
|
|
|
void update(float desired_rate, float achieved_rate, float servo_out);
|
|
|
|
|
|
|
|
// are we running?
|
|
|
|
bool running:1;
|
|
|
|
|
|
|
|
private:
|
|
|
|
// the current gains
|
|
|
|
ATGains ¤t;
|
|
|
|
|
2014-04-12 05:21:50 -03:00
|
|
|
// what type of autotune is this
|
|
|
|
ATType type;
|
|
|
|
|
|
|
|
DataFlash_Class &dataflash;
|
|
|
|
|
2014-04-12 01:11:33 -03:00
|
|
|
// did we saturate surfaces?
|
|
|
|
bool saturated_surfaces:1;
|
|
|
|
|
2014-04-12 05:21:50 -03:00
|
|
|
// have we sent log headers
|
|
|
|
bool logging_started:1;
|
|
|
|
|
2014-04-12 01:11:33 -03:00
|
|
|
// values to restore if we leave autotune mode
|
|
|
|
ATGains restore;
|
|
|
|
|
|
|
|
// values to save on the next save event
|
|
|
|
ATGains next_save;
|
|
|
|
|
|
|
|
// time when we last saved
|
|
|
|
uint32_t last_save_ms;
|
|
|
|
|
|
|
|
// the demanded/achieved state
|
|
|
|
enum ATState {DEMAND_UNSATURATED,
|
|
|
|
DEMAND_UNDER_POS,
|
|
|
|
DEMAND_OVER_POS,
|
|
|
|
DEMAND_UNDER_NEG,
|
|
|
|
DEMAND_OVER_NEG} state;
|
|
|
|
|
|
|
|
// when we entered the current state
|
|
|
|
uint32_t state_enter_ms;
|
|
|
|
|
|
|
|
void check_save(void);
|
|
|
|
void check_state_exit(uint32_t state_time_ms);
|
|
|
|
void save_gains(const ATGains &v);
|
2014-04-12 05:21:50 -03:00
|
|
|
|
|
|
|
void write_log_headers(void);
|
|
|
|
void write_log(int16_t servo, float demanded, float achieved);
|
2014-04-12 01:11:33 -03:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif // __AP_AUTOTUNE_H__
|
|
|
|
|