svn-gvsig-desktop / tags / v1_10_0_Build_1264 / libraries / libjni-proj4 / src / PJ_wink2.c @ 38629
History | View | Annotate | Download (927 Bytes)
1 |
#ifndef lint
|
---|---|
2 |
static const char SCCSID[]="@(#)PJ_wink2.c 4.1 94/02/15 GIE REL"; |
3 |
#endif
|
4 |
#define PROJ_PARMS__ \
|
5 |
double cosphi1;
|
6 |
#define PJ_LIB__
|
7 |
# include <projects.h> |
8 |
PROJ_HEAD(wink2, "Winkel II") "\n\tPCyl., Sph., no inv.\n\tlat_1="; |
9 |
#define MAX_ITER 10 |
10 |
#define LOOP_TOL 1e-7 |
11 |
#define TWO_D_PI 0.636619772367581343 |
12 |
FORWARD(s_forward); /* spheroid */
|
13 |
double k, V;
|
14 |
int i;
|
15 |
|
16 |
xy.y = lp.phi * TWO_D_PI; |
17 |
k = PI * sin(lp.phi); |
18 |
lp.phi *= 1.8; |
19 |
for (i = MAX_ITER; i ; --i) {
|
20 |
lp.phi -= V = (lp.phi + sin(lp.phi) - k) / |
21 |
(1. + cos(lp.phi));
|
22 |
if (fabs(V) < LOOP_TOL)
|
23 |
break;
|
24 |
} |
25 |
if (!i)
|
26 |
lp.phi = (lp.phi < 0.) ? -HALFPI : HALFPI;
|
27 |
else
|
28 |
lp.phi *= 0.5; |
29 |
xy.x = 0.5 * lp.lam * (cos(lp.phi) + P->cosphi1); |
30 |
xy.y = FORTPI * (sin(lp.phi) + xy.y); |
31 |
return (xy);
|
32 |
} |
33 |
FREEUP; if (P) pj_dalloc(P); }
|
34 |
ENTRY0(wink2) |
35 |
P->cosphi1 = cos(pj_param(P->params, "rlat_1").f);
|
36 |
P->es = 0.; P->inv = 0; P->fwd = s_forward; |
37 |
ENDENTRY(P) |