magplot {magicaxis} | R Documentation |
Magically pretty plots
Description
Makes scientific plots based on magaxis axes. Particularly designed for log plotting. Utilises base plot for the most part, but the axis drawing is replaced by a call to the magaxis fuction.
Usage
magplot(x, y, z = NULL, log = "", main = "", side = 1:2, majorn = 5, minorn = 'auto',
tcl = 0.5, ratio = 0.5, labels = TRUE, unlog = "auto", mgp = c(2,0.5,0), mtline = 2,
xlab = '', ylab = '', crunch = TRUE, logpretty = TRUE, prettybase = 10, powbase = 10,
hersh = FALSE, family = "sans", frame.plot = TRUE, usepar = FALSE, grid = TRUE,
grid.col = 'grey90', grid.lty = 1, grid.lwd = 1, xlim = NULL, ylim = NULL, lwd = 1,
axis.lwd = 1, ticks.lwd = axis.lwd, axis.col = 'black', zcol = hcl.colors(21),
zstretch = 'lin', dobar = TRUE, ...)
Arguments
x |
The x coordinates of points/lines in the plot. Alternatively, a single plotting structure, function or any R object with a plot method can be provided. |
y |
The y coordinates of points/lines in the plot, optional if x is an appropriate structure. |
z |
The z coordinates for colour scaling of points in the plot. This will be passed through |
log |
Log axis arguments to be passed to plot. E.g. use 'x', 'y', 'xy' or 'yx' as appropriate. Default ” assumes no logging of any axes. |
main |
Title for the plot. Default is no title. |
side |
The side to be used for axis labelling in the same sense as the base axis function (1=bottom, 2=left, 3=top, 4=right). A vector of multiple entries is allowed. By default, bottom and left axes are drawn (i.e. side 1 and 2). If side=FALSE then no sides or labels will be drawn. |
majorn |
The target number of major-axis sub-divisions for pretty plotting. If length is 1 and length of side is longer than this value is used for all axes. If length of arguments is longer than 1 then these should tally with the relevant axes in side. Obvious reason for varying this is different pretty labelling between a and y axes. |
minorn |
The exact number of minor-axis divisions (i.e. desired minor ticks + 1) to display in plotting. Auto will produce |
tcl |
The length of major tick marks as a fraction of the height of a line of text. By default these face into the plot (in common with scientific plotting) with a value of 0.5, rather than the R default of -0.5. It is possible to force magaxis to inherit directly from par by setting usepar=TRUE (see below). See |
ratio |
Ratio of minor to major tick mark lengths. |
labels |
Specifies whether major-axis ticks should be labelled for each axis. If length is 1 and length of side is longer than this value is used for all axes. If length of arguments is longer than 1 then these should tally with the relevant axes in side. Default is to label all axes. |
unlog |
Determines if axis labels should be unlogged. If axis is found to be logged in par('usr') then the minor ticks are automatically log spaced, however "unlog" still controls how the labelling is done: either logged form (FALSE) or exponent form (TRUE). If axis has been explicitly logged (e.g. log10(x)) then this will can produce exponential axis marking/labelling if set to TRUE. This case will also produce log minor tick marks. If length of unlog is 1 and length of side is longer than 1 then the assigned unlog value is used for all axes. If length of arguments is longer than 1 then these should tally with the relevant axes in side. Can also take the text argument 'x', 'y', 'xy' or 'yx', where these refer to which axes have been logged. If left at the default of ‘auto’ then unlog is assumed to be true when the axis in question is logged, and false otherwise. |
mgp |
The margin line (in mex units) for the axis title, axis labels and axis line. This has different (i.e. prettier) defaults than R of c(2,0.5,0) rather than c(3,1,0). This pushes the numbers and labels nearer to the plot compared to the defaults. It is possible to force magaxis to inherit directly from par by setting usepar=TRUE (see below). See |
mtline |
Number of lines separating axis name from axis. If length 2 then specifies x and y axis separation respectively (else these are the same). |
xlab |
x axis name. |
ylab |
y axis name. |
crunch |
In cases where the scientific text would be written as 1x10^8, should the 1x be removed so it reads 10^8. If length is 1 and length of side is longer then this value is used for all axes. If length of arguments is longer than 1 then these should tally with the relevant axes in side. TRUE by default. |
logpretty |
Should the major-ticks only be located at powers of 10. This changes cases where ticks are placed at 1, 3.1, 10, 31, 100 etc to 1, 10, 100. If length is 1 and length of side is longer then this value is used for all axes. If length of arguments is longer than 1 then these should tally with the relevant axes in side. TRUE by default. |
prettybase |
The unit of repitition desired. By default it is 10, implying a pretty plot is one with marks at 10, 20, 30 etc. If you are plotting degrees then it might be prettier to display 90, 180, 270 etc. In which case prettybase should be set to 90. If log=TRUE then the reference location of 10 is changed, so in the previous example the labels generated would be at 9, 90, 900 etc rather than the deafult of 1, 10, 100 etc. If length is 1 and length of side is longer then this value is used for all axes. If length of arguments is longer than 1 then these should tally with the relevant axes in side. |
powbase |
Set the base to use for logarithmic axes. Default is to use 10. |
hersh |
To determines whether all plot text should be passed using Hershey vector fonts. This applies to the axis labels (which are handled automatically) and the axis names. In the case of axis names the user must be careful to use the correct plot utils escape characters: http://www.gnu.org/software/plotutils/manual/en/html_node/Text-String-Format.html. magaxis will return back to the current plotting family after the function has executed. |
family |
Specifies the plotting family to be used. Allowed options are 'sans' and 'serif'. Depending on whether hersh is TRUE or FALSE these otions are either applied to the Hershey vector fonts (hersh=TRUE) or the default R Helvetica font (hersh=FALSE). magaxis will return back to the current plotting family after the function has executed. |
frame.plot |
Logical indicating whether a box should be drawn around the plot. |
usepar |
Logical indicating whether tcl and mgp should be forced to inherit the global par values. This might be preferred when you want to define global plot settings at the start of a script. |
grid |
Logical indicating whether a background grid should be drawn onto the plotting area. If true this will generate vertical and horiztonal grid lines. For more control (i.e. to only draw horizontal or verical lines) see |
grid.col |
The colour of the grid to be drawn. |
grid.lty |
The line type of the grid to be drawn. |
grid.lwd |
The line width of the grid to be drawn. |
xlim |
Vector; range of data to display. If this is set to NULL (default) then the limits will be estimated from the data dynamically. If length equals 1 then the argument is taken to mean the sigma range to select for plotting and the clipping is done by |
ylim |
Vector; range of data to display. If this is set to NULL (default) then the limits will be estimated from the data dynamically. If length equals 1 then the argument is taken to mean the sigma range to select for plotting and the clipping is done by |
lwd |
The width of plot lines to be drawn. This has different behaviour depending on the plot type. |
axis.lwd |
The line width of the axis to be drawn. This is passed to lwd argument in |
ticks.lwd |
The line width of the ticks to be drawn. This is passed to ticks.lwd argument in |
axis.col |
Colour argument to pass directly to col in axis. It is a bit clunky to have to specify this, but the option 'col' clashes too much with line and point colours. |
zcol |
Vector; a colour palette to use for z mapped colours. Must be a vector and not a function.. Only relevant if data has been passed to z |
zstretch |
Character scalar; z colour stretch, either linear (lin, default) or logarithmic (log, good for large dynamic ranges). |
dobar |
Logical; should a colour bar be added to the plot? |
... |
Further arguments to be passed to: base |
Details
This is a simple function that just turns off most of the plotting output of base plot, and replaces where possible those present in magaxis.
If x is a data.frame with more than 2 columns then the utility base plot
data.frame plotting function is used to create a full plotting grid. This ignores magaxis
settings entirely.
Setting xlim and ylim
Value
No output. Run for the side effect of producing nice plotting axes.
Author(s)
Aaron Robotham
See Also
magaxis
, maglab
, magerr
, magmap
, magrun
Examples
x=10^{1:9}
y=1:9
magplot(log10(x),y,unlog='x')
magplot(x,y,log='x')
#Not ideal to have two decades between major labels:
magplot(x,y,log='x',majorn=c(10,5))
magplot(x,y,log='xy',majorn=c(10,5,5,5),side=1:4)
#Sometimes it is helpful to focus on where most of the data actually is.
#Using a single value for xlim and ylim sigma clips the data to that range.
#Here a value of 2 means we only show the inner 2-sigma (2% to 98%) range.
#The 'auto' option allows magclip to dynamically estimate a clip value.
temp=cbind(rt(1e3,1.5),rt(1e3,1.5))
magplot(temp)
magplot(temp, xlim=2, ylim=2)
magplot(temp, xlim='auto', ylim='auto')
#Some astronomy related examples (and how to display the solar symbol):
## Not run:
temp=cbind(runif(10,8,12),runif(10,0,5))
magplot(temp[,1:2], xlab=expression(M['\u0298']), ylab=expression(M['\u0298']/Yr), unlog='xy')
## End(Not run)
#With z scaling
z=sqrt(9:1)
magplot(x, y, z, log='x', position='topleft')