⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 linearclockmodel.hpp

📁 gps源代码
💻 HPP
字号:
#pragma ident "$Id: LinearClockModel.hpp 229 2006-10-13 17:13:41Z ocibu $"//============================================================================////  This file is part of GPSTk, the GPS Toolkit.////  The GPSTk is free software; you can redistribute it and/or modify//  it under the terms of the GNU Lesser General Public License as published//  by the Free Software Foundation; either version 2.1 of the License, or//  any later version.////  The GPSTk is distributed in the hope that it will be useful,//  but WITHOUT ANY WARRANTY; without even the implied warranty of//  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the//  GNU Lesser General Public License for more details.////  You should have received a copy of the GNU Lesser General Public//  License along with GPSTk; if not, write to the Free Software Foundation,//  Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA//  //  Copyright 2004, The University of Texas at Austin////============================================================================//============================================================================////This software developed by Applied Research Laboratories at the University of//Texas at Austin, under contract to an agency or agencies within the U.S. //Department of Defense. The U.S. Government retains all rights to use,//duplicate, distribute, disclose, or release this software. ////Pursuant to DoD Directive 523024 //// DISTRIBUTION STATEMENT A: This software has been approved for public //                           release, distribution is unlimited.////=============================================================================#ifndef LINEARCLOCKMODEL_HPP#define LINEARCLOCKMODEL_HPP#include <map>#include "Exception.hpp"#include "ObsClockModel.hpp"#include "ORDEpoch.hpp"/** * @file LinearClockModel.hpp * This model is just a moving average of clock models over time. It * really is quite bad and shouldn't be used at this time. Be warned! */namespace gpstk{   class LinearClockModel : public ObsClockModel   {   public:      LinearClockModel(double sigma = 2, double elmask = 0, SvMode mode = ALWAYS)         :ObsClockModel(sigma, elmask, mode) {reset();};      virtual double getOffset(const gpstk::DayTime& t) const          throw()      {         if (!isOffsetValid(t))            return 0;         else            return clockModel.Slope()*(t-baseTime) + clockModel.Intercept();      };      virtual bool isOffsetValid(const gpstk::DayTime& t) const throw()      {return t >= startTime && t <= endTime && clockModel.N() > 1;};      /// Add in the given ord to the clock model      virtual void addEpoch(const ORDEpoch& oe) throw(gpstk::InvalidValue);      /// Reset the accumulated statistics on the clock      void reset() throw();      void dump(std::ostream& s, short detail=1) const throw();      friend std::ostream& operator<<(std::ostream& s, const LinearClockModel& r)      { r.dump(s, 0); return s; };         private:      // x is time y is clock offset      gpstk::TwoSampleStats<double> clockModel;      gpstk::DayTime startTime, endTime, baseTime;      unsigned long tossCount;         // This is were we store what SVs were used to compute the individual      // clock observations      std::map<gpstk::DayTime, SvStatusMap> prnStatus;      // This is a store of the clock observations that were added into the      // clockModel object      std::multimap<double,double> clockObs;   };   }#endif

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -