forked from mrc-ide/mipmapper
-
Notifications
You must be signed in to change notification settings - Fork 0
/
README.Rmd
90 lines (78 loc) · 3.65 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
---
output: github_document
---
```{r, echo = FALSE}
knitr::opts_chunk$set(
collapse = TRUE,
comment = "#>",
fig.path = "README-"
)
```
# mipmapper
[![Travis build status](https://travis-ci.org/mrc-ide/mipmapper.svg?branch=master)](https://travis-ci.org/mrc-ide/mipmapper)
[![AppVeyor build status](https://ci.appveyor.com/api/projects/status/github/mrc-ide/mipmapper?branch=master&svg=true)](https://ci.appveyor.com/project/mrc-ide/mipmapper)
[![Coverage status](https://codecov.io/gh/mrc-ide/mipmapper/branch/master/graph/badge.svg)](https://codecov.io/github/mrc-ide/mipmapper?branch=master)
[![Documentation](https://github.com/OJWatson/rdhs/raw/master/tools/pkgdownshield.png)](https://mrc-ide.github.io/mipmapper/)
The R package *mipmapper* package contains a series of functions for analysing and visualising Molecular Inversion Probe (MIP) data. **This package is in early stages of development**, but will eventually include a range of methods for carrying out population genetic analyses. Full documentation can be found [here](https://mrc-ide.github.io/mipmapper/).
### Installation
In R, ensure that you have the devtools package installed by running
```{r, eval = FALSE}
install.packages("devtools", repos='http://cran.us.r-project.org')
```
Then we can simply install the *mipmapper* package directly from GitHub by running
```{r, eval = FALSE}
devtools::install_github("mrc-ide/mipmapper")
```
And we can load the package by running
```{r}
library(mipmapper)
```
### Data loading and filtering
Load raw data from .csv file. You will need to change the file path to where you have stored the data. An example of this is shown below, but commented out.
```{r}
# if loading your own data, uncomment this line and change path to your data
# dat0 <- fast_read("path_to_your_data/NeutralSNPs_AheroYombo.csv")
# here we will use in-built example data
dat0 <- mipmapper_file("dummy_data.csv")
```
Some miscellaneous filtering. Subset to SNPs only (i.e. no more complex mutations), group all alternative alleles together as a single "non-reference" allele, and drop irregular loci (for example non-integer barcode counts).
```{r}
dat1 <- filter_misc(dat0, SNP_only = TRUE, group_Alt = TRUE, drop_irregular = TRUE)
```
Next we want to filter based on coverage, throwing away any loci that are below a minimum coverage level. We can visualise how much data will be left at different thresholds using the following function:
```{r plot_coverage}
plot_coverage(dat1)
```
Choose a threshold that strikes a balance between data quantity and quality. Once you have chosen a threshold, apply the filtering as follows:
```{r}
my_threshold <- 6
dat3 <- filter_coverage(dat1, min_coverage = my_threshold)
```
### Principal Components Analysis
Before carry out PCA analysis we will convert our filtered dataset into a wide format, where each row is an unique sample, with new columns for each locus. This can be achieved as follows:
```{r}
dat4 <- melt_mip_data(dat3)
```
This can then be used to impute any missing values:
```{r}
dat5 <- impute_mip_data(dat4)
```
The imputed data set can then be analysed using principal component analysis:
```{r}
pca <- pca_mip_data(dat5)
```
We can view the variance explained by each compenet graphically using:
```{r pca_variance}
plot_pca_variance(pca)
```
![](tools/pca_var.png)
And lastly we can plot the actual prinical component analysis, to see how it has clustered our data:
```{r pca_2}
plot_pca(pca, num_components = 2, meta_var = "Country")
```
![](tools/pca_2var.png)
We can control whether we want to visualise the first 2 or 3 components, with the `num_componenets` argument:
```{r pca_3}
plot_pca(pca, num_components = 3, meta_var = "Country")
```
![](tools/pca_3var.png)