Coverage Report

Created: 2025-08-26 07:08

/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
38.9k
static PJ_XY eck3_s_forward(PJ_LP lp, PJ *P) { /* Spheroidal, forward */
21
38.9k
    PJ_XY xy = {0.0, 0.0};
22
38.9k
    struct pj_opaque *Q = static_cast<struct pj_opaque *>(P->opaque);
23
24
38.9k
    xy.y = Q->C_y * lp.phi;
25
38.9k
    xy.x = Q->C_x * lp.lam * (Q->A + asqrt(1. - Q->B * lp.phi * lp.phi));
26
38.9k
    return xy;
27
38.9k
}
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
744
static PJ *setup(PJ *P) {
44
744
    P->es = 0.;
45
744
    P->inv = eck3_s_inverse;
46
744
    P->fwd = eck3_s_forward;
47
744
    return P;
48
744
}
49
50
93
PJ *PJ_PROJECTION(eck3) {
51
93
    struct pj_opaque *Q =
52
93
        static_cast<struct pj_opaque *>(calloc(1, sizeof(struct pj_opaque)));
53
93
    if (nullptr == Q)
54
0
        return pj_default_destructor(P, PROJ_ERR_OTHER /*ENOMEM*/);
55
93
    P->opaque = Q;
56
57
93
    Q->C_x = 0.42223820031577120149;
58
93
    Q->C_y = 0.84447640063154240298;
59
93
    Q->A = 1.0;
60
93
    Q->B = 0.4052847345693510857755;
61
62
93
    return setup(P);
63
93
}
64
65
55
PJ *PJ_PROJECTION(kav7) {
66
55
    struct pj_opaque *Q =
67
55
        static_cast<struct pj_opaque *>(calloc(1, sizeof(struct pj_opaque)));
68
55
    if (nullptr == Q)
69
0
        return pj_default_destructor(P, PROJ_ERR_OTHER /*ENOMEM*/);
70
55
    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
55
    Q->C_x = 0.8660254037844;
76
55
    Q->C_y = 1.;
77
55
    Q->A = 0.;
78
55
    Q->B = 0.30396355092701331433;
79
80
55
    return setup(P);
81
55
}
82
83
578
PJ *PJ_PROJECTION(wag6) {
84
578
    struct pj_opaque *Q =
85
578
        static_cast<struct pj_opaque *>(calloc(1, sizeof(struct pj_opaque)));
86
578
    if (nullptr == Q)
87
0
        return pj_default_destructor(P, PROJ_ERR_OTHER /*ENOMEM*/);
88
578
    P->opaque = Q;
89
90
578
    Q->C_x = 1.0;
91
578
    Q->C_y = 1.0;
92
578
    Q->A = 0.0;
93
578
    Q->B = 0.30396355092701331433;
94
95
578
    return setup(P);
96
578
}
97
98
18
PJ *PJ_PROJECTION(putp1) {
99
18
    struct pj_opaque *Q =
100
18
        static_cast<struct pj_opaque *>(calloc(1, sizeof(struct pj_opaque)));
101
18
    if (nullptr == Q)
102
0
        return pj_default_destructor(P, PROJ_ERR_OTHER /*ENOMEM*/);
103
18
    P->opaque = Q;
104
105
18
    Q->C_x = 1.89490;
106
18
    Q->C_y = 0.94745;
107
18
    Q->A = -0.5;
108
18
    Q->B = 0.30396355092701331433;
109
110
18
    return setup(P);
111
18
}