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
00035
00036
00037 #ifndef LDTRAVMODELEXTENDED_HPP_
00038 #define LDTRAVMODELEXTENDED_HPP_
00039 #include <labust/navigation/SSModel.hpp>
00040
00041 namespace labust
00042 {
00043 namespace navigation
00044 {
00051 class LDTravModel : public SSModel<double>
00052 {
00053 typedef SSModel<double> Base;
00054 public:
00055 typedef vector input_type;
00056 typedef vector output_type;
00057
00058 struct ModelParams
00059 {
00060 ModelParams():
00061 alpha(1),
00062 beta(1),
00063 betaa(0){};
00064
00065 ModelParams(double alpha, double beta, double betaa):
00066 alpha(alpha),
00067 beta(beta),
00068 betaa(betaa){}
00069
00070 inline double Beta(double val)
00071 {
00072 return beta + betaa*fabs(val);
00073 }
00074
00075 double alpha, beta, betaa;
00076 };
00077
00078 enum {u=0,v,w,p,q,r,xp,yp,zp,phi,theta,psi,xc,yc,b,buoyancy,roll_restore,pitch_restore,altitude, stateNum};
00079
00080 enum {inputSize = 6};
00081 enum {measSize = 7};
00082
00083 enum {X=0,Y,Z,Kroll,M,N};
00084
00088 LDTravModel();
00092 ~LDTravModel();
00093
00099 void step(const input_type& input);
00105 void estimate_y(output_type& y);
00109 void initModel();
00110
00114 const output_type& update(vector& measurements, vector& newMeas);
00115
00119 void setParameters(const ModelParams& surge,
00120 const ModelParams& sway,
00121 const ModelParams& heave,
00122 const ModelParams& roll,
00123 const ModelParams& pitch,
00124 const ModelParams& yaw)
00125 {
00126 this->surge = surge;
00127 this->sway = sway;
00128 this->heave = heave;
00129 this->roll = roll;
00130 this->pitch = pitch;
00131 this->yaw = yaw;
00132 }
00133
00134 void calculateXYInovationVariance(const matrix& P, double& xin,double &yin);
00135 void calculateUVInovationVariance(const matrix& P, double& uin,double &vin);
00136 double calculateAltInovationVariance(const matrix& P);
00137
00141 inline void getNEDSpeed(double& xdot, double& ydot)
00142 {
00143 xdot = this->xdot;
00144 ydot = this->ydot;
00145 }
00146
00147 inline void useDvlModel(int flag){this->dvlModel = flag;};
00148
00149 inline void setDVLRotationTrustFactor(double trustf){this->trustf = trustf;};
00150
00151 inline void setSwayCorrection(double kvr){this->kvr = kvr;};
00152
00153 protected:
00157 void derivativeAW();
00161 void derivativeHV(int num);
00165 void derivativeH();
00169 ModelParams surge,sway,heave,roll,pitch,yaw;
00173 output_type measurement;
00177 double xdot,ydot;
00179 double trustf;
00181 double kvr;
00185 int dvlModel;
00189 matrix Hnl;
00193 vector ynl,y;
00194 };
00195 }
00196 }
00197
00198
00199 #endif