Coverage Report

Created: 2025-06-13 06:18

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