-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathposeidon.qmd
232 lines (159 loc) · 13.6 KB
/
poseidon.qmd
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
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
---
title: "Genotype and context data management with Poseidon"
author: "Ayshin Ghalichi & Clemens Schmid"
date: "10/19/2023"
bibliography: references.bib
toc: true
reference-location: margin
citation-location: margin
execute:
eval: false
---
Poseidon is an open computational framework to enable standardised and FAIR (@Wilkinson2016) handling of genotypes with their highly relevant context information.
It includes a well-specified **data format**, advanced **software tools**, and **public, community-maintained archives** to support the entire archaeogenetic research cycle, from data acquisition to management, analysis and publication.
Poseidon and all its components is well documented at <https://www.poseidon-adna.org>. In this tutorial we will give a brief overview and highlight two workflows in the context of Poseidon.
## The components of Poseidon
![Overview of the Poseidon framework](img/poseidon/popgen_toolbox_schema.png){width="60%"}
Poseidon is an entire ecosystem built on top of the data format specification of the Poseidon package.
### The Poseidon package
A [**Poseidon package**](https://www.poseidon-adna.org/#/standard) bundles [genotype data in EIGENSTRAT/PLINK format](https://www.poseidon-adna.org/#/genotype_data) with human- and machine-readable meta-data.
![The files in a Poseidon package](img/poseidon/popgen_toolbox_package_schema.png){width="60%"}
It includes sample-wise context information like spatio-temporal origin and genetic data quality in [the `.janno`-file](https://www.poseidon-adna.org/#/janno_details), literature in the `.bib`-file, and pointers to sequencing data in [the `.ssf`-file](https://www.poseidon-adna.org/#/ssf_details).
`.janno` and `.ssf` have many predefined and specified columns, but can store arbitrary additional variables.
### The software tools
[**trident**](https://www.poseidon-adna.org/#/trident) is a command line application to create, download, inspect and merge Poseidon packages -- and therefore the central tool of the Poseidon framework. The `init` subcommand creates new packages from genotype data, `fetch` downloads them from the public archives through the Web-API, and `forge` merges and subsets them as specified. `list` gives an overview over entities in a set of packages and `validate` confirms their structural integrity.
[**xerxes**](https://www.poseidon-adna.org/#/xerxes) is derived from trident and allows to directly perform various basic and experimental genomic data analyses on Poseidon packages. It implements allele sharing statistics ($F_2$, $F_3$, $F_4$, $F_{ST}$) with a flexible permutation interface.
[**janno**](https://www.poseidon-adna.org/#/janno_r_package) is an R package to simplify reading .janno files into R and the popular tidyverse ecosystem (@Wickham2019). It provides an S3 class `janno` that inherits from `tibble`.
[**qjanno**](https://www.poseidon-adna.org/#/qjanno) is another command line tool to perform SQL queries on `.janno` files. On start-up it creates an [SQLite](https://www.sqlite.org/index.html) database in memory and reads `.janno` files into it. It then sends any user-provided SQL query to the database server and forwards its output.
### The public archives
The Poseidon community maintains [**public archives**](https://www.poseidon-adna.org/#/archive_overview) for Poseidon packages to establish a central open point of access for published archaeogenetic genotype data.
- The **Community Archive**: Author supplied per-paper packages with the genotype data published in the respective papers. Partially pre-populated from various versions of the AADR.
- The **AADR Archive**: Complete and structurally unified releases of the Allen Ancient DNA Resource (@Mallick2023) repackaged in the Poseidon package format.
- The **Minotaur Archive**: Per-paper packages with genotype data reprocessed by the Minotaur workflow (see below).
The data is versioned with Git and hosted on GitHub for easy co-editing and automatic structural validation.
It can be accessed through a [**Web-API**](https://www.poseidon-adna.org/#/web_api) with various endpoints at *server.poseidon-adna.org*, e.g. [`/packages`](https://server.poseidon-adna.org/packages) for a JSON list of packages in the community archive.
This API enables a little [**Archive explorer**](https://www.poseidon-adna.org/#/archive_explorer) web app on the Poseidon website.
### The Minotaur workflow
The [**Minotaur workflow**](https://www.poseidon-adna.org/#/minotaur) is a semi-automatic workflow to reproducibly process published sequencing data from the International Nucleotide Sequence Database Collaboration ([INSDC](https://www.insdc.org)) archives into Poseidon packages.
Community members can request new packages by submitting a build recipe as a Pull Request against a dedicated submission GitHub repository. This recipe is derived from a Sequencing Source File (`.ssf`), describing the sequencing data for the package and where it can be downloaded.
Using the recipe, the sequencing data gets processed through nf-core/eager (@FellowsYates2021) on computational infrastructure of MPI-EVA, using a standardised, yet flexible, set of parameters.
The generated genotypes, together with descriptive statistics of the sequencing data (Endogenous, Damage, Nr_SNPs, Contamination), are compiled into a Poseidon package and made available to users in the Minotaur archive.
## Forging a dataset with `trident`
`forge` creates new Poseidon packages by extracting and merging packages, populations and individuals/samples from your Poseidon repositories. It can also work directly with your genotype data. In addition, `forge` allows merging of multiple data sets (packages), in contrast to [`mergeit`](https://github.com/DReichLab/EIG) which merges only two data sets at a time.
`(-f/--forgeString)` can be used to query entire packages, groups or individuals. In general `--forgeString` query consists of multiple entities, inside `""` separated by `,` .
- To include all individuals in a Poseidon package, use `*` to surround the package title (e.g. `*2019_Jeong_InnerEurasia*`) . In cases where only genotype files are available, use the file name prefix.
- To include certain group(s) from a Poseidon package, simply add them to the `-f` query. No specific markers are required. `Russia_HG_Karelia`. You don't have to specify the group, as trident will search all packages for the given group.
- To extract individuals only, surround them by `<` and `>`. `<ALA026>` . To exclude individuals add package name `*package*` and `<individual>` with a dash sign. `"*2021_Saag_EastEuropean-3.2.0*,-<NIK003>"`\
```bash
trident forge \
-p pileupcaller.double.geno \
-d 2021_Saag_EastEuropean-3.2.0 \
-d 2016_FuNature-2.1.1 \
-f "*pileupcaller.double*,Russia_AfontovaGora3,<NIK003>" \
-o testpackage \
--outFormat EIGENSTRAT \
/
```
[Forge selection language](https://www.poseidon-adna.org/#/trident?id=the-forge-selection-language)
`forge` has a an optional flag `--intersect,` that defines whether the genotype data from different packages should be merged with an **intersect** instead of the default **union** operation. The default is to output the union of all SNPs, by setting the additional SNPs from the other merged package as missing in the samples that did not have them originally. This option is useful for making a data set based on Human Origins (HO) SNPs for analysis like PCA and ADMIXTURE.
```bash
trident forge \
--intersect \
-p pileupcaller.double.geno \
-d 2012_PattersonGenetics-2.1.3 \
-o testpackage_HO \
--outFormat EIGENSTRAT \
/
```
In case of PCA, `--forgeFile` can be used to merge necessary populations/groups from the available packages in the community archive to create specific PCA configurations.
```bash
trident forge \
-d /path/to/community/archive \
--forgeFile WestEurasia_poplist.txt \
-o WE_PCA \
/
```
In addition, `--selectSnps` allows to provide `forge` with a SNP file in EIGENSTRAT (.snp) or PLINK (.bim) format to create a package with a specific selection. This option generates a package with exactly the SNPs listed in this file.
## Contributing to the community archive
![Poseidon needs your data as soon as it is published](img/poseidon/recruiting.jpg){width="40%"}
To maintain the public data archives, specifically the community archive and the minotaur archive, Poseidon depends on work donations by an interested community.
Many practitioners of archaeogenetics both produce genotype data from archaological contexts and require the reference data from other publications, provided in public archives, to contextualize it.
If authors themselves provide high-quality, easily accessible versions of their data beyond the raw data available at the INSDC databases, they gain at least three important advantages:
- Their work will be easily findable and **potentially cited more often**.
- They have primacy over how their **data is communicated**. That is, which genotypes, dates or group names they consider correct.
- Their results for derived, genotype based analyses (PCA, F-Statistics, etc.) can be **reproduced exactly**.
And the whole community wins, because sharing the tedious data preparation tasks empowers all researchers to achieve more in shorter time.
::: column-margin
![](img/poseidon/our_data.jpg){width="50%"}
:::
------------------------------------------------------------------------
This tutorial explains the main cornerstones of a workflow to add a new Poseidon package to the community archive after publishing the corresponding dataset. The process is documented in more detail in a [**Submission guide**](https://www.poseidon-adna.org/#/archive_submission_guide) on the website.
1. **Make yourself familiar** with a number of core technologies. This is less daunting than it sounds, because: Superficial knowledge is sufficient and knowing them is useful beyond this particular task.
- Creating and validating Poseidon packages with the `trident` tool.
- Free and open source distributed version control with [Git](https://git-scm.com).
- Collaborative working on Git projects with [GitHub](https://github.com).
- Handling large files in Git using [Git LFS](https://git-lfs.com).
2. **Create a package** from your genotype data and fill it with a suitable set of meta and context information.
- `trident init` allows to wrap genotype data in a dummy Poseidon package. Imagine we had genotype data for a number of individuals in EIGENSTRAT format:
``` {filename="myData.ind"}
Sample1 M ExamplePop1
Sample2 F ExamplePop1
Sample3 M ExamplePop2
```
``` {filename="myData.snp"}
rs3094315 1 0.020130 752566 G A
rs12124819 1 0.020242 776546 A G
rs28765502 1 0.022137 832918 T C
```
``` {filename="myData.geno"}
099
922
999
```
With `trident init -p myData.geno -o myPackage` we can create a basic package around this data.
```
$ ls myPackage
myData.geno myData.snp myPackage.janno
myData.ind myPackage.bib POSEIDON.yml
```
- In a next step we modify `POSEIDON.yml`, `.janno` and `.bib` to include the context information we consider relevant. All of these files are well specified and documented, so we only demonstrate a minimal change for this example:
We replace the main contributor for the package.
``` {filename="myPackage/POSEIDON.yml"}
poseidonVersion: 2.7.1
title: myPackage
description: Empty package template. Please add a description
contributor:
- name: Clemens Schmid #- name: Josiah Carberry
email: [email protected] # email: [email protected]
orcid: 0000-0003-3448-5715 # orcid: 0000-0002-1825-0097
packageVersion: 0.1.0
lastModified: 2023-10-18
genotypeData:
format: EIGENSTRAT
genoFile: myData.geno
snpFile: myData.snp
indFile: myData.ind
snpSet: Other
jannoFile: myPackage.janno
bibFile: myPackage.bib
```
- When we applied all necessary modifications we can confirm that the package is still valid with `trident validate -d myPackage`.
3. **Submit the package** to the community archive.
- To submit the package we have to create a fork of the [community archive repository on GitHub](https://github.com/poseidon-framework/community-archive). This requires a GitHub account.
![Press the fork button in the top right corner to fork a repository on GitHub](img/poseidon/fork.png)
- And then clone the fork to our computer, while omitting the large genotype data files. Note that this requires several setup steps to work correctly:
- Git has be installed for your computer (see [here](https://git-scm.com/book/en/v2/Getting-Started-Installing-Git))
- You must have created an ssh key pair to connect to GitHub via ssh (see [here](https://docs.github.com/en/authentication/connecting-to-github-with-ssh))
- Git LFS has to be installed (see [here](https://git-lfs.com)) and configured for your user with `git lfs install`
``` bash
GIT_LFS_SKIP_SMUDGE=1 git clone [email protected]:<yourGitHubUserName>/community-archive.git
```
- With the cloned repository on our system we can copy the files into the repositories directory and commit the changes.
``` {.bash filename="in the community-archive directory"}
cp -r ../myPackage myPackage
git add myPackage
git commit -m "added a first draft of myPackage"
git push
```
- In a last step we can open a Pull Request on GitHub from our fork to the original archive repository. Poseidon core members will take it from here.
![When you pushed to your fork, GitHub will automatically offer to "contribute" to the source repository](img/poseidon/pull_request.png)