Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034 #include <labust/control/IPFFController.h>
00035 #include <math.h>
00036
00037 void IPFF_modelTune(PIDBase* self,
00038 const PT1Model* const model,
00039 float w)
00040 {
00041 self->Kp = 2*w*model->alpha-model->beta;
00042 self->Ki = model->alpha*w*w;
00043 self->Kd = self->Kt = self->Tf = 0;
00044
00045 self->model.alpha = model->alpha;
00046 self->model.beta = model->beta;
00047 self->model.betaa = model->betaa;
00048 }
00049
00050 void IPFF_tune(PIDBase* self, float w)
00051 {
00052 self->Kp = 2*w;
00053 self->Ki = w*w;
00054 self->Kd = self->Kt = self->Tf = 0;
00055 }
00056
00057 void IPFF_wffStep(PIDBase* self, float Ts, float error, float ff)
00058 {
00059
00060 if (self->autoWindup == 1)
00061 {
00062 self->track = self->output;
00063 self->windup = (self->internalState != self->track) && (error*self->track > 0);
00064 }
00065 else
00066 {
00067
00068 self->windup = (self->extWindup && (error*self->output > 0));
00069 }
00070
00071
00072 if ((self->lastI != 0) && self->windup && self->useBackward)
00073 {
00074
00075 float diff = self->track - self->internalState + self->lastI;
00076
00077
00078 self->internalState -= ((diff*self->track <= 0)?self->lastI:(self->lastI - diff));
00079 }
00080
00081
00082 self->internalState -= self->Kp*(self->state-self->lastState);
00083
00084
00085 if (!self->windup) self->internalState += (self->lastI = self->Ki*Ts*error);
00086 else self->lastI = 0;
00087 self->internalState += ff - self->lastFF;
00088
00089 self->output = self->internalState;
00090
00091 if (self->autoWindup == 1)
00092 {
00093 self->output = sat(self->output,-self->outputLimit, self->outputLimit);
00094 }
00095
00096 self->lastError = error;
00097 self->lastRef = self->desired;
00098 self->lastFF = ff;
00099 self->lastState = self->state;
00100 }
00101
00102
00103