5. GMT Coordinate Transformations¶
GMT programs read real-world coordinates and convert them to positions on a plot. This is achieved by selecting one of several coordinate transformations or projections. We distinguish between three sets of such conversions:
The next Chapter will be dedicated to GMT map projections in its entirety. Meanwhile, the present Chapter will summarize
the properties of the Cartesian and
Polar coordinate transformations available
in GMT, list which parameters define them, and demonstrate how they are used to create simple plot axes. We will mostly
be using basemap (and occasionally plot) to demonstrate the various transformations. Our illustrations
may differ from those you reproduce with the same commands because of different settings in our gmt.conf
file.
Finally, note that while we will specify dimensions in inches (by appending i), you may want to use cm (c), or
points (p) as unit instead.
5.1. Cartesian coordinate transformations¶
GMT Cartesian coordinate transformations come in three flavors:
These transformations convert input coordinates
Two subsets of linear will be discussed separately; these are a polar (cylindrical) projection and a linear projection applied to geographic coordinates (with a 360° periodicity in the x-coordinate). We will show examples of all of these projections using dummy data sets created with gmtmath, a “Reverse Polish Notation” (RPN) calculator that operates on or creates table data:
5.1.1. Linear coordinate transformation¶
There are in fact three different uses of the Cartesian linear transformation, each associated with specific command line options. The different manifestations result from specific properties of three kinds of data:
5.1.1.1. Regular floating point coordinates¶
Syntax
-Jx|Xx-scale|width[/y-scale|height]
Parameters
The x-scale in plot-units/data-unit (with -Jx) or the width (x-axis length) in plot-units (with -JX).
Optionally, the y-scale in plot-units/data-unit (with -Jx) or the height (y-axis length) in plot-units (with -JX). If the y-scale or y-axis length is different from that of the x-axis (which is most often the case), separate the two scales (or lengths) by a slash, e.g., -Jx0.1i/0.5i or -JX8i/5i.
Description
Selection of the Cartesian linear transformation with regular floating point coordinates will result in a simple linear
scaling
Normally, the user’s
Example
Our

Linear transformation of Cartesian coordinates.¶
5.1.1.2. Geographic coordinates¶
Syntax
-Jx|Xx-scale|width[/y-scale|height][d|g] or -Rg|d
Parameters
The x-scale in plot-units/data-unit (with -Jx) or the width (x-axis length) in plot-units (with -JX).
Optionally, the y-scale in plot-units/data-unit (with -Jx) or the height (y-axis length) in plot-units (with -JX). If the y-scale or y-axis length is different from that of the x-axis (which is most often the case), separate the two scales (or lengths) by a slash, e.g., -Jx0.1i/0.5i or -JX8i/5i.
d or g to indicate that data are geographical coordinates
Description
While the Cartesian linear projection is primarily designed for regular floating point
Example
A crude world map centered on 125°E can be plotted as follows:

Linear transformation of map coordinates.¶
5.1.1.3. Calendar time coordinates¶
Syntax
-Jx|Xx-scale|width[/y-scale|height]T|t or -R with [date]T[clock] time entry or relative time followed by t
Parameters
The x-scale in plot-units/data-unit (with -Jx) or the width (x-axis length) in plot-units (with -JX).
Optionally, the y-scale in plot-units/data-unit (with -Jx) or the height (y-axis length) in plot-units (with -JX). If the y-scale or y-axis length is different from that of the x-axis (which is most often the case), separate the two scales (or lengths) by a slash, e.g., -Jx0.1i/0.5i or -JX8i/5i.
t to indicate that input coordinates are time relative to TIME_EPOCH or T to indicate that input coordinates are absolute time.
Description
Several particular issues arise when we seek to make linear plots using calendar date/time as the input coordinates. As far as setting up the coordinate transformation we must indicate whether our input data have absolute time coordinates or relative time coordinates. For the former we append T after the axis scale (or width), while for the latter we append t at the end of the -Jx (or -JX) option. However, other command line arguments (like the -R option) may already specify whether the time coordinate is absolute or relative. An absolute time entry must be given as [date]T[clock] (with date given as yyyy[-mm[-dd]], yyyy[-jjj], or yyyy[-Www[-d]], and clock using the hh[:mm[:ss[.xxx]]] 24-hour clock format) whereas the relative time is simply given as the units of time since the epoch followed by t (see TIME_UNIT and TIME_EPOCH for information on specifying the time unit and the epoch).
When the coordinate ranges provided by the -R option and the projection type given by -JX (including the optional d, g, t or T) conflict, GMT will warn the users about it. In general, the options provided with -JX will prevail.
Example
A simple plot of a school week calendar can be made as follows:

Linear transformation of calendar coordinates.¶
5.1.2. Logarithmic coordinate transformation¶
Syntax
-Jx|Xx-scale|width[l][/y-scale|height[l]]
Parameters
The x-scale in plot-units/data-unit (with -Jx) or the width (x-axis length) in plot-units (with -JX).
Optionally, the y-scale in plot-units/data-unit (with -Jx) or the height (y-axis length) in plot-units (with -JX). If the y-scale or y-axis length is different from that of the x-axis (which is most often the case), separate the two scales (or lengths) by a slash, e.g., -Jx0.1i/0.5i or -JX8i/5i.
l to take log10 of values before scaling.
Description
The
Note that if
Example
A plot in which the x-axis is logarithmic (the y-axis remains linear, i.e., a semi-log plot) can be made as follows:

Logarithmic transformation of x–coordinates.¶
5.1.3. Power (exponential) coordinate transformation¶
Syntax
-Jx|Xx-scale|width[ppower][/y-scale|height[ppower]]
Parameters
The x-scale in plot-units/data-unit (with -Jx) or the width (x-axis length) in plot-units (with -JX).
Optionally, the y-scale in plot-units/data-unit (with -Jx) or the height (y-axis length) in plot-units (with -JX). If the y-scale or y-axis length is different from that of the x-axis (which is most often the case), separate the two scales (or lengths) by a slash, e.g., -Jx0.1i/0.5i or -JX8i/5i.
ppower to raise values to power before scaling.
Description
This projection uses
Example
This example uses the exponents

Exponential or power transformation of x–coordinates.¶
5.2. Polar coordinate transformations¶
Syntax
-Jp|Pscale|width[+a][+f[e|p|radius]][+roffset][+torigin][+z[p|radius]]]
Parameters
The scale (with -Jp; in plot-units/r-unit) or width (with -JP; in plot-units).
Optionally, +a to indicate that theta is azimuth CW from North instead of direction CCW from East [Default is CCW from East].
Optionally, +f to flip the radial direction to point inwards, and append e to indicate that r represents elevations in degrees (requires south >= 0 and north <= 90), p to select current planetary radius (determined by PROJ_ELLIPSOID) as maximum radius [north], or radius to specify a custom radius.
Optionally, +roffset to include a radial offset in measurement units [default is 0].
Optionally, +torigin in degrees so that this angular value is aligned with the positive x-axis (or the azimuth to be aligned with the positive y-axis if +a) [default is 0].
Optionally, +z to annotate depth rather than radius [default is radius]. Alternatively, if your r data are actually depths then you can append p or radius to get radial annotations (r = radius - z) instead.
Description
This transformation converts polar coordinates (angle
Normally,
is understood to be directions counter-clockwise from the horizontal axis, but we may choose to specify an angular offset [default is zero]. We will call this offset . Then, and .Alternatively,
can be interpreted to be azimuths clockwise from the vertical axis, yet we may again choose to specify the angular offset [default is zero]. Then, and .The radius r can either be radius or inverted to mean depth from the surface, planetary radii, or even elevations in degrees.
Example
As an example of this projection we will create a gridded data set in polar coordinates
We will use grdcontour to make a contour map of this data. Because the data file only contains values
with

Polar (Cylindrical) transformation of (