A tool for generating figure-ready graphs from file. It borrows heavily from packages developed by others, including ggplot2 and dplyr from the tidyverse and batch statistical calculations from ggpubr.
Plots can be made using combinations of geoms including bar, violin, box, crossbar, density, point, line, and errorbar.
if (!requireNamespace("BiocManager", quietly = TRUE))
install.packages("BiocManager")
BiocManager::install("plotGrouper")
BbiocManager
:devtools
:Load the package into the R session.
library(plotGrouper)
To initialize the shiny app, paste the following code in your R console and run it.
plotGrouper()
Once the web app opens, you can access the iris
dataset
by clicking the iris button to learn how to use the app. After the
iris
data loads, the selection windows will be
automatically populated and a graph should be displayed.
The Raw Data
tab displays the structure of the data loaded.
Your file should be organized in the following way:
Unique identifier | Comparisons | Variables |
---|---|---|
Sample | Species | Sepal.Length |
setosa_1 | setosa | 5.1 |
setosa_2 | setosa | 4.9 |
versicolor_1 | versicolor | 7 |
versicolor_2 | versicolor | 6.4 |
virginica_1 | virginica | 6.3 |
virginica_2 | virginica | 5.8 |
etc… | etc… | etc… |
These columns can be titled anything you want but values in the columns are important.
The Unique identifier
column should contain only
unique values that identify each individual sample (e.g.,
Sample
within iris
Raw Data
).
The Comparisons
column should contain replicated
values that identify each individual as belonging to a group (e.g.,
Species
within iris
Raw Data
).
The Variables
column(s) should created for each
variable you wish to plot. The values in these columns must be numeric
(e.g., Sepal.Length
, Sepal.Width
,
Petal.Length
, Petal.Width
within
iris
Raw Data
)
After importing a data file, a Sheet
column will be
created and populated with the sheet name(s) from the file if it came
from an excel spreadsheet or the file name if it came from a csv or tsv
file.
The Variables to plot
selection window is used to
choose which variable(s) to plot (e.g., Sepal.Width
from
the iris
data). If multiple are selected, they will be
grouped according to the Independent variable
selected.
The Comparisons
selection window is used to choose
which column contains theinformation that identifies which condition
each sample belongs to (e.g., the Species
column within the
iris
data).
The Independent variable
selection window is used to
select how the plots should be grouped. If variable
is
selected (the default), the plots will be grouped by the values in
Variables to plot
.
Use the Shapes
selector to change the shape of the
points for each comparison variable.
Use the Colors
selector to change the point colors
for each comparison variable.
Use the Fills
selector to change the fill color for
the other geoms being plotted for each comparison variable.
To prevent the Shapes
, Colors
, or
Fills
from reverting to their defaults, click the
Lock
checkboxes.
Individual plots can be saved by clicking Save
on the
Plot
tab or multiple plots may be arranged on a single page
by clicking Add plot to report
. Clicking this button will
send the current plot to the Report
tab and assign it a
number in the Report plot #
dropdown menu. To revisit a
plot stored in the Report
tab, select the plot you wish to
restore and click Load plot from report
. Changes can be
made to this plot and then updated in the Report
by
clicking Update plot in report
.
The statistics calculated for the current plot being displayed in
the Plot
tab are stored in the Statistics
tab.
These can be saved by clicking the Download
button on the
Statistics
tab.
The Plot Data
tab contains the reorganized subset of
data being plotted.
The Raw Data
tab displays the dataframe that was
created upon import of the file along with the automatically created
Sheet
column.
Here is the output of sessionInfo()
on the system on
which this package was developed:
## R version 4.4.1 (2024-06-14)
## Platform: x86_64-pc-linux-gnu
## Running under: Ubuntu 24.04.1 LTS
##
## Matrix products: default
## BLAS: /usr/lib/x86_64-linux-gnu/openblas-pthread/libblas.so.3
## LAPACK: /usr/lib/x86_64-linux-gnu/openblas-pthread/libopenblasp-r0.3.26.so; LAPACK version 3.12.0
##
## locale:
## [1] LC_CTYPE=en_US.UTF-8 LC_NUMERIC=C
## [3] LC_TIME=en_US.UTF-8 LC_COLLATE=C
## [5] LC_MONETARY=en_US.UTF-8 LC_MESSAGES=en_US.UTF-8
## [7] LC_PAPER=en_US.UTF-8 LC_NAME=C
## [9] LC_ADDRESS=C LC_TELEPHONE=C
## [11] LC_MEASUREMENT=en_US.UTF-8 LC_IDENTIFICATION=C
##
## time zone: Etc/UTC
## tzcode source: system (glibc)
##
## attached base packages:
## [1] stats graphics grDevices utils datasets methods base
##
## loaded via a namespace (and not attached):
## [1] digest_0.6.37 R6_2.5.1 fastmap_1.2.0 xfun_0.48
## [5] maketools_1.3.1 cachem_1.1.0 knitr_1.48 htmltools_0.5.8.1
## [9] rmarkdown_2.28 buildtools_1.0.0 lifecycle_1.0.4 cli_3.6.3
## [13] sass_0.4.9 jquerylib_0.1.4 compiler_4.4.1 sys_3.4.3
## [17] tools_4.4.1 mime_0.12 evaluate_1.0.1 bslib_0.8.0
## [21] yaml_2.3.10 jsonlite_1.8.9 rlang_1.1.4