| [280] | 1 | // Part of BNC, a utility for retrieving decoding and | 
|---|
| [464] | 2 | // converting GNSS data streams from NTRIP broadcasters. | 
|---|
| [280] | 3 | // | 
|---|
| [464] | 4 | // Copyright (C) 2007 | 
|---|
| [280] | 5 | // German Federal Agency for Cartography and Geodesy (BKG) | 
|---|
|  | 6 | // http://www.bkg.bund.de | 
|---|
| [464] | 7 | // Czech Technical University Prague, Department of Geodesy | 
|---|
| [280] | 8 | // http://www.fsv.cvut.cz | 
|---|
|  | 9 | // | 
|---|
|  | 10 | // Email: euref-ip@bkg.bund.de | 
|---|
|  | 11 | // | 
|---|
|  | 12 | // This program is free software; you can redistribute it and/or | 
|---|
|  | 13 | // modify it under the terms of the GNU General Public License | 
|---|
|  | 14 | // as published by the Free Software Foundation, version 2. | 
|---|
|  | 15 | // | 
|---|
|  | 16 | // This program is distributed in the hope that it will be useful, | 
|---|
|  | 17 | // but WITHOUT ANY WARRANTY; without even the implied warranty of | 
|---|
|  | 18 | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | 
|---|
|  | 19 | // GNU General Public License for more details. | 
|---|
|  | 20 | // | 
|---|
|  | 21 | // You should have received a copy of the GNU General Public License | 
|---|
|  | 22 | // along with this program; if not, write to the Free Software | 
|---|
|  | 23 | // Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. | 
|---|
| [83] | 24 |  | 
|---|
|  | 25 | #ifndef BNCUTILS_H | 
|---|
|  | 26 | #define BNCUTILS_H | 
|---|
|  | 27 |  | 
|---|
| [3408] | 28 | #include <vector> | 
|---|
|  | 29 |  | 
|---|
| [83] | 30 | #include <QString> | 
|---|
| [125] | 31 | #include <QDateTime> | 
|---|
| [83] | 32 |  | 
|---|
| [2043] | 33 | #include <newmat.h> | 
|---|
| [2063] | 34 | #include <bncconst.h> | 
|---|
| [2043] | 35 |  | 
|---|
| [5807] | 36 | void         expandEnvVar(QString& str); | 
|---|
| [83] | 37 |  | 
|---|
| [5807] | 38 | QDateTime    dateAndTimeFromGPSweek(int GPSWeek, double GPSWeeks); | 
|---|
| [125] | 39 |  | 
|---|
| [5807] | 40 | void         currentGPSWeeks(int& week, double& sec); | 
|---|
| [210] | 41 |  | 
|---|
| [5807] | 42 | QDateTime    currentDateAndTimeGPS(); | 
|---|
| [1154] | 43 |  | 
|---|
| [5807] | 44 | QByteArray   ggaString(const QByteArray& latitude, const QByteArray& longitude, | 
|---|
|  | 45 | const QByteArray& height); | 
|---|
| [1381] | 46 |  | 
|---|
| [5807] | 47 | void         RSW_to_XYZ(const ColumnVector& rr, const ColumnVector& vv, | 
|---|
|  | 48 | const ColumnVector& rsw, ColumnVector& xyz); | 
|---|
| [2043] | 49 |  | 
|---|
| [5807] | 50 | void         XYZ_to_RSW(const ColumnVector& rr, const ColumnVector& vv, | 
|---|
|  | 51 | const ColumnVector& xyz, ColumnVector& rsw); | 
|---|
| [2988] | 52 |  | 
|---|
| [5807] | 53 | t_irc        xyz2ell(const double* XYZ, double* Ell); | 
|---|
| [2063] | 54 |  | 
|---|
| [5807] | 55 | void         xyz2neu(const double* Ell, const double* xyz, double* neu); | 
|---|
| [2065] | 56 |  | 
|---|
| [5807] | 57 | void         neu2xyz(const double* Ell, const double* neu, double* xyz); | 
|---|
| [2582] | 58 |  | 
|---|
| [5807] | 59 | void         jacobiXYZ_NEU(const double* Ell, Matrix& jacobi); | 
|---|
| [5752] | 60 |  | 
|---|
| [5807] | 61 | void         jacobiEll_XYZ(const double* Ell, Matrix& jacobi); | 
|---|
| [5752] | 62 |  | 
|---|
| [5807] | 63 | void         covariXYZ_NEU(const SymmetricMatrix& Qxyz, const double* Ell, | 
|---|
|  | 64 | SymmetricMatrix& Qneu); | 
|---|
| [5752] | 65 |  | 
|---|
| [5807] | 66 | void         covariNEU_XYZ(const SymmetricMatrix& Qneu, const double* Ell, | 
|---|
|  | 67 | SymmetricMatrix& Qxyz); | 
|---|
| [5752] | 68 |  | 
|---|
| [5807] | 69 | double       Frac(double x); | 
|---|
| [5753] | 70 |  | 
|---|
| [5807] | 71 | double       Modulo(double x, double y); | 
|---|
| [3044] | 72 |  | 
|---|
| [5807] | 73 | double       nint(double val); | 
|---|
| [3044] | 74 |  | 
|---|
| [5807] | 75 | ColumnVector rungeKutta4(double xi, const ColumnVector& yi, double dx, double* acc, | 
|---|
|  | 76 | ColumnVector (*der)(double x, const ColumnVector& y, double* acc)); | 
|---|
| [3171] | 77 |  | 
|---|
| [5807] | 78 | void         GPSweekFromDateAndTime(const QDateTime& dateTime, int& GPSWeek, double& GPSWeeks); | 
|---|
| [3044] | 79 |  | 
|---|
| [5807] | 80 | void         GPSweekFromYMDhms(int year, int month, int day, int hour, int min, double sec, | 
|---|
|  | 81 | int& GPSWeek, double& GPSWeeks); | 
|---|
| [3408] | 82 |  | 
|---|
| [5807] | 83 | void         mjdFromDateAndTime(const QDateTime& dateTime, int& mjd, double& dayfrac); | 
|---|
| [3664] | 84 |  | 
|---|
| [5807] | 85 | bool         findInVector(const std::vector<QString>& vv, const QString& str); | 
|---|
| [3664] | 86 |  | 
|---|
| [5807] | 87 | int          readInt(const QString& str, int pos, int len, int& value); | 
|---|
| [4338] | 88 |  | 
|---|
| [5807] | 89 | int          readDbl(const QString& str, int pos, int len, double& value); | 
|---|
| [5230] | 90 |  | 
|---|
| [5807] | 91 | void         topos(double xRec, double yRec, double zRec, double xSat, double ySat, double zSat, | 
|---|
|  | 92 | double& rho, double& eleSat, double& azSat); | 
|---|
| [5310] | 93 |  | 
|---|
| [5807] | 94 | void         deg2DMS(double decDeg, int& deg, int& min, double& sec); | 
|---|
|  | 95 |  | 
|---|
|  | 96 | QString      fortranFormat(double value, int width, int prec); | 
|---|
|  | 97 |  | 
|---|
|  | 98 | void         kalman(const Matrix& AA, const ColumnVector& ll, const DiagonalMatrix& PP, | 
|---|
| [5866] | 99 | SymmetricMatrix& QQ, ColumnVector& xx); | 
|---|
| [5807] | 100 |  | 
|---|
| [5885] | 101 | double       djul(long j1, long m1, double tt); | 
|---|
|  | 102 |  | 
|---|
| [5886] | 103 | double       gpjd(double second, int nweek) ; | 
|---|
|  | 104 |  | 
|---|
| [5885] | 105 | void         jdgp(double tjul, double & second, long & nweek); | 
|---|
|  | 106 |  | 
|---|
| [5886] | 107 | void         jmt (double djul, long& jj, long& mm, double& dd); | 
|---|
|  | 108 |  | 
|---|
| [5910] | 109 | void         stripWhiteSpace(std::string& str); | 
|---|
|  | 110 |  | 
|---|
| [83] | 111 | #endif | 
|---|