File: generate-proj-data.pl

package info (click to toggle)
josm 0.0.svn5267%2Bdfsg1-2
  • links: PTS, VCS
  • area: main
  • in suites: wheezy
  • size: 153,404 kB
  • sloc: java: 152,210; xml: 8,902; perl: 1,346; makefile: 64; sh: 35
file content (33 lines) | stat: -rwxr-xr-x 1,378 bytes parent folder | download | duplicates (2)
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
#!/usr/bin/perl

use strict;
use warnings;

print "# Reference data created by proj.4\n";
print "#\n";
print "# code,lat,lon,east,north\n";
for my $in (<>) {
    # input data looks like this: "EPSG:4326 Bounds[-90.0,-180.0,90.0,180.0]"
    # (created by ProjectionRefTest.java)
    next unless $in =~ /EPSG:([0-9]+) Bounds\[(.*),(.*),(.*),(.*)\]/;
    my ($epsg, $minlat, $minlon, $maxlat, $maxlon) = ($1, $2, $3, $4, $5);
    next if $epsg =~ /325.../;      # strange codes, don't seem to exist
    next if $epsg eq '4326';        # trivial, but annoying, because output isn't in meters
    next if $epsg =~ /^2756[1-4]$/; # proj.4 seems to give wrong results for Lambert 4 zones (missing grid shift file?)
    if ($epsg eq '3059') {          # proj.4 cannot handle the wider bounds that are built into josm
        ($minlat, $minlon, $maxlat, $maxlon) = (55.64,20.98,58.12,28.23);
    }
    #print "$epsg: ($minlat, $minlon, $maxlat, $maxlon)\n";
    
    for (1 .. 3) {
        my $lat = rand() * ($maxlat - $minlat) + $minlat;
        my $lon = rand() * ($maxlon - $minlon) + $minlon;
        
        open PROJ4, "echo \"$lon $lat\" | cs2cs +init=epsg:4326 +to +init=epsg:$epsg -f %.9f |" or die;
        my $res = <PROJ4>;
        die unless $res =~ /(\S+)\s+(\S+)\s/;
        print "EPSG:$epsg,$lat,$lon,$1,$2\n"; 
        close PROJ4 or die "error: $! $?";
    }
    
}