/src/PROJ/src/projections/putp5.cpp
Line | Count | Source (jump to first uncovered line) |
1 | | |
2 | | |
3 | | #include <errno.h> |
4 | | #include <math.h> |
5 | | |
6 | | #include "proj.h" |
7 | | #include "proj_internal.h" |
8 | | |
9 | | namespace { // anonymous namespace |
10 | | struct pj_putp5_data { |
11 | | double A, B; |
12 | | }; |
13 | | } // anonymous namespace |
14 | | |
15 | | PROJ_HEAD(putp5, "Putnins P5") "\n\tPCyl, Sph"; |
16 | | PROJ_HEAD(putp5p, "Putnins P5'") "\n\tPCyl, Sph"; |
17 | | |
18 | 6.38k | #define C 1.01346 |
19 | 3.19k | #define D 1.2158542 |
20 | | |
21 | 3.19k | static PJ_XY putp5_s_forward(PJ_LP lp, PJ *P) { /* Spheroidal, forward */ |
22 | 3.19k | PJ_XY xy = {0.0, 0.0}; |
23 | 3.19k | struct pj_putp5_data *Q = static_cast<struct pj_putp5_data *>(P->opaque); |
24 | | |
25 | 3.19k | xy.x = C * lp.lam * (Q->A - Q->B * sqrt(1. + D * lp.phi * lp.phi)); |
26 | 3.19k | xy.y = C * lp.phi; |
27 | | |
28 | 3.19k | return xy; |
29 | 3.19k | } |
30 | | |
31 | 0 | static PJ_LP putp5_s_inverse(PJ_XY xy, PJ *P) { /* Spheroidal, inverse */ |
32 | 0 | PJ_LP lp = {0.0, 0.0}; |
33 | 0 | struct pj_putp5_data *Q = static_cast<struct pj_putp5_data *>(P->opaque); |
34 | |
|
35 | 0 | lp.phi = xy.y / C; |
36 | 0 | lp.lam = xy.x / (C * (Q->A - Q->B * sqrt(1. + D * lp.phi * lp.phi))); |
37 | |
|
38 | 0 | return lp; |
39 | 0 | } |
40 | | |
41 | 27 | PJ *PJ_PROJECTION(putp5) { |
42 | 27 | struct pj_putp5_data *Q = static_cast<struct pj_putp5_data *>( |
43 | 27 | calloc(1, sizeof(struct pj_putp5_data))); |
44 | 27 | if (nullptr == Q) |
45 | 0 | return pj_default_destructor(P, PROJ_ERR_OTHER /*ENOMEM*/); |
46 | 27 | P->opaque = Q; |
47 | | |
48 | 27 | Q->A = 2.; |
49 | 27 | Q->B = 1.; |
50 | | |
51 | 27 | P->es = 0.; |
52 | 27 | P->inv = putp5_s_inverse; |
53 | 27 | P->fwd = putp5_s_forward; |
54 | | |
55 | 27 | return P; |
56 | 27 | } |
57 | | |
58 | 85 | PJ *PJ_PROJECTION(putp5p) { |
59 | 85 | struct pj_putp5_data *Q = static_cast<struct pj_putp5_data *>( |
60 | 85 | calloc(1, sizeof(struct pj_putp5_data))); |
61 | 85 | if (nullptr == Q) |
62 | 0 | return pj_default_destructor(P, PROJ_ERR_OTHER /*ENOMEM*/); |
63 | 85 | P->opaque = Q; |
64 | | |
65 | 85 | Q->A = 1.5; |
66 | 85 | Q->B = 0.5; |
67 | | |
68 | 85 | P->es = 0.; |
69 | 85 | P->inv = putp5_s_inverse; |
70 | 85 | P->fwd = putp5_s_forward; |
71 | | |
72 | 85 | return P; |
73 | 85 | } |
74 | | |
75 | | #undef C |
76 | | #undef D |