File: gis_proj.t

package info (click to toggle)
libpdl-transform-proj4-perl 2.098-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 372 kB
  • sloc: perl: 2,823; makefile: 9
file content (62 lines) | stat: -rw-r--r-- 1,895 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
use strict;
use warnings;
use PDL::LiteF;
use Test::More;
use Test::PDL;
BEGIN {
diag "ENV $_ = ", explain $ENV{$_}
  for qw(LD_LIBRARY_PATH DYLD_LIBRARY_PATH LDFLAGS CFLAGS CXXFLAGS LD_RUN_PATH
    LC_RUN_PATH);
}
use PDL::Transform::Proj4;

my @version = eval { PDL::Transform::Proj4::proj_version() };
is $@, '', 'proj_version no die';
diag "PROJ version: @version";

print "Testing forward transformation...\n";
my $proj = "+proj=merc +ellps=WGS72 +lon_0=80.25w +lat_0=30n";
print "Perl level params: \'$proj\'\n";

my $lonlat = double [[-90.0,0.0], [-95.0,33.0], [-86.0,77.0]];
# Expected results:
my $xy_exp = double [
  [-1085364.69489521, 7.0811523e-10],
  [-1641961.97432865, 3872032.73513601],
  [-640086.87134846, 13812394.85701733],
];

my ($xy) = PDL::Transform::Proj4::fwd_transform($lonlat, $proj);
is_pdl $xy, $xy_exp;

my ($lonlat2) = PDL::Transform::Proj4::inv_transform($xy, $proj);
is_pdl $lonlat2, $lonlat;

# Do the corners of a cyl eq map, and see what we get...
my $cyl_eq = "+proj=eqc +lon_0=0 +datum=WGS84";
my $lonlat3 = double [[-180.0,90.0], [-180.0,-90.0], [180.0,90.0], [180.0,-90.0]];
my $xy3_exp = double [
  [-20037508.34278924, 10018754.17139462],
  [-20037508.34278924, -10018754.17139462],
  [20037508.34278924, 10018754.17139462],
  [20037508.34278924, -10018754.17139462]
];

my ($xy3) = PDL::Transform::Proj4::fwd_transform($lonlat3, $cyl_eq);
is_pdl $xy3, $xy3_exp;

$lonlat = ((xvals( double, 35, 17 ) - 17.0) * 10.0)->cat(
  (yvals( double, 35, 17 ) - 8.0) * 10.0)->mv(2,0);
my $exp = $lonlat->copy;
$lonlat->inplace(1);
PDL::Transform::Proj4::fwd_transform($lonlat, $proj);
ok !all(approx($lonlat, $exp)), 'check it changed';

# Get full projection information:
my $info = PDL::Transform::Proj4::load_projection_information();
#diag explain $info;

my @units = PDL::Transform::Proj4::units($cyl_eq);
is 0+@units, 2, 'got 2 units back';

done_testing;