MOOS 0.2375
|
00001 00002 // 00003 // MOOS - Mission Oriented Operating Suite 00004 // 00005 // A suit of Applications and Libraries for Mobile Robotics Research 00006 // Copyright (C) 2001-2005 Massachusetts Institute of Technology and 00007 // Oxford University. 00008 // 00009 // This software was written by Paul Newman and others 00010 // at MIT 2001-2002 and Oxford University 2003-2005. 00011 // email: pnewman@robots.ox.ac.uk. 00012 // 00013 // This file is part of a MOOS Basic (Common) Application. 00014 // 00015 // This program is free software; you can redistribute it and/or 00016 // modify it under the terms of the GNU General Public License as 00017 // published by the Free Software Foundation; either version 2 of the 00018 // License, or (at your option) any later version. 00019 // 00020 // This program is distributed in the hope that it will be useful, 00021 // but WITHOUT ANY WARRANTY; without even the implied warranty of 00022 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 00023 // General Public License for more details. 00024 // 00025 // You should have received a copy of the GNU General Public License 00026 // along with this program; if not, write to the Free Software 00027 // Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 00028 // 02111-1307, USA. 00029 // 00031 // MOOSNavTopDownCalEngine.h: interface for the CMOOSNavTopDownCalEngine class. 00032 // 00034 00035 #if !defined(AFX_MOOSNAVTOPDOWNCALENGINE_H__DCD111D4_671C_47EC_B704_680F9BAE8C14__INCLUDED_) 00036 #define AFX_MOOSNAVTOPDOWNCALENGINE_H__DCD111D4_671C_47EC_B704_680F9BAE8C14__INCLUDED_ 00037 00038 #if _MSC_VER > 1000 00039 #pragma once 00040 #endif // _MSC_VER > 1000 00041 00042 #include "MOOSNavLSQEngine.h" 00043 //#include "TopDownCalibrationController.h" // Added by ClassView 00044 00045 class CMOOSNavTopDownCalEngine : public CMOOSNavLSQEngine 00046 { 00047 public: 00048 bool SetFocus(int nChannel); 00049 00050 enum State 00051 { 00052 GATHERING, 00053 THINKING, 00054 OFFLINE, 00055 }; 00056 class CVantagePoint 00057 { 00058 public: 00059 double m_dfX; 00060 double m_dfY; 00061 double m_dfZ; 00062 double m_dfTOF; 00063 double m_dfTOFStd; 00064 double m_dfTime; 00065 int m_nChan; 00066 00067 CMOOSNavSensor* m_pRespondingSensor; 00068 CMOOSNavSensor* m_pInterrogateSensor; 00069 }; 00070 typedef list<CVantagePoint> VANTAGEPOINT_LIST; 00071 00072 CMOOSNavTopDownCalEngine(); 00073 virtual ~CMOOSNavTopDownCalEngine(); 00074 virtual bool Initialise(STRING_LIST sParams); 00075 virtual bool AddData(const CMOOSMsg &Msg); 00076 virtual bool Iterate(double dfTimeNow); 00077 00078 00079 protected: 00080 double GetRequiredPathLength(); 00081 bool Calculate(double dfTimeNow); 00082 bool SeedSolution(); 00083 bool IndicateGatherProgress(); 00084 bool OnStart(); 00085 string GetStateAsString(State eState); 00086 bool SetState(State eState); 00087 bool OnRxTopDownControl(string sInstruction); 00088 State m_eState; 00089 bool Clean(); 00090 bool OnIterateDone(); 00091 bool MakeObservations(); 00092 bool MakePseudoBeacons(); 00093 bool MakeVantagePoints(); 00094 bool GetXYZ(double & dfX, double & dfY, double & dfZ, double dfTime, double dfTolerance); 00095 virtual bool OnSolved(); 00096 double GetPathLength(); 00097 map<int,int> m_GuessedDepths; 00098 00099 string m_sJobName; 00100 00101 int m_nNoConvergenceCounter; 00102 double m_dfCalPathLength; 00103 int m_nSelectedChan; 00104 00105 //control of search for solution 00106 double m_dfLastSolveAttempt; 00107 double m_dfSpacing; 00108 double m_dfTrialRate; 00109 00110 VANTAGEPOINT_LIST m_VantagePoints; 00111 double m_dfTide; 00112 int m_nActiveChannel; 00113 }; 00114 00115 #endif // !defined(AFX_MOOSNAVTOPDOWNCALENGINE_H__DCD111D4_671C_47EC_B704_680F9BAE8C14__INCLUDED_)