Coverage Report

Created: 2026-05-16 07:15

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/PROJ/src/projections/boggs.cpp
Line
Count
Source
1
2
#include <math.h>
3
4
#include "proj.h"
5
#include "proj_internal.h"
6
7
PROJ_HEAD(boggs, "Boggs Eumorphic") "\n\tPCyl, no inv, Sph";
8
168
#define NITER 20
9
840
#define EPS 1e-7
10
168
#define FXC 2.00276
11
168
#define FXC2 1.11072
12
168
#define FYC 0.49931
13
14
168
static PJ_XY boggs_s_forward(PJ_LP lp, PJ *P) { /* Spheroidal, forward */
15
168
    PJ_XY xy = {0.0, 0.0};
16
168
    double theta, th1, c;
17
168
    int i;
18
168
    (void)P;
19
20
168
    theta = lp.phi;
21
168
    if (fabs(fabs(lp.phi) - M_HALFPI) < EPS)
22
0
        xy.x = 0.;
23
168
    else {
24
168
        c = sin(theta) * M_PI;
25
672
        for (i = NITER; i; --i) {
26
672
            th1 = (theta + sin(theta) - c) / (1. + cos(theta));
27
672
            theta -= th1;
28
672
            if (fabs(th1) < EPS)
29
168
                break;
30
672
        }
31
168
        theta *= 0.5;
32
168
        xy.x = FXC * lp.lam / (1. / cos(lp.phi) + FXC2 / cos(theta));
33
168
    }
34
168
    xy.y = FYC * (lp.phi + M_SQRT2 * sin(theta));
35
168
    return (xy);
36
168
}
37
38
96
PJ *PJ_PROJECTION(boggs) {
39
96
    P->es = 0.;
40
96
    P->fwd = boggs_s_forward;
41
96
    return P;
42
96
}
43
44
#undef NITER
45
#undef EPS
46
#undef FXC
47
#undef FXC2
48
#undef FYC