📄 computelinear.hpp
字号:
#pragma ident "$Id: $"/** * @file ComputeLinear.hpp * This class computes linear combinations of GDS data. */#ifndef COMPUTELINEAR_HPP#define COMPUTELINEAR_HPP//============================================================================//// 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// // Dagoberto Salazar - gAGE ( http://www.gage.es ). 2007////============================================================================#include "ProcessingClass.hpp"namespace gpstk{ /** @addtogroup DataStructures */ //@{ /** This class computes linear combinations of GDS data. * * This class is meant to be used with the GNSS data structures (GDS) * objects found in "DataStructures" class, and it is intended to be * used as a more flexible replacement for classes such as ComputePC.hpp. * * A typical way to use this class follows: * * @code * * // Define a linear combination to compute PC using C1 * gnssLinearCombination pcComb; * pcComb.header = TypeID::PC; * pcComb.body[TypeID::C1] = +GAMMA_GPS/0.646944444; * pcComb.body[TypeID::P2] = -1.0/0.646944444; * * * // Define another linear combination to compute PC prefit * // residual * gnssLinearCombination prefitComb; * prefitComb.header = TypeID::prefitC; * prefitComb.body[TypeID::PC] = +1.0; * prefitComb.body[TypeID::rho] = -1.0; * prefitComb.body[TypeID::dtSat] = +1.0; * prefitComb.body[TypeID::rel] = -1.0; * prefitComb.body[TypeID::tropoSlant] = -1.0; * * * // Object to compute linear combinations of data * // Linear combinations will be computed in a FIFO basis * ComputeLinear linear; * linear.addLinear(pcComb); * linear.addLinear(prefitComb); * * // Load observation data * RinexObsStream rin("ebre0300.02o"); * * // Loads precise ephemeris object with file data * SP3EphemerisStore SP3EphList; * SP3EphList.loadFile("igs11513.sp3"); * * // Sets nominal position of receiver * Position nominalPos(4833520.3800, 41536.8300, 4147461.2800); * * // Declare a MOPSTropModel object, setting the defaults * MOPSTropModel mopsTM( nominalPos.getAltitude(), * nominalPos.getGeodeticLatitude(), 30); * * // Object to compute the tropospheric data * ComputeTropModel computeTropo(mopsTM); * * // Declare a basic modeler * BasicModel basic(nominalPos, SP3EphList); * * gnssRinex gRin; * * while(rin >> gRin) { * * gRin >> basic >> computeTropo >> linear; * * // Dump results * gRin.body.dump(cout,1); * } * * @endcode * * The "ComputeLinear" object will visit every satellite in the GNSS * data structure that is "gRin" and will compute the previously defined * linear combination (or combinations). * * When used with the ">>" operator, this class returns the same * incoming data structure with the results inserted in it. Be warned * that if a given satellite does not have the observations or data * required by the linear combination definition, such data will be * taken as zero. * * \warning If the "ComputeLinear" object has more than one linear * combination definition, they will be applied in the same order they * were added to the object, i.e. in a FIFO (First Input - First Output) * basis. Therefore, you must be mindful of combination order. * * @sa ComputeCombination.hpp, ComputePC.hpp, ModelObsFixedStation.hpp * and ModelObs.hpp, among others, for related classes. */ class ComputeLinear : public ProcessingClass { public: /// Default constructor ComputeLinear() { setIndex(); clearAll(); }; /** Common constructor * * @param linearComb Linear combination to be computed. */ ComputeLinear( const gnssLinearCombination& linearComb ) { setIndex(); linearList.push_back(linearComb); }; /** Common constructor * * @param list List of linear combination definitions to compute. */ ComputeLinear(const LinearCombList& list) : linearList(list) { setIndex(); }; /** Returns a satTypeValueMap object, adding the new data generated * when calling this object. * * @param time Epoch corresponding to the data. * @param gData Data object holding the data. */ virtual satTypeValueMap& Process(const DayTime& time, satTypeValueMap& gData); /** Returns a gnnsSatTypeValue object, adding the new data * generated when calling this object. * * @param gData Data object holding the data. */ virtual gnssSatTypeValue& Process(gnssSatTypeValue& gData) { Process(gData.header.epoch, gData.body); return gData; }; /** Returns a gnnsRinex object, adding the new data generated * when calling this object. * * @param gData Data object holding the data. */ virtual gnssRinex& Process(gnssRinex& gData) { Process(gData.header.epoch, gData.body); return gData; }; /// Returns the list of linear combinations to be computed. virtual LinearCombList getLinearCombinations(void) const { return linearList; }; /// Clear all linear combinations. virtual ComputeLinear& clearAll(void) { linearList.clear(); return (*this); }; /** Sets a linear combinations to be computed. * @param linear Linear combination definition to compute. * * @warning All previous linear combinations will be deleted. */ virtual ComputeLinear& setLinearCombination( const gnssLinearCombination& linear ) { clearAll(); linearList.push_back(linear); return (*this); }; /** Sets the list of linear combinations to be computed. * @param list List of linear combination definitions to compute. * * @warning All previous linear combinations will be deleted. */ virtual ComputeLinear& setLinearCombination(const LinearCombList& list) { clearAll(); linearList = list; return (*this); }; /** Add a linear combination to be computed. * @param linear Linear combination definitions to be added. */ virtual ComputeLinear& addLinear(const gnssLinearCombination& linear) { linearList.push_back(linear); return (*this); }; /// Returns an index identifying this object. virtual int getIndex(void) const; /// Returns a string identifying this object. virtual std::string getClassName(void) const; /** Sets the index to a given arbitrary value. Use with caution. * * @param newindex New integer index to be assigned to * current object. */ ComputeLinear& setIndex(const int newindex) { index = newindex; return (*this); }; /// Destructor virtual ~ComputeLinear() {}; private: /// List of linear combinations to compute LinearCombList linearList; /// Initial index assigned to this class. static int classIndex; /// Index belonging to this object. int index; /// Sets the index and increment classIndex. void setIndex(void) { index = classIndex++; }; }; // end class ComputeLinear //@} }#endif // COMPUTELINEAR_HPP
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -