The library for full-state feedback control with integral action

Fork of STATE_FEEDBACK_INTEGRAL by Project_WIPV_antiSlip

Committer:
benson516
Date:
Tue Jan 03 14:58:57 2017 +0000
Revision:
0:37e27f2930a3
Child:
1:f19909200517
The library for full-state feedback control with integral action

Who changed what in which revision?

UserRevisionLine numberNew contents of line
benson516 0:37e27f2930a3 1 #ifndef STATE_FEEDBACK_INTEGRAL_H
benson516 0:37e27f2930a3 2 #define STATE_FEEDBACK_INTEGRAL_H
benson516 0:37e27f2930a3 3 //
benson516 0:37e27f2930a3 4 #include <vector>
benson516 0:37e27f2930a3 5
benson516 0:37e27f2930a3 6 using std::vector;
benson516 0:37e27f2930a3 7
benson516 0:37e27f2930a3 8 class STATE_FEEDBACK_INTEGRAL{
benson516 0:37e27f2930a3 9 public:
benson516 0:37e27f2930a3 10 // Dimensions
benson516 0:37e27f2930a3 11 size_t n; // Number of states
benson516 0:37e27f2930a3 12 size_t p; // Number of inputs of the plant
benson516 0:37e27f2930a3 13 size_t q; // Number of outputs of the plant, no use in full state feed back case
benson516 0:37e27f2930a3 14
benson516 0:37e27f2930a3 15 float Ts; // Sampling time
benson516 0:37e27f2930a3 16
benson516 0:37e27f2930a3 17 // System parameters
benson516 0:37e27f2930a3 18 vector<vector<float> > E_out; // System output matrix
benson516 0:37e27f2930a3 19 // Controller parameters
benson516 0:37e27f2930a3 20 vector<vector<float> > K_full; // Full state feedback gain
benson516 0:37e27f2930a3 21 vector<vector<float> > K_int; // Gain for integral action
benson516 0:37e27f2930a3 22
benson516 0:37e27f2930a3 23
benson516 0:37e27f2930a3 24 // States
benson516 0:37e27f2930a3 25 vector<float> states; // States
benson516 0:37e27f2930a3 26 vector<float> sys_inputs; // The inputs of the plant, "u", the "output" of the controller
benson516 0:37e27f2930a3 27 vector<float> sys_outputs; // The output of the plant, "y", the input of the controller
benson516 0:37e27f2930a3 28 // Command (equalibrium state)
benson516 0:37e27f2930a3 29 vector<float> sys_inputs_compensate; // N_total*r
benson516 0:37e27f2930a3 30 vector<float> command; // r
benson516 0:37e27f2930a3 31 // Integral state
benson516 0:37e27f2930a3 32 vector<float> state_int; // x_i
benson516 0:37e27f2930a3 33
benson516 0:37e27f2930a3 34 STATE_FEEDBACK_INTEGRAL(size_t num_state, size_t num_in, size_t num_out, float samplingTime);
benson516 0:37e27f2930a3 35 // Assign Parameters
benson516 0:37e27f2930a3 36 void assign_E_out(float* E_out_in, size_t q_in, size_t n_in);
benson516 0:37e27f2930a3 37 void assign_K_full(float* K_full_in, size_t p_in, size_t n_in);
benson516 0:37e27f2930a3 38 void assign_K_int(float* K_int_in, size_t p_in, size_t q_in);
benson516 0:37e27f2930a3 39 //
benson516 0:37e27f2930a3 40 void fullStateFeedBack_calc(bool enable);
benson516 0:37e27f2930a3 41
benson516 0:37e27f2930a3 42 private:
benson516 0:37e27f2930a3 43
benson516 0:37e27f2930a3 44 vector<float> zeros_n;
benson516 0:37e27f2930a3 45 vector<float> zeros_p;
benson516 0:37e27f2930a3 46 vector<float> zeros_q;
benson516 0:37e27f2930a3 47
benson516 0:37e27f2930a3 48 // Calculate the sys_outputs
benson516 0:37e27f2930a3 49 void get_sys_outputs(void); // Calculate the sys_outputs from states, by mutiplying E_out
benson516 0:37e27f2930a3 50
benson516 0:37e27f2930a3 51 // Calculate the Integral
benson516 0:37e27f2930a3 52 void get_integral(bool enable); // Calculate the state_int
benson516 0:37e27f2930a3 53
benson516 0:37e27f2930a3 54
benson516 0:37e27f2930a3 55 // Utilities
benson516 0:37e27f2930a3 56 void Mat_multiply_Vec(vector<float> &v_out, const vector<vector<float> > &m_left, const vector<float> &v_right); // v_out = m_left*v_right
benson516 0:37e27f2930a3 57 vector<float> Mat_multiply_Vec(const vector<vector<float> > &m_left, const vector<float> &v_right); // v_out = m_left*v_right
benson516 0:37e27f2930a3 58 vector<float> Get_VectorPlus(const vector<float> &v_a, const vector<float> &v_b, bool is_minus); // v_a + (or -) v_b
benson516 0:37e27f2930a3 59 vector<float> Get_VectorScalarMultiply(const vector<float> &v_a, float scale); // scale*v_a
benson516 0:37e27f2930a3 60 // Increment
benson516 0:37e27f2930a3 61 void Get_VectorIncrement(vector<float> &v_a, const vector<float> &v_b, bool is_minus); // v_a += (or -=) v_b
benson516 0:37e27f2930a3 62
benson516 0:37e27f2930a3 63
benson516 0:37e27f2930a3 64 };
benson516 0:37e27f2930a3 65
benson516 0:37e27f2930a3 66 #endif