-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathREADME.Rmd
198 lines (140 loc) · 9.24 KB
/
README.Rmd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
---
output: github_document
---
```{r, echo = FALSE}
knitr::opts_chunk$set(
collapse = TRUE,
comment = "#>",
fig.path = "man/figures/README-"
)
```
# ggPlantmap <img src="man/figures/hex.png" align="right" height="250"/>
###### Version 1.1.0
###### Author: Leonardo Jo ([email protected])
<!-- badges: start -->
<!-- badges: end -->
## Overview
ggPlantmap is an open-source R package with the goal of facilitating the generation of informative ggplot maps from plant images to explore quantitative cell-type specific data. When combined with external quantitative data, ggPlantmap can be used for the visualization and displaying of spatial profiles in distinct parts/cells of the plant.
Included in the package there is a set of pre-loaded maps created from previously published plant images that can be directly inserted into a ggplot coding workflow. ggPlantmap enables users to plot heatmap signatures of gene expression or any spatial quantitative data onto plant images providing a customizable and extensible platform for visualizing, and analyzing spatial quantitative patterns within specific plant regions This package uses the flexibility of the well-known ggplot2 R package to allow users to tailor maps to their specific research questions.
<img src="man/figures/ggPlantmap.example.jpg" align="center" width="1000"/>
## Installation
```{r, eval = FALSE}
##install devtools (if you haven't already)
install.packages("devtools")
library(devtools)
## Installing from a github respository
install_github("leonardojo/ggPlantmap")
```
## ggPlantmap useful guides (HIGHLY RECOMMENDED!)
**(NEW)** Here is a [practical guide](https://github.com/leonardojo/ggPlantmap/blob/main/guides/guide_practical_sc.md) on how to work with ggPlantmap to explore single-cell data
I created a step-by-step [user guide](https://github.com/leonardojo/ggPlantmap/blob/main/guides/ggPlantmap.userguide.md) to help users navigate through the package.
Here is a recorded [seminar](https://www.youtube.com/watch?v=TD5m5-CbWTw&t=1402s) with an overview of the package.
I also created a [step-by-step guide with tips](https://github.com/leonardojo/ggPlantmap/blob/main/guides/TutorialforXMLfile.pdf) on how to create your own ggPlantmap.
Finally, here are some [instructions](https://github.com/leonardojo/ggPlantmap/blob/main/guides/contributetoggPlantmap.md) on how your newly created ggPlantmap can be included in the package.
## What is a ggPlantmap?
Each unique ggPlantmap is a table (tibble) object with points coordinates (x,y) of specific points of polygons (ROIs) extracted from plant images.
```{r}
library(ggPlantmap)
head(ggPm.At.roottip.longitudinal)
```
<img src="man/figures/guide/Slide6.JPG" align="center" height="500"/>
## Plotting a ggPlantmap
ggPlantmaps can be easily plotted using the ggPlantmap.plot() function.
```{r,warning=F,echo=T,out.width="50%",fig.align="center"}
library(ggPlantmap)
ggPlantmap.plot(ggPm.At.earlyembryogenesis.devseries,Cell)
ggPlantmap.plot(ggPm.At.roottip.longitudinal,Level1)
```
## Pre-loaded ggPlantmaps
The package contain a series of pre-loaded ggPlantmaps created from previously published plant images.
I hope to update the package with the contribution of the plant research community.
```{r}
library(ggPlantmap)
ggPm.summary
```
<img src="man/figures/ggPm.someexamples.jpg" align="center" height="500"/>
## Color mapping
These maps can be easily loaded into a ggplot coding environment and their color mapping changed based on the distinct layer classification of each ggPlantmap.
```{r,warning=F,echo=F,out.width="50%",fig.align="center"}
library(ggplot2)
library(cowplot)
## Stage: Seed development stage
## Part: Distinct parts of a seed (Seed coat, Endosperm and Embryo)
## Region: Specific regions of each part of the Arabidopsis seed
## Reference: Belmonte, Mark F., et al. "Comprehensive developmental profiles of gene activity in regions and subregions of the Arabidopsis seed." Proceedings of the National Academy of Sciences 110.5 (2013): E435-E444.
a <- ggPlantmap.plot(ggPm.At.seed.devseries,Region,linewidth = 0.5) +
scale_fill_brewer(palette="Set3") +
ggtitle("Regions of Arabidopsis seed development") +
theme(legend.key.height= unit(0.25, 'cm'),
legend.key.width= unit(0.25, 'cm'))
b <- ggPlantmap.plot(ggPm.At.seed.devseries,Stage,linewidth = 0.5) +
scale_fill_brewer(palette="Set1") +
ggtitle("Stages of Arabidopsis seed development") +
theme(legend.key.height= unit(0.25, 'cm'),
legend.key.width= unit(0.25, 'cm'))
c <- ggPlantmap.plot(ggPm.At.seed.devseries,Part,linewidth = 0.5) +
scale_fill_brewer(palette="Set1") +
ggtitle("Parts of Arabidopsis seed development") +
theme(legend.key.height= unit(0.25, 'cm'),
legend.key.width= unit(0.25, 'cm'))
plot_grid(a,b,c,ncol=1,labels=c("a","b","c"),align = "v")
```
```{r,warning=F,echo=F,out.width="50%",fig.align="center"}
library(ggPlantmap)
library(ggplot2)
library(cowplot)
a <- ggPlantmap.plot(ggPm.At.shootapex.longitudinal,Zone) +
scale_fill_brewer(palette="Set2") +
ggtitle("Shoot Apical Meristem - Zones") +
theme(legend.key.height= unit(0.25, 'cm'),
legend.key.width= unit(0.25, 'cm'))
b <- ggPlantmap.plot(ggPm.At.shootapex.longitudinal,Layer) +
scale_fill_brewer(palette="YlGn") +
ggtitle("Shoot Apical Meristem - Layers") +
theme(legend.key.height= unit(0.25, 'cm'),
legend.key.width= unit(0.25, 'cm'))
plot_grid(a,b,ncol=1,labels=c("d","e"),align = "v")
```
## Overlaying external quantitative data into a ggPlantmap
With ggPlantmap you can overlay quantitative data into your ggPlantmap to visualize it as sort of a heatmap.
To do so, you will need another table that contains quantitative data attributed to your ROIs.
<img src="man/figures/guide/Slide7.JPG" align="center" width="1200"/><br />
This approach can be very helpful for R Shiny app developers to create web interactive tools to visualize quantitative data in plant cell or structures.
Some examples of heatmaps generated from available published data:
<img src="man/figures/README-Slide2.PNG" align="center" width="1000"/><br />
<img src="man/figures/README-Slide3.PNG" align="center" width="1000"/><br />
## Is ggPlantmap only usefull for molecular expression data?
Not at all. ggPlantmap can also be used to produce many other type of plots. Essentially anything that you can trace, you can create! Be creative! I hope to build a community where people explore the usage of ggPlantmap for the communication of Plant science.
<img src="man/figures/README-Slide4.PNG" align="center" width="1000"/><br />
## How can I create my own ggPlantmap?
The principle of creating a ggPlantmap is fairly simple. We generate a list of ROIs (region of interests) in the Icy open-source software (https://icy.bioimageanalysis.org/) from any plant image. These ROIs are saved as XML files and later be converted into ggPlantmaps with the XML.to.ggPlantmap() function.
[We created step-by-step guide with tips](https://github.com/leonardojo/ggPlantmap/blob/main/guides/TutorialforXMLfile.pdf) on how to generate xml images from plant images.
<img src="man/figures/README-Slide1.PNG" align="center" width="800"/>
```{r,out.width="50%"}
new.ggPlantmap <- XML.to.ggPlantmap("data/ggPm.sample.xml")
ggPlantmap.plot(new.ggPlantmap,ROI.name)
```
## Can my ggPlantmap be included in the package?
YES!!! Any Plant map can be included in the package.
Here are some [instructions](https://github.com/leonardojo/ggPlantmap/blob/main/guides/contributetoggPlantmap.md) on how your newly created ggPlantmap can be included in the package.
If you create one, please email me ([email protected]) your ggPlantmap as tab-delimited table and I'll make sure to include in the package. You will be credited and your information will be displayed in the summary file. I really hope this becomes an organic package with the contribution of the plant research community.
## Can my ggPlantmap be integrated into an ePlant EFP browser or any other graphical software?
YES!! You can convert your ggPlantmap table into an SVG file that can be used
<img src="man/figures/svg.png" align="center" width="800" />
```{r}
ggPlantmap.to.SVG(ggPm.At.3weekrosette.topview,
group.name = "ROI.name",
author = "ggPlantmap",
svg.name="ggPlantmap.svg")
## This will create an image file (.svg) that can be opened in an graphic software (Illustrator, Power-Point)
```
## Acknowledgements
I would like to acknowledge Kaisa Kajala, Lisa Oskam, Monica Garcia Gomez, Pierre Gautrat and Kyra van der Velde for testing ggPlantmap. I also would like to acknowledge Andres Romanowski for providing some data for the initial tests of ggPlantmap.
## How to cite
### Peer-reviewed manuscript
Jo, Leonardo, and Kaisa Kajala. "ggPlantmap: an open-source R package for the creation of informative and quantitative ggplot maps derived from plant images." Journal of Experimental Botany (2024): erae043. doi: https://doi.org/10.1093/jxb/erae043
### Pre-print
(Pre-print1) Leonardo Jo, Kaisa Kajala. ggPlantmap: an R package for creation of informative and quantitative ggplot maps derived from plant images.
bioRxiv 2023.11.30.569429; doi: https://doi.org/10.1101/2023.11.30.569429
(Pre-print2) Leonardo Jo, Kaisa Kajala. ggPlantmap: an R package for the graphic mapping of plant images. Authorea. September 21, 2023.
DOI: 10.22541/au.169531385.58441696/v1