Coverage Report

Created: 2025-08-28 06:57

/src/proj/src/projections/eck3.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
PROJ_HEAD(eck3, "Eckert III") "\n\tPCyl, Sph";
10
PROJ_HEAD(putp1, "Putnins P1") "\n\tPCyl, Sph";
11
PROJ_HEAD(wag6, "Wagner VI") "\n\tPCyl, Sph";
12
PROJ_HEAD(kav7, "Kavrayskiy VII") "\n\tPCyl, Sph";
13
14
namespace { // anonymous namespace
15
struct pj_opaque {
16
    double C_x, C_y, A, B;
17
};
18
} // anonymous namespace
19
20
0
static PJ_XY eck3_s_forward(PJ_LP lp, PJ *P) { /* Spheroidal, forward */
21
0
    PJ_XY xy = {0.0, 0.0};
22
0
    struct pj_opaque *Q = static_cast<struct pj_opaque *>(P->opaque);
23
24
0
    xy.y = Q->C_y * lp.phi;
25
0
    xy.x = Q->C_x * lp.lam * (Q->A + asqrt(1. - Q->B * lp.phi * lp.phi));
26
0
    return xy;
27
0
}
28
29
0
static PJ_LP eck3_s_inverse(PJ_XY xy, PJ *P) { /* Spheroidal, inverse */
30
0
    PJ_LP lp = {0.0, 0.0};
31
0
    struct pj_opaque *Q = static_cast<struct pj_opaque *>(P->opaque);
32
0
    double denominator;
33
34
0
    lp.phi = xy.y / Q->C_y;
35
0
    denominator = (Q->C_x * (Q->A + asqrt(1. - Q->B * lp.phi * lp.phi)));
36
0
    if (denominator == 0.0)
37
0
        lp.lam = HUGE_VAL;
38
0
    else
39
0
        lp.lam = xy.x / denominator;
40
0
    return lp;
41
0
}
42
43
571
static PJ *setup(PJ *P) {
44
571
    P->es = 0.;
45
571
    P->inv = eck3_s_inverse;
46
571
    P->fwd = eck3_s_forward;
47
571
    return P;
48
571
}
49
50
111
PJ *PJ_PROJECTION(eck3) {
51
111
    struct pj_opaque *Q =
52
111
        static_cast<struct pj_opaque *>(calloc(1, sizeof(struct pj_opaque)));
53
111
    if (nullptr == Q)
54
0
        return pj_default_destructor(P, PROJ_ERR_OTHER /*ENOMEM*/);
55
111
    P->opaque = Q;
56
57
111
    Q->C_x = 0.42223820031577120149;
58
111
    Q->C_y = 0.84447640063154240298;
59
111
    Q->A = 1.0;
60
111
    Q->B = 0.4052847345693510857755;
61
62
111
    return setup(P);
63
111
}
64
65
45
PJ *PJ_PROJECTION(kav7) {
66
45
    struct pj_opaque *Q =
67
45
        static_cast<struct pj_opaque *>(calloc(1, sizeof(struct pj_opaque)));
68
45
    if (nullptr == Q)
69
0
        return pj_default_destructor(P, PROJ_ERR_OTHER /*ENOMEM*/);
70
45
    P->opaque = Q;
71
72
    /* Defined twice in original code - Using 0.866...,
73
     * but leaving the other one here as a safety measure.
74
     * Q->C_x = 0.2632401569273184856851; */
75
45
    Q->C_x = 0.8660254037844;
76
45
    Q->C_y = 1.;
77
45
    Q->A = 0.;
78
45
    Q->B = 0.30396355092701331433;
79
80
45
    return setup(P);
81
45
}
82
83
275
PJ *PJ_PROJECTION(wag6) {
84
275
    struct pj_opaque *Q =
85
275
        static_cast<struct pj_opaque *>(calloc(1, sizeof(struct pj_opaque)));
86
275
    if (nullptr == Q)
87
0
        return pj_default_destructor(P, PROJ_ERR_OTHER /*ENOMEM*/);
88
275
    P->opaque = Q;
89
90
275
    Q->C_x = 1.0;
91
275
    Q->C_y = 1.0;
92
275
    Q->A = 0.0;
93
275
    Q->B = 0.30396355092701331433;
94
95
275
    return setup(P);
96
275
}
97
98
140
PJ *PJ_PROJECTION(putp1) {
99
140
    struct pj_opaque *Q =
100
140
        static_cast<struct pj_opaque *>(calloc(1, sizeof(struct pj_opaque)));
101
140
    if (nullptr == Q)
102
0
        return pj_default_destructor(P, PROJ_ERR_OTHER /*ENOMEM*/);
103
140
    P->opaque = Q;
104
105
140
    Q->C_x = 1.89490;
106
140
    Q->C_y = 0.94745;
107
140
    Q->A = -0.5;
108
140
    Q->B = 0.30396355092701331433;
109
110
140
    return setup(P);
111
140
}