-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathREADME.Rmd
138 lines (100 loc) · 4.99 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
---
output: github_document
---
<!-- README.md is generated from README.Rmd. Please edit that file -->
```{r, include = FALSE}
knitr::opts_chunk$set(
collapse = TRUE,
comment = "#>",
out.width = "100%"
)
```
<img src="./inst/PlastoGram/PlastoGram_logo.png" style="height: 200px;"/>
## Web server
The Shiny web server is available under the address: https://biogenies.info/PlastoGram.
## Installation
### Installing HMMER
PlastoGram uses HMMER software to predict thylakoid lumen proteins imported via Sec and Tat pathways with HMM profiles.
You can install HMMER using the following instructions (adapted from [HMMER documentation](http://hmmer.org/documentation.html)):
- installing with system packager
```
% brew install hmmer # OS/X, HomeBrew
% port install hmmer # OS/X, MacPorts
% apt install hmmer # Linux (Ubuntu, Debian...)
% dnf install hmmer # Linux (Fedora)
% yum install hmmer # Linux (older Fedora)
% conda install -c bioconda hmmer # Anaconda
```
- compiling from source
```
% wget http://eddylab.org/software/hmmer/hmmer.tar.gz
% tar zxf hmmer.tar.gz
% cd hmmer-3.3.2
% ./configure --prefix /your/install/path
% make
% make check
% make install
% (cd easel; make install)
```
For more information about HMMER please visit [HMMER website](http://hmmer.org/).
### Installing PlastoGram
You can install the latest development version of the package:
```R
if(!require("devtools")) install.packages("devtools")
devtools::install_github("https://github.com/BioGenies/PlastoGram/")
```
## PlastoGram model
PlastoGram is a robust ensemble model for detailed and accurate prediction of subplastid localization and origin of analysed protein. PlastoGram classifies protein as nuclear- or plastid-encoded and predicts its most probable localization considering envelope, stroma, thylakoid membrane or thylakoid lumen. For the latter, also the import pathway (Sec or Tat) is predicted. We provide an additional function to differentiate nuclear-encoded inner and outer membrane proteins.
PlastoGram consists of eight lower-level models trained to tackle a specific labeling problem and a higher-level random forest model, which uses results from of lower-level models to provide the prediction of a protein localization and origin. The lower-level models used in the PlastoGram with their areas of competence are listed below:
- Nuclear_model - recognizes nuclear-encoded proteins
- Membrane_model - identifies membrane proteins
- N_E_vs_N_TM_model - differentiates between nuclear-encoded envelope proteins and nuclear-encoded thylakoid membrane proteins. Prediction values over 0.5 indicate envelope, whereas lower thylakoid membrane
- Plastid_membrane_model - distinguishes plastid-encoded proteins targeted to plastid inner and thylakoid membrane. Prediction values higher than 0.5 indicate inner membrane, whereas lower thylakoid membrane
- N_E_vs_N_S_model - differentiates nuclear-encoded proteins targeted to envelope from nuclear-encoded stromal proteins. Prediction values over 0.5 indicate envelope, whereas lower stroma
- Nuclear_membrane_model - distinguishes nuclear-encoded membrane proteins from all others
- Sec_model - identifies proteins targeted to the thylakoid lumen via Sec pathway
- Tat_model - recognizes proteins targeted to the thylakoid lumen via Tat pathway
## Versions of the model
```{r, echo=FALSE, results='asis'}
cat(PlastoGram:::markdown_versions())
```
## Predicting subplastid localization
Suppopse you wish to predict localization of proteins which sequences are stored in sequence_file.fa located in the working directory using the holdout version of PlastoGram model.
``` r
# load the package
library(PlastoGram)
# read in sequences
sequences <- read_txt("sequence_file.fa")
# run predictions
predictions <- predict(PlastoGram_H, sequences)
# inspect results
# see predictions of origin and localization:
predictions[["Final_results"]]
# save predictions of origin and localization to a csv file named 'PlastoGram_predictions.csv'
write.csv(predictions[["Final_results"]], "PlastoGram_predictions.csv")
# get summary with number of proteins identified in each class
library(dplyr)
predictions[["Final_results"]] %>%
group_by(Localization) %>%
summarise(count = n())
# see predictions from lower-level models
predictions[["Lower_level_preds"]]
# see higher-level model predictions
predictions[["Higher_level_preds"]]
# see predictions of detailed localization for N_E proteins (OM or IM)
predictions[["OM_IM_preds"]]
```
## Citation
```{r, echo=FALSE, results='asis'}
cat(PlastoGram:::markdown_citation())
```
## Code availability
Code necessary to reproduce the whole analysis described in the article and leading to the final PlastoGram algorithm is available at https://github.com/BioGenies/PlastoGram-analysis.
## Contact
```{r, echo=FALSE, results='asis'}
cat(PlastoGram:::markdown_contact())
```
## Acknowledgements
```{r, echo=FALSE, results='asis'}
cat(PlastoGram:::markdown_acknowledgements())
```