File: example-Cartesian3.cpp

package info (click to toggle)
geographiclib 2.7-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 7,572 kB
  • sloc: cpp: 27,765; sh: 5,463; makefile: 695; python: 12; ansic: 10
file content (36 lines) | stat: -rw-r--r-- 998 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
// Example of using the Triaxial::Cartesian3 class.

#include <iostream>
#include <iomanip>
#include <exception>
#include <random>
#include <GeographicLib/Triaxial/Cartesian3.hpp>

using namespace std;
using namespace GeographicLib;

int main() {
  try {
    using Triaxial::Cartesian3;
    Cartesian3 cart(3, 2, 1);
    unsigned long long
      s1 = std::random_device()(),
      s2 = std::random_device()();
    std::seed_seq seq{s1, s2};
    std::mt19937 g(seq);
    cout << "10 random points on the ellipsoid with semiaxes [3, 2, 1]\n"
         << "X Y Z beta omega\n" << fixed << setprecision(3);
    Cartesian3::vec3 r;
    Angle bet, omg;
    for (int i = 0; i < 10; ++i) {
      cart.cart2rand(g, r);
      cart.cart2toany(r, Cartesian3::ELLIPSOIDAL, bet, omg);
      cout << r[0] << " " << r[1] << " " << r[2] << " "
           << double(bet) << " " << double(omg) << "\n";
    }
  }
  catch (const exception& e) {
    cerr << "Caught exception: " << e.what() << "\n";
    return 1;
  }
}