1 | #!/usr/bin/perl
|
---|
2 |
|
---|
3 | use strict;
|
---|
4 | use warnings;
|
---|
5 |
|
---|
6 | print "# Reference data created by proj.4\n";
|
---|
7 | print "#\n";
|
---|
8 | print "# code,lat,lon,east,north\n";
|
---|
9 | for my $in (<>) {
|
---|
10 | # input data looks like this: "EPSG:4326 Bounds[-90.0,-180.0,90.0,180.0]"
|
---|
11 | # (created by ProjectionRefTest.java)
|
---|
12 | next unless $in =~ /EPSG:([0-9]+) Bounds\[(.*),(.*),(.*),(.*)\]/;
|
---|
13 | my ($epsg, $minlat, $minlon, $maxlat, $maxlon) = ($1, $2, $3, $4, $5);
|
---|
14 | next if $epsg =~ /325.../; # strange codes, don't seem to exist
|
---|
15 | next if $epsg eq '4326'; # trivial, but annoying, because output isn't in meters
|
---|
16 | next if $epsg =~ /^2756[1-4]$/; # proj.4 seems to give wrong results for Lambert 4 zones (missing grid shift file?)
|
---|
17 | if ($epsg eq '3059') { # proj.4 cannot handle the wider bounds that are built into josm
|
---|
18 | ($minlat, $minlon, $maxlat, $maxlon) = (55.64,20.98,58.12,28.23);
|
---|
19 | }
|
---|
20 | #print "$epsg: ($minlat, $minlon, $maxlat, $maxlon)\n";
|
---|
21 |
|
---|
22 | for (1 .. 3) {
|
---|
23 | my $lat = rand() * ($maxlat - $minlat) + $minlat;
|
---|
24 | my $lon = rand() * ($maxlon - $minlon) + $minlon;
|
---|
25 |
|
---|
26 | open PROJ4, "echo \"$lon $lat\" | cs2cs +init=epsg:4326 +to +init=epsg:$epsg -f %.9f |" or die;
|
---|
27 | my $res = <PROJ4>;
|
---|
28 | die unless $res =~ /(\S+)\s+(\S+)\s/;
|
---|
29 | print "EPSG:$epsg,$lat,$lon,$1,$2\n";
|
---|
30 | close PROJ4 or die "error: $! $?";
|
---|
31 | }
|
---|
32 |
|
---|
33 | }
|
---|