21 #include <mrpt/examples_config.h> 23 std::vector<string>
names;
25 const double TH = 0.02;
41 results[0](0, 1) = 4194142.0571;
44 results[0](1, 1) = 4160754.7114;
47 results[0](2, 1) = 4177367.6694;
50 results[0](3, 1) = 4176492.3033;
53 results[0](4, 1) = 4156628.3641;
56 results[0](5, 1) = 4193733.3066;
104 results[3](0, 1) = 4194347.990;
107 results[3](1, 1) = 4160960.412;
110 results[3](2, 1) = 4177573.506;
113 results[3](3, 1) = 4176698.318;
116 results[3](4, 1) = 4156834.269;
119 results[3](5, 1) = 4193939.405;
125 results[4](0, 1) = 4194347.974;
128 results[4](1, 1) = 4160960.612;
131 results[4](2, 1) = 4177573.582;
134 results[4](3, 1) = 4176698.222;
137 results[4](4, 1) = 4156834.272;
140 results[4](5, 1) = 4193939.239;
146 results[5](0, 1) = 4194347.994;
149 results[5](1, 1) = 4160960.599;
152 results[5](2, 1) = 4177573.581;
155 results[5](3, 1) = 4176698.225;
158 results[5](4, 1) = 4156834.260;
161 results[5](5, 1) = 4193939.242;
167 results[6](0, 1) = 4194347.994;
170 results[6](1, 1) = 4160960.410;
173 results[6](2, 1) = 4177573.505;
176 results[6](3, 1) = 4176698.320;
179 results[6](4, 1) = 4156834.270;
182 results[6](5, 1) = 4193939.401;
188 results[7](0, 1) = 4194347.974;
191 results[7](1, 1) = 4160960.612;
194 results[7](2, 1) = 4177573.582;
197 results[7](3, 1) = 4176698.223;
200 results[7](4, 1) = 4156834.271;
203 results[7](5, 1) = 4193939.239;
208 results[9](0, 0) = 435811.2512;
209 results[9](0, 1) = 4194347.9756;
211 results[9](1, 0) = 444059.9337;
212 results[9](1, 1) = 4160960.6109;
214 results[9](2, 0) = 436653.7721;
215 results[9](2, 1) = 4177573.5812;
217 results[9](3, 0) = 406396.5970;
218 results[9](3, 1) = 4176698.2216;
220 results[9](4, 0) = 406657.9894;
221 results[9](4, 1) = 4156834.2734;
223 results[9](5, 0) = 408163.3366;
224 results[9](5, 1) = 4193939.2373;
229 results[10](0, 0) = 435811.2512;
230 results[10](0, 1) = 4194347.9756;
232 results[10](1, 0) = 444059.9337;
233 results[10](1, 1) = 4160960.6109;
235 results[10](2, 0) = 436653.7721;
236 results[10](2, 1) = 4177573.5812;
238 results[10](3, 0) = 406396.5970;
239 results[10](3, 1) = 4176698.2216;
241 results[10](4, 0) = 406657.9894;
242 results[10](4, 1) = 4156834.2734;
244 results[10](5, 0) = 408163.3366;
245 results[10](5, 1) = 4193939.2373;
250 results[11](0, 0) = 435811.156;
251 results[11](0, 1) = 4194347.892;
253 results[11](1, 0) = 444059.719;
254 results[11](1, 1) = 4160960.489;
256 results[11](2, 0) = 436653.606;
257 results[11](2, 1) = 4177573.398;
259 results[11](3, 0) = 406396.045;
260 results[11](3, 1) = 4176697.926;
262 results[11](4, 0) = 406658.812;
263 results[11](4, 1) = 4156834.183;
265 results[11](5, 0) = 408163.542;
266 results[11](5, 1) = 4193940.012;
271 results[12](0, 0) = 435811.095;
272 results[12](0, 1) = 4194348.146;
274 results[12](1, 0) = 444059.906;
275 results[12](1, 1) = 4160960.276;
277 results[12](2, 0) = 436653.748;
278 results[12](2, 1) = 4177573.521;
280 results[12](3, 0) = 406396.375;
281 results[12](3, 1) = 4176698.033;
283 results[12](4, 0) = 406658.370;
284 results[12](4, 1) = 4156834.517;
286 results[12](5, 0) = 408163.386;
287 results[12](5, 1) = 4193939.406;
292 const CVectorDouble& thisResults,
const unsigned int& example,
295 cout <<
"Example " << example <<
". Results" << setprecision(16) << endl;
296 cout <<
"------------------------------------------------------------------" 303 cout <<
"------------------------------------------------------------------" 309 const size_t N = thisResults.
size() / 3;
310 for (
unsigned int i = 0; i < N; ++i)
312 cout <<
names[i] <<
"\t";
313 if (fabs(thisResults[3 * i + 0] -
results[example - 1](i, 0)) <
TH)
317 cout << thisResults[3 * i + 0] <<
"\t";
319 if (fabs(thisResults[3 * i + 1] -
results[example - 1](i, 1)) <
TH)
323 cout << thisResults[3 * i + 1] <<
"\t";
325 if (fabs(thisResults[3 * i + 2] -
results[example - 1](i, 2)) <
TH)
329 cout << thisResults[3 * i + 2] << endl;
336 const size_t N = thisResults.size() / 3;
337 for (
unsigned int i = 0; i < N; ++i)
338 cout <<
names[i] <<
"\t" << thisResults[3 * i + 0] <<
"\t" 339 << thisResults[3 * i + 1] <<
"\t" << thisResults[3 * i + 2]
349 UTMCoords.
x = 435500;
350 UTMCoords.
y = 4194142.057;
351 UTMCoords.
z = 515.579;
354 const char hem =
'n';
357 TEllipsoid ellip = TEllipsoid::Ellipsoid_WGS84();
360 cout <<
"INPUT DATA: " << endl
361 <<
"----------------------------------" << endl;
362 cout <<
"UTM Coordinates: " << endl;
363 cout <<
"X = " << setprecision(15) << UTMCoords.
x << endl;
364 cout <<
"Y = " << UTMCoords.
y << endl;
365 cout <<
"Z = " << UTMCoords.
z << endl;
366 cout <<
"Time zone: " << huso << endl;
367 cout <<
"Hemisphery: " << hem << endl;
368 cout <<
"Ellipsoid: " << ellip.
name << endl;
369 cout <<
"----------------------------------" << endl << endl;
373 cout <<
"UTM to Geodetic" << endl;
374 cout <<
"Geodetic Coordinates:" << endl;
375 cout <<
"Lon = " <<
TCoords(GeodeticCoords.
lon) <<
" [" 376 << GeodeticCoords.
lon <<
"]" << endl;
377 cout <<
"Lat = " <<
TCoords(GeodeticCoords.
lat) <<
" [" 378 << GeodeticCoords.
lon <<
"]" << endl;
379 cout <<
"H = " << GeodeticCoords.
height << endl;
380 cout <<
"----------------------------------" << endl;
385 cout <<
"Geodetic to Geocentric" << endl;
386 cout <<
"Geocentric Coordinates:" << endl;
387 cout <<
"X = " << GeocentricCoords.
x << endl;
388 cout <<
"Y = " << GeocentricCoords.
y << endl;
389 cout <<
"Z = " << GeocentricCoords.
z << endl;
390 cout <<
"----------------------------------" << endl;
395 109.4714, 106.7407, 141.7916, 4.7834, 7.9668, -5.3771, -6.690000);
401 cout <<
"transform7params" << endl;
402 cout <<
"Transformed Geocentric Coordinates:" << endl;
403 cout <<
"X = " << GeocentricCoords2.
x << endl;
404 cout <<
"Y = " << GeocentricCoords2.
y << endl;
405 cout <<
"Z = " << GeocentricCoords2.
z << endl;
406 cout <<
"----------------------------------" << endl;
410 ellip = TEllipsoid::Ellipsoid_Hough_1960();
412 cout <<
"Geocentric to Geodetic" << endl;
413 cout <<
"Geodetic Coordinates:" << endl;
414 cout <<
"Lon = " <<
TCoords(GeodeticCoords2.
lon) <<
" [" 415 << GeodeticCoords2.
lon <<
"]" << endl;
416 cout <<
"Lat = " <<
TCoords(GeodeticCoords2.
lat) <<
" [" 417 << GeodeticCoords2.
lat <<
"]" << endl;
418 cout <<
"H = " << GeodeticCoords2.
height << endl;
419 cout <<
"----------------------------------" << endl;
429 time_zone2, latitude_band2,
TEllipsoid(6378270, 6356794.343,
"USER"));
430 cout <<
"Geodetic to UTM" << endl;
431 cout <<
"UTM Coordinates:" << endl;
432 cout <<
"X = " << UTMCoords2.
x << endl;
433 cout <<
"Y = " << UTMCoords2.
y << endl;
434 cout <<
"Z = " << UTMCoords2.
z << endl;
435 cout <<
"Time zone: " << time_zone2 << endl;
436 cout <<
"----------------------------------" << endl;
452 TCoords(37, 53, 33.072573).getDecimalValue(),
453 TCoords(-3, 43, 52.68965).getDecimalValue(), 515.579);
455 TCoords(37, 35, 31.75505).getDecimalValue(),
456 TCoords(-3, 38, 5.70754).getDecimalValue(), 1489.188);
458 TCoords(37, 44, 29.04253).getDecimalValue(),
459 TCoords(-3, 43, 12.90285).getDecimalValue(), 1054.189);
461 TCoords(37, 43, 51.28918).getDecimalValue(),
462 TCoords(-4, 3, 48.64503).getDecimalValue(), 569.182);
464 TCoords(37, 33, 6.94237).getDecimalValue(),
465 TCoords(-4, 3, 28.81611).getDecimalValue(), 897.626);
467 TCoords(37, 53, 11.26838).getDecimalValue(),
468 TCoords(-4, 2, 44.35794).getDecimalValue(), 530.446);
473 TUTMCoords MAND_UTM, OROZ_UTM, SANC_UTM, ARJO_UTM, CANI_UTM, HALC_UTM;
475 MAND_92633, MAND_UTM, UTMZone, UTMBand, TEllipsoid::Ellipsoid_WGS84());
477 OROZ_96965, OROZ_UTM, UTMZone, UTMBand, TEllipsoid::Ellipsoid_WGS84());
479 SANC_94744, SANC_UTM, UTMZone, UTMBand, TEllipsoid::Ellipsoid_WGS84());
481 ARJO_94633, ARJO_UTM, UTMZone, UTMBand, TEllipsoid::Ellipsoid_WGS84());
483 CANI_96833, CANI_UTM, UTMZone, UTMBand, TEllipsoid::Ellipsoid_WGS84());
485 HALC_92543, HALC_UTM, UTMZone, UTMBand, TEllipsoid::Ellipsoid_WGS84());
490 thisResults[0] = MAND_UTM.
x;
491 thisResults[1] = MAND_UTM.
y;
492 thisResults[2] = MAND_UTM.
z;
493 thisResults[3] = OROZ_UTM.
x;
494 thisResults[4] = OROZ_UTM.
y;
495 thisResults[5] = OROZ_UTM.
z;
496 thisResults[6] = SANC_UTM.
x;
497 thisResults[7] = SANC_UTM.
y;
498 thisResults[8] = SANC_UTM.
z;
499 thisResults[9] = ARJO_UTM.
x;
500 thisResults[10] = ARJO_UTM.
y;
501 thisResults[11] = ARJO_UTM.
z;
502 thisResults[12] = CANI_UTM.
x;
503 thisResults[13] = CANI_UTM.
y;
504 thisResults[14] = CANI_UTM.
z;
505 thisResults[15] = HALC_UTM.
x;
506 thisResults[16] = HALC_UTM.
y;
507 thisResults[17] = HALC_UTM.
z;
515 TCoords(37, 53, 33.072573).getDecimalValue(),
516 TCoords(-3, 43, 52.68965).getDecimalValue(), 515.579);
518 TCoords(37, 35, 31.75505).getDecimalValue(),
519 TCoords(-3, 38, 5.70754).getDecimalValue(), 1489.188);
521 TCoords(37, 44, 29.04253).getDecimalValue(),
522 TCoords(-3, 43, 12.90285).getDecimalValue(), 1054.189);
524 TCoords(37, 43, 51.28918).getDecimalValue(),
525 TCoords(-4, 3, 48.64503).getDecimalValue(), 569.182);
527 TCoords(37, 33, 6.94237).getDecimalValue(),
528 TCoords(-4, 3, 28.81611).getDecimalValue(), 897.626);
530 TCoords(37, 53, 11.26838).getDecimalValue(),
531 TCoords(-4, 2, 44.35794).getDecimalValue(), 530.446);
533 const TEllipsoid ellip = TEllipsoid::Ellipsoid_Internacional_1924();
547 CANI_Geoc2, HALC_Geoc2;
549 131.0320, 100.2510, 163.3540, -1.2438, -0.0195, -1.1436, -9.3900);
570 TUTMCoords MAND_UTM, OROZ_UTM, SANC_UTM, ARJO_UTM, CANI_UTM, HALC_UTM;
581 thisResults[0] = MAND_UTM.
x;
582 thisResults[1] = MAND_UTM.
y;
583 thisResults[2] = MAND_UTM.
z;
584 thisResults[3] = OROZ_UTM.
x;
585 thisResults[4] = OROZ_UTM.
y;
586 thisResults[5] = OROZ_UTM.
z;
587 thisResults[6] = SANC_UTM.
x;
588 thisResults[7] = SANC_UTM.
y;
589 thisResults[8] = SANC_UTM.
z;
590 thisResults[9] = ARJO_UTM.
x;
591 thisResults[10] = ARJO_UTM.
y;
592 thisResults[11] = ARJO_UTM.
z;
593 thisResults[12] = CANI_UTM.
x;
594 thisResults[13] = CANI_UTM.
y;
595 thisResults[14] = CANI_UTM.
z;
596 thisResults[15] = HALC_UTM.
x;
597 thisResults[16] = HALC_UTM.
y;
598 thisResults[17] = HALC_UTM.
z;
607 TCoords(37, 53, 33.072573).getDecimalValue(),
608 TCoords(-3, 43, 52.68965).getDecimalValue(), 515.579);
610 TCoords(37, 35, 31.75505).getDecimalValue(),
611 TCoords(-3, 38, 5.70754).getDecimalValue(), 1489.188);
613 TCoords(37, 44, 29.04253).getDecimalValue(),
614 TCoords(-3, 43, 12.90285).getDecimalValue(), 1054.189);
616 TCoords(37, 43, 51.28918).getDecimalValue(),
617 TCoords(-4, 3, 48.64503).getDecimalValue(), 569.182);
619 TCoords(37, 33, 6.94237).getDecimalValue(),
620 TCoords(-4, 3, 28.81611).getDecimalValue(), 897.626);
622 TCoords(37, 53, 11.26838).getDecimalValue(),
623 TCoords(-4, 2, 44.35794).getDecimalValue(), 530.446);
625 const TEllipsoid ellip = TEllipsoid::Ellipsoid_WGS84();
630 TUTMCoords MAND_UTM, OROZ_UTM, SANC_UTM, ARJO_UTM, CANI_UTM, HALC_UTM;
631 geodeticToUTM(MAND_92633, MAND_UTM, UTMZone, UTMBand, ellip);
632 geodeticToUTM(OROZ_96965, OROZ_UTM, UTMZone, UTMBand, ellip);
633 geodeticToUTM(SANC_94744, SANC_UTM, UTMZone, UTMBand, ellip);
634 geodeticToUTM(ARJO_94633, ARJO_UTM, UTMZone, UTMBand, ellip);
635 geodeticToUTM(CANI_96833, CANI_UTM, UTMZone, UTMBand, ellip);
636 geodeticToUTM(HALC_92543, HALC_UTM, UTMZone, UTMBand, ellip);
639 TPoint2D MAND_point, OROZ_point, SANC_point, ARJO_point, CANI_point,
642 1.0000008551, 0.0000002900, 110.1121641064, 202.4657352579);
644 TPoint2D(MAND_UTM.
x, MAND_UTM.
y), datum, MAND_point);
646 TPoint2D(OROZ_UTM.
x, OROZ_UTM.
y), datum, OROZ_point);
648 TPoint2D(SANC_UTM.
x, SANC_UTM.
y), datum, SANC_point);
650 TPoint2D(ARJO_UTM.
x, ARJO_UTM.
y), datum, ARJO_point);
652 TPoint2D(CANI_UTM.
x, CANI_UTM.
y), datum, CANI_point);
654 TPoint2D(HALC_UTM.
x, HALC_UTM.
y), datum, HALC_point);
659 thisResults[0] = MAND_point.
x;
660 thisResults[1] = MAND_point.
y;
661 thisResults[2] = MAND_UTM.
z;
662 thisResults[3] = OROZ_point.
x;
663 thisResults[4] = OROZ_point.
y;
664 thisResults[5] = OROZ_UTM.
z;
665 thisResults[6] = SANC_point.
x;
666 thisResults[7] = SANC_point.
y;
667 thisResults[8] = SANC_UTM.
z;
668 thisResults[9] = ARJO_point.
x;
669 thisResults[10] = ARJO_point.
y;
670 thisResults[11] = ARJO_UTM.
z;
671 thisResults[12] = CANI_point.
x;
672 thisResults[13] = CANI_point.
y;
673 thisResults[14] = CANI_UTM.
z;
674 thisResults[15] = HALC_point.
x;
675 thisResults[16] = HALC_point.
y;
676 thisResults[17] = HALC_UTM.
z;
685 TCoords(37, 53, 33.072573).getDecimalValue(),
686 TCoords(-3, 43, 52.68965).getDecimalValue(), 515.579);
688 TCoords(37, 35, 31.75505).getDecimalValue(),
689 TCoords(-3, 38, 5.70754).getDecimalValue(), 1489.188);
691 TCoords(37, 44, 29.04253).getDecimalValue(),
692 TCoords(-3, 43, 12.90285).getDecimalValue(), 1054.189);
694 TCoords(37, 43, 51.28918).getDecimalValue(),
695 TCoords(-4, 3, 48.64503).getDecimalValue(), 569.182);
697 TCoords(37, 33, 6.94237).getDecimalValue(),
698 TCoords(-4, 3, 28.81611).getDecimalValue(), 897.626);
700 TCoords(37, 53, 11.26838).getDecimalValue(),
701 TCoords(-4, 2, 44.35794).getDecimalValue(), 530.446);
703 const TEllipsoid ellip = TEllipsoid::Ellipsoid_WGS84();
708 TUTMCoords MAND_UTM, OROZ_UTM, SANC_UTM, ARJO_UTM, CANI_UTM, HALC_UTM;
709 geodeticToUTM(MAND_92633, MAND_UTM, UTMZone, UTMBand, ellip);
710 geodeticToUTM(OROZ_96965, OROZ_UTM, UTMZone, UTMBand, ellip);
711 geodeticToUTM(SANC_94744, SANC_UTM, UTMZone, UTMBand, ellip);
712 geodeticToUTM(ARJO_94633, ARJO_UTM, UTMZone, UTMBand, ellip);
713 geodeticToUTM(CANI_96833, CANI_UTM, UTMZone, UTMBand, ellip);
714 geodeticToUTM(HALC_92543, HALC_UTM, UTMZone, UTMBand, ellip);
717 TUTMCoords MAND_point, OROZ_point, SANC_point, ARJO_point, CANI_point,
720 0.9999969509, -0.0000070551, 142.4402790576, -0.0000060616,
721 1.0000054540, 185.6991268722, -49.4041666667);
732 thisResults[0] = MAND_point.
x;
733 thisResults[1] = MAND_point.
y;
734 thisResults[2] = MAND_point.
z;
735 thisResults[3] = OROZ_point.
x;
736 thisResults[4] = OROZ_point.
y;
737 thisResults[5] = OROZ_point.
z;
738 thisResults[6] = SANC_point.
x;
739 thisResults[7] = SANC_point.
y;
740 thisResults[8] = SANC_point.
z;
741 thisResults[9] = ARJO_point.
x;
742 thisResults[10] = ARJO_point.
y;
743 thisResults[11] = ARJO_point.
z;
744 thisResults[12] = CANI_point.
x;
745 thisResults[13] = CANI_point.
y;
746 thisResults[14] = CANI_point.
z;
747 thisResults[15] = HALC_point.
x;
748 thisResults[16] = HALC_point.
y;
749 thisResults[17] = HALC_point.
z;
758 TCoords(37, 53, 33.072573).getDecimalValue(),
759 TCoords(-3, 43, 52.68965).getDecimalValue(), 515.579);
761 TCoords(37, 35, 31.75505).getDecimalValue(),
762 TCoords(-3, 38, 5.70754).getDecimalValue(), 1489.188);
764 TCoords(37, 44, 29.04253).getDecimalValue(),
765 TCoords(-3, 43, 12.90285).getDecimalValue(), 1054.189);
767 TCoords(37, 43, 51.28918).getDecimalValue(),
768 TCoords(-4, 3, 48.64503).getDecimalValue(), 569.182);
770 TCoords(37, 33, 6.94237).getDecimalValue(),
771 TCoords(-4, 3, 28.81611).getDecimalValue(), 897.626);
773 TCoords(37, 53, 11.26838).getDecimalValue(),
774 TCoords(-4, 2, 44.35794).getDecimalValue(), 530.446);
781 TUTMCoords MAND_UTM, OROZ_UTM, SANC_UTM, ARJO_UTM, CANI_UTM, HALC_UTM;
782 geodeticToUTM(MAND_92633, MAND_UTM, UTMZone, UTMBand, ellip);
783 geodeticToUTM(OROZ_96965, OROZ_UTM, UTMZone, UTMBand, ellip);
784 geodeticToUTM(SANC_94744, SANC_UTM, UTMZone, UTMBand, ellip);
785 geodeticToUTM(ARJO_94633, ARJO_UTM, UTMZone, UTMBand, ellip);
786 geodeticToUTM(CANI_96833, CANI_UTM, UTMZone, UTMBand, ellip);
787 geodeticToUTM(HALC_92543, HALC_UTM, UTMZone, UTMBand, ellip);
790 TUTMCoords MAND_point, OROZ_point, SANC_point, ARJO_point, CANI_point,
793 109.035107801496, 202.610276063935, 32.727057571807, 0.9999999999,
794 0.0000005460, 0.0000156068, -0.0000005463, 0.9999999998, 0.0000180851,
795 -0.0000156068, -0.0000180851, 0.9999999997, 0.842993545636);
806 thisResults[0] = MAND_point.
x;
807 thisResults[1] = MAND_point.
y;
808 thisResults[2] = MAND_point.
z;
809 thisResults[3] = OROZ_point.
x;
810 thisResults[4] = OROZ_point.
y;
811 thisResults[5] = OROZ_point.
z;
812 thisResults[6] = SANC_point.
x;
813 thisResults[7] = SANC_point.
y;
814 thisResults[8] = SANC_point.
z;
815 thisResults[9] = ARJO_point.
x;
816 thisResults[10] = ARJO_point.
y;
817 thisResults[11] = ARJO_point.
z;
818 thisResults[12] = CANI_point.
x;
819 thisResults[13] = CANI_point.
y;
820 thisResults[14] = CANI_point.
z;
821 thisResults[15] = HALC_point.
x;
822 thisResults[16] = HALC_point.
y;
823 thisResults[17] = HALC_point.
z;
831 TCoords(37, 53, 33.072573).getDecimalValue(),
832 TCoords(-3, 43, 52.68965).getDecimalValue(), 515.579);
834 TCoords(37, 35, 31.75505).getDecimalValue(),
835 TCoords(-3, 38, 5.70754).getDecimalValue(), 1489.188);
837 TCoords(37, 44, 29.04253).getDecimalValue(),
838 TCoords(-3, 43, 12.90285).getDecimalValue(), 1054.189);
840 TCoords(37, 43, 51.28918).getDecimalValue(),
841 TCoords(-4, 3, 48.64503).getDecimalValue(), 569.182);
843 TCoords(37, 33, 6.94237).getDecimalValue(),
844 TCoords(-4, 3, 28.81611).getDecimalValue(), 897.626);
846 TCoords(37, 53, 11.26838).getDecimalValue(),
847 TCoords(-4, 2, 44.35794).getDecimalValue(), 530.446);
849 const TEllipsoid ellip = TEllipsoid::Ellipsoid_Internacional_1924();
863 CANI_Geoc2, HALC_Geoc2;
865 131.0320, 100.2510, 163.3540, -1.2438, -0.0195, -1.1436, -9.3900);
886 TUTMCoords MAND_UTM, OROZ_UTM, SANC_UTM, ARJO_UTM, CANI_UTM, HALC_UTM;
897 thisResults[0] = MAND_UTM.
x;
898 thisResults[1] = MAND_UTM.
y;
899 thisResults[2] = MAND_UTM.
z;
900 thisResults[3] = OROZ_UTM.
x;
901 thisResults[4] = OROZ_UTM.
y;
902 thisResults[5] = OROZ_UTM.
z;
903 thisResults[6] = SANC_UTM.
x;
904 thisResults[7] = SANC_UTM.
y;
905 thisResults[8] = SANC_UTM.
z;
906 thisResults[9] = ARJO_UTM.
x;
907 thisResults[10] = ARJO_UTM.
y;
908 thisResults[11] = ARJO_UTM.
z;
909 thisResults[12] = CANI_UTM.
x;
910 thisResults[13] = CANI_UTM.
y;
911 thisResults[14] = CANI_UTM.
z;
912 thisResults[15] = HALC_UTM.
x;
913 thisResults[16] = HALC_UTM.
y;
914 thisResults[17] = HALC_UTM.
z;
919 TPoint2D MAND_point, OROZ_point, SANC_point, ARJO_point, CANI_point,
922 0.9999980621, 0.0000078756, -31.7350304827, 10.8014994871);
924 TPoint2D(MAND_UTM.
x, MAND_UTM.
y), dat, MAND_point);
926 TPoint2D(OROZ_UTM.
x, OROZ_UTM.
y), dat, OROZ_point);
928 TPoint2D(SANC_UTM.
x, SANC_UTM.
y), dat, SANC_point);
930 TPoint2D(ARJO_UTM.
x, ARJO_UTM.
y), dat, ARJO_point);
932 TPoint2D(CANI_UTM.
x, CANI_UTM.
y), dat, CANI_point);
934 TPoint2D(HALC_UTM.
x, HALC_UTM.
y), dat, HALC_point);
936 thisResults[0] = MAND_point.
x;
937 thisResults[1] = MAND_point.
y;
938 thisResults[2] = MAND_UTM.
z;
939 thisResults[3] = OROZ_point.
x;
940 thisResults[4] = OROZ_point.
y;
941 thisResults[5] = OROZ_UTM.
z;
942 thisResults[6] = SANC_point.
x;
943 thisResults[7] = SANC_point.
y;
944 thisResults[8] = SANC_UTM.
z;
945 thisResults[9] = ARJO_point.
x;
946 thisResults[10] = ARJO_point.
y;
947 thisResults[11] = ARJO_UTM.
z;
948 thisResults[12] = CANI_point.
x;
949 thisResults[13] = CANI_point.
y;
950 thisResults[14] = CANI_UTM.
z;
951 thisResults[15] = HALC_point.
x;
952 thisResults[16] = HALC_point.
y;
953 thisResults[17] = HALC_UTM.
z;
961 TCoords(37, 53, 33.072573).getDecimalValue(),
962 TCoords(-3, 43, 52.68965).getDecimalValue(), 515.579);
964 TCoords(37, 35, 31.75505).getDecimalValue(),
965 TCoords(-3, 38, 5.70754).getDecimalValue(), 1489.188);
967 TCoords(37, 44, 29.04253).getDecimalValue(),
968 TCoords(-3, 43, 12.90285).getDecimalValue(), 1054.189);
970 TCoords(37, 43, 51.28918).getDecimalValue(),
971 TCoords(-4, 3, 48.64503).getDecimalValue(), 569.182);
973 TCoords(37, 33, 6.94237).getDecimalValue(),
974 TCoords(-4, 3, 28.81611).getDecimalValue(), 897.626);
976 TCoords(37, 53, 11.26838).getDecimalValue(),
977 TCoords(-4, 2, 44.35794).getDecimalValue(), 530.446);
979 const TEllipsoid ellip = TEllipsoid::Ellipsoid_Internacional_1924();
993 CANI_Geoc2, HALC_Geoc2;
995 131.0320, 100.2510, 163.3540, -1.2438, -0.0195, -1.1436, -9.3900);
1004 TGeodeticCoords MAND_Geod, OROZ_Geod, SANC_Geod, ARJO_Geod, CANI_Geod,
1016 TUTMCoords MAND_UTM, OROZ_UTM, SANC_UTM, ARJO_UTM, CANI_UTM, HALC_UTM;
1017 geodeticToUTM(MAND_Geod, MAND_UTM, UTMZone, UTMBand, ellip);
1018 geodeticToUTM(OROZ_Geod, OROZ_UTM, UTMZone, UTMBand, ellip);
1019 geodeticToUTM(SANC_Geod, SANC_UTM, UTMZone, UTMBand, ellip);
1020 geodeticToUTM(ARJO_Geod, ARJO_UTM, UTMZone, UTMBand, ellip);
1021 geodeticToUTM(CANI_Geod, CANI_UTM, UTMZone, UTMBand, ellip);
1022 geodeticToUTM(HALC_Geod, HALC_UTM, UTMZone, UTMBand, ellip);
1027 thisResults[0] = MAND_UTM.
x;
1028 thisResults[1] = MAND_UTM.
y;
1029 thisResults[2] = MAND_UTM.
z;
1030 thisResults[3] = OROZ_UTM.
x;
1031 thisResults[4] = OROZ_UTM.
y;
1032 thisResults[5] = OROZ_UTM.
z;
1033 thisResults[6] = SANC_UTM.
x;
1034 thisResults[7] = SANC_UTM.
y;
1035 thisResults[8] = SANC_UTM.
z;
1036 thisResults[9] = ARJO_UTM.
x;
1037 thisResults[10] = ARJO_UTM.
y;
1038 thisResults[11] = ARJO_UTM.
z;
1039 thisResults[12] = CANI_UTM.
x;
1040 thisResults[13] = CANI_UTM.
y;
1041 thisResults[14] = CANI_UTM.
z;
1042 thisResults[15] = HALC_UTM.
x;
1043 thisResults[16] = HALC_UTM.
y;
1044 thisResults[17] = HALC_UTM.
z;
1049 TPoint3D MAND_point, OROZ_point, SANC_point, ARJO_point, CANI_point,
1052 0.9999944446, 0.0000005236, 0.5022460081, -0.0000136628, 1.0000023039,
1053 -4.4675776973, 29.2747378118);
1061 thisResults[0] = MAND_point.
x;
1062 thisResults[1] = MAND_point.
y;
1063 thisResults[2] = MAND_point.
z;
1064 thisResults[3] = OROZ_point.
x;
1065 thisResults[4] = OROZ_point.
y;
1066 thisResults[5] = OROZ_point.
z;
1067 thisResults[6] = SANC_point.
x;
1068 thisResults[7] = SANC_point.
y;
1069 thisResults[8] = SANC_point.
z;
1070 thisResults[9] = ARJO_point.
x;
1071 thisResults[10] = ARJO_point.
y;
1072 thisResults[11] = ARJO_point.
z;
1073 thisResults[12] = CANI_point.
x;
1074 thisResults[13] = CANI_point.
y;
1075 thisResults[14] = CANI_point.
z;
1076 thisResults[15] = HALC_point.
x;
1077 thisResults[16] = HALC_point.
y;
1078 thisResults[17] = HALC_point.
z;
1086 TCoords(37, 53, 33.072573).getDecimalValue(),
1087 TCoords(-3, 43, 52.68965).getDecimalValue(), 515.579);
1089 TCoords(37, 35, 31.75505).getDecimalValue(),
1090 TCoords(-3, 38, 5.70754).getDecimalValue(), 1489.188);
1092 TCoords(37, 44, 29.04253).getDecimalValue(),
1093 TCoords(-3, 43, 12.90285).getDecimalValue(), 1054.189);
1095 TCoords(37, 43, 51.28918).getDecimalValue(),
1096 TCoords(-4, 3, 48.64503).getDecimalValue(), 569.182);
1098 TCoords(37, 33, 6.94237).getDecimalValue(),
1099 TCoords(-4, 3, 28.81611).getDecimalValue(), 897.626);
1101 TCoords(37, 53, 11.26838).getDecimalValue(),
1102 TCoords(-4, 2, 44.35794).getDecimalValue(), 530.446);
1104 const TEllipsoid ellip = TEllipsoid::Ellipsoid_Internacional_1924();
1118 CANI_Geoc2, HALC_Geoc2;
1120 131.0320, 100.2510, 163.3540, -1.2438, -0.0195, -1.1436, -9.3900);
1129 TGeodeticCoords MAND_Geod, OROZ_Geod, SANC_Geod, ARJO_Geod, CANI_Geod,
1141 TUTMCoords MAND_UTM, OROZ_UTM, SANC_UTM, ARJO_UTM, CANI_UTM, HALC_UTM;
1142 geodeticToUTM(MAND_Geod, MAND_UTM, UTMZone, UTMBand, ellip);
1143 geodeticToUTM(OROZ_Geod, OROZ_UTM, UTMZone, UTMBand, ellip);
1144 geodeticToUTM(SANC_Geod, SANC_UTM, UTMZone, UTMBand, ellip);
1145 geodeticToUTM(ARJO_Geod, ARJO_UTM, UTMZone, UTMBand, ellip);
1146 geodeticToUTM(CANI_Geod, CANI_UTM, UTMZone, UTMBand, ellip);
1147 geodeticToUTM(HALC_Geod, HALC_UTM, UTMZone, UTMBand, ellip);
1152 thisResults[0] = MAND_UTM.
x;
1153 thisResults[1] = MAND_UTM.
y;
1154 thisResults[2] = MAND_UTM.
z;
1155 thisResults[3] = OROZ_UTM.
x;
1156 thisResults[4] = OROZ_UTM.
y;
1157 thisResults[5] = OROZ_UTM.
z;
1158 thisResults[6] = SANC_UTM.
x;
1159 thisResults[7] = SANC_UTM.
y;
1160 thisResults[8] = SANC_UTM.
z;
1161 thisResults[9] = ARJO_UTM.
x;
1162 thisResults[10] = ARJO_UTM.
y;
1163 thisResults[11] = ARJO_UTM.
z;
1164 thisResults[12] = CANI_UTM.
x;
1165 thisResults[13] = CANI_UTM.
y;
1166 thisResults[14] = CANI_UTM.
z;
1167 thisResults[15] = HALC_UTM.
x;
1168 thisResults[16] = HALC_UTM.
y;
1169 thisResults[17] = HALC_UTM.
z;
1175 CANI_Geoc3, HALC_Geoc3;
1180 -34.095438458048, 10.843234125336, 212.169692142148, 0.9999999994,
1181 0.0000084308, 0.0000327341, -0.0000084321, 0.9999999991, 0.0000404737,
1182 -0.0000327338, -0.0000404737, 0.9999999986, -1.898114919019);
1190 thisResults[0] = MAND_Geoc3.
x;
1191 thisResults[1] = MAND_Geoc3.
y;
1192 thisResults[2] = MAND_Geoc3.
z;
1193 thisResults[3] = OROZ_Geoc3.
x;
1194 thisResults[4] = OROZ_Geoc3.
y;
1195 thisResults[5] = OROZ_Geoc3.
z;
1196 thisResults[6] = SANC_Geoc3.
x;
1197 thisResults[7] = SANC_Geoc3.
y;
1198 thisResults[8] = SANC_Geoc3.
z;
1199 thisResults[9] = ARJO_Geoc3.
x;
1200 thisResults[10] = ARJO_Geoc3.
y;
1201 thisResults[11] = ARJO_Geoc3.
z;
1202 thisResults[12] = CANI_Geoc3.
x;
1203 thisResults[13] = CANI_Geoc3.
y;
1204 thisResults[14] = CANI_Geoc3.
z;
1205 thisResults[15] = HALC_Geoc3.
x;
1206 thisResults[16] = HALC_Geoc3.
y;
1207 thisResults[17] = HALC_Geoc3.
z;
1215 TCoords(37, 53, 33.072573).getDecimalValue(),
1216 TCoords(-3, 43, 52.68965).getDecimalValue(), 515.579);
1218 TCoords(37, 35, 31.75505).getDecimalValue(),
1219 TCoords(-3, 38, 5.70754).getDecimalValue(), 1489.188);
1221 TCoords(37, 44, 29.04253).getDecimalValue(),
1222 TCoords(-3, 43, 12.90285).getDecimalValue(), 1054.189);
1224 TCoords(37, 43, 51.28918).getDecimalValue(),
1225 TCoords(-4, 3, 48.64503).getDecimalValue(), 569.182);
1227 TCoords(37, 33, 6.94237).getDecimalValue(),
1228 TCoords(-4, 3, 28.81611).getDecimalValue(), 897.626);
1230 TCoords(37, 53, 11.26838).getDecimalValue(),
1231 TCoords(-4, 2, 44.35794).getDecimalValue(), 530.446);
1233 const TEllipsoid ellip = TEllipsoid::Ellipsoid_Hayford_1909();
1247 CANI_Geoc2, HALC_Geoc2;
1249 284.2535, -116.9549, -34.8027, 4.78337, 7.96684, -5.37707, -6.6900);
1258 TGeodeticCoords MAND_Geod, OROZ_Geod, SANC_Geod, ARJO_Geod, CANI_Geod,
1270 TUTMCoords MAND_UTM, OROZ_UTM, SANC_UTM, ARJO_UTM, CANI_UTM, HALC_UTM;
1271 geodeticToUTM(MAND_Geod, MAND_UTM, UTMZone, UTMBand, ellip);
1272 geodeticToUTM(OROZ_Geod, OROZ_UTM, UTMZone, UTMBand, ellip);
1273 geodeticToUTM(SANC_Geod, SANC_UTM, UTMZone, UTMBand, ellip);
1274 geodeticToUTM(ARJO_Geod, ARJO_UTM, UTMZone, UTMBand, ellip);
1275 geodeticToUTM(CANI_Geod, CANI_UTM, UTMZone, UTMBand, ellip);
1276 geodeticToUTM(HALC_Geod, HALC_UTM, UTMZone, UTMBand, ellip);
1281 thisResults[0] = MAND_UTM.
x;
1282 thisResults[1] = MAND_UTM.
y;
1283 thisResults[2] = MAND_UTM.
z;
1284 thisResults[3] = OROZ_UTM.
x;
1285 thisResults[4] = OROZ_UTM.
y;
1286 thisResults[5] = OROZ_UTM.
z;
1287 thisResults[6] = SANC_UTM.
x;
1288 thisResults[7] = SANC_UTM.
y;
1289 thisResults[8] = SANC_UTM.
z;
1290 thisResults[9] = ARJO_UTM.
x;
1291 thisResults[10] = ARJO_UTM.
y;
1292 thisResults[11] = ARJO_UTM.
z;
1293 thisResults[12] = CANI_UTM.
x;
1294 thisResults[13] = CANI_UTM.
y;
1295 thisResults[14] = CANI_UTM.
z;
1296 thisResults[15] = HALC_UTM.
x;
1297 thisResults[16] = HALC_UTM.
y;
1298 thisResults[17] = HALC_UTM.
z;
1306 TCoords(37, 53, 33.072573).getDecimalValue(),
1307 TCoords(-3, 43, 52.68965).getDecimalValue(), 515.579);
1309 TCoords(37, 35, 31.75505).getDecimalValue(),
1310 TCoords(-3, 38, 5.70754).getDecimalValue(), 1489.188);
1312 TCoords(37, 44, 29.04253).getDecimalValue(),
1313 TCoords(-3, 43, 12.90285).getDecimalValue(), 1054.189);
1315 TCoords(37, 43, 51.28918).getDecimalValue(),
1316 TCoords(-4, 3, 48.64503).getDecimalValue(), 569.182);
1318 TCoords(37, 33, 6.94237).getDecimalValue(),
1319 TCoords(-4, 3, 28.81611).getDecimalValue(), 897.626);
1321 TCoords(37, 53, 11.26838).getDecimalValue(),
1322 TCoords(-4, 2, 44.35794).getDecimalValue(), 530.446);
1324 const TEllipsoid ellip = TEllipsoid::Ellipsoid_Hayford_1909();
1338 CANI_Geoc2, HALC_Geoc2;
1340 109.4714, 106.7407, 141.7916, 5039726.4242, -341417.6071, 3882515.5524,
1341 4.78337, 7.96684, -5.37707, -6.6900);
1350 TGeodeticCoords MAND_Geod, OROZ_Geod, SANC_Geod, ARJO_Geod, CANI_Geod,
1362 TUTMCoords MAND_UTM, OROZ_UTM, SANC_UTM, ARJO_UTM, CANI_UTM, HALC_UTM;
1363 geodeticToUTM(MAND_Geod, MAND_UTM, UTMZone, UTMBand, ellip);
1364 geodeticToUTM(OROZ_Geod, OROZ_UTM, UTMZone, UTMBand, ellip);
1365 geodeticToUTM(SANC_Geod, SANC_UTM, UTMZone, UTMBand, ellip);
1366 geodeticToUTM(ARJO_Geod, ARJO_UTM, UTMZone, UTMBand, ellip);
1367 geodeticToUTM(CANI_Geod, CANI_UTM, UTMZone, UTMBand, ellip);
1368 geodeticToUTM(HALC_Geod, HALC_UTM, UTMZone, UTMBand, ellip);
1373 thisResults[0] = MAND_UTM.
x;
1374 thisResults[1] = MAND_UTM.
y;
1375 thisResults[2] = MAND_UTM.
z;
1376 thisResults[3] = OROZ_UTM.
x;
1377 thisResults[4] = OROZ_UTM.
y;
1378 thisResults[5] = OROZ_UTM.
z;
1379 thisResults[6] = SANC_UTM.
x;
1380 thisResults[7] = SANC_UTM.
y;
1381 thisResults[8] = SANC_UTM.
z;
1382 thisResults[9] = ARJO_UTM.
x;
1383 thisResults[10] = ARJO_UTM.
y;
1384 thisResults[11] = ARJO_UTM.
z;
1385 thisResults[12] = CANI_UTM.
x;
1386 thisResults[13] = CANI_UTM.
y;
1387 thisResults[14] = CANI_UTM.
z;
1388 thisResults[15] = HALC_UTM.
x;
1389 thisResults[16] = HALC_UTM.
y;
1390 thisResults[17] = HALC_UTM.
z;
1398 TCoords(37, 53, 33.072573).getDecimalValue(),
1399 TCoords(-3, 43, 52.68965).getDecimalValue(), 515.579);
1401 TCoords(37, 35, 31.75505).getDecimalValue(),
1402 TCoords(-3, 38, 5.70754).getDecimalValue(), 1489.188);
1404 TCoords(37, 44, 29.04253).getDecimalValue(),
1405 TCoords(-3, 43, 12.90285).getDecimalValue(), 1054.189);
1407 TCoords(37, 43, 51.28918).getDecimalValue(),
1408 TCoords(-4, 3, 48.64503).getDecimalValue(), 569.182);
1410 TCoords(37, 33, 6.94237).getDecimalValue(),
1411 TCoords(-4, 3, 28.81611).getDecimalValue(), 897.626);
1413 TCoords(37, 53, 11.26838).getDecimalValue(),
1414 TCoords(-4, 2, 44.35794).getDecimalValue(), 530.446);
1416 const TEllipsoid ellip = TEllipsoid::Ellipsoid_Hayford_1909();
1421 TUTMCoords MAND_UTM, OROZ_UTM, SANC_UTM, ARJO_UTM, CANI_UTM, HALC_UTM;
1422 geodeticToUTM(MAND_92633, MAND_UTM, UTMZone, UTMBand, ellip);
1423 geodeticToUTM(OROZ_96965, OROZ_UTM, UTMZone, UTMBand, ellip);
1424 geodeticToUTM(SANC_94744, SANC_UTM, UTMZone, UTMBand, ellip);
1425 geodeticToUTM(ARJO_94633, ARJO_UTM, UTMZone, UTMBand, ellip);
1426 geodeticToUTM(CANI_96833, CANI_UTM, UTMZone, UTMBand, ellip);
1427 geodeticToUTM(HALC_92543, HALC_UTM, UTMZone, UTMBand, ellip);
1430 TPoint2D MAND_point, OROZ_point, SANC_point, ARJO_point, CANI_point,
1433 15.8778, 0.4491,
TCoords(0, 32, 8.75881).getDecimalValue() ,
1434 -325.9604, 422956.6976, 4176709.7722);
1443 TPoint3D MAND_point2, OROZ_point2, SANC_point2, ARJO_point2, CANI_point2,
1447 TPoint3D(MAND_point.
x, MAND_point.
y, MAND_UTM.
z), datum, MAND_point2);
1449 TPoint3D(OROZ_point.
x, OROZ_point.
y, OROZ_UTM.
z), datum, OROZ_point2);
1451 TPoint3D(SANC_point.
x, SANC_point.
y, SANC_UTM.
z), datum, SANC_point2);
1453 TPoint3D(ARJO_point.
x, ARJO_point.
y, ARJO_UTM.
z), datum, ARJO_point2);
1455 TPoint3D(CANI_point.
x, CANI_point.
y, CANI_UTM.
z), datum, CANI_point2);
1457 TPoint3D(HALC_point.
x, HALC_point.
y, HALC_UTM.
z), datum, HALC_point2);
1462 thisResults[0] = MAND_point2.
x;
1463 thisResults[1] = MAND_point2.
y;
1464 thisResults[2] = MAND_point2.
z;
1465 thisResults[3] = OROZ_point2.
x;
1466 thisResults[4] = OROZ_point2.
y;
1467 thisResults[5] = OROZ_point2.
z;
1468 thisResults[6] = SANC_point2.
x;
1469 thisResults[7] = SANC_point2.
y;
1470 thisResults[8] = SANC_point2.
z;
1471 thisResults[9] = ARJO_point2.
x;
1472 thisResults[10] = ARJO_point2.
y;
1473 thisResults[11] = ARJO_point2.
z;
1474 thisResults[12] = CANI_point2.
x;
1475 thisResults[13] = CANI_point2.
y;
1476 thisResults[14] = CANI_point2.
z;
1477 thisResults[15] = HALC_point2.
x;
1478 thisResults[16] = HALC_point2.
y;
1479 thisResults[17] = HALC_point2.
z;
1487 TCoords(37, 53, 33.072573).getDecimalValue(),
1488 TCoords(-3, 43, 52.68965).getDecimalValue(), 515.579);
1490 TCoords(37, 35, 31.75505).getDecimalValue(),
1491 TCoords(-3, 38, 5.70754).getDecimalValue(), 1489.188);
1493 TCoords(37, 44, 29.04253).getDecimalValue(),
1494 TCoords(-3, 43, 12.90285).getDecimalValue(), 1054.189);
1496 TCoords(37, 43, 51.28918).getDecimalValue(),
1497 TCoords(-4, 3, 48.64503).getDecimalValue(), 569.182);
1499 TCoords(37, 33, 6.94237).getDecimalValue(),
1500 TCoords(-4, 3, 28.81611).getDecimalValue(), 897.626);
1502 TCoords(37, 53, 11.26838).getDecimalValue(),
1503 TCoords(-4, 2, 44.35794).getDecimalValue(), 530.446);
1505 const TEllipsoid ellip = TEllipsoid::Ellipsoid_Hayford_1909();
1510 TUTMCoords MAND_UTM, OROZ_UTM, SANC_UTM, ARJO_UTM, CANI_UTM, HALC_UTM;
1511 geodeticToUTM(MAND_92633, MAND_UTM, UTMZone, UTMBand, ellip);
1512 geodeticToUTM(OROZ_96965, OROZ_UTM, UTMZone, UTMBand, ellip);
1513 geodeticToUTM(SANC_94744, SANC_UTM, UTMZone, UTMBand, ellip);
1514 geodeticToUTM(ARJO_94633, ARJO_UTM, UTMZone, UTMBand, ellip);
1515 geodeticToUTM(CANI_96833, CANI_UTM, UTMZone, UTMBand, ellip);
1516 geodeticToUTM(HALC_92543, HALC_UTM, UTMZone, UTMBand, ellip);
1519 TPoint3D MAND_point, OROZ_point, SANC_point, ARJO_point, CANI_point,
1522 423150.0514, 4197393.9437, -334.2393 , -314.2785 ,
1532 TPoint3D MAND_point2, OROZ_point2, SANC_point2, ARJO_point2, CANI_point2,
1545 thisResults[0] = MAND_point2.
x;
1546 thisResults[1] = MAND_point2.
y;
1547 thisResults[2] = MAND_point2.
z;
1548 thisResults[3] = OROZ_point2.
x;
1549 thisResults[4] = OROZ_point2.
y;
1550 thisResults[5] = OROZ_point2.
z;
1551 thisResults[6] = SANC_point2.
x;
1552 thisResults[7] = SANC_point2.
y;
1553 thisResults[8] = SANC_point2.
z;
1554 thisResults[9] = ARJO_point2.
x;
1555 thisResults[10] = ARJO_point2.
y;
1556 thisResults[11] = ARJO_point2.
z;
1557 thisResults[12] = CANI_point2.
x;
1558 thisResults[13] = CANI_point2.
y;
1559 thisResults[14] = CANI_point2.
z;
1560 thisResults[15] = HALC_point2.
x;
1561 thisResults[16] = HALC_point2.
y;
1562 thisResults[17] = HALC_point2.
z;
1574 cout <<
"**************************************" << endl;
1575 cout <<
"\tTOPCON with th = " <<
TH << endl;
1576 cout <<
"**************************************" << endl;
1587 cout <<
"**************************************" << endl;
1588 cout <<
"\tLEICA with th = " <<
TH << endl;
1589 cout <<
"**************************************" << endl;
1591 cout <<
"Example 09 missing in pdf" << endl;
1599 catch (
const std::exception& e)
1606 printf(
"Another exception!!");
void transformHelmert2D_TOPCON(const mrpt::math::TPoint2D &p, const TDatumHelmert2D_TOPCON &d, mrpt::math::TPoint2D &o)
Helmert 2D transformation: [ X Y ]_WGS84 = [ dX dY ] + ( 1 + dS ) [ cos(alpha) -sin(alpha); sin(alpha...
void TestCoordinatesConversions()
void transformHelmert2D(const mrpt::math::TPoint2D &p, const TDatumHelmert2D &d, mrpt::math::TPoint2D &o)
Helmert 2D transformation: [ X Y ]_WGS84 = [ dX dY ] + ( 1 + dS ) [ cos(alpha) -sin(alpha); sin(alpha...
This class is a "CSerializable" wrapper for "CMatrixDynamic<double>".
void displayResults(const CVectorDouble &thisResults, const unsigned int &example, const bool color)
TPoint2D_< double > TPoint2D
Lightweight 2D point.
Parameters for a topographic transfomation.
void transform7params(const mrpt::math::TPoint3D &in_point, const TDatum7Params &in_datum, mrpt::math::TPoint3D &out_point)
7-parameter Bursa-Wolf transformation: [ X Y Z ]_WGS84 = [ dX dY dZ ] + ( 1 + dS ) [ 1 RZ -RY; -RZ 1 ...
std::string name
the ellipsoid name
void setConsoleColor(TConsoleColor color, bool changeStdErr=false)
Changes the text color in the console for the text written from now on.
A set of geodetic coordinates: latitude, longitude and height, defined over a given geoid (typically...
size_type size() const
Get a 2-vector with [NROWS NCOLS] (as in MATLAB command size(x))
void transform1D(const mrpt::math::TPoint3D &p, const TDatum1DTransf &d, mrpt::math::TPoint3D &o)
1D transformation: [ Z ]_WGS84 = (dy * X - dx * Y + Z)*(1+e)+DZ
void geodeticToGeocentric(const TGeodeticCoords &in_coords, TGeocentricCoords &out_point, const TEllipsoid &ellip)
Coordinates transformation from longitude/latitude/height to geocentric X/Y/Z coordinates (with an sp...
A coordinate that is stored as a simple "decimal" angle in degrees, but can be retrieved/set in the f...
void transformHelmert3D_TOPCON(const mrpt::math::TPoint3D &p, const TDatumHelmert3D_TOPCON &d, mrpt::math::TPoint3D &o)
Helmert 3D transformation: [ X Y ]_WGS84 = [ dX dY ] + ( 1 + dS ) [ cos(alpha) -sin(alpha); sin(alpha...
void transform10params(const mrpt::math::TPoint3D &in_point, const TDatum10Params &in_datum, mrpt::math::TPoint3D &out_point)
10-parameter Molodensky-Badekas transformation: [ X Y Z ]_WGS84 = [ dX dY dZ ] + ( 1 + dS ) [ 1 RZ -R...
Parameters for a topographic transfomation.
void transfInterpolation(const mrpt::math::TPoint3D &p, const TDatumTransfInterpolation &d, mrpt::math::TPoint3D &o)
Interpolation: [ Z ]_WGS84 = (dy * X - dx * Y + Z)*(1+e)+DZ.
Parameters for a topographic transfomation.
This base provides a set of functions for maths stuff.
map< string, CVectorDouble > results
TCoords lon
Longitude (in degrees)
void geodeticToUTM(const TGeodeticCoords &GeodeticCoords, TUTMCoords &UTMCoords, int &UTMZone, char &UTMLatitudeBand, const TEllipsoid &ellip=TEllipsoid::Ellipsoid_WGS84())
void geocentricToGeodetic(const TGeocentricCoords &in_point, TGeodeticCoords &out_coords, const TEllipsoid &ellip=TEllipsoid::Ellipsoid_WGS84())
Coordinates transformation from geocentric X/Y/Z coordinates to longitude/latitude/height.
TPoint3D_< double > TPoint3D
Lightweight 3D point.
void UTMToGeodetic(double X, double Y, int zone, char hem, double &out_lon, double &out_lat, const TEllipsoid &ellip=TEllipsoid::Ellipsoid_WGS84())
Returns the Geodetic coordinates of the UTM input point.
std::vector< string > names
Parameters for a topographic transfomation.
double height
Geodetic height (in meters)
std::string exception_to_str(const std::exception &e)
Builds a nice textual representation of a nested exception, which if generated using MRPT macros (THR...
void resize(std::size_t N, bool zeroNewElements=false)
This namespace provides topography helper functions, coordinate transformations.
Parameters for a topographic transfomation.
Parameters for a topographic transfomation.
TCoords lat
Latitude (in degrees)
void transform7params_TOPCON(const mrpt::math::TPoint3D &in_point, const TDatum7Params_TOPCON &in_datum, mrpt::math::TPoint3D &out_point)
7-parameter Bursa-Wolf transformation TOPCON: [ X Y Z ]_WGS84 = [ dX dY dZ ] + ( 1 + dS ) [ 1 RZ -RY;...