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

Last change on this file since 10023 was 10023, checked in by stuerze, 13 months ago

change from receiver clock offsets to system clocks

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