NAME
Geo::Converter::dms2dd
VERSION
0.01
SYNOPSIS
use Geo::Converter::dms2dd qw { dms2dd };
my $dms_value;
my $dd_value;
$dms_value = q{S23°32'09.567"};
$dd_value = dms2dd ({value => $dms_value});
print $dms_value
# -23.5359908333333
$dms_value = q{149°23'18.009"E};
$dd_value = dms2dd ({value => $dms_value});
print $dd_value
# 149.388335833333
$dms_value = q{east 149°23'18.009};
$dd_value = dms2dd ({value => $dms_value});
print $dd_value
# 149.388335833333
# The following all croak with warnings:
$dms_value = q{S23°32'09.567"};
$dd_value = dms2dd ({value => $dms_value, is_lon => 1});
# Coord error: Longitude specified, but latitude found
$dms_value = q{149°23'18.009"E};
$dd_value = dms2dd ({value => $dms_value, is_lat => 1});
# Coord error: Latitude out of bounds: 149.388335833333
$dms_value = q{149°23'18.009"25}; # extra number
$dd_value = dms2dd ({value => $dms_value});
# DMS value error: Too many numbers in string: '149°23'18.009"25'
DESCRIPTION
Use this module to convert a coordinate value in degrees minutes seconds to decimal degrees. It exports a single sub dms2dd
which will parse and convert a single value.
A reasonable amount of location information is provided in degrees/minutes/seconds (DMS) format, for example from Google Earth, GIS packages or similar. For example, one might be given a location coordinate for just north east of Dingo in Queensland, Australia. Four possible formats are:
S23°32'09.567", E149°23'18.009"
23°32'09.567"S, 149°23'18.009"E
-23 32 9.567, +149 23 18.009
-23.535991, 149.388336
The first three coordinates are in degrees/minutes/seconds while the fourth is in decimal degrees. The fourth coordinate can be used in numeric calculations, but the first three must first be converted to decimal degrees.
The conversion process used in dms2dd is pretty generous in what it treats as DMS, as there is a multitude of variations in punctuation and the like. Up to three numeric values are extracted and any additional text is largely ignored unless it specifies the hemisphere. It croaks if there are four or more values. If the hemisphere is known or the is_lat
or is_lon
arguments are specified then values are validated (e.g. latitudes must be in the interval [-90, 90], and longitudes with a hemisphere specified must be within [-180, 180]). Otherwise values between [-180, 360] are accepted. If seconds are specified and minutes have values after the radix (decimal point) then it croaks (e.g. 35 26.5' 22"). Likewise, it croaks for cases like (35.2d 26'). It will also croak if you specify the hemisphere at teh start and end of the value, even if it is the same hemisphere.
Note that this module only works on a single value. Call it once each for latitude and longitude values to convert a full coordinate.
AUTHOR
Shawn Laffan (shawnlaffan@gmail.com).
BUGS AND IRRITATIONS
It does not deal with non-English spellings of north, south, east or west. Hemispheres need to satisfy qr/[NESWnesw+-]/. A solution could be to drop in an appropriate regexp as an argument. Patches welcome.
It could probably also give the parsed degrees, minutes and seconds rather than convert them. They are pretty easy to calculate, though.
Submit bugs, fixes and enhancement requests via the bug tracker at http://code.google.com/p/geo-converter-dms2dd/.
LICENSE
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself, either Perl version 5.8.9 or, at your option, any later version of Perl 5 you may have available.
See also
Geo::Coordinates::DecimalDegrees, although it requires the degrees, minutes and seconds values to already be parsed from the string.
1 POD Error
The following errors were encountered while parsing the POD:
- Around line 249:
Non-ASCII character seen before =encoding in 'q{S23°32'09.567"};'. Assuming CP1252