line |
stmt |
bran |
cond |
sub |
pod |
time |
code |
1
|
|
|
|
|
|
|
package Geo::Coordinates::VandH; |
2
|
1
|
|
|
1
|
|
6451
|
use strict; |
|
1
|
|
|
|
|
2
|
|
|
1
|
|
|
|
|
34
|
|
3
|
1
|
|
|
1
|
|
1476
|
use Math::Trig; |
|
1
|
|
|
|
|
20073
|
|
|
1
|
|
|
|
|
157
|
|
4
|
1
|
|
|
1
|
|
11
|
use Math::Complex; #fixes a few one-off problems with negative square roots |
|
1
|
|
|
|
|
6
|
|
|
1
|
|
|
|
|
178
|
|
5
|
1
|
|
|
1
|
|
5
|
use vars qw($VERSION); |
|
1
|
|
|
|
|
2
|
|
|
1
|
|
|
|
|
701
|
|
6
|
|
|
|
|
|
|
|
7
|
|
|
|
|
|
|
|
8
|
|
|
|
|
|
|
|
9
|
|
|
|
|
|
|
$VERSION = '1.11'; |
10
|
|
|
|
|
|
|
|
11
|
|
|
|
|
|
|
sub new { |
12
|
0
|
|
|
0
|
0
|
|
my $package = shift; |
13
|
0
|
|
|
|
|
|
return bless({}, $package); |
14
|
|
|
|
|
|
|
}; |
15
|
|
|
|
|
|
|
|
16
|
|
|
|
|
|
|
sub distance { |
17
|
0
|
|
|
0
|
0
|
|
my $self = shift; |
18
|
0
|
|
|
|
|
|
my $v1; |
19
|
|
|
|
|
|
|
my $h1; |
20
|
0
|
|
|
|
|
|
my $v2; |
21
|
0
|
|
|
|
|
|
my $h2; |
22
|
0
|
|
|
|
|
|
my $miles; |
23
|
0
|
|
|
|
|
|
my $vd; |
24
|
0
|
|
|
|
|
|
my $hd; |
25
|
0
|
|
|
|
|
|
my $sum; |
26
|
0
|
|
|
|
|
|
my $count; |
27
|
0
|
|
|
|
|
|
($v1,$h1,$v2,$h2) = @_; |
28
|
0
|
|
|
|
|
|
$vd=$v1-$v2; |
29
|
0
|
0
|
|
|
|
|
if ($vd < 0) { $vd=$vd*-1; }; |
|
0
|
|
|
|
|
|
|
30
|
0
|
|
|
|
|
|
$hd=$h1-$h2; |
31
|
0
|
0
|
|
|
|
|
if ($hd < 0) { $hd=$hd*-1; }; |
|
0
|
|
|
|
|
|
|
32
|
0
|
|
|
|
|
|
$vd=$vd/3; |
33
|
0
|
|
|
|
|
|
$hd=$hd/3; |
34
|
0
|
|
|
|
|
|
$count=1; |
35
|
0
|
|
|
|
|
|
while (($vd**2+$hd**2) > 1777) { |
36
|
0
|
|
|
|
|
|
$vd=$vd/3; |
37
|
0
|
|
|
|
|
|
$hd=$hd/3; |
38
|
0
|
|
|
|
|
|
$count++; |
39
|
|
|
|
|
|
|
}; |
40
|
0
|
|
|
|
|
|
$sum=$vd**2+$hd**2; |
41
|
0
|
|
|
|
|
|
$sum = $sum * ( 0.1 * (9**$count)); |
42
|
0
|
|
|
|
|
|
$miles=sqrt($sum); |
43
|
|
|
|
|
|
|
#round up to next greatest mile |
44
|
0
|
0
|
|
|
|
|
if (($miles-int($miles)) > 0) { $miles=int($miles)+1; }; |
|
0
|
|
|
|
|
|
|
45
|
0
|
|
|
|
|
|
return $miles; |
46
|
|
|
|
|
|
|
}; |
47
|
|
|
|
|
|
|
|
48
|
|
|
|
|
|
|
sub vh2ll { |
49
|
0
|
|
|
0
|
0
|
|
my $self = shift; |
50
|
|
|
|
|
|
|
#Constants shamelessly stolen from vh2ll.c |
51
|
0
|
|
|
|
|
|
my $m_pi=3.14159265358979323846; |
52
|
0
|
|
|
|
|
|
my $transv=6363.235; |
53
|
0
|
|
|
|
|
|
my $transh=2250.7; |
54
|
0
|
|
|
|
|
|
my $rotc=0.23179040; |
55
|
0
|
|
|
|
|
|
my $rots=0.97276575; |
56
|
0
|
|
|
|
|
|
my $radius=12481.103; |
57
|
0
|
|
|
|
|
|
my $ex=0.40426992; |
58
|
0
|
|
|
|
|
|
my $ey=0.68210848; |
59
|
0
|
|
|
|
|
|
my $ez=0.60933887; |
60
|
0
|
|
|
|
|
|
my $wx=0.65517646; |
61
|
0
|
|
|
|
|
|
my $wy=0.37733790; |
62
|
0
|
|
|
|
|
|
my $wz=0.65449210; |
63
|
0
|
|
|
|
|
|
my $px=-0.555977821730048699; |
64
|
0
|
|
|
|
|
|
my $py=-0.345728488161089920; |
65
|
0
|
|
|
|
|
|
my $pz=0.755883902605524030; |
66
|
0
|
|
|
|
|
|
my $gx=0.216507961908834992; |
67
|
0
|
|
|
|
|
|
my $gy=-0.134633014879368199; |
68
|
0
|
|
|
|
|
|
my $a=0.151646645621077297; |
69
|
0
|
|
|
|
|
|
my $q=-0.294355056616412800; |
70
|
0
|
|
|
|
|
|
my $q2=0.0866448993556515751; |
71
|
0
|
|
|
|
|
|
my @bi = ( 1.00567724920722457, -0.00344230425560210245, 0.000713971534527667990, -0.0000777240053499279217, 0.00000673180367053244284, -0.000000742595338885741395, 0.0000000905058919926194134 ); |
72
|
0
|
|
|
|
|
|
my $x; |
73
|
|
|
|
|
|
|
my $y; |
74
|
0
|
|
|
|
|
|
my $z; |
75
|
0
|
|
|
|
|
|
my $v; |
76
|
0
|
|
|
|
|
|
my $h; |
77
|
0
|
|
|
|
|
|
my $delta; |
78
|
0
|
|
|
|
|
|
($v,$h) = @_; |
79
|
0
|
|
|
|
|
|
my $t1 = ($v - $transv) / $radius; |
80
|
0
|
|
|
|
|
|
my $t2 = ($h - $transh) / $radius; |
81
|
0
|
|
|
|
|
|
my $vhat = $rotc*$t2 - $rots*$t1; |
82
|
0
|
|
|
|
|
|
my $hhat = $rots*$t2 + $rotc*$t1; |
83
|
0
|
|
|
|
|
|
my $e = cos(sqrt($vhat*$vhat + $hhat*$hhat)); |
84
|
0
|
|
|
|
|
|
my $w = cos(sqrt($vhat*$vhat + ($hhat-0.4)*($hhat-0.4))); |
85
|
0
|
|
|
|
|
|
my $fx = $ey*$w - $wy*$e; |
86
|
0
|
|
|
|
|
|
my $fy = $ex*$w - $wx*$e; |
87
|
0
|
|
|
|
|
|
my $b = $fx*$gx + $fy*$gy; |
88
|
0
|
|
|
|
|
|
my $c = $fx*$fx + $fy*$fy - $q2; |
89
|
0
|
|
|
|
|
|
my $disc = $b*$b - $a*$c; #discriminant |
90
|
0
|
0
|
|
|
|
|
if ($disc == 0.0) { #It's right on the E-W axis |
91
|
0
|
|
|
|
|
|
$z = $b/$a; |
92
|
0
|
|
|
|
|
|
$x = ($gx*$z - $fx)/$q; |
93
|
0
|
|
|
|
|
|
$y = ($fy - $gy*$z)/$q; |
94
|
|
|
|
|
|
|
} else { |
95
|
0
|
|
|
|
|
|
$delta = sqrt($disc); |
96
|
0
|
|
|
|
|
|
$z = ($b + $delta)/$a; |
97
|
0
|
|
|
|
|
|
$x = ($gx*$z - $fx)/$q; |
98
|
0
|
|
|
|
|
|
$y = ($fy - $gy*$z)/$q; |
99
|
0
|
0
|
|
|
|
|
if ( $vhat * ( $px*$x + $py*$y + $pz*$z) < 0 ) { #wrong direction |
100
|
0
|
|
|
|
|
|
$z = ($b - $delta)/$a; |
101
|
0
|
|
|
|
|
|
$x = ($gx*$z - $fx)/$q; |
102
|
0
|
|
|
|
|
|
$y = ($fy - $gy*$z)/$q; |
103
|
|
|
|
|
|
|
}; |
104
|
|
|
|
|
|
|
}; |
105
|
0
|
|
|
|
|
|
my $lat=asin($z); |
106
|
|
|
|
|
|
|
#Use polynomial approximation for inverse mapping |
107
|
|
|
|
|
|
|
#(sphere to spheroid) |
108
|
0
|
|
|
|
|
|
my $lat2 = $lat*$lat; |
109
|
0
|
|
|
|
|
|
my $earthlat = 0; |
110
|
0
|
|
|
|
|
|
for (my $i=6; $i>=0 ; $i--) { |
111
|
0
|
0
|
|
|
|
|
$earthlat = ($earthlat + $bi[$i]) * ($i? $lat2 : $lat); |
112
|
|
|
|
|
|
|
}; |
113
|
0
|
|
|
|
|
|
$earthlat *= 180/$m_pi; |
114
|
|
|
|
|
|
|
# Adjust Longitude by 52 degrees |
115
|
0
|
|
|
|
|
|
my $lon = atan2($x,$y) * 180/$m_pi; |
116
|
0
|
|
|
|
|
|
my $earthlon = $lon + 52.0000000000000000; |
117
|
0
|
|
|
|
|
|
return ($earthlat,$earthlon); |
118
|
|
|
|
|
|
|
}; |
119
|
|
|
|
|
|
|
1; |
120
|
|
|
|
|
|
|
__END__ |