.\" Automatically generated by Pod::Man 4.09 (Pod::Simple 3.35) .\" .\" Standard preamble: .\" ======================================================================== .de Sp \" Vertical space (when we can't use .PP) .if t .sp .5v .if n .sp .. .de Vb \" Begin verbatim text .ft CW .nf .ne \\$1 .. .de Ve \" End verbatim text .ft R .fi .. .\" Set up some character translations and predefined strings. \*(-- will .\" give an unbreakable dash, \*(PI will give pi, \*(L" will give a left .\" double quote, and \*(R" will give a right double quote. \*(C+ will .\" give a nicer C++. Capital omega is used to do unbreakable dashes and .\" therefore won't be available. \*(C` and \*(C' expand to `' in nroff, .\" nothing in troff, for use with C<>. .tr \(*W- .ds C+ C\v'-.1v'\h'-1p'\s-2+\h'-1p'+\s0\v'.1v'\h'-1p' .ie n \{\ . ds -- \(*W- . ds PI pi . if (\n(.H=4u)&(1m=24u) .ds -- \(*W\h'-12u'\(*W\h'-12u'-\" diablo 10 pitch . if (\n(.H=4u)&(1m=20u) .ds -- \(*W\h'-12u'\(*W\h'-8u'-\" diablo 12 pitch . ds L" "" . ds R" "" . ds C` "" . ds C' "" 'br\} .el\{\ . ds -- \|\(em\| . ds PI \(*p . ds L" `` . ds R" '' . ds C` . ds C' 'br\} .\" .\" Escape single quotes in literal strings from groff's Unicode transform. .ie \n(.g .ds Aq \(aq .el .ds Aq ' .\" .\" If the F register is >0, we'll generate index entries on stderr for .\" titles (.TH), headers (.SH), subsections (.SS), items (.Ip), and index .\" entries marked with X<> in POD. Of course, you'll have to process the .\" output yourself in some meaningful fashion. .\" .\" Avoid warning from groff about undefined register 'F'. .de IX .. .if !\nF .nr F 0 .if \nF>0 \{\ . de IX . tm Index:\\$1\t\\n%\t"\\$2" .. . if !\nF==2 \{\ . nr % 0 . nr F 2 . \} .\} .\" .\" Accent mark definitions (@(#)ms.acc 1.5 88/02/08 SMI; from UCB 4.2). .\" Fear. Run. Save yourself. No user-serviceable parts. . \" fudge factors for nroff and troff .if n \{\ . ds #H 0 . ds #V .8m . ds #F .3m . ds #[ \f1 . ds #] \fP .\} .if t \{\ . ds #H ((1u-(\\\\n(.fu%2u))*.13m) . ds #V .6m . ds #F 0 . ds #[ \& . ds #] \& .\} . \" simple accents for nroff and troff .if n \{\ . ds ' \& . ds ` \& . ds ^ \& . ds , \& . ds ~ ~ . ds / .\} .if t \{\ . ds ' \\k:\h'-(\\n(.wu*8/10-\*(#H)'\'\h"|\\n:u" . ds ` \\k:\h'-(\\n(.wu*8/10-\*(#H)'\`\h'|\\n:u' . ds ^ \\k:\h'-(\\n(.wu*10/11-\*(#H)'^\h'|\\n:u' . ds , \\k:\h'-(\\n(.wu*8/10)',\h'|\\n:u' . ds ~ \\k:\h'-(\\n(.wu-\*(#H-.1m)'~\h'|\\n:u' . ds / \\k:\h'-(\\n(.wu*8/10-\*(#H)'\z\(sl\h'|\\n:u' .\} . \" troff and (daisy-wheel) nroff accents .ds : \\k:\h'-(\\n(.wu*8/10-\*(#H+.1m+\*(#F)'\v'-\*(#V'\z.\h'.2m+\*(#F'.\h'|\\n:u'\v'\*(#V' .ds 8 \h'\*(#H'\(*b\h'-\*(#H' .ds o \\k:\h'-(\\n(.wu+\w'\(de'u-\*(#H)/2u'\v'-.3n'\*(#[\z\(de\v'.3n'\h'|\\n:u'\*(#] .ds d- \h'\*(#H'\(pd\h'-\w'~'u'\v'-.25m'\f2\(hy\fP\v'.25m'\h'-\*(#H' .ds D- D\\k:\h'-\w'D'u'\v'-.11m'\z\(hy\v'.11m'\h'|\\n:u' .ds th \*(#[\v'.3m'\s+1I\s-1\v'-.3m'\h'-(\w'I'u*2/3)'\s-1o\s+1\*(#] .ds Th \*(#[\s+2I\s-2\h'-\w'I'u*3/5'\v'-.3m'o\v'.3m'\*(#] .ds ae a\h'-(\w'a'u*4/10)'e .ds Ae A\h'-(\w'A'u*4/10)'E . \" corrections for vroff .if v .ds ~ \\k:\h'-(\\n(.wu*9/10-\*(#H)'\s-2\u~\d\s+2\h'|\\n:u' .if v .ds ^ \\k:\h'-(\\n(.wu*10/11-\*(#H)'\v'-.4m'^\v'.4m'\h'|\\n:u' . \" for low resolution devices (crt and lpr) .if \n(.H>23 .if \n(.V>19 \ \{\ . ds : e . ds 8 ss . ds o a . ds d- d\h'-1'\(ga . ds D- D\h'-1'\(hy . ds th \o'bp' . ds Th \o'LP' . ds ae ae . ds Ae AE .\} .rm #[ #] #H #V #F C .\" ======================================================================== .\" .IX Title "GENOME-MUSIC-BMR-CALC-COVG 1p" .TH GENOME-MUSIC-BMR-CALC-COVG 1p "2018-07-05" "perl v5.26.2" "User Contributed Perl Documentation" .\" For nroff, turn off justification. Always turn off hyphenation; it makes .\" way too many mistakes in technical documents. .if n .ad l .nh .SH "genome music bmr calc-covg" .IX Header "genome music bmr calc-covg" .SH "NAME" genome music bmr calc\-covg \- Uses calcRoiCovg.c to count covered bases per\-gene for each given tumor\-normal pair of BAMs. .SH "VERSION" .IX Header "VERSION" This document describes genome music bmr calc-covg version 0.04 (2018\-07\-05 at 09:17:13) .SH "SYNOPSIS" .IX Header "SYNOPSIS" genome music bmr calc-covg \-\-gene\-covg\-dir=? \-\-roi\-file=? \-\-reference\-sequence=? \-\-bam\-list=? \-\-output\-dir=? [\-\-cmd\-list\-file=?] [\-\-cmd\-prefix=?] [\-\-normal\-min\-depth=?] [\-\-tumor\-min\-depth=?] [\-\-min\-mapq=?] .PP General usage: .PP .Vb 5 \& ... music bmr calc\-covg \e \& \-\-bam\-list input_dir/bam_list \e \& \-\-output\-dir output_dir/ \e \& \-\-reference\-sequence input_dir/all_sequences.fa \e \& \-\-roi\-file input_dir/all_coding_exons.tsv .Ve .PP To create a list of commands that will allow the processing of each tumor-normal pair in parallel with an \s-1LSF\s0 job scheduler: .PP .Vb 7 \& ... music bmr calc\-covg \e \& \-\-bam\-list input_dir/bam_list \e \& \-\-output\-dir output_dir/ \e \& \-\-reference\-sequence input_dir/all_sequences.fa \e \& \-\-roi\-file input_dir/all_coding_exons.tsv \e \& \-\-cmd_list_file parallelizable_commands \e \& \-\-cmd_prefix bsub .Ve .PP In the above case, the commands printed into the output file \*(L"parallelizable_commands\*(R" can be run in parallel. After they complete, rerun this script as printed directly below (\-\-cmd_list_file and \-\-cmd_prefix have been removed) to merge the parallelized calculations: .PP .Vb 5 \& ... music bmr calc\-covg \e \& \-\-bam\-list input_dir/bam_list \e \& \-\-output\-dir output_dir/ \e \& \-\-reference\-sequence input_dir/all_sequences.fa \e \& \-\-roi\-file input_dir/all_coding_exons.tsv .Ve .SH "REQUIRED ARGUMENTS" .IX Header "REQUIRED ARGUMENTS" .IP "gene-covg-dir \fIText\fR" 4 .IX Item "gene-covg-dir Text" Directory where per-sample gene coverage files are located .IP "roi-file \fIText\fR" 4 .IX Item "roi-file Text" Tab delimited list of ROIs [chr start stop gene_name] (See Description) .IP "reference-sequence \fIText\fR" 4 .IX Item "reference-sequence Text" Path to reference sequence in \s-1FASTA\s0 format .IP "bam-list \fIText\fR" 4 .IX Item "bam-list Text" Tab delimited list of \s-1BAM\s0 files [sample_name normal_bam tumor_bam] (See Description) .IP "output-dir \fIText\fR" 4 .IX Item "output-dir Text" Directory where output files and subdirectories will be written .SH "OPTIONAL ARGUMENTS" .IX Header "OPTIONAL ARGUMENTS" .IP "cmd-list-file \fIText\fR" 4 .IX Item "cmd-list-file Text" A file to write calcRoiCovg commands to (See Description) .IP "cmd-prefix \fIText\fR" 4 .IX Item "cmd-prefix Text" A command that submits a job to your cluster (See Description) .IP "normal-min-depth \fIInteger\fR" 4 .IX Item "normal-min-depth Integer" The minimum read depth to consider a Normal \s-1BAM\s0 base as covered .IP "tumor-min-depth \fIInteger\fR" 4 .IX Item "tumor-min-depth Integer" The minimum read depth to consider a Tumor \s-1BAM\s0 base as covered .IP "min-mapq \fIInteger\fR" 4 .IX Item "min-mapq Integer" The minimum mapping quality of reads to consider towards read depth counts .SH "DESCRIPTION" .IX Header "DESCRIPTION" This script counts bases with sufficient coverage in the ROIs of each gene in the given pairs of tumor-normal \s-1BAM\s0 files and categorizes them into \- \s-1AT, CG\s0 (non-CpG), and CpG counts. It also adds up these base-counts across all ROIs of each gene for each sample, but covered bases that lie within overlapping ROIs are not counted more than once towards these total counts. .PP By default, this script runs a C\-based tool named calcRoiCovg for each sample one after another, taking ~30 mins per sample to generate per-ROI covered base counts. If the results of calcRoiCovg for a sample already exists in the output subdirectory roi_covgs, re-calculation is skipped. This allows you to run your own calcRoiCovg jobs in parallel or on multiple machines (Keep reading). .PP Speed things up by running calcRoiCovg jobs in parallel: If a compute cluster or multiple machines are available, run this script twice as follows: .IP "\(bu" 4 Define cmd-list-file and cmd-prefix to generate a file with commands that can be submitted to a cluster or run manually. These jobs will write per-ROI base counts in a subdirectory roi_covgs. .IP "\(bu" 4 After all the parallelized calcRoiCovg jobs are completed, run this script again to add them up and generate the final per-gene base counts in a subdirectory gene_covgs. Remember to remove the cmd-list-file and cmd-prefix arguments or you will just be re-creating a list of commands. .SH "ARGUMENTS" .IX Header "ARGUMENTS" .IP "\-\-roi\-file" 4 .IX Item "--roi-file" .RS 4 .PD 0 .IP "The regions of interest (ROIs) of each gene are typically regions targeted for sequencing or are merged exon loci (from multiple transcripts) of genes with 2\-bp flanks (splice junctions). ROIs from the same chromosome must be listed adjacent to each other in this file. This allows the underlying C\-based code to run much more efficiently and avoid re-counting bases seen in overlapping ROIs (for overall covered base counts). For per-gene base counts, an overlapping base will be counted each time it appears in an \s-1ROI\s0 of the same gene. To avoid this, be sure to merge together overlapping ROIs of the same gene. BEDtools' mergeBed can help if used per gene." 8 .IX Item "The regions of interest (ROIs) of each gene are typically regions targeted for sequencing or are merged exon loci (from multiple transcripts) of genes with 2-bp flanks (splice junctions). ROIs from the same chromosome must be listed adjacent to each other in this file. This allows the underlying C-based code to run much more efficiently and avoid re-counting bases seen in overlapping ROIs (for overall covered base counts). For per-gene base counts, an overlapping base will be counted each time it appears in an ROI of the same gene. To avoid this, be sure to merge together overlapping ROIs of the same gene. BEDtools' mergeBed can help if used per gene." .RE .RS 4 .RE .IP "\-\-reference\-sequence" 4 .IX Item "--reference-sequence" .RS 4 .IP "The reference sequence in \s-1FASTA\s0 format. If a reference sequence index is not found next to this file (a .fai file), it will be created." 8 .IX Item "The reference sequence in FASTA format. If a reference sequence index is not found next to this file (a .fai file), it will be created." .RE .RS 4 .RE .IP "\-\-bam\-list" 4 .IX Item "--bam-list" .RS 4 .IP "Provide a file containing sample names and normal/tumor \s-1BAM\s0 locations for each. Use the tab\- delimited format [sample_name normal_bam tumor_bam] per line. Additional columns like clinical data are allowed, but ignored. The sample_name must be the same as the tumor sample names used in the \s-1MAF\s0 file (16th column, with the header Tumor_Sample_Barcode)." 8 .IX Item "Provide a file containing sample names and normal/tumor BAM locations for each. Use the tab- delimited format [sample_name normal_bam tumor_bam] per line. Additional columns like clinical data are allowed, but ignored. The sample_name must be the same as the tumor sample names used in the MAF file (16th column, with the header Tumor_Sample_Barcode)." .RE .RS 4 .RE .IP "\-\-output\-dir" 4 .IX Item "--output-dir" .RS 4 .IP "Specify an output directory where the following will be created/written: roi_covgs: Subdirectory containing per-ROI covered base counts for each sample. gene_covgs: Subdirectory containing per-gene covered base counts for each sample. total_covgs: File containing the overall non-overlapping coverages per sample." 8 .IX Item "Specify an output directory where the following will be created/written: roi_covgs: Subdirectory containing per-ROI covered base counts for each sample. gene_covgs: Subdirectory containing per-gene covered base counts for each sample. total_covgs: File containing the overall non-overlapping coverages per sample." .RE .RS 4 .RE .IP "\-\-cmd\-list\-file" 4 .IX Item "--cmd-list-file" .RS 4 .IP "Specify a file into which a list of calcRoiCovg jobs will be written to. These can be scheduled in parallel, and will write per-ROI covered base-counts into the output subdirectory roi_covgs. If cmd-list-file is left unspecified, this script runs calcRoiCovg per sample one after another, taking ~30 mins per sample, but it skips samples whose output is already in roi_covgs." 8 .IX Item "Specify a file into which a list of calcRoiCovg jobs will be written to. These can be scheduled in parallel, and will write per-ROI covered base-counts into the output subdirectory roi_covgs. If cmd-list-file is left unspecified, this script runs calcRoiCovg per sample one after another, taking ~30 mins per sample, but it skips samples whose output is already in roi_covgs." .RE .RS 4 .RE .IP "\-\-cmd\-prefix" 4 .IX Item "--cmd-prefix" .RS 4 .ie n .IP "Specify a job submission command that will be prefixed to each command in cmd-list-file. This makes batch submission easier. Just run the cmd-list-file file as a shell script to submit jobs. cmd-prefix is ""bsub"" if your cluster uses the \s-1LSF\s0 job scheduler, or ""qsub"" in Torque. Add arguments as necessary. For example, ""bsub \-M 4GB"" sets a soft memory limit of 4GB." 8 .el .IP "Specify a job submission command that will be prefixed to each command in cmd-list-file. This makes batch submission easier. Just run the cmd-list-file file as a shell script to submit jobs. cmd-prefix is ``bsub'' if your cluster uses the \s-1LSF\s0 job scheduler, or ``qsub'' in Torque. Add arguments as necessary. For example, ``bsub \-M 4GB'' sets a soft memory limit of 4GB." 8 .IX Item "Specify a job submission command that will be prefixed to each command in cmd-list-file. This makes batch submission easier. Just run the cmd-list-file file as a shell script to submit jobs. cmd-prefix is bsub if your cluster uses the LSF job scheduler, or qsub in Torque. Add arguments as necessary. For example, bsub -M 4GB sets a soft memory limit of 4GB." .RE .RS 4 .RE .PD .SH "LICENSE" .IX Header "LICENSE" Copyright (C) 2010\-2011 Washington University in St. Louis. .PP It is released under the Lesser \s-1GNU\s0 Public License (\s-1LGPL\s0) version 3. See the associated \s-1LICENSE\s0 file in this distribution. .SH "AUTHORS" .IX Header "AUTHORS" .Vb 1 \& Cyriac Kandoth, Ph.D. .Ve .SH "SEE ALSO" .IX Header "SEE ALSO" \&\fBgenome-music-bmr\fR(1), \&\fBgenome-music\fR(1), \&\fBgenome\fR(1)