Title: | Formula Interface to the Grammar of Graphics |
---|---|
Description: | Provides a formula interface to 'ggplot2' graphics. |
Authors: | Daniel Kaplan [aut], Randall Pruim [aut, cre] |
Maintainer: | Randall Pruim <[email protected]> |
License: | MIT + file LICENSE |
Version: | 0.12.1 |
Built: | 2024-12-28 04:10:44 UTC |
Source: | https://github.com/projectmosaic/ggformula |
Creates a function that can be passed to scales for creating discrete breaks
at multilples of resolution
.
discrete_breaks(resolution = 1)
discrete_breaks(resolution = 1)
resolution |
Resolution of the breaks |
A function that can be passed to scales functions as the breaks
argument.
x <- rbinom(100, 100, 0.4) p <- gf_bar( ~ x) p |> gf_refine(scale_x_continuous(breaks = discrete_breaks())) p |> gf_refine(scale_x_continuous(breaks = discrete_breaks(5))) p |> gf_refine(scale_x_continuous(breaks = discrete_breaks(2)))
x <- rbinom(100, 100, 0.4) p <- gf_bar( ~ x) p |> gf_refine(scale_x_continuous(breaks = discrete_breaks())) p |> gf_refine(scale_x_continuous(breaks = discrete_breaks(5))) p |> gf_refine(scale_x_continuous(breaks = discrete_breaks(2)))
Some packages like expss provide mechanisms for providing longer labels to R objects.
These labels can be used when labeling plots and tables, for example, without requiring
long or awkward variable names. This is an experimental feature and currently only supports
expss or any other system that stores a label in the label
attribute of a vector.
get_variable_labels(...)
get_variable_labels(...)
... |
passed to |
get_variable_labels()
is a synonym of labelled::var_label()
.
labelled::var_label()
, labelled::set_variable_labels()
KF <- mosaicData::KidsFeet |> set_variable_labels( length = 'foot length (cm)', width = 'foot width (cm)', birthmonth = 'birth month', birthyear = 'birth year', biggerfoot = 'bigger foot', domhand = 'dominant hand' ) KF |> gf_point(length ~ width, color = ~ domhand) get_variable_labels(KF)
KF <- mosaicData::KidsFeet |> set_variable_labels( length = 'foot length (cm)', width = 'foot width (cm)', birthmonth = 'birth month', birthyear = 'birth year', biggerfoot = 'bigger foot', domhand = 'dominant hand' ) KF |> gf_point(length ~ width, color = ~ domhand) get_variable_labels(KF)
These functions create layers that display lines described i various ways. Unlike most
of the plotting functions in ggformula
, these functions do not take a formula
as input for describing positional attributes of the plot.
gf_abline( object = NULL, gformula = NULL, data = NULL, ..., slope, intercept, color, linetype, linewidth, alpha, xlab, ylab, title, subtitle, caption, show.legend = NA, show.help = NULL, inherit = FALSE, environment = parent.frame() ) gf_hline( object = NULL, gformula = NULL, data = NULL, ..., yintercept, color, linetype, linewidth, alpha, xlab, ylab, title, subtitle, caption, show.legend = NA, show.help = NULL, inherit = FALSE, environment = parent.frame() ) gf_vline( object = NULL, gformula = NULL, data = NULL, ..., xintercept, color, linetype, linewidth, alpha, xlab, ylab, title, subtitle, caption, show.legend = NA, show.help = NULL, inherit = FALSE, environment = parent.frame() ) gf_coefline(object = NULL, coef = NULL, model = NULL, ...)
gf_abline( object = NULL, gformula = NULL, data = NULL, ..., slope, intercept, color, linetype, linewidth, alpha, xlab, ylab, title, subtitle, caption, show.legend = NA, show.help = NULL, inherit = FALSE, environment = parent.frame() ) gf_hline( object = NULL, gformula = NULL, data = NULL, ..., yintercept, color, linetype, linewidth, alpha, xlab, ylab, title, subtitle, caption, show.legend = NA, show.help = NULL, inherit = FALSE, environment = parent.frame() ) gf_vline( object = NULL, gformula = NULL, data = NULL, ..., xintercept, color, linetype, linewidth, alpha, xlab, ylab, title, subtitle, caption, show.legend = NA, show.help = NULL, inherit = FALSE, environment = parent.frame() ) gf_coefline(object = NULL, coef = NULL, model = NULL, ...)
object |
When chaining, this holds an object produced in the earlier portions of the chain. Most users can safely ignore this argument. See details and examples. |
gformula |
Must be |
data |
The data to be displayed in this layer. There are three options: If A A |
... |
Additional arguments. Typically these are
(a) ggplot2 aesthetics to be set with |
color |
A color or a formula used for mapping color. |
linetype |
A linetype (numeric or "dashed", "dotted", etc.) or a formula used for mapping linetype. |
linewidth |
A numerical line width or a formula used for mapping linewidth. |
alpha |
Opacity (0 = invisible, 1 = opaque). |
xlab |
Label for x-axis. See also |
ylab |
Label for y-axis. See also |
title , subtitle , caption
|
Title, sub-title, and caption for the plot.
See also |
show.legend |
logical. Should this layer be included in the legends?
|
show.help |
If |
inherit |
A logical indicating whether default attributes are inherited. |
environment |
An environment in which to look for variables not found in |
xintercept , yintercept , slope , intercept
|
Parameters that control the
position of the line. If these are set, |
coef |
A numeric vector of coefficients. |
model |
A model from which to extract coefficients. |
ggplot2::geom_abline()
,
ggplot2::geom_vline()
,
ggplot2::geom_hline()
mtcars2 <- df_stats(wt ~ cyl, data = mtcars, median_wt = median) gf_point(wt ~ hp, size = ~wt, color = ~cyl, data = mtcars) |> gf_abline(slope = ~0, intercept = ~median_wt, color = ~cyl, data = mtcars2) gf_point(wt ~ hp, size = ~wt, color = ~cyl, data = mtcars) |> gf_abline(slope = 0, intercept = 3, color = "green") # avoid warnings by using formulas: gf_point(wt ~ hp, size = ~wt, color = ~cyl, data = mtcars) |> gf_abline(slope = ~0, intercept = ~3, color = "green") gf_point(wt ~ hp, size = ~wt, color = ~cyl, data = mtcars) |> gf_hline(yintercept = ~median_wt, color = ~cyl, data = mtcars2) gf_point(mpg ~ hp, color = ~cyl, size = ~wt, data = mtcars) |> gf_abline(color = "red", slope = ~ - 0.10, intercept = ~ 35) gf_point(mpg ~ hp, color = ~cyl, size = ~wt, data = mtcars) |> gf_abline( color = "red", slope = ~slope, intercept = ~intercept, data = data.frame(slope = -0.10, intercept = 33:35) ) # We can set the color of the guidelines while mapping color in other layers gf_point(mpg ~ hp, color = ~cyl, size = ~ wt, data = mtcars) |> gf_hline(color = "navy", yintercept = ~ c(20, 25), data = NA) |> gf_vline(color = "brown", xintercept = ~ c(200, 300), data = NA) # If we want to map the color of the guidelines, it must work with the # scale of the other colors in the plot. gf_point(mpg ~ hp, size = ~wt, data = mtcars, alpha = 0.3) |> gf_hline(color = ~"horizontal", yintercept = ~ c(20, 25), data = NA) |> gf_vline(color = ~"vertical", xintercept = ~ c(100, 200, 300), data = NA) gf_point(mpg ~ hp, size = ~wt, color = ~ factor(cyl), data = mtcars, alpha = 0.3) |> gf_hline(color = "orange", yintercept = ~ 20) |> gf_vline(color = ~ c("4", "6", "8"), xintercept = ~ c(80, 120, 250), data = NA) gf_point(mpg ~ hp, size = ~wt, color = ~ factor(cyl), data = mtcars, alpha = 0.3) |> gf_hline(color = "orange", yintercept = ~ 20) |> gf_vline(color = c("green", "red", "blue"), xintercept = ~ c(80, 120, 250), data = NA) # reversing the layers requires using inherit = FALSE gf_hline(color = "orange", yintercept = ~ 20) |> gf_vline(color = ~ c("4", "6", "8"), xintercept = ~ c(80, 120, 250), data = NA) |> gf_point(mpg ~ hp, size = ~wt, color = ~ factor(cyl), data = mtcars, alpha = 0.3, inherit = FALSE )
mtcars2 <- df_stats(wt ~ cyl, data = mtcars, median_wt = median) gf_point(wt ~ hp, size = ~wt, color = ~cyl, data = mtcars) |> gf_abline(slope = ~0, intercept = ~median_wt, color = ~cyl, data = mtcars2) gf_point(wt ~ hp, size = ~wt, color = ~cyl, data = mtcars) |> gf_abline(slope = 0, intercept = 3, color = "green") # avoid warnings by using formulas: gf_point(wt ~ hp, size = ~wt, color = ~cyl, data = mtcars) |> gf_abline(slope = ~0, intercept = ~3, color = "green") gf_point(wt ~ hp, size = ~wt, color = ~cyl, data = mtcars) |> gf_hline(yintercept = ~median_wt, color = ~cyl, data = mtcars2) gf_point(mpg ~ hp, color = ~cyl, size = ~wt, data = mtcars) |> gf_abline(color = "red", slope = ~ - 0.10, intercept = ~ 35) gf_point(mpg ~ hp, color = ~cyl, size = ~wt, data = mtcars) |> gf_abline( color = "red", slope = ~slope, intercept = ~intercept, data = data.frame(slope = -0.10, intercept = 33:35) ) # We can set the color of the guidelines while mapping color in other layers gf_point(mpg ~ hp, color = ~cyl, size = ~ wt, data = mtcars) |> gf_hline(color = "navy", yintercept = ~ c(20, 25), data = NA) |> gf_vline(color = "brown", xintercept = ~ c(200, 300), data = NA) # If we want to map the color of the guidelines, it must work with the # scale of the other colors in the plot. gf_point(mpg ~ hp, size = ~wt, data = mtcars, alpha = 0.3) |> gf_hline(color = ~"horizontal", yintercept = ~ c(20, 25), data = NA) |> gf_vline(color = ~"vertical", xintercept = ~ c(100, 200, 300), data = NA) gf_point(mpg ~ hp, size = ~wt, color = ~ factor(cyl), data = mtcars, alpha = 0.3) |> gf_hline(color = "orange", yintercept = ~ 20) |> gf_vline(color = ~ c("4", "6", "8"), xintercept = ~ c(80, 120, 250), data = NA) gf_point(mpg ~ hp, size = ~wt, color = ~ factor(cyl), data = mtcars, alpha = 0.3) |> gf_hline(color = "orange", yintercept = ~ 20) |> gf_vline(color = c("green", "red", "blue"), xintercept = ~ c(80, 120, 250), data = NA) # reversing the layers requires using inherit = FALSE gf_hline(color = "orange", yintercept = ~ 20) |> gf_vline(color = ~ c("4", "6", "8"), xintercept = ~ c(80, 120, 250), data = NA) |> gf_point(mpg ~ hp, size = ~wt, color = ~ factor(cyl), data = mtcars, alpha = 0.3, inherit = FALSE )
For each x value, geom_ribbon()
displays a y interval defined
by ymin
and ymax
. geom_area()
is a special case of
geom_ribbon()
, where the ymin
is fixed to 0 and y
is used instead
of ymax
.
gf_area( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, fill, group, linetype, linewidth, xlab, ylab, title, subtitle, caption, geom = "area", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
gf_area( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, fill, group, linetype, linewidth, xlab, ylab, title, subtitle, caption, geom = "area", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
object |
When chaining, this holds an object produced in the earlier portions of the chain. Most users can safely ignore this argument. See details and examples. |
gformula |
A formula with shape |
data |
The data to be displayed in this layer. There are three options: If A A |
... |
Additional arguments. Typically these are
(a) ggplot2 aesthetics to be set with |
alpha |
Opacity (0 = invisible, 1 = opaque). |
color |
A color or a formula used for mapping color. |
fill |
A color for filling, or a formula used for mapping fill. |
group |
Used for grouping. |
linetype |
A linetype (numeric or "dashed", "dotted", etc.) or a formula used for mapping linetype. |
linewidth |
A numerical line width or a formula used for mapping linewidth. |
xlab |
Label for x-axis. See also |
ylab |
Label for y-axis. See also |
title , subtitle , caption
|
Title, sub-title, and caption for the plot.
See also |
geom |
The geometric object to use to display the data, either as a
|
stat |
The statistical transformation to use on the data for this
layer, either as a |
position |
Position adjustment, either as a string naming the adjustment
(e.g. |
show.legend |
logical. Should this layer be included in the legends?
|
show.help |
If |
inherit |
A logical indicating whether default attributes are inherited. |
environment |
An environment in which to look for variables not found in |
if (require(dplyr) && require(mosaicData)) { Temps <- Weather |> filter(city == "Chicago", year == 2016, month <= 4) gf_linerange(low_temp + high_temp ~ date, color = ~high_temp, data = Temps) gf_ribbon(low_temp + high_temp ~ date, data = Temps, color = "navy", alpha = 0.3) gf_area(high_temp ~ date, data = Temps, color = "navy", alpha = 0.3) gf_ribbon(low_temp + high_temp ~ date, data = Weather, alpha = 0.3) |> gf_facet_grid(city ~ .) gf_linerange(low_temp + high_temp ~ date, color = ~high_temp, data = Weather) |> gf_facet_grid(city ~ .) |> gf_refine(scale_colour_gradientn(colors = rev(rainbow(5)))) }
if (require(dplyr) && require(mosaicData)) { Temps <- Weather |> filter(city == "Chicago", year == 2016, month <= 4) gf_linerange(low_temp + high_temp ~ date, color = ~high_temp, data = Temps) gf_ribbon(low_temp + high_temp ~ date, data = Temps, color = "navy", alpha = 0.3) gf_area(high_temp ~ date, data = Temps, color = "navy", alpha = 0.3) gf_ribbon(low_temp + high_temp ~ date, data = Weather, alpha = 0.3) |> gf_facet_grid(city ~ .) gf_linerange(low_temp + high_temp ~ date, color = ~high_temp, data = Weather) |> gf_facet_grid(city ~ .) |> gf_refine(scale_colour_gradientn(colors = rev(rainbow(5)))) }
An ASH plot is the average over all histograms of a fixed bin width.
geom_ash()
and gf_ash()
provide ways to create ASH plots
using ggplot2 or ggformula.
gf_ash( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, group, linetype, linewidth, xlab, ylab, title, subtitle, caption, geom = "line", stat = "ash", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) stat_ash( mapping = NULL, data = NULL, geom = "line", position = "identity", na.rm = FALSE, show.legend = NA, inherit.aes = TRUE, binwidth = NULL, adjust = 1, ... ) geom_ash( mapping = NULL, data = NULL, stat = "ash", position = "identity", na.rm = FALSE, show.legend = NA, inherit.aes = TRUE, binwidth = NULL, adjust = 1, ... )
gf_ash( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, group, linetype, linewidth, xlab, ylab, title, subtitle, caption, geom = "line", stat = "ash", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) stat_ash( mapping = NULL, data = NULL, geom = "line", position = "identity", na.rm = FALSE, show.legend = NA, inherit.aes = TRUE, binwidth = NULL, adjust = 1, ... ) geom_ash( mapping = NULL, data = NULL, stat = "ash", position = "identity", na.rm = FALSE, show.legend = NA, inherit.aes = TRUE, binwidth = NULL, adjust = 1, ... )
object |
When chaining, this holds an object produced in the earlier portions of the chain. Most users can safely ignore this argument. See details and examples. |
gformula |
A formula with shape |
data |
A data frame with the variables to be plotted. |
... |
Additional arguments. Typically these are
(a) ggplot2 aesthetics to be set with |
alpha |
Opacity (0 = invisible, 1 = opaque). |
color |
A color or a formula used for mapping color. |
group |
Used for grouping. |
linetype |
A linetype (numeric or "dashed", "dotted", etc.) or a formula used for mapping linetype. |
linewidth |
A numerical line width or a formula used for mapping linewidth. |
xlab |
Label for x-axis. See also |
ylab |
Label for y-axis. See also |
title , subtitle , caption
|
Title, sub-title, and caption for the plot.
See also |
geom |
A character string naming the geom used to make the layer. |
stat |
A character string naming the stat used to make the layer. |
position |
Either a character string naming the position function used for the layer or a position object returned from a call to a position function. |
show.legend |
A logical indicating whether this layer should be included in
the legends. |
show.help |
If |
inherit |
A logical indicating whether default attributes are inherited. |
environment |
An environment in which to look for variables not found in |
mapping |
|
na.rm |
If FALSE (the default), removes missing values with a warning. If TRUE silently removes missing values. |
inherit.aes |
A logical indicating whether default aesthetics are inherited. |
binwidth |
the width of the histogram bins. If |
adjust |
a numeric adjustment to |
a gg object
Positional attributes (a.k.a, aesthetics) are specified using the formula in gformula
.
Setting and mapping of additional attributes can be done through the
use of additional arguments.
Attributes can be set can be set using arguments of the form attribute = value
or
mapped using arguments of the form attribute = ~ expression
.
In formulas of the form A | B
, B
will be used to form facets using
facet_wrap()
or facet_grid()
.
This provides an alternative to
gf_facet_wrap()
and
gf_facet_grid()
that is terser and may feel more familiar to users
of lattice.
Evaluation of the ggplot2 code occurs in the environment of gformula
.
This will typically do the right thing when formulas are created on the fly, but might not
be the right thing if formulas created in one environment are used to create plots
in another.
geom_histogram()
, link{gf_histogram}()
.
data(penguins, package = "palmerpenguins") gf_ash(~bill_length_mm, color = ~species, data = penguins) gf_ash(~bill_length_mm, color = ~species, data = penguins, adjust = 2) gf_ash(~bill_length_mm, color = ~species, data = penguins, binwidth = 1) gf_ash(~bill_length_mm, color = ~species, data = penguins, binwidth = 1, adjust = 2) ggplot(faithful, aes(x = eruptions)) + geom_histogram(aes(y = stat(density)), fill = "lightskyblue", colour = "gray50", alpha = 0.2 ) + geom_ash(colour = "red") + geom_ash(colour = "forestgreen", adjust = 2) + geom_ash(colour = "navy", adjust = 1 / 2) + theme_minimal()
data(penguins, package = "palmerpenguins") gf_ash(~bill_length_mm, color = ~species, data = penguins) gf_ash(~bill_length_mm, color = ~species, data = penguins, adjust = 2) gf_ash(~bill_length_mm, color = ~species, data = penguins, binwidth = 1) gf_ash(~bill_length_mm, color = ~species, data = penguins, binwidth = 1, adjust = 2) ggplot(faithful, aes(x = eruptions)) + geom_histogram(aes(y = stat(density)), fill = "lightskyblue", colour = "gray50", alpha = 0.2 ) + geom_ash(colour = "red") + geom_ash(colour = "forestgreen", adjust = 2) + geom_ash(colour = "navy", adjust = 1 / 2) + theme_minimal()
There are two types of bar charts: geom_bar()
and geom_col()
.
geom_bar()
makes the height of the bar proportional to the number of
cases in each group (or if the weight
aesthetic is supplied, the sum
of the weights). If you want the heights of the bars to represent values
in the data, use geom_col()
instead. geom_bar()
uses stat_count()
by
default: it counts the number of cases at each x position. geom_col()
uses stat_identity()
: it leaves the data as is.
gf_bar( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, fill, group, linetype, linewidth, width = NULL, xlab, ylab, title, subtitle, caption, geom = "bar", stat = "count", position = "stack", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) gf_counts( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, fill, group, linetype, linewidth, width = NULL, xlab, ylab, title, subtitle, caption, geom = "bar", stat = "count", position = "stack", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) gf_props( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, fill, group, linetype, linewidth, xlab, ylab = "proportion", title, subtitle, caption, geom = "bar", stat = "count", position = "stack", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame(), denom = ~PANEL ) gf_percents( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, fill, group, linetype, linewidth, xlab, ylab = "percent", title, subtitle, caption, geom = "bar", stat = "count", position = "stack", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame(), denom = ~PANEL )
gf_bar( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, fill, group, linetype, linewidth, width = NULL, xlab, ylab, title, subtitle, caption, geom = "bar", stat = "count", position = "stack", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) gf_counts( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, fill, group, linetype, linewidth, width = NULL, xlab, ylab, title, subtitle, caption, geom = "bar", stat = "count", position = "stack", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) gf_props( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, fill, group, linetype, linewidth, xlab, ylab = "proportion", title, subtitle, caption, geom = "bar", stat = "count", position = "stack", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame(), denom = ~PANEL ) gf_percents( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, fill, group, linetype, linewidth, xlab, ylab = "percent", title, subtitle, caption, geom = "bar", stat = "count", position = "stack", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame(), denom = ~PANEL )
object |
When chaining, this holds an object produced in the earlier portions of the chain. Most users can safely ignore this argument. See details and examples. |
gformula |
A formula, typically with shape |
data |
The data to be displayed in this layer. There are three options: If A A |
... |
Additional arguments. Typically these are
(a) ggplot2 aesthetics to be set with |
alpha |
Opacity (0 = invisible, 1 = opaque). |
color |
A color or a formula used for mapping color. |
fill |
A color for filling, or a formula used for mapping fill. |
group |
Used for grouping. |
linetype |
A linetype (numeric or "dashed", "dotted", etc.) or a formula used for mapping linetype. |
linewidth |
A numerical line width or a formula used for mapping linewidth. |
width |
Width of the bars. |
xlab |
Label for x-axis. See also |
ylab |
Label for y-axis. See also |
title , subtitle , caption
|
Title, sub-title, and caption for the plot.
See also |
geom , stat
|
Override the default connection between |
position |
Position adjustment, either as a string naming the adjustment
(e.g. |
show.legend |
logical. Should this layer be included in the legends?
|
show.help |
If |
inherit |
A logical indicating whether default attributes are inherited. |
environment |
An environment in which to look for variables not found in |
denom |
A formula, the right hand side of which describes the denominators used for computing proportions and percents. These are computed after the stat has been applied to the data and should refer to variables available at that point. See the examples. |
a gg object
Positional attributes (a.k.a, aesthetics) are specified using the formula in gformula
.
Setting and mapping of additional attributes can be done through the
use of additional arguments.
Attributes can be set can be set using arguments of the form attribute = value
or
mapped using arguments of the form attribute = ~ expression
.
In formulas of the form A | B
, B
will be used to form facets using
facet_wrap()
or facet_grid()
.
This provides an alternative to
gf_facet_wrap()
and
gf_facet_grid()
that is terser and may feel more familiar to users
of lattice.
Evaluation of the ggplot2 code occurs in the environment of gformula
.
This will typically do the right thing when formulas are created on the fly, but might not
be the right thing if formulas created in one environment are used to create plots
in another.
gf_bar(~substance, data = mosaicData::HELPrct) gf_bar(~substance, data = mosaicData::HELPrct, fill = ~sex) gf_bar(~substance, data = mosaicData::HELPrct, fill = ~sex, position = position_dodge() ) # gf_counts() is another name for gf_bar() gf_counts(~substance, data = mosaicData::HELPrct, fill = ~sex, position = position_dodge() ) # gf_props() and gf_percents() use proportions or percentages instead of counts # use denom to control which denominators are used. gf_props(~substance, data = mosaicData::HELPrct, fill = ~sex, position = position_dodge() ) gf_props(substance ~ ., data = mosaicData::HELPrct, fill = ~sex, position = position_dodge(), orientation = 'y' ) gf_props(substance ~ ., data = mosaicData::HELPrct, fill = ~sex, position = "dodge" ) gf_percents(~substance, data = mosaicData::HELPrct, fill = ~sex, position = position_dodge() ) gf_percents(~substance, data = mosaicData::HELPrct, fill = ~sex, position = position_dodge(), denom = ~x ) gf_percents(~substance, data = mosaicData::HELPrct, fill = ~sex, position = position_dodge(), denom = ~fill ) gf_percents(~substance | sex, data = mosaicData::HELPrct, fill = ~homeless, position = position_dodge() ) gf_percents(~substance | sex, data = mosaicData::HELPrct, fill = ~homeless, denom = ~fill, position = position_dodge() ) gf_percents(~substance | sex, data = mosaicData::HELPrct, fill = ~homeless, denom = ~interaction(fill, PANEL), position = position_dodge() ) if (require(scales)) { gf_percents(~substance, data = mosaicData::HELPrct, fill = ~sex, position = position_dodge(), denom = ~ x, ) |> gf_refine(scale_y_continuous(labels = scales::percent)) }
gf_bar(~substance, data = mosaicData::HELPrct) gf_bar(~substance, data = mosaicData::HELPrct, fill = ~sex) gf_bar(~substance, data = mosaicData::HELPrct, fill = ~sex, position = position_dodge() ) # gf_counts() is another name for gf_bar() gf_counts(~substance, data = mosaicData::HELPrct, fill = ~sex, position = position_dodge() ) # gf_props() and gf_percents() use proportions or percentages instead of counts # use denom to control which denominators are used. gf_props(~substance, data = mosaicData::HELPrct, fill = ~sex, position = position_dodge() ) gf_props(substance ~ ., data = mosaicData::HELPrct, fill = ~sex, position = position_dodge(), orientation = 'y' ) gf_props(substance ~ ., data = mosaicData::HELPrct, fill = ~sex, position = "dodge" ) gf_percents(~substance, data = mosaicData::HELPrct, fill = ~sex, position = position_dodge() ) gf_percents(~substance, data = mosaicData::HELPrct, fill = ~sex, position = position_dodge(), denom = ~x ) gf_percents(~substance, data = mosaicData::HELPrct, fill = ~sex, position = position_dodge(), denom = ~fill ) gf_percents(~substance | sex, data = mosaicData::HELPrct, fill = ~homeless, position = position_dodge() ) gf_percents(~substance | sex, data = mosaicData::HELPrct, fill = ~homeless, denom = ~fill, position = position_dodge() ) gf_percents(~substance | sex, data = mosaicData::HELPrct, fill = ~homeless, denom = ~interaction(fill, PANEL), position = position_dodge() ) if (require(scales)) { gf_percents(~substance, data = mosaicData::HELPrct, fill = ~sex, position = position_dodge(), denom = ~ x, ) |> gf_refine(scale_y_continuous(labels = scales::percent)) }
These functions were wrappers around functions from ggstance
from an era
before ggplot2
supported horizonally oriented geoms. ggstance
has not
been updated to comply with the current version of ggplot2
, and since the
functionalilty is now available by other means, these functions have been
deprecated.
gf_barh(...) gf_countsh(...) gf_colh(...) gf_propsh(...) gf_percentsh(...) gf_boxploth(...) gf_linerangeh(...) gf_pointrangeh(...) gf_crossbarh(...) gf_violinh(...) gf_errorbarh(...)
gf_barh(...) gf_countsh(...) gf_colh(...) gf_propsh(...) gf_percentsh(...) gf_boxploth(...) gf_linerangeh(...) gf_pointrangeh(...) gf_crossbarh(...) gf_violinh(...) gf_errorbarh(...)
... |
additional arguments |
gf_violin(carat ~ color, data = diamonds) gf_violin(carat ~ color, data = diamonds) |> gf_refine(coord_flip()) gf_violin(color ~ carat, data = diamonds) gf_density(~ carat, data = diamonds) gf_density(carat ~ ., data = diamonds)
gf_violin(carat ~ color, data = diamonds) gf_violin(carat ~ color, data = diamonds) |> gf_refine(coord_flip()) gf_violin(color ~ carat, data = diamonds) gf_density(~ carat, data = diamonds) gf_density(carat ~ ., data = diamonds)
geom_bin2d()
uses ggplot2::stat_bin2d()
to bin the data before using
gf_tile()
to display the results.
gf_bin2d( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, fill, group, linetype, linewidth, xlab, ylab, title, subtitle, caption, geom = "tile", stat = "bin2d", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
gf_bin2d( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, fill, group, linetype, linewidth, xlab, ylab, title, subtitle, caption, geom = "tile", stat = "bin2d", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
object |
When chaining, this holds an object produced in the earlier portions of the chain. Most users can safely ignore this argument. See details and examples. |
gformula |
A formula with shape |
data |
A data frame with the variables to be plotted. |
... |
Additional arguments. Typically these are
(a) ggplot2 aesthetics to be set with |
alpha |
Opacity (0 = invisible, 1 = opaque). |
color |
A color or a formula used for mapping color. |
fill |
A color for filling, or a formula used for mapping fill. |
group |
Used for grouping. |
linetype |
A linetype (numeric or "dashed", "dotted", etc.) or a formula used for mapping linetype. |
linewidth |
A numerical line width or a formula used for mapping linewidth. |
xlab |
Label for x-axis. See also |
ylab |
Label for y-axis. See also |
title , subtitle , caption
|
Title, sub-title, and caption for the plot.
See also |
geom |
A character string naming the geom used to make the layer. |
stat |
A character string naming the stat used to make the layer. |
position |
Either a character string naming the position function used for the layer or a position object returned from a call to a position function. |
show.legend |
A logical indicating whether this layer should be included in
the legends. |
show.help |
If |
inherit |
A logical indicating whether default attributes are inherited. |
environment |
An environment in which to look for variables not found in |
a gg object
Positional attributes (a.k.a, aesthetics) are specified using the formula in gformula
.
Setting and mapping of additional attributes can be done through the
use of additional arguments.
Attributes can be set can be set using arguments of the form attribute = value
or
mapped using arguments of the form attribute = ~ expression
.
In formulas of the form A | B
, B
will be used to form facets using
facet_wrap()
or facet_grid()
.
This provides an alternative to
gf_facet_wrap()
and
gf_facet_grid()
that is terser and may feel more familiar to users
of lattice.
Positional attributes (a.k.a, aesthetics) are specified using the formula in gformula
.
Setting and mapping of additional attributes can be done through the
use of additional arguments.
Attributes can be set can be set using arguments of the form attribute = value
or
mapped using arguments of the form attribute = ~ expression
.
In formulas of the form A | B
, B
will be used to form facets using
facet_wrap()
or facet_grid()
.
This provides an alternative to
gf_facet_wrap()
and
gf_facet_grid()
that is terser and may feel more familiar to users
of lattice.
Evaluation of the ggplot2 code occurs in the environment of gformula
.
This will typically do the right thing when formulas are created on the fly, but might not
be the right thing if formulas created in one environment are used to create plots
in another.
Evaluation of the ggplot2 code occurs in the environment of gformula
.
This will typically do the right thing when formulas are created on the fly, but might not
be the right thing if formulas created in one environment are used to create plots
in another.
ggplot2::geom_bin2d()
, gf_tile()
gf_bin2d(eruptions ~ waiting, data = faithful, bins = 15) |> gf_refine(scale_fill_viridis_c(begin = 0.1, end = 0.9))
gf_bin2d(eruptions ~ waiting, data = faithful, bins = 15) |> gf_refine(scale_fill_viridis_c(begin = 0.1, end = 0.9))
The blank geom draws nothing, but can be a useful way of ensuring common
scales between different plots. See expand_limits()
for
more details.
gf_blank( object = NULL, gformula = NULL, data = NULL, ..., xlab, ylab, title, subtitle, caption, geom = "blank", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) gf_frame( object = NULL, gformula = NULL, data = NULL, ..., xlab, ylab, title, subtitle, caption, geom = "blank", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
gf_blank( object = NULL, gformula = NULL, data = NULL, ..., xlab, ylab, title, subtitle, caption, geom = "blank", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) gf_frame( object = NULL, gformula = NULL, data = NULL, ..., xlab, ylab, title, subtitle, caption, geom = "blank", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
object |
When chaining, this holds an object produced in the earlier portions of the chain. Most users can safely ignore this argument. See details and examples. |
gformula |
A formula with shape |
data |
A data frame with the variables to be plotted. |
... |
Additional arguments. Typically these are
(a) ggplot2 aesthetics to be set with |
xlab |
Label for x-axis. See also |
ylab |
Label for y-axis. See also |
title , subtitle , caption
|
Title, sub-title, and caption for the plot.
See also |
geom |
A character string naming the geom used to make the layer. |
stat |
A character string naming the stat used to make the layer. |
position |
Either a character string naming the position function used for the layer or a position object returned from a call to a position function. |
show.legend |
A logical indicating whether this layer should be included in
the legends. |
show.help |
If |
inherit |
A logical indicating whether default attributes are inherited. |
environment |
An environment in which to look for variables not found in |
a gg object
Positional attributes (a.k.a, aesthetics) are specified using the formula in gformula
.
Setting and mapping of additional attributes can be done through the
use of additional arguments.
Attributes can be set can be set using arguments of the form attribute = value
or
mapped using arguments of the form attribute = ~ expression
.
In formulas of the form A | B
, B
will be used to form facets using
facet_wrap()
or facet_grid()
.
This provides an alternative to
gf_facet_wrap()
and
gf_facet_grid()
that is terser and may feel more familiar to users
of lattice.
Evaluation of the ggplot2 code occurs in the environment of gformula
.
This will typically do the right thing when formulas are created on the fly, but might not
be the right thing if formulas created in one environment are used to create plots
in another.
gf_point((c(0, 1)) ~ (c(0, 5))) gf_frame((c(0, 1)) ~ (c(0, 5))) gf_blank((c(0, 1)) ~ (c(0, 5))) # gf_blank() can be used to expand the view gf_point((c(0, 1)) ~ (c(0, 5))) |> gf_blank((c(0, 3)) ~ (c(-2, 7)))
gf_point((c(0, 1)) ~ (c(0, 5))) gf_frame((c(0, 1)) ~ (c(0, 5))) gf_blank((c(0, 1)) ~ (c(0, 5))) # gf_blank() can be used to expand the view gf_point((c(0, 1)) ~ (c(0, 5))) |> gf_blank((c(0, 3)) ~ (c(-2, 7)))
The boxplot compactly displays the distribution of a continuous variable. It visualises five summary statistics (the median, two hinges and two whiskers), and all "outlying" points individually.
gf_boxplot( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, fill, group, linetype, linewidth, coef, outlier.color = NULL, outlier.fill = NULL, outlier.shape = 19, outlier.size = 1.5, outlier.stroke = 0.5, outlier.alpha = NULL, notch = FALSE, notchwidth = 0.5, varwidth = FALSE, xlab, ylab, title, subtitle, caption, geom = "boxplot", stat = "boxplot", position = "dodge", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
gf_boxplot( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, fill, group, linetype, linewidth, coef, outlier.color = NULL, outlier.fill = NULL, outlier.shape = 19, outlier.size = 1.5, outlier.stroke = 0.5, outlier.alpha = NULL, notch = FALSE, notchwidth = 0.5, varwidth = FALSE, xlab, ylab, title, subtitle, caption, geom = "boxplot", stat = "boxplot", position = "dodge", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
object |
When chaining, this holds an object produced in the earlier portions of the chain. Most users can safely ignore this argument. See details and examples. |
gformula |
A formula with shape |
data |
The data to be displayed in this layer. There are three options: If A A |
... |
Additional arguments. Typically these are
(a) ggplot2 aesthetics to be set with |
alpha |
Opacity (0 = invisible, 1 = opaque). |
color |
A color or a formula used for mapping color. |
fill |
A color for filling, or a formula used for mapping fill. |
group |
Used for grouping. |
linetype |
A linetype (numeric or "dashed", "dotted", etc.) or a formula used for mapping linetype. |
linewidth |
A numerical line width or a formula used for mapping linewidth. |
coef |
Length of the whiskers as multiple of IQR. Defaults to 1.5. |
outlier.color , outlier.fill , outlier.shape , outlier.size , outlier.stroke , outlier.alpha
|
Default aesthetics for outliers. Set to NULL to inherit from the aesthetics used for the box. In the unlikely event you specify both US and UK spellings of colour, the US spelling will take precedence. Sometimes it can be useful to hide the outliers, for example when overlaying the raw data points on top of the boxplot. Hiding the outliers can be achieved by setting outlier.shape = NA. Importantly, this does not remove the outliers, it only hides them, so the range calculated for the y-axis will be the same with outliers shown and outliers hidden. |
notch |
If |
notchwidth |
For a notched box plot, width of the notch relative to
the body (defaults to |
varwidth |
If |
xlab |
Label for x-axis. See also |
ylab |
Label for y-axis. See also |
title , subtitle , caption
|
Title, sub-title, and caption for the plot.
See also |
geom , stat
|
Use to override the default connection between
|
position |
Position adjustment, either as a string naming the adjustment
(e.g. |
show.legend |
logical. Should this layer be included in the legends?
|
show.help |
If |
inherit |
A logical indicating whether default attributes are inherited. |
environment |
An environment in which to look for variables not found in |
a gg object
Positional attributes (a.k.a, aesthetics) are specified using the formula in gformula
.
Setting and mapping of additional attributes can be done through the
use of additional arguments.
Attributes can be set can be set using arguments of the form attribute = value
or
mapped using arguments of the form attribute = ~ expression
.
In formulas of the form A | B
, B
will be used to form facets using
facet_wrap()
or facet_grid()
.
This provides an alternative to
gf_facet_wrap()
and
gf_facet_grid()
that is terser and may feel more familiar to users
of lattice.
Evaluation of the ggplot2 code occurs in the environment of gformula
.
This will typically do the right thing when formulas are created on the fly, but might not
be the right thing if formulas created in one environment are used to create plots
in another.
McGill, R., Tukey, J. W. and Larsen, W. A. (1978) Variations of box plots. The American Statistician 32, 12-16.
ggplot2::geom_boxplot()
, fivenum()
, df_stats()
gf_boxplot(age ~ substance, data = mosaicData::HELPrct) gf_boxplot(age ~ substance, data = mosaicData::HELPrct, varwidth = TRUE) gf_boxplot(age ~ substance, data = mosaicData::HELPrct, color = ~sex) gf_boxplot(age ~ substance, data = mosaicData::HELPrct, color = ~sex, outlier.color = "gray50" ) # longer whiskers gf_boxplot(age ~ substance, data = mosaicData::HELPrct, color = ~sex, coef = 2 ) # Note: width for boxplots is full width of box. # For jittering, it is the half-width. gf_boxplot(age ~ substance | sex, data = mosaicData::HELPrct, coef = 5, width = 0.4 ) |> gf_jitter(width = 0.2, alpha = 0.3) # move boxplots away a bit by adjusting dodge gf_boxplot(age ~ substance, data = mosaicData::HELPrct, color = ~sex, position = position_dodge(width = 0.9) )
gf_boxplot(age ~ substance, data = mosaicData::HELPrct) gf_boxplot(age ~ substance, data = mosaicData::HELPrct, varwidth = TRUE) gf_boxplot(age ~ substance, data = mosaicData::HELPrct, color = ~sex) gf_boxplot(age ~ substance, data = mosaicData::HELPrct, color = ~sex, outlier.color = "gray50" ) # longer whiskers gf_boxplot(age ~ substance, data = mosaicData::HELPrct, color = ~sex, coef = 2 ) # Note: width for boxplots is full width of box. # For jittering, it is the half-width. gf_boxplot(age ~ substance | sex, data = mosaicData::HELPrct, coef = 5, width = 0.4 ) |> gf_jitter(width = 0.2, alpha = 0.3) # move boxplots away a bit by adjusting dodge gf_boxplot(age ~ substance, data = mosaicData::HELPrct, color = ~sex, position = position_dodge(width = 0.9) )
There are two types of bar charts: geom_bar()
and geom_col()
.
geom_bar()
makes the height of the bar proportional to the number of
cases in each group (or if the weight
aesthetic is supplied, the sum
of the weights). If you want the heights of the bars to represent values
in the data, use geom_col()
instead. geom_bar()
uses stat_count()
by
default: it counts the number of cases at each x position. geom_col()
uses stat_identity()
: it leaves the data as is.
gf_col( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, fill, group, linetype, linewidth, xlab, ylab, title, subtitle, caption, geom = "col", stat = "identity", position = "stack", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
gf_col( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, fill, group, linetype, linewidth, xlab, ylab, title, subtitle, caption, geom = "col", stat = "identity", position = "stack", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
object |
When chaining, this holds an object produced in the earlier portions of the chain. Most users can safely ignore this argument. See details and examples. |
gformula |
A formula with shape |
data |
A data frame with the variables to be plotted. |
... |
Additional arguments. Typically these are
(a) ggplot2 aesthetics to be set with |
alpha |
Opacity (0 = invisible, 1 = opaque). |
color |
A color or a formula used for mapping color. |
fill |
A color for filling, or a formula used for mapping fill. |
group |
Used for grouping. |
linetype |
A linetype (numeric or "dashed", "dotted", etc.) or a formula used for mapping linetype. |
linewidth |
A numerical line width or a formula used for mapping linewidth. |
xlab |
Label for x-axis. See also |
ylab |
Label for y-axis. See also |
title , subtitle , caption
|
Title, sub-title, and caption for the plot.
See also |
geom |
A character string naming the geom used to make the layer. |
stat |
A character string naming the stat used to make the layer. |
position |
Either a character string naming the position function used for the layer or a position object returned from a call to a position function. |
show.legend |
A logical indicating whether this layer should be included in
the legends. |
show.help |
If |
inherit |
A logical indicating whether default attributes are inherited. |
environment |
An environment in which to look for variables not found in |
a gg object
Positional attributes (a.k.a, aesthetics) are specified using the formula in gformula
.
Setting and mapping of additional attributes can be done through the
use of additional arguments.
Attributes can be set can be set using arguments of the form attribute = value
or
mapped using arguments of the form attribute = ~ expression
.
In formulas of the form A | B
, B
will be used to form facets using
facet_wrap()
or facet_grid()
.
This provides an alternative to
gf_facet_wrap()
and
gf_facet_grid()
that is terser and may feel more familiar to users
of lattice.
Evaluation of the ggplot2 code occurs in the environment of gformula
.
This will typically do the right thing when formulas are created on the fly, but might not
be the right thing if formulas created in one environment are used to create plots
in another.
SomeData <- data.frame( group = LETTERS[1:3], count = c(20, 25, 18) ) gf_col(count ~ group, data = SomeData) # A Pareto chart if (require(dplyr) && require(mosaicData)) { HELPrct |> group_by(substance) |> summarise(count = n()) |> ungroup() |> dplyr::arrange(-count) |> mutate( cumcount = cumsum(count), substance = reorder(substance, -count) ) |> gf_col(count ~ substance, fill = "skyblue") |> gf_point(cumcount ~ substance) |> gf_line(cumcount ~ substance, group = 1) |> gf_refine( scale_y_continuous(sec.axis = sec_axis(~ . / nrow(HELPrct))) ) }
SomeData <- data.frame( group = LETTERS[1:3], count = c(20, 25, 18) ) gf_col(count ~ group, data = SomeData) # A Pareto chart if (require(dplyr) && require(mosaicData)) { HELPrct |> group_by(substance) |> summarise(count = n()) |> ungroup() |> dplyr::arrange(-count) |> mutate( cumcount = cumsum(count), substance = reorder(substance, -count) ) |> gf_col(count ~ substance, fill = "skyblue") |> gf_point(cumcount ~ substance) |> gf_line(cumcount ~ substance, group = 1) |> gf_refine( scale_y_continuous(sec.axis = sec_axis(~ . / nrow(HELPrct))) ) }
ggplot2 can not draw true 3D surfaces, but you can use geom_contour()
,
geom_contour_filled()
, and geom_tile()
to visualise 3D surfaces in 2D.
These functions require regular data, where the x
and y
coordinates
form an equally spaced grid, and each combination of x
and y
appears
once. Missing values of z
are allowed, but contouring will only work for
grid points where all four corners are non-missing. If you have irregular
data, you'll need to first interpolate on to a grid before visualising,
using interp::interp()
, akima::bilinear()
, or similar.
gf_contour( object = NULL, gformula = NULL, data = NULL, ..., xlab, ylab, title, subtitle, caption, geom = "contour", stat = "contour", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) gf_contour_filled( object = NULL, gformula = NULL, data = NULL, ..., xlab, ylab, title, subtitle, caption, geom = "contour_filled", stat = "contour_filled", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
gf_contour( object = NULL, gformula = NULL, data = NULL, ..., xlab, ylab, title, subtitle, caption, geom = "contour", stat = "contour", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) gf_contour_filled( object = NULL, gformula = NULL, data = NULL, ..., xlab, ylab, title, subtitle, caption, geom = "contour_filled", stat = "contour_filled", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
object |
When chaining, this holds an object produced in the earlier portions of the chain. Most users can safely ignore this argument. See details and examples. |
gformula |
A formula with shape |
data |
The data to be displayed in this layer. There are three options: If A A |
... |
Additional arguments. Typically these are
(a) ggplot2 aesthetics to be set with |
xlab |
Label for x-axis. See also |
ylab |
Label for y-axis. See also |
title , subtitle , caption
|
Title, sub-title, and caption for the plot.
See also |
geom |
The geometric object to use to display the data, either as a
|
stat |
The statistical transformation to use on the data for this
layer, either as a |
position |
Position adjustment, either as a string naming the adjustment
(e.g. |
show.legend |
logical. Should this layer be included in the legends?
|
show.help |
If |
inherit |
A logical indicating whether default attributes are inherited. |
environment |
An environment in which to look for variables not found in |
a gg object
Positional attributes (a.k.a, aesthetics) are specified using the formula in gformula
.
Setting and mapping of additional attributes can be done through the
use of additional arguments.
Attributes can be set can be set using arguments of the form attribute = value
or
mapped using arguments of the form attribute = ~ expression
.
In formulas of the form A | B
, B
will be used to form facets using
facet_wrap()
or facet_grid()
.
This provides an alternative to
gf_facet_wrap()
and
gf_facet_grid()
that is terser and may feel more familiar to users
of lattice.
Evaluation of the ggplot2 code occurs in the environment of gformula
.
This will typically do the right thing when formulas are created on the fly, but might not
be the right thing if formulas created in one environment are used to create plots
in another.
ggplot2::geom_contour()
, gf_density_2d()
gf_density_2d(eruptions ~ waiting, data = faithful, alpha = 0.5, color = "navy") |> gf_contour(density ~ waiting + eruptions, data = faithfuld, bins = 10, color = "red") gf_contour_filled(density ~ waiting + eruptions, data = faithfuld, bins = 10, show.legend = FALSE) |> gf_jitter(eruptions ~ waiting, data = faithful, color = "white", alpha = 0.5, inherit = FALSE)
gf_density_2d(eruptions ~ waiting, data = faithful, alpha = 0.5, color = "navy") |> gf_contour(density ~ waiting + eruptions, data = faithfuld, bins = 10, color = "red") gf_contour_filled(density ~ waiting + eruptions, data = faithfuld, bins = 10, show.legend = FALSE) |> gf_jitter(eruptions ~ waiting, data = faithful, color = "white", alpha = 0.5, inherit = FALSE)
This is a variant geom_point()
that counts the number of
observations at each location, then maps the count to point area. It
useful when you have discrete data and overplotting.
gf_count( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, fill, group, shape, size, stroke, xlab, ylab, title, subtitle, caption, geom = "point", stat = "sum", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
gf_count( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, fill, group, shape, size, stroke, xlab, ylab, title, subtitle, caption, geom = "point", stat = "sum", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
object |
When chaining, this holds an object produced in the earlier portions of the chain. Most users can safely ignore this argument. See details and examples. |
gformula |
A formula with shape |
data |
A data frame with the variables to be plotted. |
... |
Additional arguments. Typically these are
(a) ggplot2 aesthetics to be set with |
alpha |
Opacity (0 = invisible, 1 = opaque). |
color |
A color or a formula used for mapping color. |
fill |
A color for filling, or a formula used for mapping fill. |
group |
Used for grouping. |
shape |
An integer or letter shape or a formula used for mapping shape. |
size |
A numeric size or a formula used for mapping size. |
stroke |
A numeric size of the border or a formula used to map stroke. |
xlab |
Label for x-axis. See also |
ylab |
Label for y-axis. See also |
title , subtitle , caption
|
Title, sub-title, and caption for the plot.
See also |
geom |
A character string naming the geom used to make the layer. |
stat |
A character string naming the stat used to make the layer. |
position |
Either a character string naming the position function used for the layer or a position object returned from a call to a position function. |
show.legend |
A logical indicating whether this layer should be included in
the legends. |
show.help |
If |
inherit |
A logical indicating whether default attributes are inherited. |
environment |
An environment in which to look for variables not found in |
a gg object
Positional attributes (a.k.a, aesthetics) are specified using the formula in gformula
.
Setting and mapping of additional attributes can be done through the
use of additional arguments.
Attributes can be set can be set using arguments of the form attribute = value
or
mapped using arguments of the form attribute = ~ expression
.
In formulas of the form A | B
, B
will be used to form facets using
facet_wrap()
or facet_grid()
.
This provides an alternative to
gf_facet_wrap()
and
gf_facet_grid()
that is terser and may feel more familiar to users
of lattice.
Evaluation of the ggplot2 code occurs in the environment of gformula
.
This will typically do the right thing when formulas are created on the fly, but might not
be the right thing if formulas created in one environment are used to create plots
in another.
# Best used in conjunction with scale_size_area which ensures that # counts of zero would be given size 0. This doesn't make much difference # here because the smallest count is already close to 0. gf_count(hwy ~ cty, data = mpg, alpha = 0.3) |> gf_refine(scale_size_area())
# Best used in conjunction with scale_size_area which ensures that # counts of zero would be given size 0. This doesn't make much difference # here because the smallest count is already close to 0. gf_count(hwy ~ cty, data = mpg, alpha = 0.3) |> gf_refine(scale_size_area())
Various ways of representing a vertical interval defined by x
,
ymin
and ymax
. Each case draws a single graphical object.
gf_crossbar( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, group, linetype, linewidth, fatten = 2.5, xlab, ylab, title, subtitle, caption, geom = "crossbar", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
gf_crossbar( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, group, linetype, linewidth, fatten = 2.5, xlab, ylab, title, subtitle, caption, geom = "crossbar", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
object |
When chaining, this holds an object produced in the earlier portions of the chain. Most users can safely ignore this argument. See details and examples. |
gformula |
A formula with shape |
data |
The data to be displayed in this layer. There are three options: If A A |
... |
Additional arguments. Typically these are
(a) ggplot2 aesthetics to be set with |
alpha |
Opacity (0 = invisible, 1 = opaque). |
color |
A color or a formula used for mapping color. |
group |
Used for grouping. |
linetype |
A linetype (numeric or "dashed", "dotted", etc.) or a formula used for mapping linetype. |
linewidth |
A numerical line width or a formula used for mapping linewidth. |
fatten |
A multiplicative factor used to increase the size of the
middle bar in |
xlab |
Label for x-axis. See also |
ylab |
Label for y-axis. See also |
title , subtitle , caption
|
Title, sub-title, and caption for the plot.
See also |
geom |
A character string naming the geom used to make the layer. |
stat |
The statistical transformation to use on the data for this
layer, either as a |
position |
Position adjustment, either as a string naming the adjustment
(e.g. |
show.legend |
logical. Should this layer be included in the legends?
|
show.help |
If |
inherit |
A logical indicating whether default attributes are inherited. |
environment |
An environment in which to look for variables not found in |
a gg object
Positional attributes (a.k.a, aesthetics) are specified using the formula in gformula
.
Setting and mapping of additional attributes can be done through the
use of additional arguments.
Attributes can be set can be set using arguments of the form attribute = value
or
mapped using arguments of the form attribute = ~ expression
.
In formulas of the form A | B
, B
will be used to form facets using
facet_wrap()
or facet_grid()
.
This provides an alternative to
gf_facet_wrap()
and
gf_facet_grid()
that is terser and may feel more familiar to users
of lattice.
Evaluation of the ggplot2 code occurs in the environment of gformula
.
This will typically do the right thing when formulas are created on the fly, but might not
be the right thing if formulas created in one environment are used to create plots
in another.
if (require(mosaicData) && require(dplyr)) { HELP2 <- HELPrct |> summarise(.by = c(substance, sex), mean.age = mean(age), median.age = median(age), max.age = max(age), min.age = min(age), sd.age = sd(age), lo = mean.age - sd.age, hi = mean.age + sd.age ) gf_jitter(age ~ substance, data = HELPrct, alpha = 0.7, width = 0.2, height = 0, color = "skyblue") |> gf_pointrange(mean.age + lo + hi ~ substance, data = HELP2) |> gf_facet_grid(~sex) gf_jitter(age ~ substance, data = HELPrct, alpha = 0.7, width = 0.2, height = 0, color = "skyblue") |> gf_errorbar(lo + hi ~ substance, data = HELP2, inherit = FALSE) |> gf_facet_grid(~sex) gf_jitter(age ~ substance, data = HELPrct, alpha = 0.7, width = 0.2, height = 0, color = "skyblue") |> gf_crossbar(mean.age + lo + hi ~ substance, data = HELP2, fill = "transparent") |> gf_facet_grid(~sex) gf_jitter(substance ~ age, data = HELPrct, alpha = 0.7, height = 0.2, width = 0, color = "skyblue") |> gf_crossbar(substance ~ mean.age + lo + hi, data = HELP2, fill = "transparent", color = "red") |> gf_facet_grid(~sex) }
if (require(mosaicData) && require(dplyr)) { HELP2 <- HELPrct |> summarise(.by = c(substance, sex), mean.age = mean(age), median.age = median(age), max.age = max(age), min.age = min(age), sd.age = sd(age), lo = mean.age - sd.age, hi = mean.age + sd.age ) gf_jitter(age ~ substance, data = HELPrct, alpha = 0.7, width = 0.2, height = 0, color = "skyblue") |> gf_pointrange(mean.age + lo + hi ~ substance, data = HELP2) |> gf_facet_grid(~sex) gf_jitter(age ~ substance, data = HELPrct, alpha = 0.7, width = 0.2, height = 0, color = "skyblue") |> gf_errorbar(lo + hi ~ substance, data = HELP2, inherit = FALSE) |> gf_facet_grid(~sex) gf_jitter(age ~ substance, data = HELPrct, alpha = 0.7, width = 0.2, height = 0, color = "skyblue") |> gf_crossbar(mean.age + lo + hi ~ substance, data = HELP2, fill = "transparent") |> gf_facet_grid(~sex) gf_jitter(substance ~ age, data = HELPrct, alpha = 0.7, height = 0.2, width = 0, color = "skyblue") |> gf_crossbar(substance ~ mean.age + lo + hi, data = HELP2, fill = "transparent", color = "red") |> gf_facet_grid(~sex) }
geom_segment()
draws a straight line between points (x, y) and
(xend, yend). geom_curve()
draws a curved line. See the underlying
drawing function grid::curveGrob()
for the parameters that
control the curve.
gf_curve( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, group, linetype, linewidth, curvature = 0.5, angle = 90, ncp = 5, arrow = NULL, lineend = "butt", xlab, ylab, title, subtitle, caption, geom = "curve", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
gf_curve( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, group, linetype, linewidth, curvature = 0.5, angle = 90, ncp = 5, arrow = NULL, lineend = "butt", xlab, ylab, title, subtitle, caption, geom = "curve", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
object |
When chaining, this holds an object produced in the earlier portions of the chain. Most users can safely ignore this argument. See details and examples. |
gformula |
A formula with shape |
data |
The data to be displayed in this layer. There are three options: If A A |
... |
Additional arguments. Typically these are
(a) ggplot2 aesthetics to be set with |
alpha |
Opacity (0 = invisible, 1 = opaque). |
color |
A color or a formula used for mapping color. |
group |
Used for grouping. |
linetype |
A linetype (numeric or "dashed", "dotted", etc.) or a formula used for mapping linetype. |
linewidth |
A numerical line width or a formula used for mapping linewidth. |
curvature |
A numeric value giving the amount of curvature. Negative values produce left-hand curves, positive values produce right-hand curves, and zero produces a straight line. |
angle |
A numeric value between 0 and 180, giving an amount to skew the control points of the curve. Values less than 90 skew the curve towards the start point and values greater than 90 skew the curve towards the end point. |
ncp |
The number of control points used to draw the curve. More control points creates a smoother curve. |
arrow |
specification for arrow heads, as created by |
lineend |
Line end style (round, butt, square). |
xlab |
Label for x-axis. See also |
ylab |
Label for y-axis. See also |
title , subtitle , caption
|
Title, sub-title, and caption for the plot.
See also |
geom |
A character string naming the geom used to make the layer. |
stat |
The statistical transformation to use on the data for this
layer, either as a |
position |
Position adjustment, either as a string naming the adjustment
(e.g. |
show.legend |
logical. Should this layer be included in the legends?
|
show.help |
If |
inherit |
A logical indicating whether default attributes are inherited. |
environment |
An environment in which to look for variables not found in |
a gg object
Positional attributes (a.k.a, aesthetics) are specified using the formula in gformula
.
Setting and mapping of additional attributes can be done through the
use of additional arguments.
Attributes can be set can be set using arguments of the form attribute = value
or
mapped using arguments of the form attribute = ~ expression
.
In formulas of the form A | B
, B
will be used to form facets using
facet_wrap()
or facet_grid()
.
This provides an alternative to
gf_facet_wrap()
and
gf_facet_grid()
that is terser and may feel more familiar to users
of lattice.
Evaluation of the ggplot2 code occurs in the environment of gformula
.
This will typically do the right thing when formulas are created on the fly, but might not
be the right thing if formulas created in one environment are used to create plots
in another.
D <- data.frame(x1 = 2.62, x2 = 3.57, y1 = 21.0, y2 = 15.0) gf_point(mpg ~ wt, data = mtcars) |> gf_curve(y1 + y2 ~ x1 + x2, data = D, color = "navy") |> gf_segment(y1 + y2 ~ x1 + x2, data = D, color = "red")
D <- data.frame(x1 = 2.62, x2 = 3.57, y1 = 21.0, y2 = 15.0) gf_point(mpg ~ wt, data = mtcars) |> gf_curve(y1 + y2 ~ x1 + x2, data = D, color = "navy") |> gf_segment(y1 + y2 ~ x1 + x2, data = D, color = "red")
Computes and draws a kernel density estimate, which is a smoothed version of the
histogram and is a useful alternative when the data come from an underlying smooth
distribution.
The only difference between gf_dens()
and gf_density()
is the default geom
used to show the density curve: gf_density()
uses an area geom (which can be filled).
gf_dens()
using a line geom (which cannot be filled).
gf_density( object = NULL, gformula = NULL, data = NULL, ..., alpha = 0.5, color, fill, group, linetype, linewidth, kernel = "gaussian", n = 512, trim = FALSE, xlab, ylab, title, subtitle, caption, geom = "area", stat = "density", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) gf_dens( object = NULL, gformula = NULL, data = NULL, ..., alpha = 0.5, color, fill = NA, group, linetype, linewidth, kernel = "gaussian", n = 512, trim = FALSE, xlab, ylab, title, subtitle, caption, geom = "line", stat = "density", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) gf_dens2( object = NULL, gformula = NULL, data = NULL, ..., alpha = 0.5, color, fill = NA, group, linetype, linewidth, kernel = "gaussian", n = 512, trim = FALSE, xlab, ylab, title, subtitle, caption, geom = "density_line", stat = "density", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
gf_density( object = NULL, gformula = NULL, data = NULL, ..., alpha = 0.5, color, fill, group, linetype, linewidth, kernel = "gaussian", n = 512, trim = FALSE, xlab, ylab, title, subtitle, caption, geom = "area", stat = "density", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) gf_dens( object = NULL, gformula = NULL, data = NULL, ..., alpha = 0.5, color, fill = NA, group, linetype, linewidth, kernel = "gaussian", n = 512, trim = FALSE, xlab, ylab, title, subtitle, caption, geom = "line", stat = "density", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) gf_dens2( object = NULL, gformula = NULL, data = NULL, ..., alpha = 0.5, color, fill = NA, group, linetype, linewidth, kernel = "gaussian", n = 512, trim = FALSE, xlab, ylab, title, subtitle, caption, geom = "density_line", stat = "density", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
object |
When chaining, this holds an object produced in the earlier portions of the chain. Most users can safely ignore this argument. See details and examples. |
gformula |
A formula with shape |
data |
The data to be displayed in this layer. There are three options: If A A |
... |
Additional arguments. Typically these are
(a) ggplot2 aesthetics to be set with |
alpha |
Opacity (0 = invisible, 1 = opaque). |
color |
A color or a formula used for mapping color. |
fill |
A color for filling, or a formula used for mapping fill. |
group |
Used for grouping. |
linetype |
A linetype (numeric or "dashed", "dotted", etc.) or a formula used for mapping linetype. |
linewidth |
A numerical line width or a formula used for mapping linewidth. |
kernel |
Kernel. See list of available kernels in |
n |
number of equally spaced points at which the density is to be
estimated, should be a power of two, see |
trim |
If |
xlab |
Label for x-axis. See also |
ylab |
Label for y-axis. See also |
title , subtitle , caption
|
Title, sub-title, and caption for the plot.
See also |
geom , stat
|
Use to override the default connection between
|
position |
Position adjustment, either as a string naming the adjustment
(e.g. |
show.legend |
logical. Should this layer be included in the legends?
|
show.help |
If |
inherit |
A logical indicating whether default attributes are inherited. |
environment |
An environment in which to look for variables not found in |
a gg object
Positional attributes (a.k.a, aesthetics) are specified using the formula in gformula
.
Setting and mapping of additional attributes can be done through the
use of additional arguments.
Attributes can be set can be set using arguments of the form attribute = value
or
mapped using arguments of the form attribute = ~ expression
.
In formulas of the form A | B
, B
will be used to form facets using
facet_wrap()
or facet_grid()
.
This provides an alternative to
gf_facet_wrap()
and
gf_facet_grid()
that is terser and may feel more familiar to users
of lattice.
Evaluation of the ggplot2 code occurs in the environment of gformula
.
This will typically do the right thing when formulas are created on the fly, but might not
be the right thing if formulas created in one environment are used to create plots
in another.
gf_ash()
, ggplot2::geom_density()
gf_dens() data(penguins, package = "palmerpenguins") gf_density(~bill_length_mm, fill = ~species, data = penguins) gf_dens(~bill_length_mm, color = ~species, data = penguins) gf_dens2(~bill_length_mm, color = ~species, fill = ~species, data = penguins) gf_freqpoly(~bill_length_mm, color = ~species, data = penguins, bins = 15) # Chaining in the data data(penguins, package = "palmerpenguins") penguins |> gf_dens(~bill_length_mm, color = ~species) # horizontal orientation penguins |> gf_dens(bill_length_mm ~ ., color = ~species)
gf_dens() data(penguins, package = "palmerpenguins") gf_density(~bill_length_mm, fill = ~species, data = penguins) gf_dens(~bill_length_mm, color = ~species, data = penguins) gf_dens2(~bill_length_mm, color = ~species, fill = ~species, data = penguins) gf_freqpoly(~bill_length_mm, color = ~species, data = penguins, bins = 15) # Chaining in the data data(penguins, package = "palmerpenguins") penguins |> gf_dens(~bill_length_mm, color = ~species) # horizontal orientation penguins |> gf_dens(bill_length_mm ~ ., color = ~species)
Perform a 2D kernel density estimation using MASS::kde2d()
and
display the results with contours. This can be useful for dealing with
overplotting. This is a 2D version of geom_density()
. geom_density_2d()
draws contour lines, and geom_density_2d_filled()
draws filled contour
bands.
gf_density_2d( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, group, linetype, linewidth, contour = TRUE, n = 100, h = NULL, lineend = "butt", linejoin = "round", linemitre = 1, xlab, ylab, title, subtitle, caption, geom = "density_2d", stat = "density_2d", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) gf_density_2d_filled( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, group, linetype, linewidth, contour = TRUE, n = 100, h = NULL, lineend = "butt", linejoin = "round", linemitre = 1, xlab, ylab, title, subtitle, caption, geom = "density_2d_filled", stat = "density_2d_filled", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) gf_density2d( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, group, linetype, linewidth, contour = TRUE, n = 100, h = NULL, lineend = "butt", linejoin = "round", linemitre = 1, xlab, ylab, title, subtitle, caption, geom = "density2d", stat = "density2d", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) gf_density2d_filled( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, group, linetype, linewidth, contour = TRUE, n = 100, h = NULL, lineend = "butt", linejoin = "round", linemitre = 1, xlab, ylab, title, subtitle, caption, geom = "density2d_filled", stat = "density_2d_filled", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
gf_density_2d( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, group, linetype, linewidth, contour = TRUE, n = 100, h = NULL, lineend = "butt", linejoin = "round", linemitre = 1, xlab, ylab, title, subtitle, caption, geom = "density_2d", stat = "density_2d", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) gf_density_2d_filled( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, group, linetype, linewidth, contour = TRUE, n = 100, h = NULL, lineend = "butt", linejoin = "round", linemitre = 1, xlab, ylab, title, subtitle, caption, geom = "density_2d_filled", stat = "density_2d_filled", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) gf_density2d( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, group, linetype, linewidth, contour = TRUE, n = 100, h = NULL, lineend = "butt", linejoin = "round", linemitre = 1, xlab, ylab, title, subtitle, caption, geom = "density2d", stat = "density2d", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) gf_density2d_filled( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, group, linetype, linewidth, contour = TRUE, n = 100, h = NULL, lineend = "butt", linejoin = "round", linemitre = 1, xlab, ylab, title, subtitle, caption, geom = "density2d_filled", stat = "density_2d_filled", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
object |
When chaining, this holds an object produced in the earlier portions of the chain. Most users can safely ignore this argument. See details and examples. |
gformula |
A formula with shape |
data |
The data to be displayed in this layer. There are three options: If A A |
... |
Additional arguments. Typically these are
(a) ggplot2 aesthetics to be set with |
alpha |
Opacity (0 = invisible, 1 = opaque). |
color |
A color or a formula used for mapping color. |
group |
Used for grouping. |
linetype |
A linetype (numeric or "dashed", "dotted", etc.) or a formula used for mapping linetype. |
linewidth |
A numerical line width or a formula used for mapping linewidth. |
contour |
If |
n |
Number of grid points in each direction. |
h |
Bandwidth (vector of length two). If |
lineend |
Line end style (round, butt, square). |
linejoin |
Line join style (round, mitre, bevel). |
linemitre |
Line mitre limit (number greater than 1). |
xlab |
Label for x-axis. See also |
ylab |
Label for y-axis. See also |
title , subtitle , caption
|
Title, sub-title, and caption for the plot.
See also |
geom , stat
|
Use to override the default connection between
|
position |
Position adjustment, either as a string naming the adjustment
(e.g. |
show.legend |
logical. Should this layer be included in the legends?
|
show.help |
If |
inherit |
A logical indicating whether default attributes are inherited. |
environment |
An environment in which to look for variables not found in |
a gg object
Positional attributes (a.k.a, aesthetics) are specified using the formula in gformula
.
Setting and mapping of additional attributes can be done through the
use of additional arguments.
Attributes can be set can be set using arguments of the form attribute = value
or
mapped using arguments of the form attribute = ~ expression
.
In formulas of the form A | B
, B
will be used to form facets using
facet_wrap()
or facet_grid()
.
This provides an alternative to
gf_facet_wrap()
and
gf_facet_grid()
that is terser and may feel more familiar to users
of lattice.
Evaluation of the ggplot2 code occurs in the environment of gformula
.
This will typically do the right thing when formulas are created on the fly, but might not
be the right thing if formulas created in one environment are used to create plots
in another.
gf_jitter(avg_drinks ~ age, alpha = 0.2, data = mosaicData::HELPrct, width = 0.4, height = 0.4 ) |> gf_density_2d(avg_drinks ~ age, data = mosaicData::HELPrct) gf_density_2d_filled(avg_drinks ~ age, data = mosaicData::HELPrct, show.legend = FALSE) |> gf_jitter(avg_drinks ~ age, alpha = 0.3, data = mosaicData::HELPrct, width = 0.4, height = 0.4, color = "white" ) gf_jitter(avg_drinks ~ age, alpha = 0.2, data = mosaicData::HELPrct, width = 0.4, height = 0.4 ) |> gf_density2d(avg_drinks ~ age, data = mosaicData::HELPrct) gf_density2d_filled(avg_drinks ~ age, data = mosaicData::HELPrct, show.legend = FALSE) |> gf_jitter(avg_drinks ~ age, alpha = 0.4, data = mosaicData::HELPrct, width = 0.4, height = 0.4, color = "white" )
gf_jitter(avg_drinks ~ age, alpha = 0.2, data = mosaicData::HELPrct, width = 0.4, height = 0.4 ) |> gf_density_2d(avg_drinks ~ age, data = mosaicData::HELPrct) gf_density_2d_filled(avg_drinks ~ age, data = mosaicData::HELPrct, show.legend = FALSE) |> gf_jitter(avg_drinks ~ age, alpha = 0.3, data = mosaicData::HELPrct, width = 0.4, height = 0.4, color = "white" ) gf_jitter(avg_drinks ~ age, alpha = 0.2, data = mosaicData::HELPrct, width = 0.4, height = 0.4 ) |> gf_density2d(avg_drinks ~ age, data = mosaicData::HELPrct) gf_density2d_filled(avg_drinks ~ age, data = mosaicData::HELPrct, show.legend = FALSE) |> gf_jitter(avg_drinks ~ age, alpha = 0.4, data = mosaicData::HELPrct, width = 0.4, height = 0.4, color = "white" )
Create a layer displaying a probability distribution.
gf_dist( object = ggplot(), dist, ..., xlim = NULL, kind = c("density", "cdf", "qq", "qqstep", "histogram"), resolution = 5000L, eps = 1e-06, params = NULL )
gf_dist( object = ggplot(), dist, ..., xlim = NULL, kind = c("density", "cdf", "qq", "qqstep", "histogram"), resolution = 5000L, eps = 1e-06, params = NULL )
object |
a gg object. |
dist |
A character string providing the name of a distribution. Any
distribution for which the functions with names formed by prepending
"d", "p", or "q" to |
... |
additional arguments passed both to the distribution functions and
to the layer. Note: Possible ambiguities using |
xlim |
A numeric vector of length 2 providing lower and upper bounds for the portion of the distribution that will be displayed. The default is to attempt to determine reasonable bounds using quantiles of the distribution. |
kind |
One of |
resolution |
An integer specifying the number of points to use for creating the plot. |
eps |
a (small) numeric value. When other defaults are not available, the
distribution is processed from the |
params |
a list of parameters for the distribution. |
gf_dhistogram(~ rnorm(100), bins = 20) |> gf_dist("norm", color = "red") # shading tails -- but see pdist() for this gf_dist("norm", fill = ~ (abs(x) <= 2), geom = "area") gf_dist("norm", color = "red", kind = "cdf") gf_dist("norm", fill = "red", kind = "histogram") gf_dist("norm", color = "red", kind = "qqstep", resolution = 25) |> gf_dist("norm", color = "black", kind = "qq", resolution = 25, linewidth = 2, alpha = 0.5) # size is used as parameter for binomial distribution gf_dist("binom", size = 20, prob = 0.25) # If we want to adjust size argument for plots, we have two choices: gf_dist("binom", size = 20, prob = 0.25, plot_size = 2) gf_dist("binom", params = list(size = 20, prob = 0.25), size = 2)
gf_dhistogram(~ rnorm(100), bins = 20) |> gf_dist("norm", color = "red") # shading tails -- but see pdist() for this gf_dist("norm", fill = ~ (abs(x) <= 2), geom = "area") gf_dist("norm", color = "red", kind = "cdf") gf_dist("norm", fill = "red", kind = "histogram") gf_dist("norm", color = "red", kind = "qqstep", resolution = 25) |> gf_dist("norm", color = "black", kind = "qq", resolution = 25, linewidth = 2, alpha = 0.5) # size is used as parameter for binomial distribution gf_dist("binom", size = 20, prob = 0.25) # If we want to adjust size argument for plots, we have two choices: gf_dist("binom", size = 20, prob = 0.25, plot_size = 2) gf_dist("binom", params = list(size = 20, prob = 0.25), size = 2)
Scatterplots in ggformula
.
gf_dotplot( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, fill, group, binwidth = NULL, binaxis = "x", method = "dotdensity", binpositions = "bygroup", stackdir = "up", stackratio = 1, dotsize = 1, stackgroups = FALSE, origin = NULL, right = TRUE, width = 0.9, drop = FALSE, xlab, ylab, title, subtitle, caption, position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
gf_dotplot( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, fill, group, binwidth = NULL, binaxis = "x", method = "dotdensity", binpositions = "bygroup", stackdir = "up", stackratio = 1, dotsize = 1, stackgroups = FALSE, origin = NULL, right = TRUE, width = 0.9, drop = FALSE, xlab, ylab, title, subtitle, caption, position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
object |
When chaining, this holds an object produced in the earlier portions of the chain. Most users can safely ignore this argument. See details and examples. |
gformula |
A formula with shape |
data |
A data frame with the variables to be plotted. |
... |
Additional arguments. Typically these are
(a) ggplot2 aesthetics to be set with |
alpha |
Opacity (0 = invisible, 1 = opaque). |
color |
A color or a formula used for mapping color. |
fill |
A color for filling, or a formula used for mapping fill. |
group |
Used for grouping. |
binwidth |
When |
binaxis |
The axis to bin along, "x" (default) or "y" |
method |
"dotdensity" (default) for dot-density binning, or "histodot" for fixed bin widths (like stat_bin) |
binpositions |
When |
stackdir |
which direction to stack the dots. "up" (default), "down", "center", "centerwhole" (centered, but with dots aligned) |
stackratio |
how close to stack the dots. Default is 1, where dots just touch. Use smaller values for closer, overlapping dots. |
dotsize |
The diameter of the dots relative to |
stackgroups |
should dots be stacked across groups? This has the effect
that |
origin |
When |
right |
When |
width |
When |
drop |
If TRUE, remove all bins with zero counts |
xlab |
Label for x-axis. See also |
ylab |
Label for y-axis. See also |
title , subtitle , caption
|
Title, sub-title, and caption for the plot.
See also |
position |
Either a character string naming the position function used for the layer or a position object returned from a call to a position function. |
show.legend |
A logical indicating whether this layer should be included in
the legends. |
show.help |
If |
inherit |
A logical indicating whether default attributes are inherited. |
environment |
An environment in which to look for variables not found in |
There are two basic approaches: dot-density and histodot.
With dot-density binning, the bin positions are determined by the data and
binwidth
, which is the maximum width of each bin. See Wilkinson
(1999) for details on the dot-density binning algorithm. With histodot
binning, the bins have fixed positions and fixed widths, much like a
histogram.
When binning along the x axis and stacking along the y axis, the numbers on y axis are not meaningful, due to technical limitations of ggplot2. You can hide the y axis, as in one of the examples, or manually scale it to match the number of dots.
a gg object
Dotplots in ggplot2
(and hence in ggformula
) often require some fiddling because
the default y-axis is meaningless and the ideal size of the dots depends on the
aspect ratio of the plot.
Positional attributes (a.k.a, aesthetics) are specified using the formula in gformula
.
Setting and mapping of additional attributes can be done through the
use of additional arguments.
Attributes can be set can be set using arguments of the form attribute = value
or
mapped using arguments of the form attribute = ~ expression
.
In formulas of the form A | B
, B
will be used to form facets using
facet_wrap()
or facet_grid()
.
This provides an alternative to
gf_facet_wrap()
and
gf_facet_grid()
that is terser and may feel more familiar to users
of lattice.
Evaluation of the ggplot2 code occurs in the environment of gformula
.
This will typically do the right thing when formulas are created on the fly, but might not
be the right thing if formulas created in one environment are used to create plots
in another.
Wilkinson, L. (1999) Dot plots. The American Statistician, 53(3), 276-281.
data(penguins, package = "palmerpenguins") gf_dotplot(~bill_length_mm, fill = ~species, data = penguins)
data(penguins, package = "palmerpenguins") gf_dotplot(~bill_length_mm, fill = ~species, data = penguins)
The empirical cumulative distribution function (ECDF) provides an alternative visualization of distribution. Compared to other visualizations that rely on density (like histograms or density plots) the ECDF doesn't require any tuning parameters and handles both continuous and categorical variables. The downside is that it requires more training to accurately interpret, and the underlying visual tasks are somewhat more challenging.
gf_ecdf( object = NULL, gformula = NULL, data = NULL, ..., group, pad, n = NULL, xlab, ylab, title, subtitle, caption, geom = "step", stat = "ecdf", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
gf_ecdf( object = NULL, gformula = NULL, data = NULL, ..., group, pad, n = NULL, xlab, ylab, title, subtitle, caption, geom = "step", stat = "ecdf", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
object |
When chaining, this holds an object produced in the earlier portions of the chain. Most users can safely ignore this argument. See details and examples. |
gformula |
A formula with shape |
data |
The data to be displayed in this layer. There are three options: If A A |
... |
Other arguments passed on to |
group |
Used for grouping. |
pad |
If |
n |
if NULL, do not interpolate. If not NULL, this is the number of points to interpolate with. |
xlab |
Label for x-axis. See also |
ylab |
Label for y-axis. See also |
title , subtitle , caption
|
Title, sub-title, and caption for the plot.
See also |
geom |
The geometric object to use to display the data, either as a
|
stat |
The statistical transformation to use on the data for this
layer, either as a |
position |
Position adjustment, either as a string naming the adjustment
(e.g. |
show.legend |
logical. Should this layer be included in the legends?
|
show.help |
If |
inherit |
A logical indicating whether default attributes are inherited. |
environment |
An environment in which to look for variables not found in |
Data <- data.frame( x = c(rnorm(100, 0, 1), rnorm(100, 0, 3), rt(100, df = 3)), g = gl(3, 100, labels = c("N(0, 1)", "N(0, 3)", "T(df = 3)") ) ) gf_ecdf( ~ x, data = Data) # Don't go to positive/negative infinity gf_ecdf( ~ x, data = Data, pad = FALSE) # Multiple ECDFs gf_ecdf( ~ x, data = Data, color = ~ g)
Data <- data.frame( x = c(rnorm(100, 0, 1), rnorm(100, 0, 3), rt(100, df = 3)), g = gl(3, 100, labels = c("N(0, 1)", "N(0, 3)", "T(df = 3)") ) ) gf_ecdf( ~ x, data = Data) # Don't go to positive/negative infinity gf_ecdf( ~ x, data = Data, pad = FALSE) # Multiple ECDFs gf_ecdf( ~ x, data = Data, color = ~ g)
Formula interface to ggplot2::stat_ellipse()
.
gf_ellipse( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, group, type = "t", level = 0.95, segments = 51, xlab, ylab, title, subtitle, caption, geom = "path", stat = "ellipse", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
gf_ellipse( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, group, type = "t", level = 0.95, segments = 51, xlab, ylab, title, subtitle, caption, geom = "path", stat = "ellipse", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
object |
When chaining, this holds an object produced in the earlier portions of the chain. Most users can safely ignore this argument. See details and examples. |
gformula |
A formula with shape |
data |
A data frame with the variables to be plotted. |
... |
Additional arguments. Typically these are
(a) ggplot2 aesthetics to be set with |
alpha |
Opacity (0 = invisible, 1 = opaque). |
color |
A color or a formula used for mapping color. |
group |
Used for grouping. |
type |
The type of ellipse.
The default |
level |
The level at which to draw an ellipse,
or, if |
segments |
The number of segments to be used in drawing the ellipse. |
xlab |
Label for x-axis. See also |
ylab |
Label for y-axis. See also |
title , subtitle , caption
|
Title, sub-title, and caption for the plot.
See also |
geom |
Geom for drawing ellipse. Note: |
stat |
A character string naming the stat used to make the layer. |
position |
Either a character string naming the position function used for the layer or a position object returned from a call to a position function. |
show.legend |
A logical indicating whether this layer should be included in
the legends. |
show.help |
If |
inherit |
A logical indicating whether default attributes are inherited. |
environment |
An environment in which to look for variables not found in |
gf_ellipse() gf_point(eruptions ~ waiting, data = faithful) |> gf_ellipse(alpha = 0.5) gf_point(eruptions ~ waiting, data = faithful, color = ~ (eruptions > 3)) |> gf_ellipse(alpha = 0.5) gf_point(eruptions ~ waiting, data = faithful, color = ~ (eruptions > 3)) |> gf_ellipse(type = "norm", linetype = ~ "norm") |> gf_ellipse(type = "t", linetype = ~ "t") gf_point(eruptions ~ waiting, data = faithful, color = ~ (eruptions > 3)) |> gf_ellipse(type = "norm", linetype = ~ "norm") |> gf_ellipse(type = "euclid", linetype = ~ "euclid", level = 3) |> gf_refine(coord_fixed()) # Use geom = "polygon" to enable fill gf_point(eruptions ~ waiting, data = faithful, fill = ~ (eruptions > 3)) |> gf_ellipse(geom = "polygon", alpha = 0.3, color = "black") gf_point(eruptions ~ waiting, data = faithful, fill = ~ (eruptions > 3)) |> gf_ellipse(geom = "polygon", alpha = 0.3) |> gf_ellipse(alpha = 0.3, color = "black") gf_ellipse(eruptions ~ waiting, data = faithful, show.legend = FALSE, alpha = 0.3, fill = ~ (eruptions > 3), geom = "polygon") |> gf_ellipse(level = 0.68, geom = "polygon", alpha = 0.3) |> gf_point(data = faithful, color = ~ (eruptions > 3), show.legend = FALSE)
gf_ellipse() gf_point(eruptions ~ waiting, data = faithful) |> gf_ellipse(alpha = 0.5) gf_point(eruptions ~ waiting, data = faithful, color = ~ (eruptions > 3)) |> gf_ellipse(alpha = 0.5) gf_point(eruptions ~ waiting, data = faithful, color = ~ (eruptions > 3)) |> gf_ellipse(type = "norm", linetype = ~ "norm") |> gf_ellipse(type = "t", linetype = ~ "t") gf_point(eruptions ~ waiting, data = faithful, color = ~ (eruptions > 3)) |> gf_ellipse(type = "norm", linetype = ~ "norm") |> gf_ellipse(type = "euclid", linetype = ~ "euclid", level = 3) |> gf_refine(coord_fixed()) # Use geom = "polygon" to enable fill gf_point(eruptions ~ waiting, data = faithful, fill = ~ (eruptions > 3)) |> gf_ellipse(geom = "polygon", alpha = 0.3, color = "black") gf_point(eruptions ~ waiting, data = faithful, fill = ~ (eruptions > 3)) |> gf_ellipse(geom = "polygon", alpha = 0.3) |> gf_ellipse(alpha = 0.3, color = "black") gf_ellipse(eruptions ~ waiting, data = faithful, show.legend = FALSE, alpha = 0.3, fill = ~ (eruptions > 3), geom = "polygon") |> gf_ellipse(level = 0.68, geom = "polygon", alpha = 0.3) |> gf_point(data = faithful, color = ~ (eruptions > 3), show.legend = FALSE)
This is primarily useful as a way to start a sequence of piped plot layers.
gf_empty(environment = parent.frame())
gf_empty(environment = parent.frame())
environment |
An environment passed to |
A plot with now layers.
gf_empty() data(penguins, package = "palmerpenguins") gf_empty() |> gf_point(bill_length_mm ~ bill_depth_mm, data = penguins, color = ~species)
gf_empty() data(penguins, package = "palmerpenguins") gf_empty() |> gf_point(bill_length_mm ~ bill_depth_mm, data = penguins, color = ~species)
For each x value, geom_ribbon()
displays a y interval defined
by ymin
and ymax
. geom_area()
is a special case of
geom_ribbon()
, where the ymin
is fixed to 0 and y
is used instead
of ymax
.
gf_errorbar( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, group, linetype, linewidth, xlab, ylab, title, subtitle, caption, geom = "errorbar", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
gf_errorbar( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, group, linetype, linewidth, xlab, ylab, title, subtitle, caption, geom = "errorbar", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
object |
When chaining, this holds an object produced in the earlier portions of the chain. Most users can safely ignore this argument. See details and examples. |
gformula |
A formula with shape |
data |
The data to be displayed in this layer. There are three options: If A A |
... |
Additional arguments. Typically these are
(a) ggplot2 aesthetics to be set with |
alpha |
Opacity (0 = invisible, 1 = opaque). |
color |
A color or a formula used for mapping color. |
group |
Used for grouping. |
linetype |
A linetype (numeric or "dashed", "dotted", etc.) or a formula used for mapping linetype. |
linewidth |
A numerical line width or a formula used for mapping linewidth. |
xlab |
Label for x-axis. See also |
ylab |
Label for y-axis. See also |
title , subtitle , caption
|
Title, sub-title, and caption for the plot.
See also |
geom |
The geometric object to use to display the data, either as a
|
stat |
The statistical transformation to use on the data for this
layer, either as a |
position |
Position adjustment, either as a string naming the adjustment
(e.g. |
show.legend |
logical. Should this layer be included in the legends?
|
show.help |
If |
inherit |
A logical indicating whether default attributes are inherited. |
environment |
An environment in which to look for variables not found in |
if (require(mosaicData) && require(dplyr)) { HELP2 <- HELPrct |> group_by(substance, sex) |> summarise( mean.age = mean(age), median.age = median(age), max.age = max(age), min.age = min(age), sd.age = sd(age), lo = mean.age - sd.age, hi = mean.age + sd.age ) gf_jitter(age ~ substance, data = HELPrct, alpha = 0.5, width = 0.2, height = 0, color = "skyblue") |> gf_pointrange(mean.age + lo + hi ~ substance, data = HELP2, inherit = FALSE) |> gf_facet_grid(~sex) gf_jitter(age ~ substance, data = HELPrct, alpha = 0.5, width = 0.2, height = 0, color = "skyblue") |> gf_errorbar(lo + hi ~ substance, data = HELP2, inherit = FALSE) |> gf_facet_grid(~sex) gf_jitter(age ~ substance, data = HELPrct, alpha = 0.5, width = 0.2, height = 0, color = "skyblue") |> gf_boxplot(age ~ substance, data = HELPrct, color = "red") |> gf_crossbar(mean.age + lo + hi ~ substance, data = HELP2) |> gf_facet_grid(~sex) }
if (require(mosaicData) && require(dplyr)) { HELP2 <- HELPrct |> group_by(substance, sex) |> summarise( mean.age = mean(age), median.age = median(age), max.age = max(age), min.age = min(age), sd.age = sd(age), lo = mean.age - sd.age, hi = mean.age + sd.age ) gf_jitter(age ~ substance, data = HELPrct, alpha = 0.5, width = 0.2, height = 0, color = "skyblue") |> gf_pointrange(mean.age + lo + hi ~ substance, data = HELP2, inherit = FALSE) |> gf_facet_grid(~sex) gf_jitter(age ~ substance, data = HELPrct, alpha = 0.5, width = 0.2, height = 0, color = "skyblue") |> gf_errorbar(lo + hi ~ substance, data = HELP2, inherit = FALSE) |> gf_facet_grid(~sex) gf_jitter(age ~ substance, data = HELPrct, alpha = 0.5, width = 0.2, height = 0, color = "skyblue") |> gf_boxplot(age ~ substance, data = HELPrct, color = "red") |> gf_crossbar(mean.age + lo + hi ~ substance, data = HELP2) |> gf_facet_grid(~sex) }
These functions provide more control over faceting than is possible using the formula interface.
gf_facet_wrap(object, ...) gf_facet_grid(object, ...)
gf_facet_wrap(object, ...) gf_facet_grid(object, ...)
object |
A ggplot object |
... |
Additional arguments passed to |
ggplot2::facet_grid()
, ggplot2::facet_wrap()
.
gf_histogram(~avg_drinks, data = mosaicData::HELPrct) |> gf_facet_grid(~substance) gf_histogram(~avg_drinks, data = mosaicData::HELPrct) |> gf_facet_grid(~substance, scales = "free") gf_histogram(~avg_drinks, data = mosaicData::HELPrct) |> gf_facet_grid(~substance, scales = "free", space = "free") gf_line(births ~ date, data = mosaicData::Births, color = ~wday) |> gf_facet_wrap(~year, scales = "free_x", nrow = 5) |> gf_theme( axis.title.x = element_blank(), axis.text.x = element_blank(), axis.ticks.x = element_blank() ) |> gf_labs(color = "Day")
gf_histogram(~avg_drinks, data = mosaicData::HELPrct) |> gf_facet_grid(~substance) gf_histogram(~avg_drinks, data = mosaicData::HELPrct) |> gf_facet_grid(~substance, scales = "free") gf_histogram(~avg_drinks, data = mosaicData::HELPrct) |> gf_facet_grid(~substance, scales = "free", space = "free") gf_line(births ~ date, data = mosaicData::Births, color = ~wday) |> gf_facet_wrap(~year, scales = "free_x", nrow = 5) |> gf_theme( axis.title.x = element_blank(), axis.text.x = element_blank(), axis.ticks.x = element_blank() ) |> gf_labs(color = "Day")
MASS::fitdistr()
is used to fit coefficients of a specified family of
distributions and the resulting density curve is displayed.
gf_fitdistr( object = NULL, gformula = NULL, data = NULL, ..., dist = "dnorm", start = NULL, alpha, color, fill, group, linetype, linewidth, size, xlab, ylab, title, subtitle, caption, geom = "path", stat = "fitdistr", position = "identity", show.legend = NA, show.help = NULL, inherit = FALSE, environment = parent.frame() )
gf_fitdistr( object = NULL, gformula = NULL, data = NULL, ..., dist = "dnorm", start = NULL, alpha, color, fill, group, linetype, linewidth, size, xlab, ylab, title, subtitle, caption, geom = "path", stat = "fitdistr", position = "identity", show.legend = NA, show.help = NULL, inherit = FALSE, environment = parent.frame() )
object |
When chaining, this holds an object produced in the earlier portions of the chain. Most users can safely ignore this argument. See examples. |
gformula |
A formula with shape |
data |
A data frame containing the variable to be fitted. |
... |
Additional arguments |
dist |
A quoted name of a distribution function.
See |
start |
Starting value(s) for the search for MLE. (See MASS::fitdistr.) |
alpha |
Opacity (0 = invisible, 1 = opaque). |
color |
A color or a formula used for mapping color. |
fill |
A color for filling, or a formula used for mapping fill. |
group |
Used for grouping. |
linetype |
A linetype (numeric or "dashed", "dotted", etc.) or a formula used for mapping linetype. |
linewidth |
A numerical line width or a formula used for mapping linewidth. |
size |
size aesthetic for dots in pmf plots. |
xlab |
Label for x-axis. See also |
ylab |
Label for y-axis. See also |
title , subtitle , caption
|
Title, sub-title, and caption for the plot.
See also |
geom |
A character string naming the geom used to make the layer. |
stat |
A character string naming the stat used to make the layer. |
position |
Either a character string naming the position function used for the layer or a position object returned from a call to a position function. |
show.legend |
A logical indicating whether this layer should be included in
the legends. |
show.help |
If |
inherit |
A logical indicating whether default attributes are inherited. |
environment |
An environment in which to look for variables not found in |
a gg object
Positional attributes (a.k.a, aesthetics) are specified using the formula in gformula
.
Setting and mapping of additional attributes can be done through the
use of additional arguments.
Attributes can be set can be set using arguments of the form attribute = value
or
mapped using arguments of the form attribute = ~ expression
.
In formulas of the form A | B
, B
will be used to form facets using
facet_wrap()
or facet_grid()
.
This provides an alternative to
gf_facet_wrap()
and
gf_facet_grid()
that is terser and may feel more familiar to users
of lattice.
Evaluation of the ggplot2 code occurs in the environment of gformula
.
This will typically do the right thing when formulas are created on the fly, but might not
be the right thing if formulas created in one environment are used to create plots
in another.
gf_fitdistr(~length, data = mosaicData::KidsFeet, inherit = FALSE) |> gf_dhistogram(~length, data = mosaicData::KidsFeet, binwidth = 0.5, alpha = 0.25) gf_dhistogram(~length, data = mosaicData::KidsFeet, binwidth = 0.5, alpha = 0.25) |> gf_fitdistr() set.seed(12345) Dat <- data.frame( f = rf(500, df1 = 3, df2 = 47), g = rgamma(500, 3, 10) ) gf_dhistogram(~g, data = Dat) |> gf_fitdistr(dist = "dgamma", linewidth = 1.4) gf_dhistogram(~g, data = Dat) |> gf_fun(mosaicCore::fit_distr_fun(~g, data = Dat, dist = "dgamma")) gf_dhistogram(~f, data = Dat) |> gf_fitdistr(dist = "df", start = list(df1 = 2, df2 = 50)) # fitted parameters are default argument values args( mosaicCore::fit_distr_fun(~f, data = Dat, dist = "df", start = list(df1 = 2, df2 = 50) ) ) args(mosaicCore::fit_distr_fun(~g, data = Dat, dist = "dgamma"))
gf_fitdistr(~length, data = mosaicData::KidsFeet, inherit = FALSE) |> gf_dhistogram(~length, data = mosaicData::KidsFeet, binwidth = 0.5, alpha = 0.25) gf_dhistogram(~length, data = mosaicData::KidsFeet, binwidth = 0.5, alpha = 0.25) |> gf_fitdistr() set.seed(12345) Dat <- data.frame( f = rf(500, df1 = 3, df2 = 47), g = rgamma(500, 3, 10) ) gf_dhistogram(~g, data = Dat) |> gf_fitdistr(dist = "dgamma", linewidth = 1.4) gf_dhistogram(~g, data = Dat) |> gf_fun(mosaicCore::fit_distr_fun(~g, data = Dat, dist = "dgamma")) gf_dhistogram(~f, data = Dat) |> gf_fitdistr(dist = "df", start = list(df1 = 2, df2 = 50)) # fitted parameters are default argument values args( mosaicCore::fit_distr_fun(~f, data = Dat, dist = "df", start = list(df1 = 2, df2 = 50) ) ) args(mosaicCore::fit_distr_fun(~g, data = Dat, dist = "dgamma"))
Visualise the distribution of a single continuous variable by dividing
the x axis into bins and counting the number of observations in each bin.
Histograms (geom_histogram()
) display the counts with bars; frequency
polygons (geom_freqpoly()
) display the counts with lines. Frequency
polygons are more suitable when you want to compare the distribution
across the levels of a categorical variable.
gf_freqpoly( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, group, linetype, linewidth, binwidth, bins, center, boundary, xlab, ylab, title, subtitle, caption, geom = "path", stat = "bin", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
gf_freqpoly( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, group, linetype, linewidth, binwidth, bins, center, boundary, xlab, ylab, title, subtitle, caption, geom = "path", stat = "bin", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
object |
When chaining, this holds an object produced in the earlier portions of the chain. Most users can safely ignore this argument. See details and examples. |
gformula |
A formula with shape |
data |
The data to be displayed in this layer. There are three options: If A A |
... |
Additional arguments. Typically these are
(a) ggplot2 aesthetics to be set with |
alpha |
Opacity (0 = invisible, 1 = opaque). |
color |
A color or a formula used for mapping color. |
group |
Used for grouping. |
linetype |
A linetype (numeric or "dashed", "dotted", etc.) or a formula used for mapping linetype. |
linewidth |
A numerical line width or a formula used for mapping linewidth. |
binwidth |
The width of the bins. Can be specified as a numeric value
or as a function that calculates width from unscaled x. Here, "unscaled x"
refers to the original x values in the data, before application of any
scale transformation. When specifying a function along with a grouping
structure, the function will be called once per group.
The default is to use the number of bins in The bin width of a date variable is the number of days in each time; the bin width of a time variable is the number of seconds. |
bins |
Number of bins. Overridden by |
center , boundary
|
bin position specifiers. Only one, |
xlab |
Label for x-axis. See also |
ylab |
Label for y-axis. See also |
title , subtitle , caption
|
Title, sub-title, and caption for the plot.
See also |
geom , stat
|
Use to override the default connection between
|
position |
Position adjustment, either as a string naming the adjustment
(e.g. |
show.legend |
logical. Should this layer be included in the legends?
|
show.help |
If |
inherit |
A logical indicating whether default attributes are inherited. |
environment |
An environment in which to look for variables not found in |
a gg object
Positional attributes (a.k.a, aesthetics) are specified using the formula in gformula
.
Setting and mapping of additional attributes can be done through the
use of additional arguments.
Attributes can be set can be set using arguments of the form attribute = value
or
mapped using arguments of the form attribute = ~ expression
.
In formulas of the form A | B
, B
will be used to form facets using
facet_wrap()
or facet_grid()
.
This provides an alternative to
gf_facet_wrap()
and
gf_facet_grid()
that is terser and may feel more familiar to users
of lattice.
Evaluation of the ggplot2 code occurs in the environment of gformula
.
This will typically do the right thing when formulas are created on the fly, but might not
be the right thing if formulas created in one environment are used to create plots
in another.
data(penguins, package = "palmerpenguins") gf_histogram(~ bill_length_mm | species, alpha = 0.2, data = penguins, bins = 20) |> gf_freqpoly(~bill_length_mm, data = penguins, color = ~species, bins = 20) gf_freqpoly(~bill_length_mm, color = ~species, data = penguins, bins = 20) gf_dens(~bill_length_mm, data = penguins, color = "navy") |> gf_freqpoly(after_stat(density) ~ bill_length_mm, data = penguins, color = "red", bins = 20 )
data(penguins, package = "palmerpenguins") gf_histogram(~ bill_length_mm | species, alpha = 0.2, data = penguins, bins = 20) |> gf_freqpoly(~bill_length_mm, data = penguins, color = ~species, bins = 20) gf_freqpoly(~bill_length_mm, color = ~species, data = penguins, bins = 20) gf_dens(~bill_length_mm, data = penguins, color = "navy") |> gf_freqpoly(after_stat(density) ~ bill_length_mm, data = penguins, color = "red", bins = 20 )
These functions provide two different interfaces for creating a layer that contains the graph of a function.
gf_function(object = NULL, fun, data = NULL, ..., inherit = FALSE) gf_fun(object = NULL, formula, data = NULL, ..., inherit = FALSE)
gf_function(object = NULL, fun, data = NULL, ..., inherit = FALSE) gf_fun(object = NULL, formula, data = NULL, ..., inherit = FALSE)
object |
When chaining, this holds an object produced in the earlier portions of the chain. Most users can safely ignore this argument. See details and examples. |
fun |
A function. |
data |
A data frame with the variables to be plotted. |
... |
Additional arguments passed as |
inherit |
A logical indicating whether default attributes are inherited. |
formula |
A formula describing a function. See examples and |
gf_function(fun = sqrt, xlim = c(0, 10)) gf_dhistogram(~age, data = mosaicData::HELPrct, binwidth = 3, alpha = 0.6) |> gf_function( fun = stats::dnorm, args = list(mean = mean(mosaicData::HELPrct$age), sd = sd(mosaicData::HELPrct$age)), color = "red" ) gf_fun(5 + 3 * cos(10 * x) ~ x, xlim = c(0, 2)) # Utility bill is quadratic in month? f <- makeFun(lm(totalbill ~ poly(month, 2), data = mosaicData::Utilities)) gf_point(totalbill ~ month, data = mosaicData::Utilities, alpha = 0.6) |> gf_fun(f(m) ~ m, color = "red")
gf_function(fun = sqrt, xlim = c(0, 10)) gf_dhistogram(~age, data = mosaicData::HELPrct, binwidth = 3, alpha = 0.6) |> gf_function( fun = stats::dnorm, args = list(mean = mean(mosaicData::HELPrct$age), sd = sd(mosaicData::HELPrct$age)), color = "red" ) gf_fun(5 + 3 * cos(10 * x) ~ x, xlim = c(0, 2)) # Utility bill is quadratic in month? f <- makeFun(lm(totalbill ~ poly(month, 2), data = mosaicData::Utilities)) gf_point(totalbill ~ month, data = mosaicData::Utilities, alpha = 0.6) |> gf_fun(f(m) ~ m, color = "red")
Plot functions of two variables as tile and/or contour plots.
gf_function_2d( object = NULL, fun = identity, xlim = NULL, ylim = NULL, ..., tile = TRUE, contour = TRUE, resolution = 50 ) gf_function2d( object = NULL, fun = identity, xlim = NULL, ylim = NULL, ..., tile = TRUE, contour = TRUE, resolution = 50 ) gf_function_contour( object = NULL, fun = identity, xlim = NULL, ylim = NULL, ..., resolution = 50 ) gf_function_tile( object = NULL, fun = identity, xlim = NULL, ylim = NULL, ..., resolution = 50 ) gf_fun_2d( object = NULL, formula = NULL, xlim = NULL, ylim = NULL, tile = TRUE, contour = TRUE, ..., resolution = 50 ) gf_fun2d( object = NULL, formula = NULL, xlim = NULL, ylim = NULL, tile = TRUE, contour = TRUE, ..., resolution = 50 ) gf_fun_tile( object = NULL, formula = NULL, xlim = NULL, ylim = NULL, ..., resolution = 50 ) gf_fun_contour( object = NULL, formula = NULL, xlim = NULL, ylim = NULL, ..., resolution = 50 )
gf_function_2d( object = NULL, fun = identity, xlim = NULL, ylim = NULL, ..., tile = TRUE, contour = TRUE, resolution = 50 ) gf_function2d( object = NULL, fun = identity, xlim = NULL, ylim = NULL, ..., tile = TRUE, contour = TRUE, resolution = 50 ) gf_function_contour( object = NULL, fun = identity, xlim = NULL, ylim = NULL, ..., resolution = 50 ) gf_function_tile( object = NULL, fun = identity, xlim = NULL, ylim = NULL, ..., resolution = 50 ) gf_fun_2d( object = NULL, formula = NULL, xlim = NULL, ylim = NULL, tile = TRUE, contour = TRUE, ..., resolution = 50 ) gf_fun2d( object = NULL, formula = NULL, xlim = NULL, ylim = NULL, tile = TRUE, contour = TRUE, ..., resolution = 50 ) gf_fun_tile( object = NULL, formula = NULL, xlim = NULL, ylim = NULL, ..., resolution = 50 ) gf_fun_contour( object = NULL, formula = NULL, xlim = NULL, ylim = NULL, ..., resolution = 50 )
object |
An R object, typically of class "gg". |
fun |
A function of two variables to be plotted. |
xlim |
x limits for generating points to be plotted. |
ylim |
y limits for generating points to be plotted. |
... |
additional arguments passed to |
tile |
A logical indicating whether the tile layer should be drawn. |
contour |
A logical indicating whether the contour layer should be drawn. |
resolution |
A numeric vector of length 1 or 2 specifying the number of grid points at which the function is evaluated (in each dimension). |
formula |
A formula describing a function of two variables to be plotted. See |
A gg plot.
theme_set(theme_bw()) gf_function_2d(fun = function(x, y) sin(2 * x * y), xlim = c(-pi, pi), ylim = c(-pi, pi)) |> gf_refine(scale_fill_viridis_c()) gf_function_2d(fun = function(x, y) x + y, contour = FALSE) gf_function_tile(fun = function(x, y) x * y) |> gf_function_contour(fun = function(x, y) x * y, color = "white") |> gf_refine(scale_fill_viridis_c()) gf_fun_tile(x * y ~ x + y, xlim = c(-3, 3), ylim = c(-2, 2)) |> gf_fun_contour(x * y ~ x + y, color = "white") |> gf_refine(scale_fill_viridis_c()) |> gf_labs(fill = "product")
theme_set(theme_bw()) gf_function_2d(fun = function(x, y) sin(2 * x * y), xlim = c(-pi, pi), ylim = c(-pi, pi)) |> gf_refine(scale_fill_viridis_c()) gf_function_2d(fun = function(x, y) x + y, contour = FALSE) gf_function_tile(fun = function(x, y) x * y) |> gf_function_contour(fun = function(x, y) x * y, color = "white") |> gf_refine(scale_fill_viridis_c()) gf_fun_tile(x * y ~ x + y, xlim = c(-3, 3), ylim = c(-2, 2)) |> gf_fun_contour(x * y ~ x + y, color = "white") |> gf_refine(scale_fill_viridis_c()) |> gf_labs(fill = "product")
Line plots in ggformula
. gf_path()
differs from gf_line()
in that points
are connected in the order in which they appear in data
.
gf_hex( object = NULL, gformula = NULL, data = NULL, ..., bins, binwidth, alpha, color, fill, group, linetype, linewidth, xlab, ylab, title, subtitle, caption, geom = "hex", stat = "binhex", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
gf_hex( object = NULL, gformula = NULL, data = NULL, ..., bins, binwidth, alpha, color, fill, group, linetype, linewidth, xlab, ylab, title, subtitle, caption, geom = "hex", stat = "binhex", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
object |
When chaining, this holds an object produced in the earlier portions of the chain. Most users can safely ignore this argument. See details and examples. |
gformula |
A formula with shape |
data |
The data to be displayed in this layer. There are three options: If A A |
... |
Additional arguments. Typically these are
(a) ggplot2 aesthetics to be set with |
bins |
numeric vector giving number of bins in both vertical and horizontal directions. Set to 30 by default. |
binwidth |
Numeric vector giving bin width in both vertical and
horizontal directions. Overrides |
alpha |
Opacity (0 = invisible, 1 = opaque). |
color |
A color or a formula used for mapping color. |
fill |
A color for filling, or a formula used for mapping fill. |
group |
Used for grouping. |
linetype |
A linetype (numeric or "dashed", "dotted", etc.) or a formula used for mapping linetype. |
linewidth |
A numerical line width or a formula used for mapping linewidth. |
xlab |
Label for x-axis. See also |
ylab |
Label for y-axis. See also |
title , subtitle , caption
|
Title, sub-title, and caption for the plot.
See also |
geom , stat
|
Override the default connection between |
position |
Position adjustment, either as a string naming the adjustment
(e.g. |
show.legend |
logical. Should this layer be included in the legends?
|
show.help |
If |
inherit |
A logical indicating whether default attributes are inherited. |
environment |
An environment in which to look for variables not found in |
a gg object
Positional attributes (a.k.a, aesthetics) are specified using the formula in gformula
.
Setting and mapping of additional attributes can be done through the
use of additional arguments.
Attributes can be set can be set using arguments of the form attribute = value
or
mapped using arguments of the form attribute = ~ expression
.
In formulas of the form A | B
, B
will be used to form facets using
facet_wrap()
or facet_grid()
.
This provides an alternative to
gf_facet_wrap()
and
gf_facet_grid()
that is terser and may feel more familiar to users
of lattice.
Evaluation of the ggplot2 code occurs in the environment of gformula
.
This will typically do the right thing when formulas are created on the fly, but might not
be the right thing if formulas created in one environment are used to create plots
in another.
gf_hex(avg_drinks ~ age, data = mosaicData::HELPrct, bins = 15) |> gf_density2d(avg_drinks ~ age, data = mosaicData::HELPrct, color = "red", alpha = 0.5)
gf_hex(avg_drinks ~ age, data = mosaicData::HELPrct, bins = 15) |> gf_density2d(avg_drinks ~ age, data = mosaicData::HELPrct, color = "red", alpha = 0.5)
Count and density histograms in ggformula
.
gf_histogram( object = NULL, gformula = NULL, data = NULL, ..., bins = 25, binwidth, alpha = 0.5, color, fill, group, linetype, linewidth, xlab, ylab, title, subtitle, caption, geom = "bar", stat = "bin", position = "stack", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) gf_dhistogram( object = NULL, gformula = NULL, data = NULL, ..., bins = 25, binwidth, alpha = 0.5, color, fill, group, linetype, linewidth, xlab, ylab, title, subtitle, caption, geom = "bar", stat = "bin", position = "stack", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) gf_dhistogramh( object = NULL, gformula = NULL, data = NULL, ..., bins = 25, binwidth, alpha = 0.5, color, fill, group, linetype, linewidth, xlab, ylab, title, subtitle, caption, geom = "bar", stat = "bin", position = "stack", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
gf_histogram( object = NULL, gformula = NULL, data = NULL, ..., bins = 25, binwidth, alpha = 0.5, color, fill, group, linetype, linewidth, xlab, ylab, title, subtitle, caption, geom = "bar", stat = "bin", position = "stack", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) gf_dhistogram( object = NULL, gformula = NULL, data = NULL, ..., bins = 25, binwidth, alpha = 0.5, color, fill, group, linetype, linewidth, xlab, ylab, title, subtitle, caption, geom = "bar", stat = "bin", position = "stack", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) gf_dhistogramh( object = NULL, gformula = NULL, data = NULL, ..., bins = 25, binwidth, alpha = 0.5, color, fill, group, linetype, linewidth, xlab, ylab, title, subtitle, caption, geom = "bar", stat = "bin", position = "stack", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
object |
When chaining, this holds an object produced in the earlier portions of the chain. Most users can safely ignore this argument. See details and examples. |
gformula |
A formula with shape |
data |
The data to be displayed in this layer. There are three options: If A A |
... |
Additional arguments. Typically these are
(a) ggplot2 aesthetics to be set with |
bins |
Number of bins. Overridden by |
binwidth |
The width of the bins. Can be specified as a numeric value
or as a function that calculates width from unscaled x. Here, "unscaled x"
refers to the original x values in the data, before application of any
scale transformation. When specifying a function along with a grouping
structure, the function will be called once per group.
The default is to use the number of bins in The bin width of a date variable is the number of days in each time; the bin width of a time variable is the number of seconds. |
alpha |
Opacity (0 = invisible, 1 = opaque). |
color |
A color or a formula used for mapping color. |
fill |
A color for filling, or a formula used for mapping fill. |
group |
Used for grouping. |
linetype |
A linetype (numeric or "dashed", "dotted", etc.) or a formula used for mapping linetype. |
linewidth |
A numerical line width or a formula used for mapping linewidth. |
xlab |
Label for x-axis. See also |
ylab |
Label for y-axis. See also |
title , subtitle , caption
|
Title, sub-title, and caption for the plot.
See also |
geom , stat
|
Use to override the default connection between
|
position |
Position adjustment, either as a string naming the adjustment
(e.g. |
show.legend |
logical. Should this layer be included in the legends?
|
show.help |
If |
inherit |
A logical indicating whether default attributes are inherited. |
environment |
An environment in which to look for variables not found in |
a gg object
Positional attributes (a.k.a, aesthetics) are specified using the formula in gformula
.
Setting and mapping of additional attributes can be done through the
use of additional arguments.
Attributes can be set can be set using arguments of the form attribute = value
or
mapped using arguments of the form attribute = ~ expression
.
In formulas of the form A | B
, B
will be used to form facets using
facet_wrap()
or facet_grid()
.
This provides an alternative to
gf_facet_wrap()
and
gf_facet_grid()
that is terser and may feel more familiar to users
of lattice.
Evaluation of the ggplot2 code occurs in the environment of gformula
.
This will typically do the right thing when formulas are created on the fly, but might not
be the right thing if formulas created in one environment are used to create plots
in another.
x <- rnorm(1000) gf_histogram(~x, bins = 30) gf_dhistogram(~x, bins = 30) gf_dhistogram(~x, binwidth = 0.5, center = 0, color = "black") gf_dhistogram(~x, binwidth = 0.5, boundary = 0, color = "black") gf_dhistogramh(x ~ ., binwidth = 0.5, boundary = 0, color = "black") gf_dhistogram(~x, bins = 30) |> gf_fitdistr(dist = "dnorm") # see help for gf_fitdistr() for more info. gf_histogram(~x, fill = ~ (abs(x) <= 2), boundary = 2, binwidth = 0.25) data(penguins, package = "palmerpenguins") gf_histogram(~ bill_length_mm | species, data = penguins, binwidth = 0.25) gf_histogram(~age, data = mosaicData::HELPrct, binwidth = 5, fill = "skyblue", color = "black" ) # bins can be adjusted left/right using center or boundary gf_histogram(~age, data = mosaicData::HELPrct, binwidth = 5, fill = "skyblue", color = "black", center = 42.5 ) gf_histogram(~age, data = mosaicData::HELPrct, binwidth = 5, fill = "skyblue", color = "black", boundary = 40 ) gf_histogram(age ~ ., data = mosaicData::HELPrct, binwidth = 5, fill = "skyblue", color = "black", boundary = 40 )
x <- rnorm(1000) gf_histogram(~x, bins = 30) gf_dhistogram(~x, bins = 30) gf_dhistogram(~x, binwidth = 0.5, center = 0, color = "black") gf_dhistogram(~x, binwidth = 0.5, boundary = 0, color = "black") gf_dhistogramh(x ~ ., binwidth = 0.5, boundary = 0, color = "black") gf_dhistogram(~x, bins = 30) |> gf_fitdistr(dist = "dnorm") # see help for gf_fitdistr() for more info. gf_histogram(~x, fill = ~ (abs(x) <= 2), boundary = 2, binwidth = 0.25) data(penguins, package = "palmerpenguins") gf_histogram(~ bill_length_mm | species, data = penguins, binwidth = 0.25) gf_histogram(~age, data = mosaicData::HELPrct, binwidth = 5, fill = "skyblue", color = "black" ) # bins can be adjusted left/right using center or boundary gf_histogram(~age, data = mosaicData::HELPrct, binwidth = 5, fill = "skyblue", color = "black", center = 42.5 ) gf_histogram(~age, data = mosaicData::HELPrct, binwidth = 5, fill = "skyblue", color = "black", boundary = 40 ) gf_histogram(age ~ ., data = mosaicData::HELPrct, binwidth = 5, fill = "skyblue", color = "black", boundary = 40 )
Jittered scatter plots in ggformula
.
gf_jitter( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, size, shape, fill, width, height, group, stroke, xlab, ylab, title, subtitle, caption, geom = "point", stat = "identity", position = "jitter", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
gf_jitter( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, size, shape, fill, width, height, group, stroke, xlab, ylab, title, subtitle, caption, geom = "point", stat = "identity", position = "jitter", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
object |
When chaining, this holds an object produced in the earlier portions of the chain. Most users can safely ignore this argument. See details and examples. |
gformula |
A formula with shape |
data |
A data frame with the variables to be plotted. |
... |
Additional arguments. Typically these are
(a) ggplot2 aesthetics to be set with |
alpha |
Opacity (0 = invisible, 1 = opaque). |
color |
A color or a formula used for mapping color. |
size |
A numeric size or a formula used for mapping size. |
shape |
An integer or letter shape or a formula used for mapping shape. |
fill |
A color for filling, or a formula used for mapping fill. |
width |
Amount of horizontal jitter. |
height |
Amount of vertical jitter. |
group |
Used for grouping. |
stroke |
A numeric size of the border or a formula used to map stroke. |
xlab |
Label for x-axis. See also |
ylab |
Label for y-axis. See also |
title , subtitle , caption
|
Title, sub-title, and caption for the plot.
See also |
geom |
A character string naming the geom used to make the layer. |
stat |
A character string naming the stat used to make the layer. |
position |
Either a character string naming the position function used for the layer or a position object returned from a call to a position function. |
show.legend |
A logical indicating whether this layer should be included in
the legends. |
show.help |
If |
inherit |
A logical indicating whether default attributes are inherited. |
environment |
An environment in which to look for variables not found in |
a gg object
Positional attributes (a.k.a, aesthetics) are specified using the formula in gformula
.
Setting and mapping of additional attributes can be done through the
use of additional arguments.
Attributes can be set can be set using arguments of the form attribute = value
or
mapped using arguments of the form attribute = ~ expression
.
In formulas of the form A | B
, B
will be used to form facets using
facet_wrap()
or facet_grid()
.
This provides an alternative to
gf_facet_wrap()
and
gf_facet_grid()
that is terser and may feel more familiar to users
of lattice.
Evaluation of the ggplot2 code occurs in the environment of gformula
.
This will typically do the right thing when formulas are created on the fly, but might not
be the right thing if formulas created in one environment are used to create plots
in another.
ggplot2::geom_jitter()
, gf_point()
gf_jitter() # without jitter gf_point(age ~ sex, alpha = 0.25, data = mosaicData::HELPrct) # jitter only horizontally gf_jitter(age ~ sex, alpha = 0.25, data = mosaicData::HELPrct, width = 0.2, height = 0) # alternative way to get jitter gf_point(age ~ sex, alpha = 0.25, data = mosaicData::HELPrct, position = "jitter", width = 0.2, height = 0 )
gf_jitter() # without jitter gf_point(age ~ sex, alpha = 0.25, data = mosaicData::HELPrct) # jitter only horizontally gf_jitter(age ~ sex, alpha = 0.25, data = mosaicData::HELPrct, width = 0.2, height = 0) # alternative way to get jitter gf_point(age ~ sex, alpha = 0.25, data = mosaicData::HELPrct, position = "jitter", width = 0.2, height = 0 )
These functions modify things like labels, limits, scales, etc. for plots ggplot2 plots. They are wrappers around functions in ggplot2 that allow for chaining syntax.
gf_labs(object, ...) gf_lims(object, ...) gf_refine(object, ...)
gf_labs(object, ...) gf_lims(object, ...) gf_refine(object, ...)
object |
a gg object |
... |
additional arguments passed through to the similarly named function in ggplot2. |
gf_refine()
provides a mechanism to replace +
with the
chaining/pipe operator |>
.
Each of its \dots
arguments is added in turn to the
base plot in object
. The other functions are thin wrappers around
specific ggplot2
refinement functions and pass their \dots
arguments through to the similarly named ggplot2
functions.
a modified gg object
gf_dens(~cesd, color = ~substance, linewidth = 1.5, data = mosaicData::HELPrct) |> gf_labs( title = "Center for Epidemiologic Studies Depression measure", subtitle = "(at baseline)", color = "Abused substance: ", x = "CESD score", y = "", caption = "Source: HELPrct" ) |> gf_theme(theme_classic()) |> gf_theme( axis.text.y = element_blank(), legend.position = "top", plot.title = element_text(hjust = 0.5, color = "navy"), plot.subtitle = element_text(hjust = 0.5, color = "navy", size = 12) ) gf_point(eruptions ~ waiting, data = faithful, alpha = 0.5) gf_point(eruptions ~ waiting, data = faithful, alpha = 0.5) |> gf_lims(x = c(65, NA), y = c(3, NA)) # modify scales using gf_refine() data(penguins, package = "palmerpenguins") gf_jitter(bill_length_mm ~ bill_depth_mm, color = ~species, data = penguins) |> gf_refine(scale_color_brewer(type = "qual", palette = 3)) |> gf_theme(theme_bw()) gf_jitter(bill_length_mm ~ bill_depth_mm, color = ~species, data = penguins) |> gf_refine(scale_color_manual(values = c("red", "navy", "limegreen"))) |> gf_theme(theme_bw())
gf_dens(~cesd, color = ~substance, linewidth = 1.5, data = mosaicData::HELPrct) |> gf_labs( title = "Center for Epidemiologic Studies Depression measure", subtitle = "(at baseline)", color = "Abused substance: ", x = "CESD score", y = "", caption = "Source: HELPrct" ) |> gf_theme(theme_classic()) |> gf_theme( axis.text.y = element_blank(), legend.position = "top", plot.title = element_text(hjust = 0.5, color = "navy"), plot.subtitle = element_text(hjust = 0.5, color = "navy", size = 12) ) gf_point(eruptions ~ waiting, data = faithful, alpha = 0.5) gf_point(eruptions ~ waiting, data = faithful, alpha = 0.5) |> gf_lims(x = c(65, NA), y = c(3, NA)) # modify scales using gf_refine() data(penguins, package = "palmerpenguins") gf_jitter(bill_length_mm ~ bill_depth_mm, color = ~species, data = penguins) |> gf_refine(scale_color_brewer(type = "qual", palette = 3)) |> gf_theme(theme_bw()) gf_jitter(bill_length_mm ~ bill_depth_mm, color = ~species, data = penguins) |> gf_refine(scale_color_manual(values = c("red", "navy", "limegreen"))) |> gf_theme(theme_bw())
Line plots in ggformula
. gf_path()
differs from gf_line()
in that points
are connected in the order in which they appear in data
.
gf_line( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, fill, group, linetype, linewidth, lineend, linejoin, linemitre, arrow, xlab, ylab, title, subtitle, caption, geom = "line", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) gf_path( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, group, linetype, linewidth, lineend = "butt", linejoin = "round", linemitre = 1, arrow = NULL, xlab, ylab, title, subtitle, caption, geom = "path", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
gf_line( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, fill, group, linetype, linewidth, lineend, linejoin, linemitre, arrow, xlab, ylab, title, subtitle, caption, geom = "line", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) gf_path( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, group, linetype, linewidth, lineend = "butt", linejoin = "round", linemitre = 1, arrow = NULL, xlab, ylab, title, subtitle, caption, geom = "path", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
object |
When chaining, this holds an object produced in the earlier portions of the chain. Most users can safely ignore this argument. See details and examples. |
gformula |
A formula with shape |
data |
A data frame with the variables to be plotted. |
... |
Additional arguments. Typically these are
(a) ggplot2 aesthetics to be set with |
alpha |
Opacity (0 = invisible, 1 = opaque). |
color |
A color or a formula used for mapping color. |
fill |
A color for filling, or a formula used for mapping fill. |
group |
Used for grouping. |
linetype |
A linetype (numeric or "dashed", "dotted", etc.) or a formula used for mapping linetype. |
linewidth |
A numerical line width or a formula used for mapping linewidth. |
lineend |
Line end style (round, butt, square). |
linejoin |
Line join style (round, mitre, bevel). |
linemitre |
Line mitre limit (number greater than 1). |
arrow |
Arrow specification, as created by |
xlab |
Label for x-axis. See also |
ylab |
Label for y-axis. See also |
title , subtitle , caption
|
Title, sub-title, and caption for the plot.
See also |
geom |
A character string naming the geom used to make the layer. |
stat |
A character string naming the stat used to make the layer. |
position |
Either a character string naming the position function used for the layer or a position object returned from a call to a position function. |
show.legend |
A logical indicating whether this layer should be included in
the legends. |
show.help |
If |
inherit |
A logical indicating whether default attributes are inherited. |
environment |
An environment in which to look for variables not found in |
a gg object
Positional attributes (a.k.a, aesthetics) are specified using the formula in gformula
.
Setting and mapping of additional attributes can be done through the
use of additional arguments.
Attributes can be set can be set using arguments of the form attribute = value
or
mapped using arguments of the form attribute = ~ expression
.
In formulas of the form A | B
, B
will be used to form facets using
facet_wrap()
or facet_grid()
.
This provides an alternative to
gf_facet_wrap()
and
gf_facet_grid()
that is terser and may feel more familiar to users
of lattice.
Evaluation of the ggplot2 code occurs in the environment of gformula
.
This will typically do the right thing when formulas are created on the fly, but might not
be the right thing if formulas created in one environment are used to create plots
in another.
ggplot2::geom_line()
, gf_point()
gf_line() gf_point(age ~ sex, alpha = 0.25, data = mosaicData::HELPrct) gf_point(births ~ date, color = ~wday, data = mosaicData::Births78) # lines make the exceptions stand out more prominently gf_line(births ~ date, color = ~wday, data = mosaicData::Births78) gf_path() if (require(dplyr)) { data.frame(t = seq(1, 10 * pi, length.out = 400)) |> mutate(x = t * cos(t), y = t * sin(t)) |> gf_path(y ~ x, color = ~t) }
gf_line() gf_point(age ~ sex, alpha = 0.25, data = mosaicData::HELPrct) gf_point(births ~ date, color = ~wday, data = mosaicData::Births78) # lines make the exceptions stand out more prominently gf_line(births ~ date, color = ~wday, data = mosaicData::Births78) gf_path() if (require(dplyr)) { data.frame(t = seq(1, 10 * pi, length.out = 400)) |> mutate(x = t * cos(t), y = t * sin(t)) |> gf_path(y ~ x, color = ~t) }
Various ways of representing a vertical interval defined by x
,
ymin
and ymax
. Each case draws a single graphical object.
gf_linerange( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, group, linetype, linewidth, xlab, ylab, title, subtitle, caption, geom = "linerange", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) gf_pointrange( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, group, linetype, linewidth, size, fatten = 2, xlab, ylab, title, subtitle, caption, geom = "pointrange", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) gf_summary( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, group, linetype, linewidth, size, fun.y = NULL, fun.ymax = NULL, fun.ymin = NULL, fun.args = list(), fatten = 2, xlab, ylab, title, subtitle, caption, geom = "pointrange", stat = "summary", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
gf_linerange( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, group, linetype, linewidth, xlab, ylab, title, subtitle, caption, geom = "linerange", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) gf_pointrange( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, group, linetype, linewidth, size, fatten = 2, xlab, ylab, title, subtitle, caption, geom = "pointrange", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) gf_summary( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, group, linetype, linewidth, size, fun.y = NULL, fun.ymax = NULL, fun.ymin = NULL, fun.args = list(), fatten = 2, xlab, ylab, title, subtitle, caption, geom = "pointrange", stat = "summary", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
object |
When chaining, this holds an object produced in the earlier portions of the chain. Most users can safely ignore this argument. See details and examples. |
gformula |
A formula with shape |
data |
The data to be displayed in this layer. There are three options: If A A |
... |
Additional arguments. Typically these are
(a) ggplot2 aesthetics to be set with |
alpha |
Opacity (0 = invisible, 1 = opaque). |
color |
A color or a formula used for mapping color. |
group |
Used for grouping. |
linetype |
A linetype (numeric or "dashed", "dotted", etc.) or a formula used for mapping linetype. |
linewidth |
A numerical line width or a formula used for mapping linewidth. |
xlab |
Label for x-axis. See also |
ylab |
Label for y-axis. See also |
title , subtitle , caption
|
Title, sub-title, and caption for the plot.
See also |
geom |
The geometric object to use to display the data, either as a
|
stat |
The statistical transformation to use on the data for this
layer, either as a |
position |
Position adjustment, either as a string naming the adjustment
(e.g. |
show.legend |
logical. Should this layer be included in the legends?
|
show.help |
If |
inherit |
A logical indicating whether default attributes are inherited. |
environment |
An environment in which to look for variables not found in |
size |
size aesthetic for points ( |
fatten |
A multiplicative factor used to increase the size of the
middle bar in |
fun.ymin , fun.y , fun.ymax
|
|
fun.args |
Optional additional arguments passed on to the functions. |
ggplot2::geom_pointrange()
, ggplot2::stat_summary()
gf_linerange() gf_ribbon(low_temp + high_temp ~ date, data = mosaicData::Weather, fill = ~city, alpha = 0.4 ) |> gf_theme(theme = theme_minimal()) gf_linerange( low_temp + high_temp ~ date | city ~ ., data = mosaicData::Weather, color = ~ ((low_temp + high_temp) / 2) ) |> gf_refine(scale_colour_gradientn(colors = rev(rainbow(5)))) |> gf_labs(color = "mid-temp") gf_ribbon(low_temp + high_temp ~ date | city ~ ., data = mosaicData::Weather) # Chaining in the data mosaicData::Weather |> gf_ribbon(low_temp + high_temp ~ date, alpha = 0.4) |> gf_facet_grid(city ~ .) if (require(mosaicData) && require(dplyr)) { HELP2 <- HELPrct |> group_by(substance, sex) |> summarise( age = NA, mean.age = mean(age), median.age = median(age), max.age = max(age), min.age = min(age), sd.age = sd(age), lo = mean.age - sd.age, hi = mean.age + sd.age ) gf_jitter(age ~ substance, data = HELPrct, alpha = 0.5, width = 0.2, height = 0, color = "skyblue") |> gf_pointrange(mean.age + lo + hi ~ substance, data = HELP2) |> gf_facet_grid(~sex) gf_jitter(age ~ substance, data = HELPrct, alpha = 0.5, width = 0.2, height = 0, color = "skyblue") |> gf_errorbar(lo + hi ~ substance, data = HELP2, inherit = FALSE) |> gf_facet_grid(~sex) # width is defined differently for gf_boxplot() and gf_jitter() # * for gf_boxplot() it is the full width of the box. # * for gf_jitter() it is half that -- the maximum amount added or subtracted. gf_boxplot(age ~ substance, data = HELPrct, width = 0.4) |> gf_jitter(width = 0.4, height = 0, color = "skyblue", alpha = 0.5) gf_boxplot(age ~ substance, data = HELPrct, width = 0.4) |> gf_jitter(width = 0.2, height = 0, color = "skyblue", alpha = 0.5) } p <- gf_jitter(mpg ~ cyl, data = mtcars, height = 0, width = 0.15); p p |> gf_summary(fun.data = "mean_cl_boot", color = "red", size = 2, linewidth = 1.3) # You can supply individual functions to summarise the value at # each x: p |> gf_summary(fun.y = "median", color = "red", size = 3, geom = "point") p |> gf_summary(fun.y = "mean", color = "red", size = 3, geom = "point") |> gf_summary(fun.y = mean, geom = "line") p |> gf_summary(fun.y = mean, fun.ymin = min, fun.ymax = max, color = "red") ## Not run: p |> gf_summary(fun.ymin = min, fun.ymax = max, color = "red", geom = "linerange") ## End(Not run) gf_bar(~ cut, data = diamonds) gf_col(price ~ cut, data = diamonds, stat = "summary_bin", fun.y = "mean") # Don't use gf_lims() to zoom into a summary plot - this throws the # data away p <- gf_summary(mpg ~ cyl, data = mtcars, fun.y = "mean", geom = "point") p p |> gf_lims(y = c(15, 30)) # Instead use coord_cartesian() p |> gf_refine(coord_cartesian(ylim = c(15, 30))) # A set of useful summary functions is provided from the Hmisc package. ## Not run: p <- gf_jitter(mpg ~ cyl, data = mtcars, width = 0.15, height = 0); p p |> gf_summary(fun.data = mean_cl_boot, color = "red") p |> gf_summary(fun.data = mean_cl_boot, color = "red", geom = "crossbar") p |> gf_summary(fun.data = mean_sdl, group = ~ cyl, color = "red", geom = "crossbar", width = 0.3) p |> gf_summary(group = ~ cyl, color = "red", geom = "crossbar", width = 0.3, fun.data = mean_sdl, fun.args = list(mult = 1)) p |> gf_summary(fun.data = median_hilow, group = ~ cyl, color = "red", geom = "crossbar", width = 0.3) ## End(Not run) # An example with highly skewed distributions: if (require("ggplot2movies")) { set.seed(596) Mov <- movies[sample(nrow(movies), 1000), ] m2 <- gf_jitter(votes ~ factor(round(rating)), data = Mov, width = 0.15, height = 0, alpha = 0.3) m2 <- m2 |> gf_summary(fun.data = "mean_cl_boot", geom = "crossbar", colour = "red", width = 0.3) |> gf_labs(x = "rating") m2 # Notice how the overplotting skews off visual perception of the mean # supplementing the raw data with summary statistics is _very_ important # Next, we'll look at votes on a log scale. # Transforming the scale means the data are transformed # first, after which statistics are computed: m2 |> gf_refine(scale_y_log10()) # Transforming the coordinate system occurs after the # statistic has been computed. This means we're calculating the summary on the raw data # and stretching the geoms onto the log scale. Compare the widths of the # standard errors. m2 |> gf_refine(coord_trans(y="log10")) }
gf_linerange() gf_ribbon(low_temp + high_temp ~ date, data = mosaicData::Weather, fill = ~city, alpha = 0.4 ) |> gf_theme(theme = theme_minimal()) gf_linerange( low_temp + high_temp ~ date | city ~ ., data = mosaicData::Weather, color = ~ ((low_temp + high_temp) / 2) ) |> gf_refine(scale_colour_gradientn(colors = rev(rainbow(5)))) |> gf_labs(color = "mid-temp") gf_ribbon(low_temp + high_temp ~ date | city ~ ., data = mosaicData::Weather) # Chaining in the data mosaicData::Weather |> gf_ribbon(low_temp + high_temp ~ date, alpha = 0.4) |> gf_facet_grid(city ~ .) if (require(mosaicData) && require(dplyr)) { HELP2 <- HELPrct |> group_by(substance, sex) |> summarise( age = NA, mean.age = mean(age), median.age = median(age), max.age = max(age), min.age = min(age), sd.age = sd(age), lo = mean.age - sd.age, hi = mean.age + sd.age ) gf_jitter(age ~ substance, data = HELPrct, alpha = 0.5, width = 0.2, height = 0, color = "skyblue") |> gf_pointrange(mean.age + lo + hi ~ substance, data = HELP2) |> gf_facet_grid(~sex) gf_jitter(age ~ substance, data = HELPrct, alpha = 0.5, width = 0.2, height = 0, color = "skyblue") |> gf_errorbar(lo + hi ~ substance, data = HELP2, inherit = FALSE) |> gf_facet_grid(~sex) # width is defined differently for gf_boxplot() and gf_jitter() # * for gf_boxplot() it is the full width of the box. # * for gf_jitter() it is half that -- the maximum amount added or subtracted. gf_boxplot(age ~ substance, data = HELPrct, width = 0.4) |> gf_jitter(width = 0.4, height = 0, color = "skyblue", alpha = 0.5) gf_boxplot(age ~ substance, data = HELPrct, width = 0.4) |> gf_jitter(width = 0.2, height = 0, color = "skyblue", alpha = 0.5) } p <- gf_jitter(mpg ~ cyl, data = mtcars, height = 0, width = 0.15); p p |> gf_summary(fun.data = "mean_cl_boot", color = "red", size = 2, linewidth = 1.3) # You can supply individual functions to summarise the value at # each x: p |> gf_summary(fun.y = "median", color = "red", size = 3, geom = "point") p |> gf_summary(fun.y = "mean", color = "red", size = 3, geom = "point") |> gf_summary(fun.y = mean, geom = "line") p |> gf_summary(fun.y = mean, fun.ymin = min, fun.ymax = max, color = "red") ## Not run: p |> gf_summary(fun.ymin = min, fun.ymax = max, color = "red", geom = "linerange") ## End(Not run) gf_bar(~ cut, data = diamonds) gf_col(price ~ cut, data = diamonds, stat = "summary_bin", fun.y = "mean") # Don't use gf_lims() to zoom into a summary plot - this throws the # data away p <- gf_summary(mpg ~ cyl, data = mtcars, fun.y = "mean", geom = "point") p p |> gf_lims(y = c(15, 30)) # Instead use coord_cartesian() p |> gf_refine(coord_cartesian(ylim = c(15, 30))) # A set of useful summary functions is provided from the Hmisc package. ## Not run: p <- gf_jitter(mpg ~ cyl, data = mtcars, width = 0.15, height = 0); p p |> gf_summary(fun.data = mean_cl_boot, color = "red") p |> gf_summary(fun.data = mean_cl_boot, color = "red", geom = "crossbar") p |> gf_summary(fun.data = mean_sdl, group = ~ cyl, color = "red", geom = "crossbar", width = 0.3) p |> gf_summary(group = ~ cyl, color = "red", geom = "crossbar", width = 0.3, fun.data = mean_sdl, fun.args = list(mult = 1)) p |> gf_summary(fun.data = median_hilow, group = ~ cyl, color = "red", geom = "crossbar", width = 0.3) ## End(Not run) # An example with highly skewed distributions: if (require("ggplot2movies")) { set.seed(596) Mov <- movies[sample(nrow(movies), 1000), ] m2 <- gf_jitter(votes ~ factor(round(rating)), data = Mov, width = 0.15, height = 0, alpha = 0.3) m2 <- m2 |> gf_summary(fun.data = "mean_cl_boot", geom = "crossbar", colour = "red", width = 0.3) |> gf_labs(x = "rating") m2 # Notice how the overplotting skews off visual perception of the mean # supplementing the raw data with summary statistics is _very_ important # Next, we'll look at votes on a log scale. # Transforming the scale means the data are transformed # first, after which statistics are computed: m2 |> gf_refine(scale_y_log10()) # Transforming the coordinate system occurs after the # statistic has been computed. This means we're calculating the summary on the raw data # and stretching the geoms onto the log scale. Compare the widths of the # standard errors. m2 |> gf_refine(coord_trans(y="log10")) }
Create a new ggplot and (optionally) set default dataset aesthetics mapping.
gf_plot(...)
gf_plot(...)
... |
arguments that can include |
a gg object
gf_plot(mtcars, x = ~ wt, y = ~ mpg, color = ~ factor(cyl)) |> gf_density_2d() |> gf_point()
gf_plot(mtcars, x = ~ wt, y = ~ mpg, color = ~ factor(cyl)) |> gf_density_2d() |> gf_point()
Scatterplots in ggformula
.
gf_point( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, size, shape, fill, group, stroke, xlab, ylab, title, subtitle, caption, geom = "point", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
gf_point( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, size, shape, fill, group, stroke, xlab, ylab, title, subtitle, caption, geom = "point", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
object |
When chaining, this holds an object produced in the earlier portions of the chain. Most users can safely ignore this argument. See details and examples. |
gformula |
A formula with shape |
data |
A data frame with the variables to be plotted. |
... |
Additional arguments. Typically these are
(a) ggplot2 aesthetics to be set with |
alpha |
Opacity (0 = invisible, 1 = opaque). |
color |
A color or a formula used for mapping color. |
size |
A numeric size or a formula used for mapping size. |
shape |
An integer or letter shape or a formula used for mapping shape. |
fill |
A color for filling, or a formula used for mapping fill. |
group |
Used for grouping. |
stroke |
A numeric size of the border or a formula used to map stroke. |
xlab |
Label for x-axis. See also |
ylab |
Label for y-axis. See also |
title , subtitle , caption
|
Title, sub-title, and caption for the plot.
See also |
geom |
A character string naming the geom used to make the layer. |
stat |
A character string naming the stat used to make the layer. |
position |
Either a character string naming the position function used for the layer or a position object returned from a call to a position function. |
show.legend |
A logical indicating whether this layer should be included in
the legends. |
show.help |
If |
inherit |
A logical indicating whether default attributes are inherited. |
environment |
An environment in which to look for variables not found in |
a gg object
Positional attributes (a.k.a, aesthetics) are specified using the formula in gformula
.
Setting and mapping of additional attributes can be done through the
use of additional arguments.
Attributes can be set can be set using arguments of the form attribute = value
or
mapped using arguments of the form attribute = ~ expression
.
In formulas of the form A | B
, B
will be used to form facets using
facet_wrap()
or facet_grid()
.
This provides an alternative to
gf_facet_wrap()
and
gf_facet_grid()
that is terser and may feel more familiar to users
of lattice.
Evaluation of the ggplot2 code occurs in the environment of gformula
.
This will typically do the right thing when formulas are created on the fly, but might not
be the right thing if formulas created in one environment are used to create plots
in another.
ggplot2::geom_point()
, gf_line()
, gf_jitter()
gf_point() gf_point((10 * ((1:25) %/% 10)) ~ ((1:25) %% 10), shape = 1:25, fill = "skyblue", color = "navy", size = 4, stroke = 1, data = NA ) gf_point(mpg ~ hp, color = ~cyl, size = ~wt, data = mtcars) # faceting -- two ways gf_point(mpg ~ hp, data = mtcars) |> gf_facet_wrap(~am) gf_point(mpg ~ hp | am, group = ~cyl, data = mtcars) gf_point(mpg ~ hp | ~am, group = ~cyl, data = mtcars) gf_point(mpg ~ hp | am ~ ., group = ~cyl, data = mtcars) # Chaining in the data mtcars |> gf_point(mpg ~ wt) # short cuts for main labels in the plot gf_point(births ~ date, color = ~wday, data = mosaicData::Births78, xlab = "Date", ylab = "Number of Live Births", title = "Interesting Patterns in the Number of Births", subtitle = "(United States, 1978)", caption = "Source: mosaicData::Births78" )
gf_point() gf_point((10 * ((1:25) %/% 10)) ~ ((1:25) %% 10), shape = 1:25, fill = "skyblue", color = "navy", size = 4, stroke = 1, data = NA ) gf_point(mpg ~ hp, color = ~cyl, size = ~wt, data = mtcars) # faceting -- two ways gf_point(mpg ~ hp, data = mtcars) |> gf_facet_wrap(~am) gf_point(mpg ~ hp | am, group = ~cyl, data = mtcars) gf_point(mpg ~ hp | ~am, group = ~cyl, data = mtcars) gf_point(mpg ~ hp | am ~ ., group = ~cyl, data = mtcars) # Chaining in the data mtcars |> gf_point(mpg ~ wt) # short cuts for main labels in the plot gf_point(births ~ date, color = ~wday, data = mosaicData::Births78, xlab = "Date", ylab = "Number of Live Births", title = "Interesting Patterns in the Number of Births", subtitle = "(United States, 1978)", caption = "Source: mosaicData::Births78" )
Line plots in ggformula
. gf_path()
differs from gf_line()
in that points
are connected in the order in which they appear in data
.
gf_polygon( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, linewidth, shape, fill, group, stroke, xlab, ylab, title, subtitle, caption, geom = "polygon", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
gf_polygon( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, linewidth, shape, fill, group, stroke, xlab, ylab, title, subtitle, caption, geom = "polygon", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
object |
When chaining, this holds an object produced in the earlier portions of the chain. Most users can safely ignore this argument. See details and examples. |
gformula |
A formula with shape |
data |
A data frame with the variables to be plotted. |
... |
Additional arguments. Typically these are
(a) ggplot2 aesthetics to be set with |
alpha |
Opacity (0 = invisible, 1 = opaque). |
color |
A color or a formula used for mapping color. |
linewidth |
A numerical line width or a formula used for mapping linewidth. |
shape , stroke
|
Aesthetics for polygons. |
fill |
A color for filling, or a formula used for mapping fill. |
group |
Used for grouping. |
xlab |
Label for x-axis. See also |
ylab |
Label for y-axis. See also |
title , subtitle , caption
|
Title, sub-title, and caption for the plot.
See also |
geom |
A character string naming the geom used to make the layer. |
stat |
A character string naming the stat used to make the layer. |
position |
Either a character string naming the position function used for the layer or a position object returned from a call to a position function. |
show.legend |
A logical indicating whether this layer should be included in
the legends. |
show.help |
If |
inherit |
A logical indicating whether default attributes are inherited. |
environment |
An environment in which to look for variables not found in |
a gg object
Positional attributes (a.k.a, aesthetics) are specified using the formula in gformula
.
Setting and mapping of additional attributes can be done through the
use of additional arguments.
Attributes can be set can be set using arguments of the form attribute = value
or
mapped using arguments of the form attribute = ~ expression
.
In formulas of the form A | B
, B
will be used to form facets using
facet_wrap()
or facet_grid()
.
This provides an alternative to
gf_facet_wrap()
and
gf_facet_grid()
that is terser and may feel more familiar to users
of lattice.
Evaluation of the ggplot2 code occurs in the environment of gformula
.
This will typically do the right thing when formulas are created on the fly, but might not
be the right thing if formulas created in one environment are used to create plots
in another.
ggplot2::geom_line()
, gf_point()
gf_polygon() if (require(maps) && require(ggthemes) && require(dplyr)) { US <- map_data("state") |> dplyr::mutate(name_length = nchar(region)) States <- US |> dplyr::group_by(region) |> dplyr::summarise(lat = mean(range(lat)), long = mean(range(long))) |> dplyr::mutate(name = abbreviate(region, 3)) gf_polygon(lat ~ long, data = US, group = ~group, fill = ~name_length, color = "white" ) |> gf_text(lat ~ long, label = ~name, data = States, color = "gray70", inherit = FALSE ) |> gf_refine(ggthemes::theme_map()) }
gf_polygon() if (require(maps) && require(ggthemes) && require(dplyr)) { US <- map_data("state") |> dplyr::mutate(name_length = nchar(region)) States <- US |> dplyr::group_by(region) |> dplyr::summarise(lat = mean(range(lat)), long = mean(range(long))) |> dplyr::mutate(name = abbreviate(region, 3)) gf_polygon(lat ~ long, data = US, group = ~group, fill = ~name_length, color = "white" ) |> gf_text(lat ~ long, label = ~name, data = States, color = "gray70", inherit = FALSE ) |> gf_refine(ggthemes::theme_map()) }
gf_qq()
an gf_qqstep()
both create quantile-quantile plots. They
differ in how they display the qq-plot.
gf_qq()
uses points and gf_qqstep()
plots a step function
through these points.
gf_qq( object = NULL, gformula = NULL, data = NULL, ..., group, distribution = stats::qnorm, dparams = list(), xlab, ylab, title, subtitle, caption, geom = "point", stat = "qq", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) gf_qqline( object = NULL, gformula = NULL, data = NULL, ..., group, distribution = stats::qnorm, dparams = list(), linetype = "dashed", alpha = 0.7, xlab, ylab, title, subtitle, caption, geom = "path", stat = "qq_line", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) gf_qqstep( object = NULL, gformula = NULL, data = NULL, ..., group, distribution = stats::qnorm, dparams = list(), xlab, ylab, title, subtitle, caption, geom = "step", stat = "qq", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
gf_qq( object = NULL, gformula = NULL, data = NULL, ..., group, distribution = stats::qnorm, dparams = list(), xlab, ylab, title, subtitle, caption, geom = "point", stat = "qq", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) gf_qqline( object = NULL, gformula = NULL, data = NULL, ..., group, distribution = stats::qnorm, dparams = list(), linetype = "dashed", alpha = 0.7, xlab, ylab, title, subtitle, caption, geom = "path", stat = "qq_line", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) gf_qqstep( object = NULL, gformula = NULL, data = NULL, ..., group, distribution = stats::qnorm, dparams = list(), xlab, ylab, title, subtitle, caption, geom = "step", stat = "qq", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
object |
When chaining, this holds an object produced in the earlier portions of the chain. Most users can safely ignore this argument. See details and examples. |
gformula |
A formula with shape |
data |
The data to be displayed in this layer. There are three options: If A A |
... |
Additional arguments. Typically these are
(a) ggplot2 aesthetics to be set with |
group |
Used for grouping. |
distribution |
Distribution function to use, if x not specified |
dparams |
Additional parameters passed on to |
xlab |
Label for x-axis. See also |
ylab |
Label for y-axis. See also |
title , subtitle , caption
|
Title, sub-title, and caption for the plot.
See also |
geom , stat
|
Use to override the default connection between
|
position |
Position adjustment, either as a string naming the adjustment
(e.g. |
show.legend |
logical. Should this layer be included in the legends?
|
show.help |
If |
inherit |
A logical indicating whether default attributes are inherited. |
environment |
An environment in which to look for variables not found in |
linetype |
A linetype (numeric or "dashed", "dotted", etc.) or a formula used for mapping linetype. |
alpha |
Opacity (0 = invisible, 1 = opaque). |
a gg object
Positional attributes (a.k.a, aesthetics) are specified using the formula in gformula
.
Setting and mapping of additional attributes can be done through the
use of additional arguments.
Attributes can be set can be set using arguments of the form attribute = value
or
mapped using arguments of the form attribute = ~ expression
.
In formulas of the form A | B
, B
will be used to form facets using
facet_wrap()
or facet_grid()
.
This provides an alternative to
gf_facet_wrap()
and
gf_facet_grid()
that is terser and may feel more familiar to users
of lattice.
Evaluation of the ggplot2 code occurs in the environment of gformula
.
This will typically do the right thing when formulas are created on the fly, but might not
be the right thing if formulas created in one environment are used to create plots
in another.
gf_qq(~ rnorm(100)) data(penguins, package = "palmerpenguins") gf_qq(~ bill_length_mm | species, data = penguins) |> gf_qqline() gf_qq(~ bill_length_mm | species, data = penguins) |> gf_qqline(tail = 0.10) gf_qq(~bill_length_mm, color = ~species, data = penguins) |> gf_qqstep(~bill_length_mm, color = ~species, data = penguins)
gf_qq(~ rnorm(100)) data(penguins, package = "palmerpenguins") gf_qq(~ bill_length_mm | species, data = penguins) |> gf_qqline() gf_qq(~ bill_length_mm | species, data = penguins) |> gf_qqline(tail = 0.10) gf_qq(~bill_length_mm, color = ~species, data = penguins) |> gf_qqstep(~bill_length_mm, color = ~species, data = penguins)
This fits a quantile regression to the data and draws the fitted quantiles
with lines. This is as a continuous analogue to geom_boxplot()
.
gf_quantile( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, group, linetype, linewidth, lineend = "butt", linejoin = "round", linemitre = 1, quantiles, formula, method, method.args, xlab, ylab, title, subtitle, caption, geom = "quantile", stat = "quantile", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
gf_quantile( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, group, linetype, linewidth, lineend = "butt", linejoin = "round", linemitre = 1, quantiles, formula, method, method.args, xlab, ylab, title, subtitle, caption, geom = "quantile", stat = "quantile", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
object |
When chaining, this holds an object produced in the earlier portions of the chain. Most users can safely ignore this argument. See details and examples. |
gformula |
A formula with shape |
data |
The data to be displayed in this layer. There are three options: If A A |
... |
Additional arguments. Typically these are
(a) ggplot2 aesthetics to be set with |
alpha |
Opacity (0 = invisible, 1 = opaque). |
color |
A color or a formula used for mapping color. |
group |
Used for grouping. |
linetype |
A linetype (numeric or "dashed", "dotted", etc.) or a formula used for mapping linetype. |
linewidth |
A numerical line width or a formula used for mapping linewidth. |
lineend |
Line end style (round, butt, square). |
linejoin |
Line join style (round, mitre, bevel). |
linemitre |
Line mitre limit (number greater than 1). |
quantiles |
conditional quantiles of y to calculate and display |
formula |
formula relating y variables to x variables |
method |
Quantile regression method to use. Available options are |
method.args |
List of additional arguments passed on to the modelling
function defined by |
xlab |
Label for x-axis. See also |
ylab |
Label for y-axis. See also |
title , subtitle , caption
|
Title, sub-title, and caption for the plot.
See also |
geom , stat
|
Use to override the default connection between
|
position |
Position adjustment, either as a string naming the adjustment
(e.g. |
show.legend |
logical. Should this layer be included in the legends?
|
show.help |
If |
inherit |
A logical indicating whether default attributes are inherited. |
environment |
An environment in which to look for variables not found in |
a gg object
Positional attributes (a.k.a, aesthetics) are specified using the formula in gformula
.
Setting and mapping of additional attributes can be done through the
use of additional arguments.
Attributes can be set can be set using arguments of the form attribute = value
or
mapped using arguments of the form attribute = ~ expression
.
In formulas of the form A | B
, B
will be used to form facets using
facet_wrap()
or facet_grid()
.
This provides an alternative to
gf_facet_wrap()
and
gf_facet_grid()
that is terser and may feel more familiar to users
of lattice.
Evaluation of the ggplot2 code occurs in the environment of gformula
.
This will typically do the right thing when formulas are created on the fly, but might not
be the right thing if formulas created in one environment are used to create plots
in another.
gf_point((1 / hwy) ~ displ, data = mpg) |> gf_quantile((1 / hwy) ~ displ)
gf_point((1 / hwy) ~ displ, data = mpg) |> gf_quantile((1 / hwy) ~ displ)
Formula interface to geom_raster()
gf_raster( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, fill, group, linetype, linewidth, hjust = 0.5, vjust = 0.5, interpolate = FALSE, xlab, ylab, title, subtitle, caption, geom = "raster", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
gf_raster( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, fill, group, linetype, linewidth, hjust = 0.5, vjust = 0.5, interpolate = FALSE, xlab, ylab, title, subtitle, caption, geom = "raster", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
object |
When chaining, this holds an object produced in the earlier portions of the chain. Most users can safely ignore this argument. See details and examples. |
gformula |
A formula with shape |
data |
A data frame with the variables to be plotted. |
... |
Additional arguments. Typically these are
(a) ggplot2 aesthetics to be set with |
alpha |
Opacity (0 = invisible, 1 = opaque). |
color |
A color or a formula used for mapping color. |
fill |
A color for filling, or a formula used for mapping fill. |
group |
Used for grouping. |
linetype |
A linetype (numeric or "dashed", "dotted", etc.) or a formula used for mapping linetype. |
linewidth |
A numerical line width or a formula used for mapping linewidth. |
hjust , vjust
|
horizontal and vertical justification of the grob. Each justification value should be a number between 0 and 1. Defaults to 0.5 for both, centering each pixel over its data location. |
interpolate |
If |
xlab |
Label for x-axis. See also |
ylab |
Label for y-axis. See also |
title , subtitle , caption
|
Title, sub-title, and caption for the plot.
See also |
geom |
A character string naming the geom used to make the layer. |
stat |
A character string naming the stat used to make the layer. |
position |
Either a character string naming the position function used for the layer or a position object returned from a call to a position function. |
show.legend |
A logical indicating whether this layer should be included in
the legends. |
show.help |
If |
inherit |
A logical indicating whether default attributes are inherited. |
environment |
An environment in which to look for variables not found in |
a gg object
Positional attributes (a.k.a, aesthetics) are specified using the formula in gformula
.
Setting and mapping of additional attributes can be done through the
use of additional arguments.
Attributes can be set can be set using arguments of the form attribute = value
or
mapped using arguments of the form attribute = ~ expression
.
In formulas of the form A | B
, B
will be used to form facets using
facet_wrap()
or facet_grid()
.
This provides an alternative to
gf_facet_wrap()
and
gf_facet_grid()
that is terser and may feel more familiar to users
of lattice.
Evaluation of the ggplot2 code occurs in the environment of gformula
.
This will typically do the right thing when formulas are created on the fly, but might not
be the right thing if formulas created in one environment are used to create plots
in another.
# Justification controls where the cells are anchored D <- expand.grid(x = 0:5, y = 0:5) D$z <- runif(nrow(D)) # centered squares gf_raster(z ~ x + y, data = D) gf_raster(y ~ x, fill = ~z, data = D) # zero padding gf_raster(z ~ x + y, data = D, hjust = 0, vjust = 0)
# Justification controls where the cells are anchored D <- expand.grid(x = 0:5, y = 0:5) D$z <- runif(nrow(D)) # centered squares gf_raster(z ~ x + y, data = D) gf_raster(y ~ x, fill = ~z, data = D) # zero padding gf_raster(z ~ x + y, data = D, hjust = 0, vjust = 0)
Line plots in ggformula
. gf_path()
differs from gf_line()
in that points
are connected in the order in which they appear in data
.
gf_rect( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, fill, group, linetype, linewidth, xlab, ylab, title, subtitle, caption, geom = "rect", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
gf_rect( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, fill, group, linetype, linewidth, xlab, ylab, title, subtitle, caption, geom = "rect", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
object |
When chaining, this holds an object produced in the earlier portions of the chain. Most users can safely ignore this argument. See details and examples. |
gformula |
A formula with shape |
data |
A data frame with the variables to be plotted. |
... |
Additional arguments. Typically these are
(a) ggplot2 aesthetics to be set with |
alpha |
Opacity (0 = invisible, 1 = opaque). |
color |
A color or a formula used for mapping color. |
fill |
A color for filling, or a formula used for mapping fill. |
group |
Used for grouping. |
linetype |
A linetype (numeric or "dashed", "dotted", etc.) or a formula used for mapping linetype. |
linewidth |
A numerical line width or a formula used for mapping linewidth. |
xlab |
Label for x-axis. See also |
ylab |
Label for y-axis. See also |
title , subtitle , caption
|
Title, sub-title, and caption for the plot.
See also |
geom |
A character string naming the geom used to make the layer. |
stat |
A character string naming the stat used to make the layer. |
position |
Either a character string naming the position function used for the layer or a position object returned from a call to a position function. |
show.legend |
A logical indicating whether this layer should be included in
the legends. |
show.help |
If |
inherit |
A logical indicating whether default attributes are inherited. |
environment |
An environment in which to look for variables not found in |
a gg object
Positional attributes (a.k.a, aesthetics) are specified using the formula in gformula
.
Setting and mapping of additional attributes can be done through the
use of additional arguments.
Attributes can be set can be set using arguments of the form attribute = value
or
mapped using arguments of the form attribute = ~ expression
.
In formulas of the form A | B
, B
will be used to form facets using
facet_wrap()
or facet_grid()
.
This provides an alternative to
gf_facet_wrap()
and
gf_facet_grid()
that is terser and may feel more familiar to users
of lattice.
Evaluation of the ggplot2 code occurs in the environment of gformula
.
This will typically do the right thing when formulas are created on the fly, but might not
be the right thing if formulas created in one environment are used to create plots
in another.
gf_rect(1 + 2 ~ 3 + 4, alpha = 0.3, color = "red") # use data = data.frame() so we get 1 rectangle and not 1 per row of faithful # use inherit = FALSE because we are not reusing eruptions and waiting gf_point(eruptions ~ waiting, data = faithful) |> gf_rect(1.5 + 3 ~ 45 + 68, fill = "red", alpha = 0.2, data = data.frame(), inherit = FALSE) |> gf_rect(3 + 5.5 ~ 68 + 100, fill = "green", alpha = 0.2, data = data.frame(), inherit = FALSE)
gf_rect(1 + 2 ~ 3 + 4, alpha = 0.3, color = "red") # use data = data.frame() so we get 1 rectangle and not 1 per row of faithful # use inherit = FALSE because we are not reusing eruptions and waiting gf_point(eruptions ~ waiting, data = faithful) |> gf_rect(1.5 + 3 ~ 45 + 68, fill = "red", alpha = 0.2, data = data.frame(), inherit = FALSE) |> gf_rect(3 + 5.5 ~ 68 + 100, fill = "green", alpha = 0.2, data = data.frame(), inherit = FALSE)
Some packages like expss provide mechanisms for providing longer labels to R objects.
These labels can be used when labeling plots and tables, for example, without requiring
long or awkward variable names. This is an experimental feature and currently only supports
expss or any other system that stores a label in the label
attribute of a vector.
gf_relabel(plot, labels = get_variable_labels(plot$data), ...) ## S3 method for class 'gf_ggplot' print(x, labels = get_variable_labels(x$data), ...)
gf_relabel(plot, labels = get_variable_labels(plot$data), ...) ## S3 method for class 'gf_ggplot' print(x, labels = get_variable_labels(x$data), ...)
plot |
A ggplot. |
labels |
A named list of labels. |
... |
Additional named labels. See examples. |
x |
A ggplot. |
A plot with potentially modified labels.
# labeling using a list labels <- list(width = "width of foot (cm)", length = "length of foot (cm)", domhand = "dominant hand") gf_point(length ~ width, color = ~domhand, data = mosaicData::KidsFeet) |> gf_relabel(labels) # labeling using ... gf_point(length ~ width, color = ~domhand, data = mosaicData::KidsFeet) |> gf_relabel( width = "width of foot (cm)", length = "length of foot (cm)", domhand = "dominant hand") # Alternatively, we can store labels with data. KF <- mosaicData::KidsFeet |> set_variable_labels( length = 'foot length (cm)', width = 'foot width (cm)' ) gf_point(length ~ width, data = KF) gf_density2d(length ~ width, data = KF) get_variable_labels(KF)
# labeling using a list labels <- list(width = "width of foot (cm)", length = "length of foot (cm)", domhand = "dominant hand") gf_point(length ~ width, color = ~domhand, data = mosaicData::KidsFeet) |> gf_relabel(labels) # labeling using ... gf_point(length ~ width, color = ~domhand, data = mosaicData::KidsFeet) |> gf_relabel( width = "width of foot (cm)", length = "length of foot (cm)", domhand = "dominant hand") # Alternatively, we can store labels with data. KF <- mosaicData::KidsFeet |> set_variable_labels( length = 'foot length (cm)', width = 'foot width (cm)' ) gf_point(length ~ width, data = KF) gf_density2d(length ~ width, data = KF) get_variable_labels(KF)
For each x value, geom_ribbon()
displays a y interval defined
by ymin
and ymax
. geom_area()
is a special case of
geom_ribbon()
, where the ymin
is fixed to 0 and y
is used instead
of ymax
.
gf_ribbon( object = NULL, gformula = NULL, data = NULL, ..., alpha = 0.3, xlab, ylab, title, subtitle, caption, geom = "ribbon", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
gf_ribbon( object = NULL, gformula = NULL, data = NULL, ..., alpha = 0.3, xlab, ylab, title, subtitle, caption, geom = "ribbon", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
object |
When chaining, this holds an object produced in the earlier portions of the chain. Most users can safely ignore this argument. See details and examples. |
gformula |
A formula with shape |
data |
The data to be displayed in this layer. There are three options: If A A |
... |
Additional arguments. Typically these are
(a) ggplot2 aesthetics to be set with |
alpha |
Opacity (0 = invisible, 1 = opaque). |
xlab |
Label for x-axis. See also |
ylab |
Label for y-axis. See also |
title , subtitle , caption
|
Title, sub-title, and caption for the plot.
See also |
geom |
The geometric object to use to display the data, either as a
|
stat |
The statistical transformation to use on the data for this
layer, either as a |
position |
Position adjustment, either as a string naming the adjustment
(e.g. |
show.legend |
logical. Should this layer be included in the legends?
|
show.help |
If |
inherit |
A logical indicating whether default attributes are inherited. |
environment |
An environment in which to look for variables not found in |
gf_ribbon() gf_ribbon(low_temp + high_temp ~ date, data = mosaicData::Weather, fill = ~city, alpha = 0.4) |> gf_theme(theme = theme_minimal()) gf_linerange( low_temp + high_temp ~ date | city ~ ., color = ~high_temp, data = mosaicData::Weather ) |> gf_refine(scale_colour_gradientn(colors = rev(rainbow(5)))) gf_ribbon(low_temp + high_temp ~ date | city ~ ., data = mosaicData::Weather) # Chaining in the data ## Not run: mosaicData::Weather |> gf_ribbon(low_temp + high_temp ~ date, alpha = 0.4) |> gf_facet_grid(city ~ .) ## End(Not run)
gf_ribbon() gf_ribbon(low_temp + high_temp ~ date, data = mosaicData::Weather, fill = ~city, alpha = 0.4) |> gf_theme(theme = theme_minimal()) gf_linerange( low_temp + high_temp ~ date | city ~ ., color = ~high_temp, data = mosaicData::Weather ) |> gf_refine(scale_colour_gradientn(colors = rev(rainbow(5)))) gf_ribbon(low_temp + high_temp ~ date | city ~ ., data = mosaicData::Weather) # Chaining in the data ## Not run: mosaicData::Weather |> gf_ribbon(low_temp + high_temp ~ date, alpha = 0.4) |> gf_facet_grid(city ~ .) ## End(Not run)
Formula interface to ggridges plots
gf_ridgeline( object = NULL, gformula = NULL, data = NULL, ..., height, scale = 1, min_height = 0, color, fill, alpha, group, linetype, linewidth, point_size, point_shape, point_colour, point_fill, point_alpha, point_stroke, xlab, ylab, title, subtitle, caption, geom = "ridgeline", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) gf_density_ridges( object = NULL, gformula = NULL, data = NULL, ..., height, scale = 1, rel_min_height = 0, color, fill, alpha, group, linetype, linewidth, point_size, point_shape, point_colour, point_fill, point_alpha, point_stroke, panel_scaling = TRUE, xlab, ylab, title, subtitle, caption, geom = "density_ridges", stat = "density_ridges", position = "points_sina", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) gf_density_ridges2( object = NULL, gformula = NULL, data = NULL, ..., height, scale = 1, rel_min_height = 0, color, fill, alpha, group, linetype, linewidth, point_size, point_shape, point_colour, point_fill, point_alpha, point_stroke, panel_scaling = TRUE, xlab, ylab, title, subtitle, caption, geom = "density_ridges2", stat = "density_ridges", position = "points_sina", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) gf_density_ridgeline_gradient( object = NULL, gformula = NULL, data = NULL, ..., height, color, fill, alpha, group, linetype, linewidth, gradient_lwd = 0.5, xlab, ylab, title, subtitle, caption, geom = "ridgeline_gradient", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) gf_density_ridges_gradient( object = NULL, gformula = NULL, data = NULL, ..., height, panel_scaling = TRUE, color, fill = ~stat(x), alpha, group, linetype, linewidth, gradient_lwd = 0.5, xlab, ylab, title, subtitle, caption, geom = "density_ridges_gradient", stat = "density_ridges", position = "points_sina", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
gf_ridgeline( object = NULL, gformula = NULL, data = NULL, ..., height, scale = 1, min_height = 0, color, fill, alpha, group, linetype, linewidth, point_size, point_shape, point_colour, point_fill, point_alpha, point_stroke, xlab, ylab, title, subtitle, caption, geom = "ridgeline", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) gf_density_ridges( object = NULL, gformula = NULL, data = NULL, ..., height, scale = 1, rel_min_height = 0, color, fill, alpha, group, linetype, linewidth, point_size, point_shape, point_colour, point_fill, point_alpha, point_stroke, panel_scaling = TRUE, xlab, ylab, title, subtitle, caption, geom = "density_ridges", stat = "density_ridges", position = "points_sina", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) gf_density_ridges2( object = NULL, gformula = NULL, data = NULL, ..., height, scale = 1, rel_min_height = 0, color, fill, alpha, group, linetype, linewidth, point_size, point_shape, point_colour, point_fill, point_alpha, point_stroke, panel_scaling = TRUE, xlab, ylab, title, subtitle, caption, geom = "density_ridges2", stat = "density_ridges", position = "points_sina", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) gf_density_ridgeline_gradient( object = NULL, gformula = NULL, data = NULL, ..., height, color, fill, alpha, group, linetype, linewidth, gradient_lwd = 0.5, xlab, ylab, title, subtitle, caption, geom = "ridgeline_gradient", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) gf_density_ridges_gradient( object = NULL, gformula = NULL, data = NULL, ..., height, panel_scaling = TRUE, color, fill = ~stat(x), alpha, group, linetype, linewidth, gradient_lwd = 0.5, xlab, ylab, title, subtitle, caption, geom = "density_ridges_gradient", stat = "density_ridges", position = "points_sina", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
object |
When chaining, this holds an object produced in the earlier portions of the chain. Most users can safely ignore this argument. See details and examples. |
gformula |
A formula with shape |
data |
The data to be displayed in this layer. There are three options: If A A |
... |
Additional arguments. Typically these are
(a) ggplot2 aesthetics to be set with |
height |
The height of each ridgeline at the respective x value.
Automatically calculated and provided by |
scale |
A scaling factor to scale the height of the ridgelines relative to the spacing between them. A value of 1 indicates that the maximum point of any ridgeline touches the baseline right above, assuming even spacing between baselines. |
min_height |
A height cutoff on the drawn ridgelines. All values that fall below this cutoff will be removed. The main purpose of this cutoff is to remove long tails right at the baseline level, but other uses are possible. The cutoff is applied before any height scaling is applied via the scale aesthetic. Default is 0, so negative values are removed. |
color |
A color or a formula used for mapping color. |
fill |
A color for filling, or a formula used for mapping fill. |
alpha |
Opacity (0 = invisible, 1 = opaque). |
group |
Used for grouping. |
linetype |
A linetype (numeric or "dashed", "dotted", etc.) or a formula used for mapping linetype. |
linewidth |
A numerical line width or a formula used for mapping linewidth. |
point_shape , point_colour , point_size , point_fill , point_alpha , point_stroke
|
As in |
xlab |
Label for x-axis. See also |
ylab |
Label for y-axis. See also |
title , subtitle , caption
|
Title, sub-title, and caption for the plot.
See also |
geom , stat
|
Use to override the default connection between
|
position |
Position adjustment, either as a string naming the adjustment
(e.g. |
show.legend |
logical. Should this layer be included in the legends?
|
show.help |
If |
inherit |
A logical indicating whether default attributes are inherited. |
environment |
An environment in which to look for variables not found in |
rel_min_height |
Lines with heights below this cutoff will be removed. The cutoff is
measured relative to the overall maximum, so |
panel_scaling |
If |
gradient_lwd |
A parameter to needed to remove rendering artifacts inside the rendered gradients. Should ideally be 0, but often needs to be around 0.5 or higher. |
Note that the ggridges::stat_density_ridges()
makes joint density estimation
across all datasets. This may not generate the desired result when using
faceted plots. As an alternative, you can set stat = "density"
to use
ggplot2::stat_density()
. In this case, it is required to add the aesthetic mapping
height = after_stat(density)
(see examples).
ggridges::geom_density_ridges()
ggridges::geom_density_ridges_gradient()
data.frame( x = rep(1:5, 3), y = c(rep(0, 5), rep(1, 5), rep(3, 5)), height = c(0, 1, 3, 4, 0, 1, 2, 3, 5, 4, 0, 5, 4, 4, 1) ) |> gf_ridgeline(y ~ x, height = ~ height, group = ~y, fill = "lightblue", alpha = 0.7) diamonds |> gf_density_ridges(cut ~ price, scale = 2, fill = ~ cut, alpha = 0.6, show.legend = FALSE) |> gf_theme(theme_ridges()) |> gf_refine( scale_y_discrete(expand = c(0.01, 0)), scale_x_continuous(expand = c(0.01, 0)) ) diamonds |> gf_density_ridges(clarity ~ price | cut, scale = 2, fill = ~ clarity, alpha = 0.6, show.legend = FALSE) |> gf_theme(theme_ridges()) |> gf_refine( scale_y_discrete(expand = c(0.01, 0)), scale_x_continuous(expand = c(0.01, 0)) ) ## Not run: diamonds |> gf_density_ridges(clarity ~ price | cut, height = ~after_stat(density), stat = "density", scale = 2, fill = ~ clarity, alpha = 0.6, show.legend = FALSE) |> gf_theme(theme_ridges()) |> gf_refine( scale_y_discrete(expand = c(0.01, 0)), scale_x_continuous(expand = c(0.01, 0)) ) ## End(Not run) ## Not run: diamonds |> gf_density_ridges2(cut ~ price, scale = 2, fill = ~ cut, alpha = 0.6, show.legend = FALSE) |> gf_theme(theme_ridges()) |> gf_refine( scale_y_discrete(expand = c(0.01, 0)), scale_x_continuous(expand = c(0.01, 0)) ) ## End(Not run) diamonds |> gf_density_ridges(cut ~ price, scale = 2, fill = ~ cut, alpha = 0.6, show.legend = FALSE) |> gf_theme(theme_ridges()) |> gf_refine( scale_y_discrete(expand = c(0.01, 0)), scale_x_continuous(expand = c(0.01, 0)) ) diamonds |> gf_density_ridges(clarity ~ price | cut, scale = 2, fill = ~ clarity, alpha = 0.6, show.legend = FALSE) |> gf_theme(theme_ridges()) |> gf_refine( scale_y_discrete(expand = c(0.01, 0)), scale_x_continuous(expand = c(0.01, 0)) ) ## Not run: diamonds |> gf_density_ridges(clarity ~ price | cut, height = ~ after_stat(density), stat = "density", scale = 2, fill = ~ clarity, alpha = 0.6, show.legend = FALSE) |> gf_theme(theme_ridges()) |> gf_refine( scale_y_discrete(expand = c(0.01, 0)), scale_x_continuous(expand = c(0.01, 0)) ) ## End(Not run) ## Not run: mosaicData::Weather |> gf_density_ridges_gradient(month ~ high_temp | city ~ ., fill = ~stat(x), group = ~ month, show.legend = FALSE, rel_min_height = 0.02) |> gf_refine(scale_fill_viridis_c(option = "B"), theme_bw()) ## End(Not run)
data.frame( x = rep(1:5, 3), y = c(rep(0, 5), rep(1, 5), rep(3, 5)), height = c(0, 1, 3, 4, 0, 1, 2, 3, 5, 4, 0, 5, 4, 4, 1) ) |> gf_ridgeline(y ~ x, height = ~ height, group = ~y, fill = "lightblue", alpha = 0.7) diamonds |> gf_density_ridges(cut ~ price, scale = 2, fill = ~ cut, alpha = 0.6, show.legend = FALSE) |> gf_theme(theme_ridges()) |> gf_refine( scale_y_discrete(expand = c(0.01, 0)), scale_x_continuous(expand = c(0.01, 0)) ) diamonds |> gf_density_ridges(clarity ~ price | cut, scale = 2, fill = ~ clarity, alpha = 0.6, show.legend = FALSE) |> gf_theme(theme_ridges()) |> gf_refine( scale_y_discrete(expand = c(0.01, 0)), scale_x_continuous(expand = c(0.01, 0)) ) ## Not run: diamonds |> gf_density_ridges(clarity ~ price | cut, height = ~after_stat(density), stat = "density", scale = 2, fill = ~ clarity, alpha = 0.6, show.legend = FALSE) |> gf_theme(theme_ridges()) |> gf_refine( scale_y_discrete(expand = c(0.01, 0)), scale_x_continuous(expand = c(0.01, 0)) ) ## End(Not run) ## Not run: diamonds |> gf_density_ridges2(cut ~ price, scale = 2, fill = ~ cut, alpha = 0.6, show.legend = FALSE) |> gf_theme(theme_ridges()) |> gf_refine( scale_y_discrete(expand = c(0.01, 0)), scale_x_continuous(expand = c(0.01, 0)) ) ## End(Not run) diamonds |> gf_density_ridges(cut ~ price, scale = 2, fill = ~ cut, alpha = 0.6, show.legend = FALSE) |> gf_theme(theme_ridges()) |> gf_refine( scale_y_discrete(expand = c(0.01, 0)), scale_x_continuous(expand = c(0.01, 0)) ) diamonds |> gf_density_ridges(clarity ~ price | cut, scale = 2, fill = ~ clarity, alpha = 0.6, show.legend = FALSE) |> gf_theme(theme_ridges()) |> gf_refine( scale_y_discrete(expand = c(0.01, 0)), scale_x_continuous(expand = c(0.01, 0)) ) ## Not run: diamonds |> gf_density_ridges(clarity ~ price | cut, height = ~ after_stat(density), stat = "density", scale = 2, fill = ~ clarity, alpha = 0.6, show.legend = FALSE) |> gf_theme(theme_ridges()) |> gf_refine( scale_y_discrete(expand = c(0.01, 0)), scale_x_continuous(expand = c(0.01, 0)) ) ## End(Not run) ## Not run: mosaicData::Weather |> gf_density_ridges_gradient(month ~ high_temp | city ~ ., fill = ~stat(x), group = ~ month, show.legend = FALSE, rel_min_height = 0.02) |> gf_refine(scale_fill_viridis_c(option = "B"), theme_bw()) ## End(Not run)
gf_rugx()
and gf_rugy()
are versions that only add a rug to x- or y- axis.
By default, these functions do not inherit from the formula in the original layer
(because doing so would often result in rugs on both axes), so the formula is required.
gf_rug( object = NULL, gformula = NULL, data = NULL, ..., sides = "bl", alpha, color, group, linetype, linewidth, xlab, ylab, title, subtitle, caption, geom = "rug", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) gf_rugx( object = NULL, gformula = NULL, data = NULL, ..., sides = "b", alpha, color, group, linetype, linewidth, height = 0, xlab, ylab, title, subtitle, caption, geom = "rug", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = FALSE, environment = parent.frame() ) gf_rugy( object = NULL, gformula = NULL, data = NULL, ..., sides = "l", alpha, color, group, linetype, linewidth, width = 0, xlab, ylab, title, subtitle, caption, geom = "rug", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = FALSE, environment = parent.frame() )
gf_rug( object = NULL, gformula = NULL, data = NULL, ..., sides = "bl", alpha, color, group, linetype, linewidth, xlab, ylab, title, subtitle, caption, geom = "rug", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) gf_rugx( object = NULL, gformula = NULL, data = NULL, ..., sides = "b", alpha, color, group, linetype, linewidth, height = 0, xlab, ylab, title, subtitle, caption, geom = "rug", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = FALSE, environment = parent.frame() ) gf_rugy( object = NULL, gformula = NULL, data = NULL, ..., sides = "l", alpha, color, group, linetype, linewidth, width = 0, xlab, ylab, title, subtitle, caption, geom = "rug", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = FALSE, environment = parent.frame() )
object |
When chaining, this holds an object produced in the earlier portions of the chain. Most users can safely ignore this argument. See details and examples. |
gformula |
A formula with shape |
data |
The data to be displayed in this layer. There are three options: If A A |
... |
Additional arguments. Typically these are
(a) ggplot2 aesthetics to be set with |
sides |
A string that controls which sides of the plot the rugs appear on.
It can be set to a string containing any of |
alpha |
Opacity (0 = invisible, 1 = opaque). |
color |
A color or a formula used for mapping color. |
group |
Used for grouping. |
linetype |
A linetype (numeric or "dashed", "dotted", etc.) or a formula used for mapping linetype. |
linewidth |
A numerical line width or a formula used for mapping linewidth. |
xlab |
Label for x-axis. See also |
ylab |
Label for y-axis. See also |
title , subtitle , caption
|
Title, sub-title, and caption for the plot.
See also |
geom |
A character string naming the geom used to make the layer. |
stat |
The statistical transformation to use on the data for this
layer, either as a |
position |
Position adjustment, either as a string naming the adjustment
(e.g. |
show.legend |
logical. Should this layer be included in the legends?
|
show.help |
If |
inherit |
A logical indicating whether default attributes are inherited. |
environment |
An environment in which to look for variables not found in |
height |
amount of vertical jittering when position is jittered. |
width |
amount of horizontal jittering when position is jittered. |
a gg object
Positional attributes (a.k.a, aesthetics) are specified using the formula in gformula
.
Setting and mapping of additional attributes can be done through the
use of additional arguments.
Attributes can be set can be set using arguments of the form attribute = value
or
mapped using arguments of the form attribute = ~ expression
.
In formulas of the form A | B
, B
will be used to form facets using
facet_wrap()
or facet_grid()
.
This provides an alternative to
gf_facet_wrap()
and
gf_facet_grid()
that is terser and may feel more familiar to users
of lattice.
Evaluation of the ggplot2 code occurs in the environment of gformula
.
This will typically do the right thing when formulas are created on the fly, but might not
be the right thing if formulas created in one environment are used to create plots
in another.
data(penguins, package = "palmerpenguins") gf_point(bill_length_mm ~ bill_depth_mm, data = penguins) |> gf_rug(bill_length_mm ~ bill_depth_mm) # There are several ways to control x- and y-rugs separately gf_point(bill_length_mm ~ bill_depth_mm, data = penguins) |> gf_rugx(~bill_depth_mm, data = penguins, color = "red") |> gf_rugy(bill_length_mm ~ ., data = penguins, color = "green") gf_point(bill_length_mm ~ bill_depth_mm, data = penguins) |> gf_rug(. ~ bill_depth_mm, data = penguins, color = "red", inherit = FALSE) |> gf_rug(bill_length_mm ~ ., data = penguins, color = "green", inherit = FALSE) gf_point(bill_length_mm ~ bill_depth_mm, data = penguins) |> gf_rug(. ~ bill_depth_mm, data = penguins, color = "red", sides = "b") |> gf_rug(bill_length_mm ~ ., data = penguins, color = "green", sides = "l") # jitter requires both an x and a y, but we can turn off one or the other with sides gf_jitter(bill_length_mm ~ bill_depth_mm, data = penguins) |> gf_rug(color = "green", sides = "b", position = "jitter") # rugs work with some 1-varialbe plots as well. gf_histogram(~eruptions, data = faithful) |> gf_rug(~eruptions, data = faithful, color = "red") |> gf_rug(~eruptions, data = faithful, color = "navy", sides = "t") # we can take advantage of inheritance to shorten the code gf_histogram(~eruptions, data = faithful) |> gf_rug(color = "red") |> gf_rug(color = "navy", sides = "t") # Need to turn off inheritance when using gf_dhistogram: gf_dhistogram(~eruptions, data = faithful) |> gf_rug(~eruptions, data = faithful, color = "red", inherit = FALSE) # using jitter with gf_histogram() requires manually setting the y value. gf_dhistogram(~bill_depth_mm, data = penguins) |> gf_rug(0 ~ bill_depth_mm, data = penguins, color = "green", sides = "b", position = "jitter") # the choice of y value can affect how the plot looks. gf_dhistogram(~bill_depth_mm, data = penguins) |> gf_rug(0.5 ~ bill_depth_mm, data = penguins, color = "green", sides = "b", position = "jitter")
data(penguins, package = "palmerpenguins") gf_point(bill_length_mm ~ bill_depth_mm, data = penguins) |> gf_rug(bill_length_mm ~ bill_depth_mm) # There are several ways to control x- and y-rugs separately gf_point(bill_length_mm ~ bill_depth_mm, data = penguins) |> gf_rugx(~bill_depth_mm, data = penguins, color = "red") |> gf_rugy(bill_length_mm ~ ., data = penguins, color = "green") gf_point(bill_length_mm ~ bill_depth_mm, data = penguins) |> gf_rug(. ~ bill_depth_mm, data = penguins, color = "red", inherit = FALSE) |> gf_rug(bill_length_mm ~ ., data = penguins, color = "green", inherit = FALSE) gf_point(bill_length_mm ~ bill_depth_mm, data = penguins) |> gf_rug(. ~ bill_depth_mm, data = penguins, color = "red", sides = "b") |> gf_rug(bill_length_mm ~ ., data = penguins, color = "green", sides = "l") # jitter requires both an x and a y, but we can turn off one or the other with sides gf_jitter(bill_length_mm ~ bill_depth_mm, data = penguins) |> gf_rug(color = "green", sides = "b", position = "jitter") # rugs work with some 1-varialbe plots as well. gf_histogram(~eruptions, data = faithful) |> gf_rug(~eruptions, data = faithful, color = "red") |> gf_rug(~eruptions, data = faithful, color = "navy", sides = "t") # we can take advantage of inheritance to shorten the code gf_histogram(~eruptions, data = faithful) |> gf_rug(color = "red") |> gf_rug(color = "navy", sides = "t") # Need to turn off inheritance when using gf_dhistogram: gf_dhistogram(~eruptions, data = faithful) |> gf_rug(~eruptions, data = faithful, color = "red", inherit = FALSE) # using jitter with gf_histogram() requires manually setting the y value. gf_dhistogram(~bill_depth_mm, data = penguins) |> gf_rug(0 ~ bill_depth_mm, data = penguins, color = "green", sides = "b", position = "jitter") # the choice of y value can affect how the plot looks. gf_dhistogram(~bill_depth_mm, data = penguins) |> gf_rug(0.5 ~ bill_depth_mm, data = penguins, color = "green", sides = "b", position = "jitter")
geom_segment()
draws a straight line between points (x, y) and
(xend, yend). geom_curve()
draws a curved line. See the underlying
drawing function grid::curveGrob()
for the parameters that
control the curve.
gf_segment( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, group, linetype, linewidth, arrow = NULL, lineend = "butt", xlab, ylab, title, subtitle, caption, geom = "segment", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
gf_segment( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, group, linetype, linewidth, arrow = NULL, lineend = "butt", xlab, ylab, title, subtitle, caption, geom = "segment", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
object |
When chaining, this holds an object produced in the earlier portions of the chain. Most users can safely ignore this argument. See details and examples. |
gformula |
A formula with shape |
data |
The data to be displayed in this layer. There are three options: If A A |
... |
Additional arguments. Typically these are
(a) ggplot2 aesthetics to be set with |
alpha |
Opacity (0 = invisible, 1 = opaque). |
color |
A color or a formula used for mapping color. |
group |
Used for grouping. |
linetype |
A linetype (numeric or "dashed", "dotted", etc.) or a formula used for mapping linetype. |
linewidth |
A numerical line width or a formula used for mapping linewidth. |
arrow |
specification for arrow heads, as created by |
lineend |
Line end style (round, butt, square). |
xlab |
Label for x-axis. See also |
ylab |
Label for y-axis. See also |
title , subtitle , caption
|
Title, sub-title, and caption for the plot.
See also |
geom |
A character string naming the geom used to make the layer. |
stat |
The statistical transformation to use on the data for this
layer, either as a |
position |
Position adjustment, either as a string naming the adjustment
(e.g. |
show.legend |
logical. Should this layer be included in the legends?
|
show.help |
If |
inherit |
A logical indicating whether default attributes are inherited. |
environment |
An environment in which to look for variables not found in |
a gg object
Positional attributes (a.k.a, aesthetics) are specified using the formula in gformula
.
Setting and mapping of additional attributes can be done through the
use of additional arguments.
Attributes can be set can be set using arguments of the form attribute = value
or
mapped using arguments of the form attribute = ~ expression
.
In formulas of the form A | B
, B
will be used to form facets using
facet_wrap()
or facet_grid()
.
This provides an alternative to
gf_facet_wrap()
and
gf_facet_grid()
that is terser and may feel more familiar to users
of lattice.
Evaluation of the ggplot2 code occurs in the environment of gformula
.
This will typically do the right thing when formulas are created on the fly, but might not
be the right thing if formulas created in one environment are used to create plots
in another.
D <- data.frame(x1 = 2.62, x2 = 3.57, y1 = 21.0, y2 = 15.0) gf_point(mpg ~ wt, data = mtcars) |> gf_curve(y1 + y2 ~ x1 + x2, data = D, color = "navy") |> gf_segment(y1 + y2 ~ x1 + x2, data = D, color = "red")
D <- data.frame(x1 = 2.62, x2 = 3.57, y1 = 21.0, y2 = 15.0) gf_point(mpg ~ wt, data = mtcars) |> gf_curve(y1 + y2 ~ x1 + x2, data = D, color = "navy") |> gf_segment(y1 + y2 ~ x1 + x2, data = D, color = "red")
Mapping with shape files
gf_sf( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, fill, group, linetype, linewidth, geometry, xlab, ylab, title, subtitle, caption, stat = "sf", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
gf_sf( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, fill, group, linetype, linewidth, geometry, xlab, ylab, title, subtitle, caption, stat = "sf", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
object |
When chaining, this holds an object produced in the earlier portions of the chain. Most users can safely ignore this argument. See details and examples. |
gformula |
A formula with shape |
data |
A data frame with the variables to be plotted. |
... |
Additional arguments. Typically these are
(a) ggplot2 aesthetics to be set with |
alpha |
Opacity (0 = invisible, 1 = opaque). |
color |
A color or a formula used for mapping color. |
fill |
A color for filling, or a formula used for mapping fill. |
group |
Used for grouping. |
linetype |
A linetype (numeric or "dashed", "dotted", etc.) or a formula used for mapping linetype. |
linewidth |
A numerical line width or a formula used for mapping linewidth. |
geometry |
A column of class sfc containing simple features data. (Another option
is that |
xlab |
Label for x-axis. See also |
ylab |
Label for y-axis. See also |
title , subtitle , caption
|
Title, sub-title, and caption for the plot.
See also |
stat |
A character string naming the stat used to make the layer. |
position |
Either a character string naming the position function used for the layer or a position object returned from a call to a position function. |
show.legend |
A logical indicating whether this layer should be included in
the legends. |
show.help |
If |
inherit |
A logical indicating whether default attributes are inherited. |
environment |
An environment in which to look for variables not found in |
a gg object
Positional attributes (a.k.a, aesthetics) are specified using the formula in gformula
.
Setting and mapping of additional attributes can be done through the
use of additional arguments.
Attributes can be set can be set using arguments of the form attribute = value
or
mapped using arguments of the form attribute = ~ expression
.
In formulas of the form A | B
, B
will be used to form facets using
facet_wrap()
or facet_grid()
.
This provides an alternative to
gf_facet_wrap()
and
gf_facet_grid()
that is terser and may feel more familiar to users
of lattice.
Evaluation of the ggplot2 code occurs in the environment of gformula
.
This will typically do the right thing when formulas are created on the fly, but might not
be the right thing if formulas created in one environment are used to create plots
in another.
ggplot2::geom_line()
, gf_point()
if (requireNamespace('maps', quietly = TRUE)) { library(maps) world1 <- sf::st_as_sf(map('world', plot = FALSE, fill = TRUE)) gf_sf(data = world1) } if (requireNamespace('maps', quietly = TRUE)) { world2 <- sf::st_transform( world1, "+proj=laea +y_0=0 +lon_0=155 +lat_0=-90 +ellps=WGS84 +no_defs" ) gf_sf(data = world2) }
if (requireNamespace('maps', quietly = TRUE)) { library(maps) world1 <- sf::st_as_sf(map('world', plot = FALSE, fill = TRUE)) gf_sf(data = world1) } if (requireNamespace('maps', quietly = TRUE)) { world2 <- sf::st_transform( world1, "+proj=laea +y_0=0 +lon_0=155 +lat_0=-90 +ellps=WGS84 +no_defs" ) gf_sf(data = world2) }
The sina plot is a data visualization chart suitable for plotting any single variable in a multiclass dataset. It is an enhanced jitter strip chart, where the width of the jitter is controlled by the density distribution of the data within each class.
gf_sina( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, size, fill, group, xlab, ylab, title, subtitle, caption, geom = "point", stat = "sina", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
gf_sina( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, size, fill, group, xlab, ylab, title, subtitle, caption, geom = "point", stat = "sina", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
object |
When chaining, this holds an object produced in the earlier portions of the chain. Most users can safely ignore this argument. See details and examples. |
gformula |
A formula with shape |
data |
The data to be displayed in this layer. There are three options: If A A |
... |
Other arguments passed on to |
alpha |
Opacity (0 = invisible, 1 = opaque). |
color |
A color or a formula used for mapping color. |
size |
A numeric size or a formula used for mapping size. |
fill |
A color for filling, or a formula used for mapping fill. |
group |
Used for grouping. |
xlab |
Label for x-axis. See also |
ylab |
Label for y-axis. See also |
title , subtitle , caption
|
Title, sub-title, and caption for the plot.
See also |
geom |
The geometric object to use to display the data, either as a
|
stat |
The statistical transformation to use on the data for this
layer, either as a |
position |
Position adjustment, either as a string naming the adjustment
(e.g. |
show.legend |
logical. Should this layer be included in the legends?
|
show.help |
If |
inherit |
A logical indicating whether default attributes are inherited. |
environment |
An environment in which to look for variables not found in |
a gg object
Positional attributes (a.k.a, aesthetics) are specified using the formula in gformula
.
Setting and mapping of additional attributes can be done through the
use of additional arguments.
Attributes can be set can be set using arguments of the form attribute = value
or
mapped using arguments of the form attribute = ~ expression
.
In formulas of the form A | B
, B
will be used to form facets using
facet_wrap()
or facet_grid()
.
This provides an alternative to
gf_facet_wrap()
and
gf_facet_grid()
that is terser and may feel more familiar to users
of lattice.
Evaluation of the ggplot2 code occurs in the environment of gformula
.
This will typically do the right thing when formulas are created on the fly, but might not
be the right thing if formulas created in one environment are used to create plots
in another.
## Not run: library(ggforce) gf_sina(age ~ substance, data = mosaicData::HELPrct) ## End(Not run)
## Not run: library(ggforce) gf_sina(age ~ substance, data = mosaicData::HELPrct) ## End(Not run)
LOESS and linear model smoothers in ggformula
.
gf_smooth( object = NULL, gformula = NULL, data = NULL, ..., method = "auto", formula = y ~ x, se = FALSE, method.args, n = 80, span = 0.75, fullrange = FALSE, level = 0.95, xlab, ylab, title, subtitle, caption, geom = "smooth", stat = "smooth", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) gf_lm( object = NULL, gformula = NULL, data = NULL, ..., alpha = 0.3, lm.args = list(), interval = "none", level = 0.95, fullrange = TRUE, xlab, ylab, title, subtitle, caption, geom = "lm", stat = "lm", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
gf_smooth( object = NULL, gformula = NULL, data = NULL, ..., method = "auto", formula = y ~ x, se = FALSE, method.args, n = 80, span = 0.75, fullrange = FALSE, level = 0.95, xlab, ylab, title, subtitle, caption, geom = "smooth", stat = "smooth", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) gf_lm( object = NULL, gformula = NULL, data = NULL, ..., alpha = 0.3, lm.args = list(), interval = "none", level = 0.95, fullrange = TRUE, xlab, ylab, title, subtitle, caption, geom = "lm", stat = "lm", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
object |
When chaining, this holds an object produced in the earlier portions of the chain. Most users can safely ignore this argument. See details and examples. |
gformula |
A formula with shape |
data |
A data frame with the variables to be plotted. |
... |
Additional arguments. Typically these are
(a) ggplot2 aesthetics to be set with |
method |
Smoothing method (function) to use, accepts either
For If you have fewer than 1,000 observations but want to use the same |
formula |
Formula to use in smoothing function, eg. |
se |
Display confidence interval around smooth? ( |
method.args |
List of additional arguments passed on to the modelling
function defined by |
n |
Number of points at which to evaluate smoother. |
span |
Controls the amount of smoothing for the default loess smoother.
Smaller numbers produce wigglier lines, larger numbers produce smoother
lines. Only used with loess, i.e. when |
fullrange |
If |
level |
Level of confidence interval to use (0.95 by default). |
xlab |
Label for x-axis. See also |
ylab |
Label for y-axis. See also |
title , subtitle , caption
|
Title, sub-title, and caption for the plot.
See also |
geom |
A character string naming the geom used to make the layer. |
stat |
A character string naming the stat used to make the layer. |
position |
Either a character string naming the position function used for the layer or a position object returned from a call to a position function. |
show.legend |
A logical indicating whether this layer should be included in
the legends. |
show.help |
If |
inherit |
A logical indicating whether default attributes are inherited. |
environment |
An environment in which to look for variables not found in |
alpha |
Opacity (0 = invisible, 1 = opaque). |
lm.args |
A list of arguments to |
interval |
One of |
a gg object
Positional attributes (a.k.a, aesthetics) are specified using the formula in gformula
.
Setting and mapping of additional attributes can be done through the
use of additional arguments.
Attributes can be set can be set using arguments of the form attribute = value
or
mapped using arguments of the form attribute = ~ expression
.
In formulas of the form A | B
, B
will be used to form facets using
facet_wrap()
or facet_grid()
.
This provides an alternative to
gf_facet_wrap()
and
gf_facet_grid()
that is terser and may feel more familiar to users
of lattice.
Evaluation of the ggplot2 code occurs in the environment of gformula
.
This will typically do the right thing when formulas are created on the fly, but might not
be the right thing if formulas created in one environment are used to create plots
in another.
ggplot2::geom_smooth()
, gf_spline()
gf_smooth() gf_lm() gf_smooth(births ~ date, color = ~wday, data = mosaicData::Births78) gf_smooth(births ~ date, color = ~wday, data = mosaicData::Births78, fullrange = TRUE ) gf_smooth(births ~ date, color = ~wday, data = mosaicData::Births78, show.legend = FALSE, se = FALSE ) gf_smooth(births ~ date, color = ~wday, data = mosaicData::Births78, show.legend = FALSE, se = TRUE ) gf_lm(length ~ width, data = mosaicData::KidsFeet, color = ~biggerfoot, alpha = 0.2 ) |> gf_point() gf_lm(length ~ width, data = mosaicData::KidsFeet, color = ~biggerfoot, fullrange = FALSE, alpha = 0.2 ) gf_point() gf_lm(length ~ width, color = ~sex, data = mosaicData::KidsFeet, formula = y ~ poly(x, 2), linetype = "dashed" ) |> gf_point() gf_lm(length ~ width, color = ~sex, data = mosaicData::KidsFeet, formula = log(y) ~ x, backtrans = exp ) |> gf_point() gf_lm(hwy ~ displ, data = mpg, formula = log(y) ~ poly(x, 3), backtrans = exp, interval = "prediction", fill = "skyblue" ) |> gf_lm( formula = log(y) ~ poly(x, 3), backtrans = exp, interval = "confidence", color = "red" ) |> gf_point() clotting <- data.frame( u = c(5,10,15,20,30,40,60,80,100), lot1 = c(118,58,42,35,27,25,21,19,18), lot2 = c(69,35,26,21,18,16,13,12,12)) gf_point(lot1 ~ u, data = clotting) |> gf_smooth(formula = y ~ log(x), method = "glm", method.args = list(family = Gamma)) gf_point(lot2 ~ u, data = clotting) |> gf_smooth(formula = y ~ log(x), color = "red", method = "glm", method.args = list(family = Gamma))
gf_smooth() gf_lm() gf_smooth(births ~ date, color = ~wday, data = mosaicData::Births78) gf_smooth(births ~ date, color = ~wday, data = mosaicData::Births78, fullrange = TRUE ) gf_smooth(births ~ date, color = ~wday, data = mosaicData::Births78, show.legend = FALSE, se = FALSE ) gf_smooth(births ~ date, color = ~wday, data = mosaicData::Births78, show.legend = FALSE, se = TRUE ) gf_lm(length ~ width, data = mosaicData::KidsFeet, color = ~biggerfoot, alpha = 0.2 ) |> gf_point() gf_lm(length ~ width, data = mosaicData::KidsFeet, color = ~biggerfoot, fullrange = FALSE, alpha = 0.2 ) gf_point() gf_lm(length ~ width, color = ~sex, data = mosaicData::KidsFeet, formula = y ~ poly(x, 2), linetype = "dashed" ) |> gf_point() gf_lm(length ~ width, color = ~sex, data = mosaicData::KidsFeet, formula = log(y) ~ x, backtrans = exp ) |> gf_point() gf_lm(hwy ~ displ, data = mpg, formula = log(y) ~ poly(x, 3), backtrans = exp, interval = "prediction", fill = "skyblue" ) |> gf_lm( formula = log(y) ~ poly(x, 3), backtrans = exp, interval = "confidence", color = "red" ) |> gf_point() clotting <- data.frame( u = c(5,10,15,20,30,40,60,80,100), lot1 = c(118,58,42,35,27,25,21,19,18), lot2 = c(69,35,26,21,18,16,13,12,12)) gf_point(lot1 ~ u, data = clotting) |> gf_smooth(formula = y ~ log(x), method = "glm", method.args = list(family = Gamma)) gf_point(lot2 ~ u, data = clotting) |> gf_smooth(formula = y ~ log(x), color = "red", method = "glm", method.args = list(family = Gamma))
Fitting splines in ggformula
.
gf_spline( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, group, linetype, linewidth, weight, df, spar, tol, xlab, ylab, title, subtitle, caption, geom = "line", stat = "spline", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
gf_spline( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, group, linetype, linewidth, weight, df, spar, tol, xlab, ylab, title, subtitle, caption, geom = "line", stat = "spline", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
object |
When chaining, this holds an object produced in the earlier portions of the chain. Most users can safely ignore this argument. See details and examples. |
gformula |
A formula with shape |
data |
A data frame with the variables to be plotted. |
... |
Additional arguments. Typically these are
(a) ggplot2 aesthetics to be set with |
alpha |
Opacity (0 = invisible, 1 = opaque). |
color |
A color or a formula used for mapping color. |
group |
Used for grouping. |
linetype |
A linetype (numeric or "dashed", "dotted", etc.) or a formula used for mapping linetype. |
linewidth |
A numerical line width or a formula used for mapping linewidth. |
weight |
An optional vector of weights.
See |
df |
desired equivalent degrees of freedom.
See |
spar |
A smoothing parameter, typically in (0,1].
See |
tol |
A tolerance for sameness or uniqueness of the |
xlab |
Label for x-axis. See also |
ylab |
Label for y-axis. See also |
title , subtitle , caption
|
Title, sub-title, and caption for the plot.
See also |
geom |
A character string naming the geom used to make the layer. |
stat |
A character string naming the stat used to make the layer. |
position |
Either a character string naming the position function used for the layer or a position object returned from a call to a position function. |
show.legend |
A logical indicating whether this layer should be included in
the legends. |
show.help |
If |
inherit |
A logical indicating whether default attributes are inherited. |
environment |
An environment in which to look for variables not found in |
a gg object
Positional attributes (a.k.a, aesthetics) are specified using the formula in gformula
.
Setting and mapping of additional attributes can be done through the
use of additional arguments.
Attributes can be set can be set using arguments of the form attribute = value
or
mapped using arguments of the form attribute = ~ expression
.
In formulas of the form A | B
, B
will be used to form facets using
facet_wrap()
or facet_grid()
.
This provides an alternative to
gf_facet_wrap()
and
gf_facet_grid()
that is terser and may feel more familiar to users
of lattice.
Evaluation of the ggplot2 code occurs in the environment of gformula
.
This will typically do the right thing when formulas are created on the fly, but might not
be the right thing if formulas created in one environment are used to create plots
in another.
geom_spline()
, gf_smooth()
, gf_lm()
gf_spline(births ~ date, color = ~wday, data = mosaicData::Births78) gf_spline(births ~ date, color = ~wday, data = mosaicData::Births78, df = 20) gf_spline(births ~ date, color = ~wday, data = mosaicData::Births78, df = 4)
gf_spline(births ~ date, color = ~wday, data = mosaicData::Births78) gf_spline(births ~ date, color = ~wday, data = mosaicData::Births78, df = 20) gf_spline(births ~ date, color = ~wday, data = mosaicData::Births78, df = 4)
This is a polar parameterisation of geom_segment. It is useful when you have variables that describe direction and distance.
gf_spoke( object = NULL, gformula = NULL, data = NULL, ..., angle, radius, alpha, color, group, linetype, linewidth, xlab, ylab, title, subtitle, caption, geom = "spoke", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
gf_spoke( object = NULL, gformula = NULL, data = NULL, ..., angle, radius, alpha, color, group, linetype, linewidth, xlab, ylab, title, subtitle, caption, geom = "spoke", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
object |
When chaining, this holds an object produced in the earlier portions of the chain. Most users can safely ignore this argument. See details and examples. |
gformula |
A formula with shape |
data |
The data to be displayed in this layer. There are three options: If A A |
... |
Additional arguments. Typically these are
(a) ggplot2 aesthetics to be set with |
angle |
The angle at which segment leaves the point (x,y). |
radius |
The length of the segment. |
alpha |
Opacity (0 = invisible, 1 = opaque). |
color |
A color or a formula used for mapping color. |
group |
Used for grouping. |
linetype |
A linetype (numeric or "dashed", "dotted", etc.) or a formula used for mapping linetype. |
linewidth |
A numerical line width or a formula used for mapping linewidth. |
xlab |
Label for x-axis. See also |
ylab |
Label for y-axis. See also |
title , subtitle , caption
|
Title, sub-title, and caption for the plot.
See also |
geom |
A character string naming the geom used to make the layer. |
stat |
The statistical transformation to use on the data for this
layer, either as a |
position |
Position adjustment, either as a string naming the adjustment
(e.g. |
show.legend |
logical. Should this layer be included in the legends?
|
show.help |
If |
inherit |
A logical indicating whether default attributes are inherited. |
environment |
An environment in which to look for variables not found in |
a gg object
Positional attributes (a.k.a, aesthetics) are specified using the formula in gformula
.
Setting and mapping of additional attributes can be done through the
use of additional arguments.
Attributes can be set can be set using arguments of the form attribute = value
or
mapped using arguments of the form attribute = ~ expression
.
In formulas of the form A | B
, B
will be used to form facets using
facet_wrap()
or facet_grid()
.
This provides an alternative to
gf_facet_wrap()
and
gf_facet_grid()
that is terser and may feel more familiar to users
of lattice.
Evaluation of the ggplot2 code occurs in the environment of gformula
.
This will typically do the right thing when formulas are created on the fly, but might not
be the right thing if formulas created in one environment are used to create plots
in another.
SomeData <- expand.grid(x = 1:10, y = 1:10) SomeData$angle <- runif(100, 0, 2 * pi) SomeData$speed <- runif(100, 0, sqrt(0.1 * SomeData$x)) gf_point(y ~ x, data = SomeData) |> gf_spoke(y ~ x, angle = ~angle, radius = 0.5) gf_point(y ~ x, data = SomeData) |> gf_spoke(y ~ x, angle = ~angle, radius = ~speed)
SomeData <- expand.grid(x = 1:10, y = 1:10) SomeData$angle <- runif(100, 0, 2 * pi) SomeData$speed <- runif(100, 0, sqrt(0.1 * SomeData$x)) gf_point(y ~ x, data = SomeData) |> gf_spoke(y ~ x, angle = ~angle, radius = 0.5) gf_point(y ~ x, data = SomeData) |> gf_spoke(y ~ x, angle = ~angle, radius = ~speed)
geom_path()
connects the observations in the order in which they appear
in the data. geom_line()
connects them in order of the variable on the
x axis. geom_step()
creates a stairstep plot, highlighting exactly
when changes occur. The group
aesthetic determines which cases are
connected together.
gf_step( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, group, linetype, linewidth, direction = "hv", xlab, ylab, title, subtitle, caption, geom = "step", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
gf_step( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, group, linetype, linewidth, direction = "hv", xlab, ylab, title, subtitle, caption, geom = "step", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
object |
When chaining, this holds an object produced in the earlier portions of the chain. Most users can safely ignore this argument. See details and examples. |
gformula |
A formula with shape |
data |
The data to be displayed in this layer. There are three options: If A A |
... |
Additional arguments. Typically these are
(a) ggplot2 aesthetics to be set with |
alpha |
Opacity (0 = invisible, 1 = opaque). |
color |
A color or a formula used for mapping color. |
group |
Used for grouping. |
linetype |
A linetype (numeric or "dashed", "dotted", etc.) or a formula used for mapping linetype. |
linewidth |
A numerical line width or a formula used for mapping linewidth. |
direction |
direction of stairs: 'vh' for vertical then horizontal, 'hv' for horizontal then vertical, or 'mid' for step half-way between adjacent x-values. |
xlab |
Label for x-axis. See also |
ylab |
Label for y-axis. See also |
title , subtitle , caption
|
Title, sub-title, and caption for the plot.
See also |
geom |
A character string naming the geom used to make the layer. |
stat |
The statistical transformation to use on the data for this
layer, either as a |
position |
Position adjustment, either as a string naming the adjustment
(e.g. |
show.legend |
logical. Should this layer be included in the legends?
|
show.help |
If |
inherit |
A logical indicating whether default attributes are inherited. |
environment |
An environment in which to look for variables not found in |
a gg object
Positional attributes (a.k.a, aesthetics) are specified using the formula in gformula
.
Setting and mapping of additional attributes can be done through the
use of additional arguments.
Attributes can be set can be set using arguments of the form attribute = value
or
mapped using arguments of the form attribute = ~ expression
.
In formulas of the form A | B
, B
will be used to form facets using
facet_wrap()
or facet_grid()
.
This provides an alternative to
gf_facet_wrap()
and
gf_facet_grid()
that is terser and may feel more familiar to users
of lattice.
Evaluation of the ggplot2 code occurs in the environment of gformula
.
This will typically do the right thing when formulas are created on the fly, but might not
be the right thing if formulas created in one environment are used to create plots
in another.
gf_step(births ~ date, data = mosaicData::Births78, color = ~wday) # Roll your own Kaplan-Meier plot if (require(survival) && require(broom)) { # fit a survival model surv_fit <- survfit(coxph(Surv(time, status) ~ age + sex, lung)) surv_fit # use broom::tidy() to create a tidy data frame for plotting surv_df <- tidy(surv_fit) head(surv_df) # now create a plot surv_df |> gf_step(estimate ~ time) |> gf_ribbon(conf.low + conf.high ~ time, alpha = 0.2) }
gf_step(births ~ date, data = mosaicData::Births78, color = ~wday) # Roll your own Kaplan-Meier plot if (require(survival) && require(broom)) { # fit a survival model surv_fit <- survfit(coxph(Surv(time, status) ~ age + sex, lung)) surv_fit # use broom::tidy() to create a tidy data frame for plotting surv_df <- tidy(surv_fit) head(surv_df) # now create a plot surv_df |> gf_step(estimate ~ time) |> gf_ribbon(conf.low + conf.high ~ time, alpha = 0.2) }
Text geoms are useful for labeling plots. They can be used by themselves as
scatterplots or in combination with other geoms, for example, for labeling
points or for annotating the height of bars. geom_text()
adds only text
to the plot. geom_label()
draws a rectangle behind the text, making it
easier to read.
gf_text( object = NULL, gformula = NULL, data = NULL, ..., label, alpha, angle, color, family, fontface, group, hjust, lineheight, size, vjust, parse = FALSE, nudge_x = 0, nudge_y = 0, check_overlap = FALSE, xlab, ylab, title, subtitle, caption, geom = "text", stat = "identity", position = "nudge", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) gf_label( object = NULL, gformula = NULL, data = NULL, ..., label, alpha, angle, color, family, fontface, group, hjust, vjust, lineheight, size, parse, nudge_x = 0, nudge_y = 0, label.padding = unit(0.25, "lines"), label.r = unit(0.15, "lines"), label.size = 0.25, xlab, ylab, title, subtitle, caption, stat = "identity", position = "nudge", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
gf_text( object = NULL, gformula = NULL, data = NULL, ..., label, alpha, angle, color, family, fontface, group, hjust, lineheight, size, vjust, parse = FALSE, nudge_x = 0, nudge_y = 0, check_overlap = FALSE, xlab, ylab, title, subtitle, caption, geom = "text", stat = "identity", position = "nudge", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() ) gf_label( object = NULL, gformula = NULL, data = NULL, ..., label, alpha, angle, color, family, fontface, group, hjust, vjust, lineheight, size, parse, nudge_x = 0, nudge_y = 0, label.padding = unit(0.25, "lines"), label.r = unit(0.15, "lines"), label.size = 0.25, xlab, ylab, title, subtitle, caption, stat = "identity", position = "nudge", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
object |
When chaining, this holds an object produced in the earlier portions of the chain. Most users can safely ignore this argument. See details and examples. |
gformula |
A formula with shape |
data |
The data to be displayed in this layer. There are three options: If A A |
... |
Additional arguments. Typically these are
(a) ggplot2 aesthetics to be set with |
label |
The text to be displayed. |
alpha |
Opacity (0 = invisible, 1 = opaque). |
angle |
An angle for rotating the text. |
color |
A color or a formula used for mapping color. |
family |
A font family. |
fontface |
One of |
group |
Used for grouping. |
hjust , vjust
|
Numbers between 0 and 1 indicating how to justify text relative the the specified location. |
lineheight |
Line height. |
size |
A numeric size or a formula used for mapping size. |
parse |
If |
nudge_x , nudge_y
|
Horizontal and vertical adjustment to nudge labels by.
Useful for offsetting text from points, particularly on discrete scales.
Cannot be jointly specified with |
check_overlap |
If |
xlab |
Label for x-axis. See also |
ylab |
Label for y-axis. See also |
title , subtitle , caption
|
Title, sub-title, and caption for the plot.
See also |
geom |
A character string naming the geom used to make the layer. |
stat |
The statistical transformation to use on the data for this
layer, either as a |
position |
Position adjustment, either as a string, or the result of
a call to a position adjustment function. Cannot be jointly specified with
|
show.legend |
logical. Should this layer be included in the legends?
|
show.help |
If |
inherit |
A logical indicating whether default attributes are inherited. |
environment |
An environment in which to look for variables not found in |
label.padding |
Amount of padding around label. Defaults to 0.25 lines. |
label.r |
Radius of rounded corners. Defaults to 0.15 lines. |
label.size |
Size of label border, in mm. |
a gg object
Positional attributes (a.k.a, aesthetics) are specified using the formula in gformula
.
Setting and mapping of additional attributes can be done through the
use of additional arguments.
Attributes can be set can be set using arguments of the form attribute = value
or
mapped using arguments of the form attribute = ~ expression
.
In formulas of the form A | B
, B
will be used to form facets using
facet_wrap()
or facet_grid()
.
This provides an alternative to
gf_facet_wrap()
and
gf_facet_grid()
that is terser and may feel more familiar to users
of lattice.
Evaluation of the ggplot2 code occurs in the environment of gformula
.
This will typically do the right thing when formulas are created on the fly, but might not
be the right thing if formulas created in one environment are used to create plots
in another.
data(penguins, package = "palmerpenguins") gf_text(bill_length_mm ~ bill_depth_mm, data = penguins, label = ~species, color = ~species, size = 2, angle = 30 ) penguins |> gf_point(bill_length_mm ~ bill_depth_mm, color = ~species, alpha = 0.5) |> gf_text(bill_length_mm ~ bill_depth_mm, label = ~species, color = ~species, size = 2, angle = 0, hjust = 0, nudge_x = 0.1, nudge_y = 0.1 ) if (require(dplyr)) { data(penguins, package = "palmerpenguins") penguins_means <- penguins |> group_by(species) |> summarise(bill_length_mm = mean(bill_length_mm), bill_depth_mm = mean(bill_depth_mm)) gf_point(bill_length_mm ~ bill_depth_mm, data = penguins, color = ~species) |> gf_label(bill_length_mm ~ bill_depth_mm, data = penguins_means, label = ~species, color = ~species, size = 2, alpha = 0.7 ) }
data(penguins, package = "palmerpenguins") gf_text(bill_length_mm ~ bill_depth_mm, data = penguins, label = ~species, color = ~species, size = 2, angle = 30 ) penguins |> gf_point(bill_length_mm ~ bill_depth_mm, color = ~species, alpha = 0.5) |> gf_text(bill_length_mm ~ bill_depth_mm, label = ~species, color = ~species, size = 2, angle = 0, hjust = 0, nudge_x = 0.1, nudge_y = 0.1 ) if (require(dplyr)) { data(penguins, package = "palmerpenguins") penguins_means <- penguins |> group_by(species) |> summarise(bill_length_mm = mean(bill_length_mm), bill_depth_mm = mean(bill_depth_mm)) gf_point(bill_length_mm ~ bill_depth_mm, data = penguins, color = ~species) |> gf_label(bill_length_mm ~ bill_depth_mm, data = penguins_means, label = ~species, color = ~species, size = 2, alpha = 0.7 ) }
Themes for ggformula
gf_theme(object, theme, ...)
gf_theme(object, theme, ...)
object |
a gg object |
theme |
a ggplot2 theme function like |
... |
If |
a modified gg object
geom_rect()
and geom_tile()
do the same thing, but are
parameterised differently: geom_rect()
uses the locations of the four
corners (xmin
, xmax
, ymin
and ymax
), while
geom_tile()
uses the center of the tile and its size (x
,
y
, width
, height
). geom_raster()
is a high
performance special case for when all the tiles are the same size.
gf_tile( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, fill, group, linetype, linewidth, xlab, ylab, title, subtitle, caption, geom = "tile", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
gf_tile( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, fill, group, linetype, linewidth, xlab, ylab, title, subtitle, caption, geom = "tile", stat = "identity", position = "identity", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
object |
When chaining, this holds an object produced in the earlier portions of the chain. Most users can safely ignore this argument. See details and examples. |
gformula |
A formula with shape |
data |
A data frame with the variables to be plotted. |
... |
Additional arguments. Typically these are
(a) ggplot2 aesthetics to be set with |
alpha |
Opacity (0 = invisible, 1 = opaque). |
color |
A color or a formula used for mapping color. |
fill |
A color for filling, or a formula used for mapping fill. |
group |
Used for grouping. |
linetype |
A linetype (numeric or "dashed", "dotted", etc.) or a formula used for mapping linetype. |
linewidth |
A numerical line width or a formula used for mapping linewidth. |
xlab |
Label for x-axis. See also |
ylab |
Label for y-axis. See also |
title , subtitle , caption
|
Title, sub-title, and caption for the plot.
See also |
geom |
A character string naming the geom used to make the layer. |
stat |
A character string naming the stat used to make the layer. |
position |
Either a character string naming the position function used for the layer or a position object returned from a call to a position function. |
show.legend |
A logical indicating whether this layer should be included in
the legends. |
show.help |
If |
inherit |
A logical indicating whether default attributes are inherited. |
environment |
An environment in which to look for variables not found in |
a gg object
Positional attributes (a.k.a, aesthetics) are specified using the formula in gformula
.
Setting and mapping of additional attributes can be done through the
use of additional arguments.
Attributes can be set can be set using arguments of the form attribute = value
or
mapped using arguments of the form attribute = ~ expression
.
In formulas of the form A | B
, B
will be used to form facets using
facet_wrap()
or facet_grid()
.
This provides an alternative to
gf_facet_wrap()
and
gf_facet_grid()
that is terser and may feel more familiar to users
of lattice.
Positional attributes (a.k.a, aesthetics) are specified using the formula in gformula
.
Setting and mapping of additional attributes can be done through the
use of additional arguments.
Attributes can be set can be set using arguments of the form attribute = value
or
mapped using arguments of the form attribute = ~ expression
.
In formulas of the form A | B
, B
will be used to form facets using
facet_wrap()
or facet_grid()
.
This provides an alternative to
gf_facet_wrap()
and
gf_facet_grid()
that is terser and may feel more familiar to users
of lattice.
Evaluation of the ggplot2 code occurs in the environment of gformula
.
This will typically do the right thing when formulas are created on the fly, but might not
be the right thing if formulas created in one environment are used to create plots
in another.
Evaluation of the ggplot2 code occurs in the environment of gformula
.
This will typically do the right thing when formulas are created on the fly, but might not
be the right thing if formulas created in one environment are used to create plots
in another.
D <- expand.grid(x = 0:5, y = 0:5) D$z <- runif(nrow(D)) gf_tile(y ~ x, fill = ~z, data = D) gf_tile(z ~ x + y, data = D)
D <- expand.grid(x = 0:5, y = 0:5) D$z <- runif(nrow(D)) gf_tile(y ~ x, fill = ~z, data = D) gf_tile(z ~ x + y, data = D)
A violin plot is a compact display of a continuous distribution. It is a
blend of geom_boxplot()
and geom_density()
: a
violin plot is a mirrored density plot displayed in the same way as a
boxplot.
gf_violin( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, fill, group, linetype, linewidth, weight, draw_quantiles = NULL, trim = TRUE, scale = "area", bw, adjust = 1, kernel = "gaussian", xlab, ylab, title, subtitle, caption, geom = "violin", stat = "ydensity", position = "dodge", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
gf_violin( object = NULL, gformula = NULL, data = NULL, ..., alpha, color, fill, group, linetype, linewidth, weight, draw_quantiles = NULL, trim = TRUE, scale = "area", bw, adjust = 1, kernel = "gaussian", xlab, ylab, title, subtitle, caption, geom = "violin", stat = "ydensity", position = "dodge", show.legend = NA, show.help = NULL, inherit = TRUE, environment = parent.frame() )
object |
When chaining, this holds an object produced in the earlier portions of the chain. Most users can safely ignore this argument. See details and examples. |
gformula |
A formula with shape |
data |
The data to be displayed in this layer. There are three options: If A A |
... |
Additional arguments. Typically these are
(a) ggplot2 aesthetics to be set with |
alpha |
Opacity (0 = invisible, 1 = opaque). |
color |
A color or a formula used for mapping color. |
fill |
A color for filling, or a formula used for mapping fill. |
group |
Used for grouping. |
linetype |
A linetype (numeric or "dashed", "dotted", etc.) or a formula used for mapping linetype. |
linewidth |
A numerical line width or a formula used for mapping linewidth. |
weight |
Useful for summarized data, |
draw_quantiles |
If |
trim |
If |
scale |
if "area" (default), all violins have the same area (before trimming the tails). If "count", areas are scaled proportionally to the number of observations. If "width", all violins have the same maximum width. |
bw |
The smoothing bandwidth to be used.
If numeric, the standard deviation of the smoothing kernel.
If character, a rule to choose the bandwidth, as listed in
|
adjust |
A multiplicate bandwidth adjustment. This makes it possible
to adjust the bandwidth while still using the a bandwidth estimator.
For example, |
kernel |
Kernel. See list of available kernels in |
xlab |
Label for x-axis. See also |
ylab |
Label for y-axis. See also |
title , subtitle , caption
|
Title, sub-title, and caption for the plot.
See also |
geom , stat
|
Use to override the default connection between
|
position |
Position adjustment, either as a string naming the adjustment
(e.g. |
show.legend |
logical. Should this layer be included in the legends?
|
show.help |
If |
inherit |
A logical indicating whether default attributes are inherited. |
environment |
An environment in which to look for variables not found in |
a gg object
Positional attributes (a.k.a, aesthetics) are specified using the formula in gformula
.
Setting and mapping of additional attributes can be done through the
use of additional arguments.
Attributes can be set can be set using arguments of the form attribute = value
or
mapped using arguments of the form attribute = ~ expression
.
In formulas of the form A | B
, B
will be used to form facets using
facet_wrap()
or facet_grid()
.
This provides an alternative to
gf_facet_wrap()
and
gf_facet_grid()
that is terser and may feel more familiar to users
of lattice.
Evaluation of the ggplot2 code occurs in the environment of gformula
.
This will typically do the right thing when formulas are created on the fly, but might not
be the right thing if formulas created in one environment are used to create plots
in another.
Hintze, J. L., Nelson, R. D. (1998) Violin Plots: A Box Plot-Density Trace Synergism. The American Statistician 52, 181-184.
gf_violin(age ~ substance, data = mosaicData::HELPrct) gf_violin(age ~ substance, data = mosaicData::HELPrct, fill = ~sex)
gf_violin(age ~ substance, data = mosaicData::HELPrct) gf_violin(age ~ substance, data = mosaicData::HELPrct, fill = ~sex)
Primarily intended for package developers, this function factory is used to create the layer functions in the ggformula package.
layer_factory( geom = "point", position = "identity", stat = "identity", pre = { }, aes_form = y ~ x, extras = alist(), note = NULL, aesthetics = aes(), inherit.aes = TRUE, check.aes = TRUE, data = NULL, layer_fun = quo(ggplot2::layer), ... )
layer_factory( geom = "point", position = "identity", stat = "identity", pre = { }, aes_form = y ~ x, extras = alist(), note = NULL, aesthetics = aes(), inherit.aes = TRUE, check.aes = TRUE, data = NULL, layer_fun = quo(ggplot2::layer), ... )
geom |
The geom to use for the layer (may be specified as a string). |
position |
The position function to use for the layer (may be specified as a string). |
stat |
The stat function to use for the layer (may be specified as a string). |
pre |
code to run as a "pre-process". |
aes_form |
A single formula or a list of formulas specifying
how attributes are inferred from the formula. Use |
extras |
An alist of additional arguments (potentially with defaults) |
note |
A note to add to the quick help. |
aesthetics |
Additional aesthetics (typically created using
|
inherit.aes |
A logical indicating whether aesthetics should be inherited from prior layers or a vector of character names of aesthetics to inherit. |
check.aes |
A logical indicating whether a warning should be emited when aesthetics provided don't match what is expected. |
data |
A data frame or |
layer_fun |
The function used to create the layer or a quosure that evaluates to such a function. |
... |
Additional arguments. |
A function.
Population of Michigan counties
data(MIpop)
data(MIpop)
A data frame with populations of Michigan counties.
Population rank.
County name.
Population (2010 census).
Transform a vector of counts and a vector of groups into a vector of proportions or percentages within groups.
percs_by_group(x, group) props_by_group(x, group)
percs_by_group(x, group) props_by_group(x, group)
x |
A vector of counts |
group |
A vector to determine groups. |
x <- c(20, 30, 30, 70) g1 <- c("A", "A", "B", "B") g2 <- c("A", "B", "A", "B") props_by_group(x, g1) percs_by_group(x, g1) props_by_group(x, g2)
x <- c(20, 30, 30, 70) g1 <- c("A", "A", "B", "B") g2 <- c("A", "B", "A", "B") props_by_group(x, g1) percs_by_group(x, g1) props_by_group(x, g2)
This stat computes points for plotting a distribution function. Fitting is done
using MASS::fitdistr()
when analytic solutions are not available.
stat_fitdistr( mapping = NULL, data = NULL, geom = "path", position = "identity", na.rm = FALSE, show.legend = NA, inherit.aes = TRUE, dist = "dnorm", start = NULL, ... )
stat_fitdistr( mapping = NULL, data = NULL, geom = "path", position = "identity", na.rm = FALSE, show.legend = NA, inherit.aes = TRUE, dist = "dnorm", start = NULL, ... )
mapping |
Aesthetics created using |
data |
A data frame. |
geom |
A character string naming the geom used to make the layer. |
position |
Either a character string naming the position function used for the layer or a position object returned from a call to a position function. |
na.rm |
If TRUE, do not emit a warning about missing data. |
show.legend |
A logical. Should this layer be included in the legends? |
inherit.aes |
If |
dist |
A character string indicating the distribution to fit. Examples include
|
start |
A list of starting values used by |
... |
Additional arguments. |
A gg object
Adds linear model fits to plots. geom_lm()
and stat_lm()
are essentially
equivalent. Use geom_lm()
unless you want a non-standard geom.
stat_lm( mapping = NULL, data = NULL, geom = "lm", position = "identity", interval = c("none", "prediction", "confidence"), level = 0.95, formula = y ~ x, lm.args = list(), backtrans = identity, ..., na.rm = FALSE, show.legend = NA, inherit.aes = TRUE ) geom_lm( mapping = NULL, data = NULL, stat = "lm", position = "identity", interval = c("none", "prediction", "confidence"), level = 0.95, formula = y ~ x, lm.args = list(), backtrans = identity, ..., na.rm = FALSE, show.legend = NA, inherit.aes = TRUE )
stat_lm( mapping = NULL, data = NULL, geom = "lm", position = "identity", interval = c("none", "prediction", "confidence"), level = 0.95, formula = y ~ x, lm.args = list(), backtrans = identity, ..., na.rm = FALSE, show.legend = NA, inherit.aes = TRUE ) geom_lm( mapping = NULL, data = NULL, stat = "lm", position = "identity", interval = c("none", "prediction", "confidence"), level = 0.95, formula = y ~ x, lm.args = list(), backtrans = identity, ..., na.rm = FALSE, show.legend = NA, inherit.aes = TRUE )
mapping |
Set of aesthetic mappings created by |
data |
The data to be displayed in this layer. There are three options: If A A |
geom , stat
|
Use to override the default connection between
|
position |
Position adjustment, either as a string naming the adjustment
(e.g. |
interval |
One of |
level |
The level used for confidence or prediction intervals |
formula |
a formula describing the model in terms of |
lm.args |
A list of arguments supplied to |
backtrans |
a function that transforms the response back to
the original scale when the |
... |
Other arguments passed on to |
na.rm |
If |
show.legend |
logical. Should this layer be included in the legends?
|
inherit.aes |
If |
Stat calculation is performed by the (currently undocumented)
predictdf
. Pointwise confidence or prediction bands are
calculated using the predict()
method.
lm()
for details on linear model fitting.
ggplot(data = mosaicData::KidsFeet, aes(y = length, x = width, color = sex)) + geom_lm() + geom_point() ggplot(data = mosaicData::KidsFeet, aes(y = length, x = width, color = sex)) + geom_lm(interval = "prediction", color = "skyblue") + geom_lm(interval = "confidence") + geom_point() + facet_wrap(~sex) # non-standard display ggplot(data = mosaicData::KidsFeet, aes(y = length, x = width, color = sex)) + stat_lm(aes(fill = sex), color = NA, interval = "confidence", geom = "ribbon", alpha = 0.2 ) + geom_point() + facet_wrap(~sex) ggplot(mpg, aes(displ, hwy)) + geom_lm( formula = log(y) ~ poly(x, 3), backtrans = exp, interval = "prediction", fill = "skyblue" ) + geom_lm( formula = log(y) ~ poly(x, 3), backtrans = exp, interval = "confidence", color = "red" ) + geom_point()
ggplot(data = mosaicData::KidsFeet, aes(y = length, x = width, color = sex)) + geom_lm() + geom_point() ggplot(data = mosaicData::KidsFeet, aes(y = length, x = width, color = sex)) + geom_lm(interval = "prediction", color = "skyblue") + geom_lm(interval = "confidence") + geom_point() + facet_wrap(~sex) # non-standard display ggplot(data = mosaicData::KidsFeet, aes(y = length, x = width, color = sex)) + stat_lm(aes(fill = sex), color = NA, interval = "confidence", geom = "ribbon", alpha = 0.2 ) + geom_point() + facet_wrap(~sex) ggplot(mpg, aes(displ, hwy)) + geom_lm( formula = log(y) ~ poly(x, 3), backtrans = exp, interval = "prediction", fill = "skyblue" ) + geom_lm( formula = log(y) ~ poly(x, 3), backtrans = exp, interval = "confidence", color = "red" ) + geom_point()
This stat computes quantiles of the sample and theoretical distribution for the purpose of providing reference lines for QQ-plots.
stat_qqline( mapping = NULL, data = NULL, geom = "line", position = "identity", ..., distribution = stats::qnorm, dparams = list(), na.rm = FALSE, show.legend = NA, inherit.aes = TRUE )
stat_qqline( mapping = NULL, data = NULL, geom = "line", position = "identity", ..., distribution = stats::qnorm, dparams = list(), na.rm = FALSE, show.legend = NA, inherit.aes = TRUE )
mapping |
An aesthetic mapping produced with |
data |
A data frame. |
geom |
A geom. |
position |
A position object. |
... |
Additional arguments |
distribution |
A quantile function. |
dparams |
A list of arguments for |
na.rm |
A logical indicating whether a warning should be issued when missing values are removed before plotting. |
show.legend |
A logical indicating whether legends should be included
for this layer. If |
inherit.aes |
A logical indicating whether aesthetics should be
inherited. When |
data(penguins, package = "palmerpenguins") ggplot(data = penguins, aes(sample = bill_length_mm)) + geom_qq() + stat_qqline(alpha = 0.7, color = "red", linetype = "dashed") + facet_wrap(~species)
data(penguins, package = "palmerpenguins") ggplot(data = penguins, aes(sample = bill_length_mm)) + geom_qq() + stat_qqline(alpha = 0.7, color = "red", linetype = "dashed") + facet_wrap(~species)
Similar to geom_smooth, this adds spline fits to plots.
stat_spline( mapping = NULL, data = NULL, geom = "line", position = "identity", na.rm = FALSE, show.legend = NA, inherit.aes = TRUE, weight = NULL, df = NULL, spar = NULL, cv = FALSE, all.knots = FALSE, nknots = stats::.nknots.smspl, df.offset = 0, penalty = 1, control.spar = list(), tol = NULL, ... ) geom_spline( mapping = NULL, data = NULL, stat = "spline", position = "identity", na.rm = FALSE, show.legend = NA, inherit.aes = TRUE, weight = NULL, df = NULL, spar = NULL, cv = FALSE, all.knots = FALSE, nknots = stats::.nknots.smspl, df.offset = 0, penalty = 1, control.spar = list(), tol = NULL, ... )
stat_spline( mapping = NULL, data = NULL, geom = "line", position = "identity", na.rm = FALSE, show.legend = NA, inherit.aes = TRUE, weight = NULL, df = NULL, spar = NULL, cv = FALSE, all.knots = FALSE, nknots = stats::.nknots.smspl, df.offset = 0, penalty = 1, control.spar = list(), tol = NULL, ... ) geom_spline( mapping = NULL, data = NULL, stat = "spline", position = "identity", na.rm = FALSE, show.legend = NA, inherit.aes = TRUE, weight = NULL, df = NULL, spar = NULL, cv = FALSE, all.knots = FALSE, nknots = stats::.nknots.smspl, df.offset = 0, penalty = 1, control.spar = list(), tol = NULL, ... )
mapping |
An aesthetic mapping produced with |
data |
A data frame. |
geom |
A geom. |
position |
A position object. |
na.rm |
A logical indicating whether a warning should be issued when missing values are removed before plotting. |
show.legend |
A logical indicating whether legends should be included
for this layer. If |
inherit.aes |
A logical indicating whether aesthetics should be
inherited. When |
weight |
An optional vector of weights.
See |
df |
desired equivalent degrees of freedom.
See |
spar |
A smoothing parameter, typically in (0,1].
See |
cv |
A logical.
See |
all.knots |
A logical.
See |
nknots |
An integer or function giving the number of knots to use
when |
df.offset |
A numerical value used to increase the degrees of freedom
when using GVC.
See |
penalty |
the coefficient of the penalty for degrees of freedom in the
GVC criterion.
See |
control.spar |
An optional list used to control root finding
when the parameter |
tol |
A tolerance for sameness or uniqueness of the |
... |
Additional arguments |
stat |
A stat. |
if (require(mosaicData)) { ggplot(Births) + geom_spline(aes(x = date, y = births, colour = wday)) ggplot(Births) + geom_spline(aes(x = date, y = births, colour = wday), nknots = 10) }
if (require(mosaicData)) { ggplot(Births) + geom_spline(aes(x = date, y = births, colour = wday)) ggplot(Births) + geom_spline(aes(x = date, y = births, colour = wday), nknots = 10) }
These are typically accessed through their associated geom_*
, stat_*
or
gf_*
functions.
These are typically accessed through their associated geom_*
, stat_*
or
gf_*
functions.
StatAsh StatSpline StatQqline StatLm GeomLm StatAsh StatFitdistr
StatAsh StatSpline StatQqline StatLm GeomLm StatAsh StatFitdistr