diff options
| author | Micah Cochran <micahcochran@users.noreply.github.com> | 2016-05-28 11:26:35 -0500 |
|---|---|---|
| committer | Micah Cochran <micahcochran@users.noreply.github.com> | 2016-05-28 11:26:35 -0500 |
| commit | 3043b2f7fcf4471983c8d4472b17ccf9df1710c8 (patch) | |
| tree | 94e63e8367dad31a6f0fe1703050d0ad79340785 /src/PJ_lcc.c | |
| parent | a112ea3172e89230fa307567be3d70e286b1eeb5 (diff) | |
| download | PROJ-3043b2f7fcf4471983c8d4472b17ccf9df1710c8.tar.gz PROJ-3043b2f7fcf4471983c8d4472b17ccf9df1710c8.zip | |
Change math constants, similar to PR #372. Use M_ namespace with the de facto standard M_PI and its ilk. Change names that are widely used in the project to be in the M_ namespace, so HALFPI becomes M_HALFPI. HALFPI is #defined as M_PI_2 (the defacto standard name). #defines _USE_MATH_DEFINES for MS Visual Studio (I didn't personally test this part, but Appveyor will not build otherwise).
Diffstat (limited to 'src/PJ_lcc.c')
| -rw-r--r-- | src/PJ_lcc.c | 24 |
1 files changed, 12 insertions, 12 deletions
diff --git a/src/PJ_lcc.c b/src/PJ_lcc.c index e7b74be4..e53ee9ba 100644 --- a/src/PJ_lcc.c +++ b/src/PJ_lcc.c @@ -21,12 +21,12 @@ static XY e_forward (LP lp, PJ *P) { /* Ellipsoidal, forward */ struct pj_opaque *Q = P->opaque; double rho; - if (fabs(fabs(lp.phi) - HALFPI) < EPS10) { + if (fabs(fabs(lp.phi) - M_HALFPI) < EPS10) { if ((lp.phi * Q->n) <= 0.) F_ERROR; rho = 0.; } else { rho = Q->c * (Q->ellips ? pow(pj_tsfn(lp.phi, sin(lp.phi), - P->e), Q->n) : pow(tan(FORTPI + .5 * lp.phi), -Q->n)); + P->e), Q->n) : pow(tan(M_FORTPI + .5 * lp.phi), -Q->n)); } lp.lam *= Q->n; xy.x = P->k0 * (rho * sin( lp.lam) ); @@ -56,11 +56,11 @@ static LP e_inverse (XY xy, PJ *P) { /* Ellipsoidal, inverse */ if (lp.phi == HUGE_VAL) I_ERROR; } else - lp.phi = 2. * atan(pow(Q->c / rho, 1./Q->n)) - HALFPI; + lp.phi = 2. * atan(pow(Q->c / rho, 1./Q->n)) - M_HALFPI; lp.lam = atan2(xy.x, xy.y) / Q->n; } else { lp.lam = 0.; - lp.phi = Q->n > 0. ? HALFPI : - HALFPI; + lp.phi = Q->n > 0. ? M_HALFPI : -M_HALFPI; } return lp; } @@ -68,12 +68,12 @@ static LP e_inverse (XY xy, PJ *P) { /* Ellipsoidal, inverse */ static void special(LP lp, PJ *P, struct FACTORS *fac) { struct pj_opaque *Q = P->opaque; double rho; - if (fabs(fabs(lp.phi) - HALFPI) < EPS10) { + if (fabs(fabs(lp.phi) - M_HALFPI) < EPS10) { if ((lp.phi * Q->n) <= 0.) return; rho = 0.; } else rho = Q->c * (Q->ellips ? pow(pj_tsfn(lp.phi, sin(lp.phi), - P->e), Q->n) : pow(tan(FORTPI + .5 * lp.phi), -Q->n)); + P->e), Q->n) : pow(tan(M_FORTPI + .5 * lp.phi), -Q->n)); fac->code |= IS_ANAL_HK + IS_ANAL_CONV; fac->k = fac->h = P->k0 * Q->n * rho / pj_msfn(sin(lp.phi), cos(lp.phi), P->es); @@ -131,16 +131,16 @@ PJ *PROJECTION(lcc) { Q->n /= log(ml1 / pj_tsfn(Q->phi2, sinphi, P->e)); } Q->c = (Q->rho0 = m1 * pow(ml1, -Q->n) / Q->n); - Q->rho0 *= (fabs(fabs(P->phi0) - HALFPI) < EPS10) ? 0. : + Q->rho0 *= (fabs(fabs(P->phi0) - M_HALFPI) < EPS10) ? 0. : pow(pj_tsfn(P->phi0, sin(P->phi0), P->e), Q->n); } else { if (secant) Q->n = log(cosphi / cos(Q->phi2)) / - log(tan(FORTPI + .5 * Q->phi2) / - tan(FORTPI + .5 * Q->phi1)); - Q->c = cosphi * pow(tan(FORTPI + .5 * Q->phi1), Q->n) / Q->n; - Q->rho0 = (fabs(fabs(P->phi0) - HALFPI) < EPS10) ? 0. : - Q->c * pow(tan(FORTPI + .5 * P->phi0), -Q->n); + log(tan(M_FORTPI + .5 * Q->phi2) / + tan(M_FORTPI + .5 * Q->phi1)); + Q->c = cosphi * pow(tan(M_FORTPI + .5 * Q->phi1), Q->n) / Q->n; + Q->rho0 = (fabs(fabs(P->phi0) - M_HALFPI) < EPS10) ? 0. : + Q->c * pow(tan(M_FORTPI + .5 * P->phi0), -Q->n); } P->inv = e_inverse; |
