[Proj] How to build the correct paramater list for pj_init()
Hamish
hamish_nospam at yahoo.com
Wed Oct 31 03:01:57 PDT 2007
Richard Zinn wrote:
> Hi, Sorry if this has been addressed before, I couldn't see any way to
> search the archive.
>
> I want to build the correct paramater list for proj based on this data:
> PROJCS["NAD_1983_UTM_Zone_12N",GEOGCS["GCS_North_American_1983",
> DATUM["D_North_American_1983",
> SPHEROID["GRS_1980",6378137.0,298.257222101]],
> PRIMEM["Greenwich",0.0],
> UNIT["Degree",0.0174532925199433]],
>
> PROJECTION["Transverse_Mercator"],
> PARAMETER["False_Easting",500000.0],
> PARAMETER["False_Northing",0.0],
> PARAMETER["Central_Meridian",-111.0],
> PARAMETER["Scale_Factor",0.9996],
> PARAMETER["Latitude_Of_Origin",0.0],
> UNIT["Meter",1.0]]
>
> I've read the documentation, and since I'm just a newbie to cartography
> it is all still a little unclear and I need to learn by example.
>
> Is there any code out there (any language) I could see that takes this
> kind of input and builds out the paramaters for prj_init()?
>
> My guess is that it is something like this:
> static char *params_in[] = {
> "proj=tmerc",
> "lat_0=0",
> "lon_0=500000",
> "units=m"
> };
> prj_init(4, params_in);
>
> But that doesn't work :) And I'm sure it is pretty far off.
The above is WKT "Well known text" format,
http://en.wikipedia.org/wiki/Well-known_text
Yours looks a lot like standard UTM zone 12 North.
>From the /usr/share/proj/epsg file:
# NAD83 / UTM zone 12N
<26912> +proj=utm +zone=12 +ellps=GRS80 +datum=NAD83 +units=m +no_defs <>
simple method: does it work using that EPSG code? or one of the other
UTM12N epsg codes?
using the WKT with GRASS GIS's g.proj module to make a new project location:
GRASS6.3> g.proj -c location=foo wkt=- << EOF
PROJCS["NAD_1983_UTM_Zone_12N",GEOGCS["GCS_North_American_1983",
DATUM["D_North_American_1983",
SPHEROID["GRS_1980",6378137.0,298.257222101]],
PRIMEM["Greenwich",0.0],
UNIT["Degree",0.0174532925199433]],
PROJECTION["Transverse_Mercator"],
PARAMETER["False_Easting",500000.0],
PARAMETER["False_Northing",0.0],
PARAMETER["Central_Meridian",-111.0],
PARAMETER["Scale_Factor",0.9996],
PARAMETER["Latitude_Of_Origin",0.0],
UNIT["Meter",1.0]]
EOF
Location foo created!
then in the new location we can check by outputting projection info in
WKT format: (should be the same as the input)
GRASS6.3> g.proj -w
PROJCS["UTM Zone 12, Northern Hemisphere",
GEOGCS["grs80",
DATUM["North_American_Datum_1983",
SPHEROID["Geodetic_Reference_System_1980",6378137,298.257222101]],
PRIMEM["Greenwich",0],
UNIT["degree",0.0174532925199433]],
PROJECTION["Transverse_Mercator"],
PARAMETER["latitude_of_origin",0],
PARAMETER["central_meridian",-111],
PARAMETER["scale_factor",0.9996],
PARAMETER["false_easting",500000],
PARAMETER["false_northing",0],
UNIT["Meter",1]]
and output in PROj.4 format:
GRASS6.3> g.proj -j
+proj=utm
+no_defs
+zone=12
+a=6378137
+rf=298.257222101
+towgs84=0.000,0.000,0.000
+to_meter=1
does that help?
Hamish
More information about the Proj
mailing list