Title: | Area-Proportional Euler and Venn Diagrams with Ellipses |
---|---|
Description: | Generate area-proportional Euler diagrams using numerical optimization. An Euler diagram is a generalization of a Venn diagram, relaxing the criterion that all interactions need to be represented. Diagrams may be fit with ellipses and circles via a wide range of inputs and can be visualized in numerous ways. |
Authors: | Johan Larsson [aut, cre] , A. Jonathan R. Godfrey [ctb], Peter Gustafsson [ctb], David H. Eberly [ctb] (geometric algorithms), Emanuel Huber [ctb] (root solver code), Florian Privé [ctb] |
Maintainer: | Johan Larsson <[email protected]> |
License: | GPL-3 |
Version: | 7.0.2 |
Built: | 2025-01-22 04:27:17 UTC |
Source: | https://github.com/jolars/eulerr |
euler
objectsThis is a diagnostic tool for evaluating the fit from a call
to euler()
visually. A color key is provided by default, which
represents the chosen error metric so that one can easily detect
which areas in the diagram to be skeptical about.
error_plot( x, type = c("regionError", "residuals"), quantities = TRUE, pal = NULL, ... )
error_plot( x, type = c("regionError", "residuals"), quantities = TRUE, pal = NULL, ... )
x |
an object of class |
type |
error metric. |
quantities |
whether to draw the error metric on the plot |
pal |
color palette for the fills in the legend |
... |
arguments passed down to |
Notice that this function is purely provided for diagnostic reasons
and does not come with the same kind of customization that
plot.euler()
provides: the color legend can only be customized
in regards to its color palette and another key (instead of labels)
is completely turned off.
Returns an object of class eulergram
, which will be
plotted on the device in the same manner as objects from
plot.euler()
. See plot.eulergram()
for details.
plot.euler()
, euler()
,
plot.eulergram()
error_plot(euler(organisms), quantities = FALSE)
error_plot(euler(organisms), quantities = FALSE)
Fit Euler diagrams (a generalization of Venn diagrams) using numerical optimization to find exact or approximate solutions to a specification of set relationships. The shape of the diagram may be a circle or an ellipse.
euler(combinations, ...) ## Default S3 method: euler( combinations, input = c("disjoint", "union"), shape = c("circle", "ellipse"), loss = c("square", "abs", "region"), loss_aggregator = c("sum", "max"), control = list(), ... ) ## S3 method for class 'data.frame' euler( combinations, weights = NULL, by = NULL, sep = "_", factor_names = TRUE, ... ) ## S3 method for class 'matrix' euler(combinations, ...) ## S3 method for class 'table' euler(combinations, ...) ## S3 method for class 'list' euler(combinations, ...)
euler(combinations, ...) ## Default S3 method: euler( combinations, input = c("disjoint", "union"), shape = c("circle", "ellipse"), loss = c("square", "abs", "region"), loss_aggregator = c("sum", "max"), control = list(), ... ) ## S3 method for class 'data.frame' euler( combinations, weights = NULL, by = NULL, sep = "_", factor_names = TRUE, ... ) ## S3 method for class 'matrix' euler(combinations, ...) ## S3 method for class 'table' euler(combinations, ...) ## S3 method for class 'list' euler(combinations, ...)
combinations |
set relationships as a named numeric vector, matrix, or data.frame (see methods (by class)) |
... |
arguments passed down to other methods |
input |
type of input: disjoint identities
( |
shape |
geometric shape used in the diagram |
loss |
type of loss to minimize over. If |
loss_aggregator |
how the final loss is computed. |
control |
a list of control parameters.
|
weights |
a numeric vector of weights of the same length as
the number of rows in |
by |
a factor or character matrix to be used in |
sep |
a character to use to separate the dummy-coded factors if there are factor or character vectors in 'combinations'. |
factor_names |
whether to include factor names when constructing dummy codes |
If the input is a matrix or data frame and argument by
is specified,
the function returns a list of euler diagrams.
The function minimizes the residual sums of squares,
by default, where the size of the ith disjoint subset, and
the corresponding area in the diagram, that is, the unique
contribution to the total area from this overlap. The loss function
can, however, be controlled via the
loss
argument.
euler()
also returns stress
(from venneuler), as well as
diagError
, and regionError
from eulerAPE.
The stress statistic is computed as
where
regionError
is computed as
diagError
is simply the maximum of regionError.
A list object of class 'euler'
with the following parameters.
ellipses |
a matrix of |
original.values |
set relationships in the input |
fitted.values |
set relationships in the solution |
residuals |
residuals |
regionError |
the difference in percentage points between each disjoint subset in the input and the respective area in the output |
diagError |
the largest |
stress |
normalized residual sums of squares |
euler(default)
: a named numeric vector, with
combinations separated by an ampersand, for instance A&B = 10
.
Missing combinations are treated as being 0.
euler(data.frame)
: a data.frame
of logicals, binary integers, or
factors.
euler(matrix)
: a matrix that can be converted to a data.frame of logicals
(as in the description above) via base::as.data.frame.matrix()
.
euler(table)
: A table with max(dim(x)) < 3
.
euler(list)
: a list of vectors, each vector giving the contents of
that set (with no duplicates). Vectors in the list must be named.
Wilkinson L. Exact and Approximate Area-Proportional Circular Venn and Euler Diagrams. IEEE Transactions on Visualization and Computer Graphics (Internet). 2012 Feb (cited 2016 Apr 9);18(2):321-31. Available from: doi:10.1109/TVCG.2011.56
Micallef L, Rodgers P. eulerAPE: Drawing Area-Proportional 3-Venn Diagrams Using Ellipses. PLOS ONE (Internet). 2014 Jul (cited 2016 Dec 10);9(7):e101717. Available from: doi:10.1371/journal.pone.0101717
plot.euler()
, print.euler()
, eulerr_options()
, venn()
# Fit a diagram with circles combo <- c(A = 2, B = 2, C = 2, "A&B" = 1, "A&C" = 1, "B&C" = 1) fit1 <- euler(combo) # Investigate the fit fit1 # Refit using ellipses instead fit2 <- euler(combo, shape = "ellipse") # Investigate the fit again (which is now exact) fit2 # Plot it plot(fit2) # A set with no perfect solution euler(c( "a" = 3491, "b" = 3409, "c" = 3503, "a&b" = 120, "a&c" = 114, "b&c" = 132, "a&b&c" = 50 )) # Using grouping via the 'by' argument through the data.frame method euler(fruits, by = list(sex, age)) # Using the matrix method euler(organisms) # Using weights euler(organisms, weights = c(10, 20, 5, 4, 8, 9, 2)) # The table method euler(pain, factor_names = FALSE) # A euler diagram from a list of sample spaces (the list method) euler(plants[c("erigenia", "solanum", "cynodon")])
# Fit a diagram with circles combo <- c(A = 2, B = 2, C = 2, "A&B" = 1, "A&C" = 1, "B&C" = 1) fit1 <- euler(combo) # Investigate the fit fit1 # Refit using ellipses instead fit2 <- euler(combo, shape = "ellipse") # Investigate the fit again (which is now exact) fit2 # Plot it plot(fit2) # A set with no perfect solution euler(c( "a" = 3491, "b" = 3409, "c" = 3503, "a&b" = 120, "a&c" = 114, "b&c" = 132, "a&b&c" = 50 )) # Using grouping via the 'by' argument through the data.frame method euler(fruits, by = list(sex, age)) # Using the matrix method euler(organisms) # Using weights euler(organisms, weights = c(10, 20, 5, 4, 8, 9, 2)) # The table method euler(pain, factor_names = FALSE) # A euler diagram from a list of sample spaces (the list method) euler(plants[c("erigenia", "solanum", "cynodon")])
This function provides a means to set default parameters for functions
in eulerr. Query eulerr_options()
(without any
argument) to see all the available options and read more about
the plot-related ones in grid::gpar()
and graphics::par()
.
eulerr_options(...)
eulerr_options(...)
... |
objects to update the global graphical parameters for eulerr with. |
Currently, the following items will be considered:
size in pts to be used as basis for fontsizes and some margin sizes in the resulting plot
#'
a list of items fill
and alpha
a list of items col
, alpha
, lex
, lwd
, and lty
a list of items rot
,
col
, alpha
, fontsize
, cex
, fontfamily
, fontface
,
lineheight
, and font
a list of items type
, rot
,
col
, alpha
, fontsize
, cex
, fontfamily
,
lineheight
, and font
col
, alpha
, fontsize
, cex
, fontfamily
,
lineheight
, and font
arguments to grid::legendGrob()
as well as col
, alpha
,
fontsize
, cex
, fontfamily
, lineheight
, and font
arguments to grid::textGrob()
a grid::unit()
giving the padding between various
elements in plots from plot.euler()
, which you can change
if you, for instance, want to increase spacing between labels,
quantities, and percentages.
This function gets or sets updates in the global environment
that are used in plot.euler()
.
plot.euler()
, grid::gpar()
, graphics::par()
eulerr_options(edges = list(col = "blue"), fontsize = 10) eulerr_options(n_threads = 2)
eulerr_options(edges = list(col = "blue"), fontsize = 10) eulerr_options(n_threads = 2)
A synthethic data set of preferences for fruits and their overlaps, generated only to be a showcase for the examples for this package.
fruits
fruits
A data.frame with 100 observations of 5 variables:
whether the person likes bananas, a logical
whether the person likes apples, a logical
whether the person likes oranges, a logical
the sex of the person, a factor with levels 'male' and 'female'
the age of the person, a factor with levels 'child' and 'adult'
Example data from the VennMaster package.
organisms
organisms
A matrix with 7 observations, consisting of various organisms, and 5 variables: animal, mammal, plant, sea, and, spiny, indicating whether the organism belongs to the category or not.
Note that this data is difficult to fit using an Euler diagram, even if we use ellipses, which is clear if one chooses to study the various overlaps in the resulting diagrams.
https://github.com/sysbio-bioinf/VennMaster/blob/master/data_examples/deploy/example1.list
Data from a study on pain distribution for patients with persistent neck pain in relation to a whiplash trauma.
pain
pain
A flat table (cross-table) with with sex in columns and pain distribution in rows and integer counts making up the cells of the table.
Note that the maintainer of this package is an author of the source for this data.
Westergren H, Larsson J, Freeman M, Carlsson A, Jöud A, Malmström E-M. Sex-based differences in pain distribution in a cohort of patients with persistent post-traumatic neck pain. Disability and Rehabilitation. 2017 Jan 27
Data on plants and the states in the US and Canada they occur in.
plants
plants
A list with 33,721 plants, each containing a character vector listing the states in the US and Canada in which they occur. The names in the list specify the species or genus of the plant.
USDA, NRCS. 2008. The PLANTS Database (http://plants.usda.gov/, 31 December 2008). National Plant Data Center, Baton Rouge, LA 70874-4490 USA.
Dua, D. and Karra Taniskidou, E. (2017). UCI Machine Learning Repository http://archive.ics.uci.edu/ml/. Irvine, CA: University of California, School of Information and Computer Science.
Plot diagrams fit with euler()
and venn()
using grid::Grid()
graphics.
This
function sets up all the necessary plot parameters and computes
the geometry of the diagram. plot.eulergram()
, meanwhile,
does the actual plotting of the diagram. Please see the Details section
to learn about the individual settings for each argument.
## S3 method for class 'euler' plot( x, fills = TRUE, edges = TRUE, legend = FALSE, labels = identical(legend, FALSE), quantities = FALSE, strips = NULL, main = NULL, n = 200L, adjust_labels = TRUE, ... ) ## S3 method for class 'venn' plot( x, fills = TRUE, edges = TRUE, legend = FALSE, labels = identical(legend, FALSE), quantities = TRUE, strips = NULL, main = NULL, n = 200L, adjust_labels = TRUE, ... )
## S3 method for class 'euler' plot( x, fills = TRUE, edges = TRUE, legend = FALSE, labels = identical(legend, FALSE), quantities = FALSE, strips = NULL, main = NULL, n = 200L, adjust_labels = TRUE, ... ) ## S3 method for class 'venn' plot( x, fills = TRUE, edges = TRUE, legend = FALSE, labels = identical(legend, FALSE), quantities = TRUE, strips = NULL, main = NULL, n = 200L, adjust_labels = TRUE, ... )
x |
an object of class |
fills |
a logical, vector, or list of graphical parameters for the fills
in the diagram. Vectors are assumed to be colors for the fills.
See |
edges |
a logical, vector, or list of graphical parameters for the edges
in the diagram. Vectors are assumed to be colors for the edges.
See |
legend |
a logical scalar or list. If a list,
the item |
labels |
a logical, vector, or list. Vectors are assumed to be
text for the labels. See |
quantities |
a logical, vector, or list. Vectors are assumed to be
text for the quantities' labels, which by
default are the original values in the input to |
strips |
a list, ignored unless the |
main |
a title for the plot in the form of a
character, expression, list or something that can be
sensibly converted to a label via |
n |
number of vertices for the |
adjust_labels |
a logical. If |
... |
parameters to update |
The only difference between plot.euler()
and plot.venn()
is that
quantities
is set to TRUE
by default in the latter and FALSE
in
the former.
Most of the arguments to this function accept either a logical, a vector, or a list where
logical values set the attribute on or off,
vectors are shortcuts to commonly used options (see the individual parameters), and
lists enable fine-grained control, including graphical
parameters as described in grid::gpar()
and control
arguments that are specific to each argument.
The various grid::gpar()
values that are available for each argument
are:
fills | edges | labels | quantities | strips | legend | main | |
col | x | x | x | x | x | x | |
fill | x | ||||||
alpha | x | x | x | x | x | x | x |
lty | x | ||||||
lwd | x | ||||||
lex | x | ||||||
fontsize | x | x | x | x | x | ||
cex | x | x | x | x | x | ||
fontfamily | x | x | x | x | x | ||
lineheight | x | x | x | x | x | ||
font | x | x | x | x | x | ||
Defaults for these values, as well as other parameters of the plots, can
be set globally using eulerr_options()
.
If the diagram has been fit using the data.frame
or matrix
methods
and using the by
argument, the plot area will be split into panels for
each combination of the one to two factors.
For users who are looking to plot their diagram using another package, all the necessary parameters can be collected if the result of this function is assigned to a variable (rather than printed to screen).
Provides an object of class 'eulergram'
, which is a
description of the diagram to be drawn. plot.eulergram()
does the actual
drawing of the diagram.
euler()
, plot.eulergram()
, grid::gpar()
,
grid::grid.polyline()
, grid::grid.path()
,
grid::grid.legend()
, grid::grid.text()
fit <- euler(c("A" = 10, "B" = 5, "A&B" = 3)) # Customize colors, remove borders, bump alpha, color labels white plot(fit, fills = list(fill = c("red", "steelblue4"), alpha = 0.5), labels = list(col = "white", font = 4)) # Add quantities to the plot plot(fit, quantities = TRUE) # Add a custom legend and retain quantities plot(fit, quantities = TRUE, legend = list(labels = c("foo", "bar"))) # Plot without fills and distinguish sets with border types instead plot(fit, fills = "transparent", lty = 1:2) # Save plot parameters to plot using some other method diagram_description <- plot(fit) # Plots using 'by' argument plot(euler(fruits[, 1:4], by = list(sex)), legend = TRUE)
fit <- euler(c("A" = 10, "B" = 5, "A&B" = 3)) # Customize colors, remove borders, bump alpha, color labels white plot(fit, fills = list(fill = c("red", "steelblue4"), alpha = 0.5), labels = list(col = "white", font = 4)) # Add quantities to the plot plot(fit, quantities = TRUE) # Add a custom legend and retain quantities plot(fit, quantities = TRUE, legend = list(labels = c("foo", "bar"))) # Plot without fills and distinguish sets with border types instead plot(fit, fills = "transparent", lty = 1:2) # Save plot parameters to plot using some other method diagram_description <- plot(fit) # Plots using 'by' argument plot(euler(fruits[, 1:4], by = list(sex)), legend = TRUE)
This function is responsible for the actual drawing of
'eulergram'
objects created through plot.euler()
. print.eulergram()
is an alias for plot.eulergram()
, which has been provided so that
plot.euler()
gets called automatically.
## S3 method for class 'eulergram' plot(x, newpage = TRUE, ...) ## S3 method for class 'eulergram' print(x, ...)
## S3 method for class 'eulergram' plot(x, newpage = TRUE, ...) ## S3 method for class 'eulergram' print(x, ...)
x |
an object of class |
newpage |
if |
... |
ignored |
A plot is drawn on the current device using grid::Grid()
graphics.
This function is responsible for printing fits from euler()
and provides
a summary of the fit. Prints a data frame of the original set relationships
and the fitted values as well as diagError
and stress
statistics.
## S3 method for class 'euler' print(x, round = 3, vsep = strrep("-", 0.75 * getOption("width")), ...)
## S3 method for class 'euler' print(x, round = 3, vsep = strrep("-", 0.75 * getOption("width")), ...)
x |
|
round |
number of decimal places to round to |
vsep |
character string to paste in between |
... |
arguments passed to |
Summary statistics of the fitted Euler diagram are printed to screen.
euler()
, base::print.data.frame()
euler(organisms)
euler(organisms)
This function is responsible for printing objects from
from venn()
and provides a simple description of the number of
sets and the specifications for the ellipses of the Venn diagram.
## S3 method for class 'venn' print(x, round = 3, vsep = strrep("-", 0.75 * getOption("width")), ...)
## S3 method for class 'venn' print(x, round = 3, vsep = strrep("-", 0.75 * getOption("width")), ...)
x |
an object of class |
round |
number of digits to round the ellipse specification to |
vsep |
character string to paste in between |
... |
arguments passed to |
Summary statistics of the fitted Venn diagram are printed to screen.
venn()
, base::print.data.frame()
venn(organisms)
venn(organisms)
This function fits Venn diagrams using an interface that is
almost identical to euler()
. Strictly speaking,
Venn diagrams are Euler diagrams where every intersection is visible,
regardless of whether or not it is zero. In almost every incarnation of
Venn diagrams, however, the areas in the diagram are also
non-proportional to the input; this is also the case here.
venn(combinations, ...) ## Default S3 method: venn( combinations, input = c("disjoint", "union"), names = letters[length(combinations)], ... ) ## S3 method for class 'table' venn(combinations, ...) ## S3 method for class 'data.frame' venn( combinations, weights = NULL, by = NULL, sep = "_", factor_names = TRUE, ... ) ## S3 method for class 'matrix' venn(combinations, ...) ## S3 method for class 'list' venn(combinations, ...)
venn(combinations, ...) ## Default S3 method: venn( combinations, input = c("disjoint", "union"), names = letters[length(combinations)], ... ) ## S3 method for class 'table' venn(combinations, ...) ## S3 method for class 'data.frame' venn( combinations, weights = NULL, by = NULL, sep = "_", factor_names = TRUE, ... ) ## S3 method for class 'matrix' venn(combinations, ...) ## S3 method for class 'list' venn(combinations, ...)
combinations |
set relationships as a named numeric vector, matrix, or data.frame (see methods (by class)) |
... |
arguments passed down to other methods |
input |
type of input: disjoint identities
( |
names |
a character vector for the names of each set of the same
length as 'combinations'. Must not be |
weights |
a numeric vector of weights of the same length as
the number of rows in |
by |
a factor or character matrix to be used in |
sep |
a character to use to separate the dummy-coded factors if there are factor or character vectors in 'combinations'. |
factor_names |
whether to include factor names when constructing dummy codes |
Returns an object of class 'venn', 'euler'
with items
ellipses |
a matrix of |
original.values |
set relationships in the input |
fitted.values |
set relationships in the solution |
venn(default)
: a named numeric vector, with
combinations separated by an ampersand, for instance A&B = 10
.
Missing combinations are treated as being 0.
venn(table)
: A table with max(dim(x)) < 3
.
venn(data.frame)
: a data.frame
of logicals, binary integers, or
factors.
venn(matrix)
: a matrix that can be converted to a data.frame of logicals
(as in the description above) via base::as.data.frame.matrix()
.
venn(list)
: a list of vectors, each vector giving the contents of
that set (with no duplicates). Vectors in the list do not need to be named.
plot.venn()
, print.venn()
, euler()
# The trivial version f1 <- venn(5, names = letters[1:5]) plot(f1) # Using data (a numeric vector) f2 <- venn(c(A = 1, "B&C" = 3, "A&D" = 0.3)) # The table method venn(pain, factor_names = FALSE) # Using grouping via the 'by' argument through the data.frame method venn(fruits, by = list(sex, age)) # Using the matrix method venn(organisms) # Using weights venn(organisms, weights = c(10, 20, 5, 4, 8, 9, 2)) # A venn diagram from a list of sample spaces (the list method) venn(plants[c("erigenia", "solanum", "cynodon")])
# The trivial version f1 <- venn(5, names = letters[1:5]) plot(f1) # Using data (a numeric vector) f2 <- venn(c(A = 1, "B&C" = 3, "A&D" = 0.3)) # The table method venn(pain, factor_names = FALSE) # Using grouping via the 'by' argument through the data.frame method venn(fruits, by = list(sex, age)) # Using the matrix method venn(organisms) # Using weights venn(organisms, weights = c(10, 20, 5, 4, 8, 9, 2)) # A venn diagram from a list of sample spaces (the list method) venn(plants[c("erigenia", "solanum", "cynodon")])