forked from patrick-praher/PyLOH_Opt
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathPyLOH.py
executable file
·110 lines (81 loc) · 5.21 KB
/
PyLOH.py
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
#!/usr/bin/env python
#=======================================================================================================================
# Created on 2013-07-28
# @author: Yi Li
#
# PyLOH
# Copyright (c) 2013 Yi Li <[email protected]>
#
# This code is free software; you can redistribute it and/or modify it
# under the terms of GNU GPL v2.0 (see the file LICENSE included with the distribution).
# Some features are built on top of JointSNVMix-0.6.2 (http://code.google.com/p/joint-snv-mix/).
#=======================================================================================================================
import argparse
from pyloh.preprocess.run_preprocess import run_preprocess
from pyloh.model.run_model import run_poisson_model
from pyloh.postprocess.plot import plot_BAF_heatmap
parser = argparse.ArgumentParser(prog='PyLOH')
subparsers = parser.add_subparsers()
#===============================================================================
# Add preprocess sub-command
#===============================================================================
parser_preprocess = subparsers.add_parser('preprocess',
help='''Preprocess paired normal and tumor BAM files''')
parser_preprocess.add_argument('reference_genome',
help='''FASTA file for reference genome.''')
parser_preprocess.add_argument('normal_bam',
help='''BAM file for normal sample.''')
parser_preprocess.add_argument('tumor_bam',
help='''BAM file for tumor sample.''')
parser_preprocess.add_argument('filename_base',
help='''Base name of preprocessed files to be created.''')
parser_preprocess.add_argument('--segments_bed', default=None, type=str,
help='''BED file for segments. If not provided,
use autosomes as segments. Default is None.''')
parser_preprocess.add_argument('--WES', default=False, action='store_true',
help='''Flag indicating whether the BAM files are whole exome sequencing(WES) or not.
If not provided, the BAM files are assumed to be whole genome sequencing(WGS).
Default is False.''')
parser_preprocess.add_argument('--min_depth', default=20, type=int,
help='''Minimum reads depth required for both normal and tumor samples.
Default is 20.''')
parser_preprocess.add_argument('--min_base_qual', default=10, type=int,
help='''Minimum base quality required. Default is 10.''')
parser_preprocess.add_argument('--min_map_qual', default=10, type=int,
help='''Minimum mapping quality required. Default is 10.''')
parser_preprocess.add_argument('--process_num', default=1, type=int,
help='''Number of processes to launch for preprocessing. Default is 1.''')
parser_preprocess.set_defaults(func=run_preprocess)
#===============================================================================
# Add run_model sub-command
#===============================================================================
parser_run_model = subparsers.add_parser('run_model',
help='''Run a probabilistic model based analysis. Requires preprocessed counts
file and segments file that have been created.''')
parser_run_model.add_argument('filename_base',
help='Base name of preprocessed files created.')
parser_run_model.add_argument('--allelenumber_max', default=2, type=int,
help='''Maximum copy number of each allele allows to take. Default is 2.''')
parser_run_model.add_argument('--priors', default=None, type=str,
help='''File of the prior distribution. If not provided,
use uniform prior. Default is None.''')
parser_run_model.add_argument('--max_iters', default=100, type=int,
help='''Maximum number of iterations for training. Default is 100.''')
parser_run_model.add_argument('--stop_value', default=1e-7, type=float,
help='''Stop value of the EM algorithm for training. If the change of log-likelihood is lower
than this value, stop training. Default is 1e-7.''')
parser_run_model.set_defaults(func=run_poisson_model)
#===============================================================================
# Add BAF_heatmap sub-command
#===============================================================================
parser_BAF_heatmap = subparsers.add_parser('BAF_heatmap',
help='''Plot the BAF heat map for each segment. Requires preprocessed
heatmap file that have been created.''')
parser_BAF_heatmap.add_argument('filename_base',
help='''Base name of preprocessed files created.''')
parser_BAF_heatmap.set_defaults(func=plot_BAF_heatmap)
#===============================================================================
# Run
#===============================================================================
args = parser.parse_args()
args.func(args)