source: ntrip/trunk/BNC/rinex/reqcanalyze.cpp@ 4265

Last change on this file since 4265 was 4265, checked in by mervart, 12 years ago
File size: 4.5 KB
Line 
1// Part of BNC, a utility for retrieving decoding and
2// converting GNSS data streams from NTRIP broadcasters.
3//
4// Copyright (C) 2007
5// German Federal Agency for Cartography and Geodesy (BKG)
6// http://www.bkg.bund.de
7// Czech Technical University Prague, Department of Geodesy
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.
24
25/* -------------------------------------------------------------------------
26 * BKG NTRIP Client
27 * -------------------------------------------------------------------------
28 *
29 * Class: t_reqcAnalyze
30 *
31 * Purpose: Analyze RINEX Files
32 *
33 * Author: L. Mervart
34 *
35 * Created: 11-Apr-2012
36 *
37 * Changes:
38 *
39 * -----------------------------------------------------------------------*/
40
41#include <iostream>
42#include "reqcanalyze.h"
43#include "bncapp.h"
44#include "bncsettings.h"
45#include "reqcedit.h"
46#include "bncutils.h"
47#include "bncpostprocess.h"
48
49using namespace std;
50
51// Constructor
52////////////////////////////////////////////////////////////////////////////
53t_reqcAnalyze::t_reqcAnalyze(QObject* parent) : QThread(parent) {
54
55 bncSettings settings;
56
57 _logFileName = settings.value("reqcOutLogFile").toString(); expandEnvVar(_logFileName);
58 _logFile = 0;
59 _log = 0;
60 _obsFileNames = settings.value("reqcObsFile").toString().split(",", QString::SkipEmptyParts);
61 _navFileNames = settings.value("reqcNavFile").toString().split(",", QString::SkipEmptyParts);
62}
63
64// Destructor
65////////////////////////////////////////////////////////////////////////////
66t_reqcAnalyze::~t_reqcAnalyze() {
67 for (int ii = 0; ii < _rnxObsFiles.size(); ii++) {
68 delete _rnxObsFiles[ii];
69 }
70 for (int ii = 0; ii < _ephs.size(); ii++) {
71 delete _ephs[ii];
72 }
73 delete _log; _log = 0;
74 delete _logFile; _logFile = 0;
75}
76
77//
78////////////////////////////////////////////////////////////////////////////
79void t_reqcAnalyze::run() {
80
81 // Open Log File
82 // -------------
83 _logFile = new QFile(_logFileName);
84 _logFile->open(QIODevice::WriteOnly | QIODevice::Text);
85 _log = new QTextStream();
86 _log->setDevice(_logFile);
87
88 // Initialize RINEX Observation Files
89 // ----------------------------------
90 t_reqcEdit::initRnxObsFiles(_obsFileNames, _rnxObsFiles);
91
92 // Read Ephemerides
93 // ----------------
94 t_reqcEdit::readEphemerides(_navFileNames, _ephs);
95
96 // Loop over all RINEX Files
97 // -------------------------
98 for (int ii = 0; ii < _rnxObsFiles.size(); ii++) {
99 analyzeFile(_rnxObsFiles[ii]);
100 }
101
102 // Exit
103 // ----
104 bncApp* app = (bncApp*) qApp;
105 if ( app->mode() != bncApp::interactive) {
106 app->exit(0);
107 }
108 else {
109 emit finished();
110 deleteLater();
111 }
112}
113
114//
115////////////////////////////////////////////////////////////////////////////
116void t_reqcAnalyze::analyzeFile(t_rnxObsFile* obsFile) {
117
118 *_log << "Analyze File\n"
119 << "------------\n"
120 << obsFile->fileName().toAscii().data() << endl << endl;
121
122 // Loop over all Epochs
123 // --------------------
124 t_rnxObsFile::t_rnxEpo* epo = 0;
125 while ( (epo = obsFile->nextEpoch()) != 0) {
126
127 // Loop over all satellites
128 // ------------------------
129 for (unsigned iObs = 0; iObs < epo->rnxSat.size(); iObs++) {
130 const t_rnxObsFile::t_rnxSat& rnxSat = epo->rnxSat[iObs];
131 t_obs obs;
132 t_postProcessing::setObsFromRnx(obsFile, epo, rnxSat, obs);
133
134 if (obs.satSys == 'R') {
135 // TODO: set channel number
136 }
137
138 QString prn = QString("%1%2").arg(obs.satSys)
139 .arg(obs.satNum, 2, 10, QChar('0'));
140 _satStat[prn].addObs(obs);
141 }
142
143 } // while (epo)
144
145 _log->flush();
146}
147
148//
149////////////////////////////////////////////////////////////////////////////
150void t_reqcAnalyze::t_satStat::addObs(const t_obs& obs) {
151 if (currObs) {
152 delete prevObs;
153 prevObs = currObs;
154 }
155 currObs = new t_obs(obs);
156
157 if (obs.p1() != 0.0 && obs.p2() != 0.0 && obs.l1() != 0.0 && obs.l2() != 0.0){
158
159 }
160}
Note: See TracBrowser for help on using the repository browser.