-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy path3_make_overlap_table.Snakefile
78 lines (66 loc) · 1.98 KB
/
3_make_overlap_table.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
74
75
76
77
#!/usr/bin/env snakemake
'''
Makes locus overlap table
Note: I convert the parquet to tsv to support the existing locus overlap
script (uses pypy, therefore can't use pandas).
'''
from snakemake.remote.FTP import RemoteProvider as FTPRemoteProvider
from snakemake.remote.GS import RemoteProvider as GSRemoteProvider
from snakemake.remote.HTTP import RemoteProvider as HTTPRemoteProvider
import pandas as pd
from datetime import date
# Load configuration
configfile: "configs/config.yaml"
tmpdir = config['temp_dir']
KEEP_LOCAL = False
if 'version' not in config:
config['version'] = date.today().strftime("%y%m%d")
targets = []
# Make targets for locus overlap table (pseudo-coloc)
targets.append(
'output/{version}/locus_overlap.parquet'.format(version=config['version'])
)
# Trigger making of targets
rule all:
input:
targets
rule parquet_to_tsv:
input:
'{filename}.parquet'
output:
temp('{filename}.tsv.gz')
run:
print(input)
(
pd.read_parquet(input[0], engine='pyarrow')
.to_csv(output[0], sep='\t', index=None)
)
rule calculate_overlaps:
''' Calcs overlap between trait associated loci
'''
input:
top_loci='output/{version}/toploci.tsv.gz',
ld='output/{version}/ld.tsv.gz',
finemap='output/{version}/finemapping.tsv.gz'
output:
tmpdir + '/{version}/locus_overlap.tsv.gz'
params:
min_r2=config['overlap_min_r2']
shell:
'pypy3 scripts/calculate_locus_set_overlaps.py '
'--top_loci {input.top_loci} '
'--ld {input.ld} '
'--finemap {input.finemap} '
'--min_r2 {params.min_r2} '
'--outf {output}'
rule format_overlap:
''' Formats the overlap table to parquets
'''
input:
tmpdir + '/{version}/locus_overlap.tsv.gz'
output:
'output/{version}/locus_overlap.parquet'
shell:
'python scripts/format_overlap_table.py '
'--inf {input} '
'--outf {output}'