MOOS 0.2375
/home/toby/moos-ivp/MOOS-2375-Oct0611/NavigationAndControl/MOOSNavLib/MOOSNavTopDownCalEngine.h
Go to the documentation of this file.
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_)
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Defines