Quick Start

From PileLine

(Difference between revisions)
Jump to: navigation, search
(4. Join two sorted GP files by common rows:)
(3. You can also compare multiple samples to report consistent variants.)
 
(28 intermediate revisions not shown)
Line 1: Line 1:
-
==PipeLine Input Files==
+
==PileLine Input Files==
[[File:Glez_Peña_et_al_Figure2.png|right|thumb|PileLine commands and accepted input files.]]
[[File:Glez_Peña_et_al_Figure2.png|right|thumb|PileLine commands and accepted input files.]]
'''PileLine''' is capable to handle, filter and compare genomic position files (GP) including standard [http://samtools.sourceforge.net/pileup.shtml pileup], [http://genome.ucsc.edu/FAQ/FAQformat#format1 BED],[http://genome.ucsc.edu/FAQ/FAQformat#format3 GFF], or [http://1000genomes.org/wiki/doku.php?id=1000_genomes:analysis:vcfv3.2 VCF] files.  
'''PileLine''' is capable to handle, filter and compare genomic position files (GP) including standard [http://samtools.sourceforge.net/pileup.shtml pileup], [http://genome.ucsc.edu/FAQ/FAQformat#format1 BED],[http://genome.ucsc.edu/FAQ/FAQformat#format3 GFF], or [http://1000genomes.org/wiki/doku.php?id=1000_genomes:analysis:vcfv3.2 VCF] files.  
Line 10: Line 10:
  chr10    121636    optional1    optional2    optional3    ...
  chr10    121636    optional1    optional2    optional3    ...
-
==PipeLine Guided Example #1==
+
==PileLine Guided Example #1==
The code included in this tutorial runs on UNIX systems. For Windows you must use '''PileLine''' commands adding .bat extension (i.e. pileline-2smc.bat)  
The code included in this tutorial runs on UNIX systems. For Windows you must use '''PileLine''' commands adding .bat extension (i.e. pileline-2smc.bat)  
-
==='''1.'''  '''Download''' GP files (pileup format) and Annotation files to your working directory:===
+
==='''1.'''  '''Download''' and uncompress GP files (pileup format) and Annotation files to your working directory:===
* GP files-Experiment 1.
* GP files-Experiment 1.
-
:[[File:Control1Files.zip]]
+
:[[Media:Control1Files.zip|Control1Files.zip]]
-
:[[File:Case1Files.zip]]
+
:[[Media:Case1Files.zip|Case1Files.zip]]
* GP files-Experiment 2.
* GP files-Experiment 2.
-
:[[File:Control2Files.zip]]
+
:[[Media:Control2Files.zip|Control2Files.zip]]
-
:[[File:Case2Files.zip]]
+
:[[Media:Case2Files.zip|Case2Files.zip]]
* Annotation files
* Annotation files
-
:[[File:Hg18_hgnc_ensembl_genes.bed.zip]]
+
:[[Media:Hg18_hgnc_ensembl_genes.bed.zip|Hg18_hgnc_ensembl_genes.bed.zip]]
-
:[[File:DbSNP_36.3.txt.zip]]
+
:[[Media:DbSNP_36.3.bed.bgz.zip|DbSNP_36.3.bed.bgz.zip]] (to annotate using rfilter --annotate)
 +
:[[Media:DbSNP_36.3.gpfile.zip|DbSNP_36.3.gpfile.zip]] (to annotate using fastjoin)
 +
 
Each Experiment .zip file contains 2 pileup files:
Each Experiment .zip file contains 2 pileup files:
Line 33: Line 35:
==='''2.'''  You may '''compare 2 samples''' at variant level using '''''pileline-2smc.sh''''' functionality.===
==='''2.'''  You may '''compare 2 samples''' at variant level using '''''pileline-2smc.sh''''' functionality.===
-
Use this command line to compare file A (Control1) vs file B (Case1) :
+
Use this command line to compare file A (Control1) vs file B (Case1), remind that INPUT FILES MUST BE SORTED :
  $ cd DOWNLOADED_FILES_DIRECTORY  
  $ cd DOWNLOADED_FILES_DIRECTORY  
  $ sh YOUR_PATH_TO_PILELINE/cmd/pileline-2smc.sh  
  $ sh YOUR_PATH_TO_PILELINE/cmd/pileline-2smc.sh  
-
  –a ./Control1.pileup –b ./Case1.pileup
+
  -a ./Control1.pileup -b ./Case1.pileup
-
  –v ./Control1.variants.pileup –w ./Case1.variants.pileup  
+
  -v ./Control1.variants.pileup -w ./Case1.variants.pileup  
-
  –o ./myoutput1.txt
+
  -o ./myoutput1.txt
Line 89: Line 91:
Now, run '''''pileline-2smc.sh''''' to compare Case2 vs Control2:
Now, run '''''pileline-2smc.sh''''' to compare Case2 vs Control2:
  $ sh YOUR_PATH_TO_PILELINE/cmd/pileline-2smc.sh  
  $ sh YOUR_PATH_TO_PILELINE/cmd/pileline-2smc.sh  
-
  –a ./Control2.pileup –b ./Case2.pileup
+
  -a ./Control2.pileup -b ./Case2.pileup
-
  –v ./Control2.variants.pileup –w ./Case2.variants.pileup  
+
  -v ./Control2.variants.pileup -w ./Case2.variants.pileup  
-
  –o ./myoutput2.txt
+
  -o ./myoutput2.txt
==='''3.'''  You can also '''compare  multiple samples''' to report consistent variants. ===
==='''3.'''  You can also '''compare  multiple samples''' to report consistent variants. ===
You should use '''''pileline-nsmc.sh''''' command.  
You should use '''''pileline-nsmc.sh''''' command.  
-
In the following example we compare 4 samples (Control1 and Control2 variants vs Case1 and Case2 variants) but '''''pileline-nsmc.sh''''' can be applied to n samples:
+
In the following example we compare 4 samples (Control1 and Control2 variants vs Case1 and Case2 variants) but '''''pileline-nsmc.sh''''' can be applied to n samples (reminder: INPUT FILES MUST BE SORTED):
  $ sh YOUR_PATH_TO_PILELINE/cmd/pileline-nsmc.sh  
  $ sh YOUR_PATH_TO_PILELINE/cmd/pileline-nsmc.sh  
Line 134: Line 136:
==='''4.''' Variants annotation (e.g. SNPs, Ensembl IDs, HGNC Gene Names ...)===
==='''4.''' Variants annotation (e.g. SNPs, Ensembl IDs, HGNC Gene Names ...)===
-
To annotate SNPs in variants found between Case1 and Control1 , you should execute '''''pileline-fastjoin.sh''''' command as follows:
+
To annotate SNPs in variants found between Case1 and Control1, you have two choices:
 +
 
 +
* Use the dbSNP_36.3.bed.bgz (a BED, that is, an intervals GP file) and execute '''''pileline-rfilter.sh --annotate''''' command as follows:
 +
$ sh YOUR_PATH_TO_PILELINE/cmd/pileline-rfilter --annotate
 +
-A ./myoutput1.txt.onlyB.pileup
 +
-i ./dbSNP_36.3.gpfile > ./mydbSNPannotation1.txt
 +
 
 +
* Use the dbSNP_36.3.gpfile (a single-nucleotide GP file) and execute '''''pileline-fastjoin.sh''''' command as follows:
  $ sh YOUR_PATH_TO_PILELINE/cmd/pileline-fastjoin.sh  
  $ sh YOUR_PATH_TO_PILELINE/cmd/pileline-fastjoin.sh  
-
  –a ./myoutput1.txt.onlyB.pileup  
+
  -a ./myoutput1.txt.onlyB.pileup  
-
  -b ./dbSNP_36.3.txt --left-outer-join > ./mydbSNPannotation1.txt
+
  -b ./dbSNP_36.3.gpfile --left-outer-join > ./mydbSNPannotation1.txt
The output file (mydbSNPannotation1.txt) generated contains the same information as the input file but adding a new annotation column. SNPs are annotated with their respective dbSNP ID (i.e.rs7906865). Those variants which do not match to reported SNPs are annotated with NULL label.
The output file (mydbSNPannotation1.txt) generated contains the same information as the input file but adding a new annotation column. SNPs are annotated with their respective dbSNP ID (i.e.rs7906865). Those variants which do not match to reported SNPs are annotated with NULL label.
Line 145: Line 154:
  $ sh YOUR_PATH_TO_PILELINE/cmd/pileline-rfilter.sh  
  $ sh YOUR_PATH_TO_PILELINE/cmd/pileline-rfilter.sh  
-
  --annotate –A ./mydbSNPannotation1.txt
+
  --annotate -A ./mydbSNPannotation1.txt
-
  –i ./hg18_hgnc_ensembl_genes.bed > ./mydbSNPandGeneannotation1.txt
+
  -b ./hg18_hgnc_ensembl_genes.bed > ./mydbSNPandGeneannotation1.txt
-
Note here that you can customize your annotations using your own BED file.
+
Note here that you can customize your annotations using your own BED file. Combining ''pileline-rfilter.sh''  and basic UNIX commands you can even '''annotate your pileup files with multiple .BED files''' using a single command line. See the following example:
 +
cat mypileup | pileline-rfilter.sh --annotate -A - -i annotations_file1.bed | pileline-rfilter.sh --annotate -A - -i annotations_file2.bed > myfullyannotated.pileup
==='''5.''' Generate input for external mutational effects prediction software.===
==='''5.''' Generate input for external mutational effects prediction software.===
Line 168: Line 178:
==='''1.'''  '''Download''' GP files (vcf, .bed and .gff format):===
==='''1.'''  '''Download''' GP files (vcf, .bed and .gff format):===
-
:[[File:GP_Files_vcf_bed_gff.zip]]
+
:[[Media:GP_Files_vcf_bed_gff.zip|GP_Files_vcf_bed_gff.zip]]
This .zip compressed file contains 3 GP files:
This .zip compressed file contains 3 GP files:
Line 175: Line 185:
#'''TestBed.bed'''
#'''TestBed.bed'''
#'''TestGff.gff'''
#'''TestGff.gff'''
 +
#'''My.intervals.gff'''
* Note: All the guided examples showed here may be also applied to .pileup files.
* Note: All the guided examples showed here may be also applied to .pileup files.
Line 212: Line 223:
==='''5.''' Filters''' (or annotates) a GP file:===
==='''5.''' Filters''' (or annotates) a GP file:===
-
'''.vcf'''  
+
'''Annotate a .vcf file with Ensembl IDs contained in a .bed file'''  
  $ cd DOWNLOADED_FILES_DIRECTORY  
  $ cd DOWNLOADED_FILES_DIRECTORY  
-
  $ sh YOUR_PATH_TO_PILELINE/cmd/pileline-rfilter.sh
+
  $ sh YOUR_PATH_TO_PILELINE/cmd/pileline-rfilter.sh --annotate -A ./My.sorted.Vcf -b ./hg18_hgnc_ensembl_genes.bed
-
'''.bed'''
+
'''Filter .bed using a .gff file containing intervals to be filtered '''
-
$ cd DOWNLOADED_FILES_DIRECTORY
+
-
$ sh YOUR_PATH_TO_PILELINE/cmd/pileline-rfilter.sh
+
-
'''.gff'''
+
  $ cd DOWNLOADED_FILES_DIRECTORY  
  $ cd DOWNLOADED_FILES_DIRECTORY  
-
  $ sh YOUR_PATH_TO_PILELINE/cmd/pileline-rfilter.sh
+
  $ sh YOUR_PATH_TO_PILELINE/cmd/pileline-rfilter.sh -A ./My.sorted.bed -g ./My.intervals.gff --start-col-intervals 4 --end-col-intervals 5

Latest revision as of 12:15, 31 August 2011

Contents

PileLine Input Files

PileLine commands and accepted input files.

PileLine is capable to handle, filter and compare genomic position files (GP) including standard pileup, BED,GFF, or VCF files.

Basically, GP are tabular files where the two first columns contain sequence name (i.e. chromosome name) and position coordinate respectively. Additional optional fields are accepted in PileLine, see an example of GP input file below:

chr10     118829     optional1     optional2     optional3     ...    
chr10     121207     optional1     optional2     optional3     ...
chr10     121337     optional1     optional2     optional3     ...
chr10     121636     optional1     optional2     optional3     ...

PileLine Guided Example #1

The code included in this tutorial runs on UNIX systems. For Windows you must use PileLine commands adding .bat extension (i.e. pileline-2smc.bat)

1. Download and uncompress GP files (pileup format) and Annotation files to your working directory:

  • GP files-Experiment 1.
Control1Files.zip
Case1Files.zip
  • GP files-Experiment 2.
Control2Files.zip
Case2Files.zip
  • Annotation files
Hg18_hgnc_ensembl_genes.bed.zip
DbSNP_36.3.bed.bgz.zip (to annotate using rfilter --annotate)
DbSNP_36.3.gpfile.zip (to annotate using fastjoin)


Each Experiment .zip file contains 2 pileup files:

  • Whole pileup file (.pileup)
  • Variants against reference genome pileup file (.variants.pileup).

2. You may compare 2 samples at variant level using pileline-2smc.sh functionality.

Use this command line to compare file A (Control1) vs file B (Case1), remind that INPUT FILES MUST BE SORTED :

$ cd DOWNLOADED_FILES_DIRECTORY 
$ sh YOUR_PATH_TO_PILELINE/cmd/pileline-2smc.sh 
-a ./Control1.pileup -b ./Case1.pileup
-v ./Control1.variants.pileup -w ./Case1.variants.pileup 
-o ./myoutput1.txt


Executing this command using by default parameters you will obtain 4 output files containing:

  • myoutput1.txt.onlyA: Only variants found in File A. In this example variants found in Control1 but not in Case1 (i.e. germ-line reverted mutations or SNPs)
  • myoutput1.txt.onlyB: Only variants found in File B. In this case, variants found in Case1 but not in Control1 (i.e. somatic mutations or SNPs)
  • myoutput1.txt.both: Both File A and File B variants present the same allele and both of them are different to the reference genome allele. (i.e. germ-line variants or SNPs)
  • myoutput1.txt.AdiscrepantB: Both File A and File B variants present different alleles and both of them are different to the reference genome allele. (i.e. germ-line variants mutated or SNPs).

See an example in this table:

pileline-2smc.sh output files
Ref genome File A File B Output File Name
T A T myoutput1.txt.onlyA
T T G myoutput1.txt.onlyB
T A A myoutput1.txt.both
T C G myoutput1.txt.AdiscrepantB


pileline-2smc.sh output file format specifications are shown in the next table:

pileline-2smc.sh output files format
Chr Position Ref Genome Allele Variant Allele File ID Variant Score FileA_inputdata FileB_inputdata

See an explained example here:

10	116237	G	A	A	234	...	...	# Variant (G => A) found in File A (Control1 in this example)		
10	116402	T	C	B	424	...	...	# Variant (T => C) found in File B (Case1 in this example)
10	118829	A	G	AB	125	...	...	# Variant (A => G) found in both A and B files (Control and Case1)
10	118845	A	K	D	127	...	...	# Discrepant variant (A => K) found in both A and B files (Control and Case1). IUPAC code is used here.

Note: If you apply pileline-2smc.sh to pileup files you'll find a variant score in the output file. This score reports the sum of Phred-scale Consensus Qualities (PCQ) for each position in both conditions (PCQ_Control + PCQ_Case).


Now, run pileline-2smc.sh to compare Case2 vs Control2:

$ sh YOUR_PATH_TO_PILELINE/cmd/pileline-2smc.sh 
-a ./Control2.pileup -b ./Case2.pileup
-v ./Control2.variants.pileup -w ./Case2.variants.pileup 
-o ./myoutput2.txt

3. You can also compare multiple samples to report consistent variants.

You should use pileline-nsmc.sh command. In the following example we compare 4 samples (Control1 and Control2 variants vs Case1 and Case2 variants) but pileline-nsmc.sh can be applied to n samples (reminder: INPUT FILES MUST BE SORTED):

$ sh YOUR_PATH_TO_PILELINE/cmd/pileline-nsmc.sh 
-a  ./Control1.variants.pileup -a ./Control2.variants.pileup 
-b ./Case1.variants.pileup -b ./Case2.variants.pileup
-o ./mycommonvariants.txt

The output file (mycommonvariants.txt in this tutorial) contains the following information:

pileline-nsmc.sh output files
Chr Position Ref Genome Allele Variant Allele Presence of variant in -a files Presence of variant in -b files # of samples containing the variant Fisher's test p-value FDR

pileline-nsmc.sh performs a Fisher's test to estimate dependency amongst variants presence and samples type. The False Discovery Rate (FDR) is obtained by using Benjamini-Hochberg adjustment.


See next an example of the pileline-nsmc.sh output file:

10	115839	C	Y	NO	NO	NO	YES	1	0.50000002	1.0
10	116237	G	R	NO	YES	NO	YES	2	1.00000002	1.0
10	116402	T	C	YES	YES	NO	YES	3	0.50000002	1.0
10	116699	C	M	NO	YES	NO	YES	2	1.00000002	1.0
10	118829	A	R	YES	YES	YES	YES	4	1.00000002	1.0
10	6101971	A	M	YES	YES	NO	NO	2	0.16666669	1.0
...
10	42940557	G	R	NO	NO	YES	YES	2	0.166666667	1

In this case the variant located at position 6101971 has been found in both Control samples (-a files) but not in Case samples (-b files). On the contrary, the variant located in position 42940557 has been found in both Cases samples but not in Controls.


Note that pileline-nsmc.sh command may be particularly useful whether you want to find common variants in biological replicates. You should run pileline-nsmc.sh in this way:

$ sh YOUR_PATH_TO_PILELINE/cmd/pileline-nsmc.sh 
-a /Case1.variants.pileup -a ./Case2.variants.pileup
-o  ./mycommonvariants_in_Cases.txt

4. Variants annotation (e.g. SNPs, Ensembl IDs, HGNC Gene Names ...)

To annotate SNPs in variants found between Case1 and Control1, you have two choices:

  • Use the dbSNP_36.3.bed.bgz (a BED, that is, an intervals GP file) and execute pileline-rfilter.sh --annotate command as follows:
$ sh YOUR_PATH_TO_PILELINE/cmd/pileline-rfilter --annotate 
-A ./myoutput1.txt.onlyB.pileup 
-i ./dbSNP_36.3.gpfile > ./mydbSNPannotation1.txt
  • Use the dbSNP_36.3.gpfile (a single-nucleotide GP file) and execute pileline-fastjoin.sh command as follows:
$ sh YOUR_PATH_TO_PILELINE/cmd/pileline-fastjoin.sh 
-a ./myoutput1.txt.onlyB.pileup 
-b ./dbSNP_36.3.gpfile --left-outer-join > ./mydbSNPannotation1.txt

The output file (mydbSNPannotation1.txt) generated contains the same information as the input file but adding a new annotation column. SNPs are annotated with their respective dbSNP ID (i.e.rs7906865). Those variants which do not match to reported SNPs are annotated with NULL label.


In order to annotate the variants with Gene Symbols, you need the pileline-rfilter.sh command:

$ sh YOUR_PATH_TO_PILELINE/cmd/pileline-rfilter.sh 
--annotate -A ./mydbSNPannotation1.txt
-b ./hg18_hgnc_ensembl_genes.bed > ./mydbSNPandGeneannotation1.txt

Note here that you can customize your annotations using your own BED file. Combining pileline-rfilter.sh and basic UNIX commands you can even annotate your pileup files with multiple .BED files using a single command line. See the following example:

cat mypileup | pileline-rfilter.sh --annotate -A - -i annotations_file1.bed | pileline-rfilter.sh --annotate -A - -i annotations_file2.bed > myfullyannotated.pileup

5. Generate input for external mutational effects prediction software.

Finally, you may be interested in generate SIFT, Polyphen and Firestar compatible input files to predict the functional consequences of variants found between Case1 and Control1. Use pileline-pileup2sift.sh and pileline-pileup2polyphen.sh commands to this end.

#To generate SIFT-compatible inputs
$ sh YOUR_PATH_TO_PILELINE/cmd/pileline-pileup2sift.sh -i ./mydbSNPandGeneannotation1.txt > ./mysiftinput.txt
#To generate PolyPhen-compatible inputs:
$ sh YOUR_PATH_TO_PILELINE/cmd/pileline-pileup2polyphen.sh -i ./mydbSNPandGeneannotation1.txt > ./mypolypheninput.txt
#To generate Firestar-compatible inputs:
$ sh YOUR_PATH_TO_PILELINE/cmd/pileline-pileup2firestar.sh -i ./mydbSNPandGeneannotation1.txt > ./myfirestarinput.txt

PipeLine Guided Example #2

The code included in this tutorial runs on UNIX systems. For Windows you must use PileLine commands adding .bat extension (i.e. pileline-fastseek.bat)

1. Download GP files (vcf, .bed and .gff format):

GP_Files_vcf_bed_gff.zip

This .zip compressed file contains 3 GP files:

  1. TestVcf.vcf
  2. TestBed.bed
  3. TestGff.gff
  4. My.intervals.gff
  • Note: All the guided examples showed here may be also applied to .pileup files.

2. Sort GP files by chromosomic positions:

.vcf

$ cd DOWNLOADED_FILES_DIRECTORY 
$ sh YOUR_PATH_TO_PILELINE/cmd/pileline-sort.sh -i ./TestVcf.vcf -o ./My.sorted.Vcf

.bed

$ cd DOWNLOADED_FILES_DIRECTORY 
$ sh YOUR_PATH_TO_PILELINE/cmd/pileline-sort.sh -i ./TestBed.bed -o ./My.sorted.bed

.gff

$ cd DOWNLOADED_FILES_DIRECTORY 
$ sh YOUR_PATH_TO_PILELINE/cmd/pileline-sort.sh -i ./TestGff.gff --pos-col 4  -o ./My.sorted.gff

3. Search for chromosomic positions within the GP files:

.vcf

$ cd DOWNLOADED_FILES_DIRECTORY 
$ sh YOUR_PATH_TO_PILELINE/cmd/pileline-fastseek.sh -p ./My.sorted.Vcf -s 1:762969:804635

.bed

$ cd DOWNLOADED_FILES_DIRECTORY 
$ sh YOUR_PATH_TO_PILELINE/cmd/pileline-fastseek.sh -p ./My.sorted.bed -s 9:138938078:138940781

.gff

$ cd DOWNLOADED_FILES_DIRECTORY 
$ sh YOUR_PATH_TO_PILELINE/cmd/pileline-fastseek.sh -p ./My.sorted.gff --pos-col 4 -s 7:157540895:157681138

4. Join two sorted GP files by common rows (if any):

.vcf and .bed

$ cd DOWNLOADED_FILES_DIRECTORY 
$ sh YOUR_PATH_TO_PILELINE/cmd/pileline-fastjoin.sh -a My.sorted.Vcf -b My.sorted.bed

.vcf and .gff

$ cd DOWNLOADED_FILES_DIRECTORY 
$ sh YOUR_PATH_TO_PILELINE/cmd/pileline-fastjoin.sh -a My.sorted.Vcf -b My.sorted.gff --pos-col-b 4

bed and .gff

$ cd DOWNLOADED_FILES_DIRECTORY 
$ sh YOUR_PATH_TO_PILELINE/cmd/pileline-fastjoin.sh -a My.sorted.bed -b My.sorted.gff --pos-col-b 4

5. Filters (or annotates) a GP file:

Annotate a .vcf file with Ensembl IDs contained in a .bed file

$ cd DOWNLOADED_FILES_DIRECTORY 
$ sh YOUR_PATH_TO_PILELINE/cmd/pileline-rfilter.sh --annotate -A ./My.sorted.Vcf -b ./hg18_hgnc_ensembl_genes.bed

Filter .bed using a .gff file containing intervals to be filtered

$ cd DOWNLOADED_FILES_DIRECTORY 
$ sh YOUR_PATH_TO_PILELINE/cmd/pileline-rfilter.sh -A ./My.sorted.bed -g ./My.intervals.gff --start-col-intervals 4 --end-col-intervals 5
Personal tools