-
Notifications
You must be signed in to change notification settings - Fork 2
/
Snakefile
74 lines (64 loc) · 2.44 KB
/
Snakefile
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
"""Workflow for BIOINF 545 Group 1 Project
Downloads data from SRA, and quantifies with kallisto
"""
from pathlib import Path
import pandas as pd
from snakemake.remote.FTP import RemoteProvider
# Load config file into directionairy config
configfile: "config.yaml"
# Define paths
int_dir = Path(config["intermediate_dir"])
out_dir = Path(config["output_dir"])
# Load manifest
manifest = pd.read_csv(config["manifest"],sep="\t")
# Define anonymous
FTP = RemoteProvider()
rule all:
input:
expand(str(int_dir / "quant" / "{SRR_ID}" / "abundance.tsv"),SRR_ID=manifest["SRR"]),
expand(str(int_dir / "fastqc" / "{SRR_ID}" / "{SRR_ID}_1_fastqc.html"),SRR_ID=manifest["SRR"]),
expand(str(int_dir / "fastqc" / "{SRR_ID}" / "{SRR_ID}_2_fastqc.html"),SRR_ID=manifest["SRR"])
rule fastq_dump:
output:
R1 = int_dir / "fastqs" / "{SRR_ID}" / "{SRR_ID}_1.fastq.gz",
R2 = int_dir / "fastqs" / "{SRR_ID}" / "{SRR_ID}_2.fastq.gz"
shell:
"""
mkdir -p $(dirname {output.R1})
fastq-dump -O $(dirname {output.R1}) --split-files --gzip {wildcards.SRR_ID}
"""
rule fastqc:
input:
R1 = int_dir / "fastqs" / "{SRR_ID}" / "{SRR_ID}_1.fastq.gz",
R2 = int_dir / "fastqs" / "{SRR_ID}" / "{SRR_ID}_2.fastq.gz"
output:
fastqc_1 = int_dir / "fastqc" / "{SRR_ID}" / "{SRR_ID}_1_fastqc.html",
fastqc_2 = int_dir / "fastqc" / "{SRR_ID}" / "{SRR_ID}_2_fastqc.html"
shell:
"""
mkdir -p $(dirname {output.fastqc_1})
mkdir -p $(dirname {output.fastqc_2})
fastqc -o $(dirname {output.fastqc_1}) {input.R1}
fastqc -o $(dirname {output.fastqc_2}) {input.R2}
"""
rule kallisto_make_index:
input: FTP.remote(config["reference"])
output: int_dir / "reference_index.idx"
shell:
"""
kallisto index -i {output} {input}
"""
rule kallisto_quant:
input:
R1 = int_dir / "fastqs" / "{SRR_ID}" / "{SRR_ID}_1.fastq.gz",
R2 = int_dir / "fastqs" / "{SRR_ID}" / "{SRR_ID}_2.fastq.gz",
index = int_dir / "reference_index.idx"
output:
h5 = int_dir / "quant" / "{SRR_ID}" / "abundance.h5",
abundances = int_dir / "quant" / "{SRR_ID}" / "abundance.tsv",
run_info = int_dir / "quant" / "{SRR_ID}" / "run_info.json"
shell:
"""
mkdir -p $(dirname {output.h5})
kallisto quant -i {input.index} -o $(dirname {output.h5}) {input.R1} {input.R2}
"""