Geo-Distance

 view release on metacpan or  search on metacpan

t/issue-github-2.t  view on Meta::CPAN

#!/usr/bin/env perl
use 5.008001;
use strict;
use warnings;
use Test2::V0;

use Geo::Distance;
use Math::Trig qw( asin );

my $geo = Geo::Distance->new();
$geo->formula('gcd');

my $new_value = $geo->distance( 'mile', "-81.044","35.244", "-80.8272","35.1935" );
my $old_value = old_gcd( $geo, 'mile', "-81.044","35.244", "-80.8272","35.1935" );

$geo->formula('hsin');
my $control_value = $geo->distance( 'mile', "-81.044","35.244", "-80.8272","35.1935" );

cmp_ok(
    abs($new_value - $control_value), '<', 0.00000000001,
    'gcd now produces same result as hsin',
);

cmp_ok(
    abs($old_value - $control_value), '>', 0.00000000001,
    'old gcd did not produce same result as hsin',
);

done_testing;

sub old_gcd {
    my($geo,$unit,$lon1,$lat1,$lon2,$lat2) = @_;

    $unit = $geo->{units}->{$unit};

    my $c = 2*asin( sqrt(
        ( sin(($lat1-$lat2)/2) )^2 + 
        cos($lat1) * cos($lat2) * 
        ( sin(($lon1-$lon2)/2) )^2
    ) );

    return $unit * $c;
}



( run in 0.717 second using v1.01-cache-2.11-cpan-39bf76dae61 )