source: ntrip/trunk/BNC/src/PPP/pppParlist.cpp@ 10259

Last change on this file since 10259 was 10259, checked in by stuerze, 12 months ago

changes regarding PPP

  • Property svn:keywords set to Author Date Id Rev URL;svn:eol-style=native
  • Property svn:mime-type set to text/plain
File size: 24.3 KB
RevLine 
[7237]1/* -------------------------------------------------------------------------
2 * BKG NTRIP Client
3 * -------------------------------------------------------------------------
4 *
5 * Class: t_pppParlist
6 *
7 * Purpose: List of estimated parameters
8 *
9 * Author: L. Mervart
10 *
11 * Created: 29-Jul-2014
12 *
13 * Changes:
14 *
15 * -----------------------------------------------------------------------*/
16
17#include <cmath>
18#include <iostream>
19#include <sstream>
20#include <iomanip>
21#include <algorithm>
22#include <newmatio.h>
23
24#include "pppParlist.h"
25#include "pppSatObs.h"
26#include "pppStation.h"
27#include "bncutils.h"
28#include "bncconst.h"
29#include "pppClient.h"
30
31using namespace BNC_PPP;
32using namespace std;
33
34// Constructor
35////////////////////////////////////////////////////////////////////////////
36t_pppParam::t_pppParam(e_type type, const t_prn& prn, t_lc::type tLC,
[9504]37 const vector<t_pppSatObs*>* obsVector) {
[7237]38
39 _type = type;
40 _prn = prn;
41 _tLC = tLC;
42 _x0 = 0.0;
43 _indexOld = -1;
44 _indexNew = -1;
45 _noise = 0.0;
46 _ambInfo = 0;
47
48 switch (_type) {
49 case crdX:
50 _epoSpec = false;
51 _sigma0 = OPT->_aprSigCrd[0];
52 _noise = OPT->_noiseCrd[0];
53 break;
54 case crdY:
55 _epoSpec = false;
56 _sigma0 = OPT->_aprSigCrd[1];
57 _noise = OPT->_noiseCrd[1];
58 break;
59 case crdZ:
60 _epoSpec = false;
61 _sigma0 = OPT->_aprSigCrd[2];
62 _noise = OPT->_noiseCrd[2];
63 break;
[10256]64 case rClk:
[7237]65 _epoSpec = true;
[9303]66 _sigma0 = OPT->_aprSigClk;
[7237]67 break;
68 case amb:
69 _epoSpec = false;
70 _sigma0 = OPT->_aprSigAmb;
71 _ambInfo = new t_ambInfo();
72 if (obsVector) {
73 for (unsigned ii = 0; ii < obsVector->size(); ii++) {
74 const t_pppSatObs* obs = obsVector->at(ii);
75 if (obs->prn() == _prn) {
[10256]76 double offGlo = 0;
77 if (_prn.system() == 'R' && tLC != t_lc::MW) {
78 offGlo = PPP_CLIENT->offGlo();
79 }
80 double offGal = 0;
81 if (_prn.system() == 'E' && tLC != t_lc::MW) {
82 offGal = PPP_CLIENT->offGal();
83 }
84 double offBds = 0;
85 if (_prn.system() == 'C' && tLC != t_lc::MW) {
86 offBds = PPP_CLIENT->offBds();
87 }
88 _x0 = floor((obs->obsValue(tLC) - offGlo - offGal - offBds - obs->cmpValue(tLC)) / obs->lambda(tLC) + 0.5);
[7237]89 break;
90 }
91 }
92 }
93 break;
[10256]94 case offGlo:
95 _epoSpec = true;
96 _sigma0 = OPT->_aprSigClk;
97 _x0 = PPP_CLIENT->offGlo();
98 break;
99 case offGal:
100 _epoSpec = true;
101 _sigma0 = OPT->_aprSigClk;
102 _x0 = PPP_CLIENT->offGal();
103 break;
104 case offBds:
105 _epoSpec = true;
106 _sigma0 = OPT->_aprSigClk;
107 _x0 = PPP_CLIENT->offBds();
108 break;
[7237]109 case trp:
110 _epoSpec = false;
111 _sigma0 = OPT->_aprSigTrp;
112 _noise = OPT->_noiseTrp;
113 break;
[8905]114 case ion:
[9439]115 _epoSpec = false;
[9386]116 _sigma0 = OPT->_aprSigIon;
[9439]117 _noise = OPT->_noiseIon;
[8905]118 break;
[9644]119 case cBiasG1: case cBiasR1: case cBiasE1: case cBiasC1:
120 case cBiasG2: case cBiasR2: case cBiasE2: case cBiasC2:
121 _epoSpec = false;
122 _sigma0 = OPT->_aprSigCodeBias;
123 _noise = OPT->_noiseCodeBias;
124 break;
125 case pBiasG1: case pBiasR1: case pBiasE1: case pBiasC1:
126 case pBiasG2: case pBiasR2: case pBiasE2: case pBiasC2:
127 _epoSpec = false;
128 _sigma0 = OPT->_aprSigPhaseBias;
129 _noise = OPT->_noisePhaseBias;
130 break;
[7237]131 }
132}
133
134// Destructor
135////////////////////////////////////////////////////////////////////////////
136t_pppParam::~t_pppParam() {
[9504]137 if (_ambInfo) {
138 delete _ambInfo;
139 }
[7237]140}
141//
142////////////////////////////////////////////////////////////////////////////
143double t_pppParam::partial(const bncTime& /* epoTime */, const t_pppSatObs* obs,
[10034]144 const t_lc::type& tLC) const {
[7237]145
146 // Special Case - Melbourne-Wuebbena
147 // ---------------------------------
148 if (tLC == t_lc::MW && _type != amb) {
149 return 0.0;
150 }
151
152 const t_pppStation* sta = PPP_CLIENT->staRover();
[8905]153 ColumnVector rhoV = sta->xyzApr() - obs->xc().Rows(1,3);
[7237]154
[8905]155 map<t_frequency::type, double> codeCoeff;
156 map<t_frequency::type, double> phaseCoeff;
157 map<t_frequency::type, double> ionoCoeff;
158 obs->lcCoeff(tLC, codeCoeff, phaseCoeff, ionoCoeff);
159
[7237]160 switch (_type) {
161 case crdX:
[9548]162 if (tLC == t_lc::GIM) {return 0.0;}
[8905]163 return (sta->xyzApr()[0] - obs->xc()[0]) / rhoV.NormFrobenius();
[7237]164 case crdY:
[9548]165 if (tLC == t_lc::GIM) {return 0.0;}
[8905]166 return (sta->xyzApr()[1] - obs->xc()[1]) / rhoV.NormFrobenius();
[7237]167 case crdZ:
[9548]168 if (tLC == t_lc::GIM) {return 0.0;}
[8905]169 return (sta->xyzApr()[2] - obs->xc()[2]) / rhoV.NormFrobenius();
[10256]170 case rClk:
[9548]171 if (tLC == t_lc::GIM) {return 0.0;}
[10256]172 return 1.0;
173 case offGlo:
[9548]174 if (tLC == t_lc::GIM) {return 0.0;}
[7237]175 return (obs->prn().system() == 'R') ? 1.0 : 0.0;
[10256]176 case offGal:
[10003]177 if (tLC == t_lc::GIM) {return 0.0;}
178 return (obs->prn().system() == 'E') ? 1.0 : 0.0;
[10256]179 case offBds:
[10003]180 if (tLC == t_lc::GIM) {return 0.0;}
181 return (obs->prn().system() == 'C') ? 1.0 : 0.0;
[7237]182 case amb:
[10034]183 if (tLC == t_lc::GIM) {
184 return 0.0;
185 }
186 else {
[8905]187 if (obs->prn() == _prn) {
188 if (tLC == _tLC) {
189 return (obs->lambda(tLC));
190 }
191 else if (tLC == t_lc::lIF && _tLC == t_lc::MW) {
192 return obs->lambda(t_lc::lIF) * obs->lambda(t_lc::MW) / obs->lambda(t_lc::l2);
193 }
194 else {
195 if (_tLC == t_lc::l1) {
[10251]196 return obs->lambda(t_lc::l1) * phaseCoeff[obs->fType1()];
[8905]197 }
198 else if (_tLC == t_lc::l2) {
[10251]199 return obs->lambda(t_lc::l2) * phaseCoeff[obs->fType2()];
[8905]200 }
201 }
202 }
203 }
204 break;
205 case trp:
[8961]206 if (tLC == t_lc::GIM) {
207 return 0.0;
208 }
209 else {
210 return 1.0 / sin(obs->eleSat());
211 }
[8905]212 case ion:
[7237]213 if (obs->prn() == _prn) {
[8905]214 if (tLC == t_lc::c1) {
[10251]215 return ionoCoeff[obs->fType1()];
[7237]216 }
[8905]217 else if (tLC == t_lc::c2) {
[10251]218 return ionoCoeff[obs->fType2()];
[7237]219 }
[8905]220 else if (tLC == t_lc::l1) {
[10251]221 return ionoCoeff[obs->fType1()];
[7237]222 }
[8905]223 else if (tLC == t_lc::l2) {
[10251]224 return ionoCoeff[obs->fType2()];
[8905]225 }
226 else if (tLC == t_lc::GIM) {
[10034]227 return 1.0;
[8905]228 }
[7237]229 }
[8905]230 break;
[9386]231 case cBiasG1:
232 if ((obs->prn().system() == 'G') && (tLC == t_lc::c1)) {return 1.0;} else {return 0.0;}
[8905]233 break;
[9561]234 case cBiasR1:
235 if ((obs->prn().system() == 'R') && (tLC == t_lc::c1)) {return 1.0;} else {return 0.0;}
236 break;
[9386]237 case cBiasE1:
238 if ((obs->prn().system() == 'E') && (tLC == t_lc::c1)) {return 1.0;} else {return 0.0;}
[8905]239 break;
[9386]240 case cBiasC1:
241 if ((obs->prn().system() == 'C') && (tLC == t_lc::c1)) {return 1.0;} else {return 0.0;}
242 break;
243 case cBiasG2:
244 if ((obs->prn().system() == 'G') && (tLC == t_lc::c2)) {return 1.0;} else {return 0.0;}
245 break;
[9561]246 case cBiasR2:
247 if ((obs->prn().system() == 'R') && (tLC == t_lc::c2)) {return 1.0;} else {return 0.0;}
248 break;
[9386]249 case cBiasE2:
250 if ((obs->prn().system() == 'E') && (tLC == t_lc::c2)) {return 1.0;} else {return 0.0;}
251 break;
252 case cBiasC2:
253 if ((obs->prn().system() == 'C') && (tLC == t_lc::c2)) {return 1.0;} else {return 0.0;}
254 break;
255 case pBiasG1:
256 if ((obs->prn().system() == 'G') && (tLC == t_lc::l1)) {return 1.0;} else {return 0.0;}
257 break;
[9561]258 case pBiasR1:
259 if ((obs->prn().system() == 'R') && (tLC == t_lc::l1)) {return 1.0;} else {return 0.0;}
260 break;
[9386]261 case pBiasE1:
262 if ((obs->prn().system() == 'E') && (tLC == t_lc::l1)) {return 1.0;} else {return 0.0;}
263 break;
264 case pBiasC1:
265 if ((obs->prn().system() == 'C') && (tLC == t_lc::l1)) {return 1.0;} else {return 0.0;}
266 break;
267 case pBiasG2:
268 if ((obs->prn().system() == 'G') && (tLC == t_lc::l2)) {return 1.0;} else {return 0.0;}
269 break;
[9561]270 case pBiasR2:
271 if ((obs->prn().system() == 'R') && (tLC == t_lc::l2)) {return 1.0;} else {return 0.0;}
272 break;
[9386]273 case pBiasE2:
274 if ((obs->prn().system() == 'E') && (tLC == t_lc::l2)) {return 1.0;} else {return 0.0;}
275 break;
276 case pBiasC2:
277 if ((obs->prn().system() == 'C') && (tLC == t_lc::l2)) {return 1.0;} else {return 0.0;}
278 break;
279
[7237]280 }
281 return 0.0;
282}
283
284//
285////////////////////////////////////////////////////////////////////////////
286string t_pppParam::toString() const {
287 stringstream ss;
288 switch (_type) {
289 case crdX:
290 ss << "CRD_X";
291 break;
292 case crdY:
293 ss << "CRD_Y";
294 break;
295 case crdZ:
296 ss << "CRD_Z";
297 break;
[10256]298 case rClk:
299 ss << "REC_CLK ";
[7237]300 break;
[10256]301 case offGlo:
302 ss << "OFF_GLO ";
[7237]303 break;
[10256]304 case offGal:
305 ss << "OFF_GAL ";
[10003]306 break;
[10256]307 case offBds:
308 ss << "OFF_BDS ";
[10003]309 break;
[7237]310 case trp:
[9386]311 ss << "TRP ";
[7237]312 break;
[8905]313 case amb:
314 ss << "AMB " << left << setw(3) << t_lc::toString(_tLC) << right << ' ' << _prn.toString();
315 break;
316 case ion:
317 ss << "ION " << left << setw(3) << t_lc::toString(_tLC) << right << ' ' << _prn.toString();
318 break;
[9386]319 case cBiasG1: case pBiasG1:
320 case cBiasG2: case pBiasG2:
321 ss << "BIA " << left << setw(3) << t_lc::toString(_tLC) << right << " G ";
[8905]322 break;
[9561]323 case cBiasR1: case pBiasR1:
324 case cBiasR2: case pBiasR2:
325 ss << "BIA " << left << setw(3) << t_lc::toString(_tLC) << right << " R ";
326 break;
[9386]327 case cBiasE1: case pBiasE1:
328 case cBiasE2: case pBiasE2:
329 ss << "BIA " << left << setw(3) << t_lc::toString(_tLC) << right << " E ";
330 break;
331 case cBiasC1: case pBiasC1:
332 case cBiasC2: case pBiasC2:
333 ss << "BIA " << left << setw(3) << t_lc::toString(_tLC) << right << " C ";
334 break;
[7237]335 }
336 return ss.str();
337}
338
339// Constructor
340////////////////////////////////////////////////////////////////////////////
341t_pppParlist::t_pppParlist() {
342}
343
344// Destructor
345////////////////////////////////////////////////////////////////////////////
346t_pppParlist::~t_pppParlist() {
[9504]347 _usedSystems.clear();
348
[10034]349 for (unsigned ii = 0; ii < _params.size(); ii++) {
350 delete _params[ii];
[7237]351 }
352}
353
354//
355////////////////////////////////////////////////////////////////////////////
[10034]356t_irc t_pppParlist::set(const bncTime& epoTime, const std::vector<t_pppSatObs*>& obsVector) {
[9504]357
[7237]358 // Remove some Parameters
359 // ----------------------
360 vector<t_pppParam*>::iterator it = _params.begin();
361 while (it != _params.end()) {
362 t_pppParam* par = *it;
363
364 bool remove = false;
365
366 if (par->epoSpec()) {
367 remove = true;
368 }
369
[10034]370 else if (par->type() == t_pppParam::amb ||
371 par->type() == t_pppParam::crdX ||
[7988]372 par->type() == t_pppParam::crdY ||
373 par->type() == t_pppParam::crdZ) {
[10219]374 if (par->lastObsTime().valid() && (epoTime - par->lastObsTime() > 60.0)) {
[7237]375 remove = true;
376 }
377 }
[10219]378 else if (par->type() == t_pppParam::ion) {
379 if (par->lastObsTime().valid() && (epoTime - par->lastObsTime() > 5.0)) {
380 remove = true;
381 }
382}
[9419]383
[7237]384 if (remove) {
[9508]385#ifdef BNC_DEBUG_PPP
[10018]386// LOG << "remove0 " << par->toString() << std::endl;
[9508]387#endif
[7237]388 delete par;
389 it = _params.erase(it);
390 }
391 else {
392 ++it;
393 }
394 }
395
[9532]396 // check which systems have observations
397 // -------------------------------------
398 _usedSystems.clear();
399 for (unsigned jj = 0; jj < obsVector.size(); jj++) {
400 const t_pppSatObs* satObs = obsVector[jj];
[9533]401 char sys = satObs->prn().system();
[9532]402 if (!_usedSystems.contains(sys)) {
403 _usedSystems.append(sys);
404 }
405 }
406
[7237]407 // Check whether parameters have observations
408 // ------------------------------------------
409 for (unsigned ii = 0; ii < _params.size(); ii++) {
410 t_pppParam* par = _params[ii];
411 if (par->prn() == 0) {
412 par->setLastObsTime(epoTime);
413 if (par->firstObsTime().undef()) {
414 par->setFirstObsTime(epoTime);
415 }
416 }
417 else {
418 for (unsigned jj = 0; jj < obsVector.size(); jj++) {
419 const t_pppSatObs* satObs = obsVector[jj];
420 if (satObs->prn() == par->prn()) {
421 par->setLastObsTime(epoTime);
422 if (par->firstObsTime().undef()) {
423 par->setFirstObsTime(epoTime);
424 }
425 break;
426 }
427 }
428 }
429 }
430
[10251]431 if (OPT->_ionoModelType == OPT->PPP_RTK || OPT->_pseudoObsIono) {
[9419]432 vector<t_pppParam*>::iterator it = _params.begin();
433 while (it != _params.end()) {
434 t_pppParam* par = *it;
[9532]435 // Check if systems have to be presented per biases
[9535]436 // ----------------------------------------------
[10034]437 if (( par->type() == t_pppParam::cBiasG1 ||
[9532]438 par->type() == t_pppParam::cBiasG2 ||
439 par->type() == t_pppParam::pBiasG1 ||
440 par->type() == t_pppParam::pBiasG2) && !usedSystems().contains('G')) {
[9534]441#ifdef BNC_DEBUG_PPP
[10031]442 //LOG << "remove1 " << par->toString() << std::endl;
[9534]443#endif
[9548]444 delete par;
445 it = _params.erase(it);
[9532]446 }
[9561]447 else if ((par->type() == t_pppParam::cBiasR1 ||
448 par->type() == t_pppParam::cBiasR2 ||
449 par->type() == t_pppParam::pBiasR1 ||
450 par->type() == t_pppParam::pBiasR2) && !usedSystems().contains('R')) {
451#ifdef BNC_DEBUG_PPP
[10031]452 //LOG << "remove1 " << par->toString() << std::endl;
[9561]453#endif
454 delete par;
455 it = _params.erase(it);
456 }
[9532]457 else if ((par->type() == t_pppParam::cBiasE1 ||
458 par->type() == t_pppParam::cBiasE2 ||
459 par->type() == t_pppParam::pBiasE1 ||
460 par->type() == t_pppParam::pBiasE2) && !usedSystems().contains('E')) {
[9534]461#ifdef BNC_DEBUG_PPP
[10031]462 //LOG << "remove1 " << par->toString() << std::endl;
[9534]463#endif
[9548]464 delete par;
465 it = _params.erase(it);
[9532]466 }
467 else if ((par->type() == t_pppParam::cBiasC1 ||
468 par->type() == t_pppParam::cBiasC2 ||
469 par->type() == t_pppParam::pBiasC1 ||
[9548]470 par->type() == t_pppParam::pBiasC2) && !usedSystems().contains('C')) {
[9534]471#ifdef BNC_DEBUG_PPP
[10031]472 //LOG << "remove1 " << par->toString() << std::endl;
[9534]473#endif
[9548]474 delete par;
475 it = _params.erase(it);
[9532]476 }
[9419]477 else {
478 ++it;
479 }
480 }
481 }
482
[7237]483 // Required Set of Parameters
484 // --------------------------
485 vector<t_pppParam*> required;
486
487 // Coordinates
488 // -----------
489 required.push_back(new t_pppParam(t_pppParam::crdX, t_prn(), t_lc::dummy));
490 required.push_back(new t_pppParam(t_pppParam::crdY, t_prn(), t_lc::dummy));
491 required.push_back(new t_pppParam(t_pppParam::crdZ, t_prn(), t_lc::dummy));
492
[10232]493 // Receiver Clocks
494 // ---------------
[10256]495 required.push_back(new t_pppParam(t_pppParam::rClk, t_prn(), t_lc::dummy));
[10034]496
[10256]497 // GLONASS Clock Offset
498 // --------------------
[10259]499 if ( _usedSystems.contains('R') &&
500 (_usedSystems.contains('G') || _usedSystems.contains('E') || _usedSystems.contains('C'))) {
[10256]501 required.push_back(new t_pppParam(t_pppParam::offGlo, t_prn(), t_lc::dummy));
502 }
[10259]503 else {
504 PPP_CLIENT->resetOffGlo();
505 }
[10034]506
[10256]507 // Galileo Clock Offset
508 // --------------------
[10259]509 if (_usedSystems.contains('E') && _usedSystems.contains('G')) {
[10256]510 required.push_back(new t_pppParam(t_pppParam::offGal, t_prn(), t_lc::dummy));
511 }
[10259]512 else {
513 PPP_CLIENT->resetOffGal();
514 }
[10034]515
[10256]516 // BDS Clock Offset
517 // ----------------
[10259]518 if (_usedSystems.contains('C') && (_usedSystems.contains('G') || _usedSystems.contains('E'))) {
[10256]519 required.push_back(new t_pppParam(t_pppParam::offBds, t_prn(), t_lc::dummy));
520 }
[10259]521 else {
522 PPP_CLIENT->resetOffBds();
523 }
[10034]524
525 // Troposphere
526 // -----------
527 if (OPT->estTrp()) {
528 required.push_back(new t_pppParam(t_pppParam::trp, t_prn(), t_lc::dummy));
529 }
530
531 // Ionosphere
532 // ----------
[10251]533 if (OPT->_ionoModelType == OPT->est) {
[10034]534 for (unsigned jj = 0; jj < obsVector.size(); jj++) {
535 const t_pppSatObs* satObs = obsVector[jj];
[10251]536 char sys = satObs->prn().system();
537 std::vector<t_lc::type> LCs = OPT->LCs(sys);
538 if (std::find(LCs.begin(), LCs.end(), t_lc::cIF) == LCs.end() &&
539 std::find(LCs.begin(), LCs.end(), t_lc::lIF) == LCs.end()) {
540 required.push_back(new t_pppParam(t_pppParam::ion, satObs->prn(), t_lc::dummy));
541 }
[10034]542 }
543 }
544 // Ambiguities
545 // -----------
546 for (unsigned jj = 0; jj < obsVector.size(); jj++) {
547 const t_pppSatObs* satObs = obsVector[jj];
[10251]548 char sys = satObs->prn().system();
549 const vector<t_lc::type>& ambLCs = OPT->ambLCs(sys);
[10034]550 for (unsigned ii = 0; ii < ambLCs.size(); ii++) {
551 required.push_back(new t_pppParam(t_pppParam::amb, satObs->prn(), ambLCs[ii], &obsVector));
552 }
553 }
554
[9386]555 // Receiver Code Biases
556 // --------------------
[10251]557 if (OPT->_ionoModelType == OPT->PPP_RTK) {
[9494]558 std::vector<t_lc::type> lc;
[9419]559 if (_usedSystems.contains('G')) {
[9494]560 lc = OPT->LCs('G');
561 if (std::find(lc.begin(), lc.end(), t_lc::c1) != lc.end()) {
562 required.push_back(new t_pppParam(t_pppParam::cBiasG1, t_prn(), t_lc::c1));
563 }
564 if (std::find(lc.begin(), lc.end(), t_lc::c2) != lc.end()) {
565 required.push_back(new t_pppParam(t_pppParam::cBiasG2, t_prn(), t_lc::c2));
566 }
[9663]567 }
[9561]568 if (_usedSystems.contains('R')) {
569 lc = OPT->LCs('R');
570 if (std::find(lc.begin(), lc.end(), t_lc::c1) != lc.end()) {
571 required.push_back(new t_pppParam(t_pppParam::cBiasR1, t_prn(), t_lc::c1));
572 }
573 if (std::find(lc.begin(), lc.end(), t_lc::c2) != lc.end()) {
574 required.push_back(new t_pppParam(t_pppParam::cBiasR2, t_prn(), t_lc::c2));
575 }
[9663]576 }
[9419]577 if (_usedSystems.contains('E')) {
[9494]578 lc = OPT->LCs('E');
579 if (std::find(lc.begin(), lc.end(), t_lc::c1) != lc.end()) {
580 required.push_back(new t_pppParam(t_pppParam::cBiasE1, t_prn(), t_lc::c1));
581 }
582 if (std::find(lc.begin(), lc.end(), t_lc::c2) != lc.end()) {
583 required.push_back(new t_pppParam(t_pppParam::cBiasE2, t_prn(), t_lc::c2));
584 }
[9386]585 }
[9419]586 if (_usedSystems.contains('C')) {
[9494]587 lc = OPT->LCs('C');
588 if (std::find(lc.begin(), lc.end(), t_lc::c1) != lc.end()) {
589 required.push_back(new t_pppParam(t_pppParam::cBiasC1, t_prn(), t_lc::c1));
590 }
591 if (std::find(lc.begin(), lc.end(), t_lc::c2) != lc.end()) {
592 required.push_back(new t_pppParam(t_pppParam::cBiasC2, t_prn(), t_lc::c2));
593 }
[9386]594 }
595 }
[10034]596 if (OPT->_pseudoObsIono) {
597 std::vector<t_lc::type> lc;
598 if (_usedSystems.contains('G')) {
599 lc = OPT->LCs('G');
600 if (std::find(lc.begin(), lc.end(), t_lc::c2) != lc.end()) {
601 required.push_back(new t_pppParam(t_pppParam::cBiasG2, t_prn(), t_lc::c2));
602 }
603 }
604 if (_usedSystems.contains('R')) {
605 lc = OPT->LCs('R');
606 if (std::find(lc.begin(), lc.end(), t_lc::c2) != lc.end()) {
607 required.push_back(new t_pppParam(t_pppParam::cBiasR2, t_prn(), t_lc::c2));
608 }
609 }
610 if (_usedSystems.contains('E')) {
611 lc = OPT->LCs('E');
612 if (std::find(lc.begin(), lc.end(), t_lc::c2) != lc.end()) {
613 required.push_back(new t_pppParam(t_pppParam::cBiasE2, t_prn(), t_lc::c2));
614 }
615 }
616 if (_usedSystems.contains('C')) {
617 lc = OPT->LCs('C');
618 if (std::find(lc.begin(), lc.end(), t_lc::c2) != lc.end()) {
619 required.push_back(new t_pppParam(t_pppParam::cBiasC2, t_prn(), t_lc::c2));
620 }
621 }
622 }
[9386]623
624 // Receiver Phase Biases
625 // ---------------------
[10251]626 if (OPT->_ionoModelType == OPT->PPP_RTK) {
[9494]627 std::vector<t_lc::type> lc;
[9419]628 if (_usedSystems.contains('G')) {
[9494]629 lc = OPT->LCs('G');
630 if (std::find(lc.begin(), lc.end(), t_lc::l1) != lc.end()) {
631 required.push_back(new t_pppParam(t_pppParam::pBiasG1, t_prn(), t_lc::l1));
632 }
633 if (std::find(lc.begin(), lc.end(), t_lc::l2) != lc.end()) {
634 required.push_back(new t_pppParam(t_pppParam::pBiasG2, t_prn(), t_lc::l2));
635 }
[9663]636 }
[9561]637 if (_usedSystems.contains('R')) {
638 lc = OPT->LCs('R');
639 if (std::find(lc.begin(), lc.end(), t_lc::l1) != lc.end()) {
640 required.push_back(new t_pppParam(t_pppParam::pBiasR1, t_prn(), t_lc::l1));
641 }
642 if (std::find(lc.begin(), lc.end(), t_lc::l2) != lc.end()) {
643 required.push_back(new t_pppParam(t_pppParam::pBiasR2, t_prn(), t_lc::l2));
644 }
[9663]645 }
[9419]646 if (_usedSystems.contains('E')) {
[9494]647 lc = OPT->LCs('E');
648 if (std::find(lc.begin(), lc.end(), t_lc::l1) != lc.end()) {
649 required.push_back(new t_pppParam(t_pppParam::pBiasE1, t_prn(), t_lc::l1));
650 }
651 if (std::find(lc.begin(), lc.end(), t_lc::l2) != lc.end()) {
652 required.push_back(new t_pppParam(t_pppParam::pBiasE2, t_prn(), t_lc::l2));
653 }
[9386]654 }
[9419]655 if (_usedSystems.contains('C')) {
[9494]656 lc = OPT->LCs('C');
657 if (std::find(lc.begin(), lc.end(), t_lc::l1) != lc.end()) {
658 required.push_back(new t_pppParam(t_pppParam::pBiasC1, t_prn(), t_lc::l1));
659 }
660 if (std::find(lc.begin(), lc.end(), t_lc::l2) != lc.end()) {
661 required.push_back(new t_pppParam(t_pppParam::pBiasC2, t_prn(), t_lc::l2));
662 }
[9386]663 }
664 }
[9419]665
[7237]666 // Check if all required parameters are present
667 // --------------------------------------------
668 for (unsigned ii = 0; ii < required.size(); ii++) {
669 t_pppParam* parReq = required[ii];
670
671 bool found = false;
672 for (unsigned jj = 0; jj < _params.size(); jj++) {
673 t_pppParam* parOld = _params[jj];
674 if (parOld->isEqual(parReq)) {
675 found = true;
676 break;
677 }
678 }
679 if (found) {
680 delete parReq;
681 }
682 else {
[9508]683#ifdef BNC_DEBUG_PPP
[10031]684 //LOG << "push_back parReq " << parReq->toString() << std::endl;
[9508]685#endif
[7237]686 _params.push_back(parReq);
687 }
688 }
689
690 // Set Parameter Indices
691 // ---------------------
692 sort(_params.begin(), _params.end(), t_pppParam::sortFunction);
693
694 for (unsigned ii = 0; ii < _params.size(); ii++) {
695 t_pppParam* par = _params[ii];
696 par->setIndex(ii);
697 for (unsigned jj = 0; jj < obsVector.size(); jj++) {
698 const t_pppSatObs* satObs = obsVector[jj];
699 if (satObs->prn() == par->prn()) {
700 par->setAmbEleSat(satObs->eleSat());
701 par->stepAmbNumEpo();
702 }
703 }
704 }
705
706 return success;
707}
708
709//
710////////////////////////////////////////////////////////////////////////////
711void t_pppParlist::printResult(const bncTime& epoTime, const SymmetricMatrix& QQ,
712 const ColumnVector& xx) const {
713
714 string epoTimeStr = string(epoTime);
715 const t_pppStation* sta = PPP_CLIENT->staRover();
716
717 LOG << endl;
718
719 t_pppParam* parX = 0;
720 t_pppParam* parY = 0;
721 t_pppParam* parZ = 0;
[10034]722 for (unsigned ii = 0; ii < _params.size(); ii++) {
723 t_pppParam* par = _params[ii];
[7237]724 if (par->type() == t_pppParam::crdX) {
725 parX = par;
726 }
727 else if (par->type() == t_pppParam::crdY) {
728 parY = par;
729 }
730 else if (par->type() == t_pppParam::crdZ) {
731 parZ = par;
732 }
733 else {
734 int ind = par->indexNew();
735 double apr = (par->type() == t_pppParam::trp) ?
736 t_tropo::delay_saast(sta->xyzApr(), M_PI/2.0) : par->x0();
737 LOG << epoTimeStr << ' ' << par->toString() << ' '
738 << setw(10) << setprecision(4) << apr << ' '
739 << showpos << setw(10) << setprecision(4) << xx[ind] << noshowpos << " +- "
740 << setw(8) << setprecision(4) << sqrt(QQ[ind][ind]);
741 if (par->type() == t_pppParam::amb) {
742 LOG << " el = " << setw(6) << setprecision(2) << par->ambEleSat() * 180.0 / M_PI
743 << " epo = " << setw(4) << par->ambNumEpo();
744 }
745 LOG << endl;
746 }
747 }
748
749 if (parX && parY && parZ) {
750
751 ColumnVector xyz(3);
752 xyz[0] = xx[parX->indexNew()];
753 xyz[1] = xx[parY->indexNew()];
754 xyz[2] = xx[parZ->indexNew()];
755
756 ColumnVector neu(3);
757 xyz2neu(sta->ellApr().data(), xyz.data(), neu.data());
758
759 SymmetricMatrix QQxyz = QQ.SymSubMatrix(1,3);
760
761 SymmetricMatrix QQneu(3);
762 covariXYZ_NEU(QQxyz, sta->ellApr().data(), QQneu);
763
764 LOG << epoTimeStr << ' ' << sta->name()
765 << " X = " << setprecision(4) << sta->xyzApr()[0] + xyz[0] << " +- "
766 << setprecision(4) << sqrt(QQxyz[0][0])
767
768 << " Y = " << setprecision(4) << sta->xyzApr()[1] + xyz[1] << " +- "
769 << setprecision(4) << sqrt(QQxyz[1][1])
770
771 << " Z = " << setprecision(4) << sta->xyzApr()[2] + xyz[2] << " +- "
772 << setprecision(4) << sqrt(QQxyz[2][2])
773
774 << " dN = " << setprecision(4) << neu[0] << " +- "
775 << setprecision(4) << sqrt(QQneu[0][0])
776
777 << " dE = " << setprecision(4) << neu[1] << " +- "
778 << setprecision(4) << sqrt(QQneu[1][1])
779
780 << " dU = " << setprecision(4) << neu[2] << " +- "
781 << setprecision(4) << sqrt(QQneu[2][2])
782
783 << endl;
784 }
[9545]785 return;
[7237]786}
787
[9525]788//
789////////////////////////////////////////////////////////////////////////////
[9527]790void t_pppParlist::printParams(const bncTime& epoTime) {
[9526]791
792 for (unsigned iPar = 0; iPar < _params.size(); iPar++) {
[9527]793 LOG << _params[iPar]->toString()
794 << "\t lastObsTime().valid() \t" << _params[iPar]->lastObsTime().valid()
795 << "\t epoTime - par->lastObsTime() \t" << (epoTime - _params[iPar]->lastObsTime())
796 << endl;
[9525]797 }
798}
799
Note: See TracBrowser for help on using the repository browser.