projects
/
spider.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
put in temp fix for pc10 talk crashes
[spider.git]
/
perl
/
DXBearing.pm
diff --git
a/perl/DXBearing.pm
b/perl/DXBearing.pm
index e7736f8a138d64a367865bce605631389f96f861..b98d746a5b5c88d4e2df409068ad43dd312aae2b 100644
(file)
--- a/
perl/DXBearing.pm
+++ b/
perl/DXBearing.pm
@@
-8,25
+8,19
@@
#
# Copyright (c) 1998 - Dirk Koopman G1TLH
#
#
# Copyright (c) 1998 - Dirk Koopman G1TLH
#
-#
$Id$
+#
#
package DXBearing;
#
package DXBearing;
-use POSIX;
use DXUtil;
use DXUtil;
+use POSIX qw(:math_h);
use strict;
use vars qw($pi);
$pi = 3.14159265358979;
use strict;
use vars qw($pi);
$pi = 3.14159265358979;
-use vars qw($VERSION $BRANCH);
-$VERSION = sprintf( "%d.%03d", q$Revision$ =~ /(\d+)\.(\d+)/ );
-$BRANCH = sprintf( "%d.%03d", q$Revision$ =~ /\d+\.\d+\.(\d+)\.(\d+)/ || (0,0));
-$main::build += $VERSION;
-$main::branch += $BRANCH;
-
# convert a qra locator into lat/long in DEGREES
sub qratoll
{
# convert a qra locator into lat/long in DEGREES
sub qratoll
{
@@
-95,12
+89,12
@@
sub bdist
my $e = dr(shift);
return (0, 0) if $hn == $n && $he == $e;
my $co = cos($he-$e)*cos($hn)*cos($n)+sin($hn)*sin($n);
my $e = dr(shift);
return (0, 0) if $hn == $n && $he == $e;
my $co = cos($he-$e)*cos($hn)*cos($n)+sin($hn)*sin($n);
- my $ca =
atan(abs(sqrt(1-$co*$co)/$co))
;
+ my $ca =
$co ? atan(abs(sqrt(1-$co*$co)/$co)) : $pi
;
$ca = $pi-$ca if $co < 0;
my $dx = 6367*$ca;
my $si = sin($e-$he)*cos($n)*cos($hn);
$co = sin($n)-sin($hn)*cos($ca);
$ca = $pi-$ca if $co < 0;
my $dx = 6367*$ca;
my $si = sin($e-$he)*cos($n)*cos($hn);
$co = sin($n)-sin($hn)*cos($ca);
- my $az =
atan(abs($si/$co))
;
+ my $az =
$co ? atan(abs($si/$co)) : $pi
;
$az = $pi - $az if $co < 0;
$az = -$az if $si < 0;
$az = $az+2*$pi if $az < 0;
$az = $pi - $az if $co < 0;
$az = -$az if $si < 0;
$az = $az+2*$pi if $az < 0;