diff --git a/README.md b/README.md index 5f4bbd4..7ca05ae 100644 --- a/README.md +++ b/README.md @@ -1,14 +1,14 @@ ![pizzly](logo.jpg) -# pizzly +# pizzly Fast fusion detection using kallisto ### About -pizzly is a program for detecting gene fusions from RNA-Seq data of cancer samples. +pizzly is a program for detecting gene fusions from RNA-Seq data of cancer samples. It requires running [kallisto](https://pachterlab.github.io/kallisto) with the `--fusion` -parameter (available in version `0.43.1` or later). +parameter (available in version `0.43.1` or later). ### Building @@ -31,7 +31,7 @@ make install Pizzly requires the reference transcriptome in FASTA format as well as a GTF file describing the transcriptome. We recommend using the [Ensembl](http://www.ensembl.org/index.html) transcriptomes. -The example below assumes you have your transcriptome in FASTA format as `transcripts.fa.gz`, the GTF file `transcripts.gtf.gz` +The example below assumes you have your transcriptome in FASTA format as `transcripts.fa.gz`, the GTF file `transcripts.gtf.gz` and your paired-end RNA-Seq data sets in `r1.fastq.gz` and `r2.fastq.gz` ### Running @@ -48,19 +48,34 @@ Next we quantify using kallisto with fusion detection enabled kallisto quant -i index.idx --fusion -o output r1.fastq.gz r2.fastq.gz ``` -This creates the file `output/fusion.txt` which is used by pizzly, finally we run pizzly +This creates the file `output/fusion.txt` which is used by pizzly. Next, we +get the insert size + +``` +pizzly_get_fragment_length.py output/abundance.h5 +400 +``` + +Finally we run pizzly ``` pizzly -k 31 --gtf transcripts.gtf --cache index.cache.txt --align-score 2 \ --insert-size 400 --fasta transcripts.fa.gz --output test output/fusion.txt ``` -The parameters to set are +Optionally, pizzly transcript-level fusion calls can be collapsed down to gene +level fusion calls by using the `pizzly_flatten_json.py` script + +``` +pizzly_flatten_json.py test.json > test-fusion-genes.tsv +``` + +The parameters to set are * `--insert-size`, which should be the maximum insert size of the paired-end library (kallisto will estimate this from the reads, default used is 400) * `--align-score`, the number of mismatches allowed when aligning reads to a reference transcript (default used is 2) `--ignore-protein`, ignore any information about protein coding in the annotation, **warning** this will probably lead to an increase in the number of false positives reported. -* `--cache`, if this file does not exist, pizzly will parse the GTF (which can take up to a minute or two) and store the required data in the cached file. If the cache file exists (if you've run pizzly previously on the same GTF file), pizzly will parse this file instead, which is much faster than parsing the GTF. +* `--cache`, if this file does not exist, pizzly will parse the GTF (which can take up to a minute or two) and store the required data in the cached file. If the cache file exists (if you've run pizzly previously on the same GTF file), pizzly will parse this file instead, which is much faster than parsing the GTF. A more sophisticated example is in the `test` directory which contains a `snakemake` workflow to index, quantify, call fusions and requantify using `kallisto` and `pizzly`. @@ -75,8 +90,8 @@ The `--output test` parameter is used as a prefix and two files are created `tes The `scripts` subfolder contains useful Python scripts -- `get_fragment_length.py` examines an `abundance.h5` produced by `kallisto` and finds the 95th percentile of the fragment length distribution -- `flatten_json.py` reads the `.json` output and converts to a simple gene table +- `pizzly_get_fragment_length.py` examines an `abundance.h5` produced by `kallisto` and finds the 95th percentile of the fragment length distribution +- `pizzly_flatten_json.py` reads the `.json` output and converts to a simple gene table ### Annotations diff --git a/scripts/flatten_json.py b/scripts/pizzly_flatten_json.py similarity index 92% rename from scripts/flatten_json.py rename to scripts/pizzly_flatten_json.py index 3679011..979b7da 100644 --- a/scripts/flatten_json.py +++ b/scripts/pizzly_flatten_json.py @@ -1,3 +1,4 @@ +#!/usr/bin/env python -Es import sys import json from collections import OrderedDict @@ -26,7 +27,7 @@ def outputGeneTable(fusions, outf, filters = None): outf.write('\n') def usage(): - print("Usage: python flatten_json.py fusion.out.json [genetable.txt]") + print("Usage: python pizzly_flatten_json.py fusion.out.json [genetable.txt]") print("") print(" outputs a flat table listing all gene fusions, if the output file is not") print(" specified it prints to standard output") diff --git a/scripts/get_fragment_length.py b/scripts/pizzly_get_fragment_length.py similarity index 75% rename from scripts/get_fragment_length.py rename to scripts/pizzly_get_fragment_length.py index 5b48543..22ab8ed 100644 --- a/scripts/get_fragment_length.py +++ b/scripts/pizzly_get_fragment_length.py @@ -1,18 +1,19 @@ +#!/usr/bin/env python -Es import h5py import numpy as np import sys def get_cumulative_dist(fn): - f = h5py.File(fn) - x = np.asarray(f['aux']['fld'], dtype='float64') + with h5py.File(fn) as f: + x = np.asarray(f['aux']['fld'], dtype='float64') y = np.cumsum(x)/np.sum(x) f.close() return y if __name__ == "__main__": if len(sys.argv) < 2: - print("Usage: python get_fragment_length.py H5FILE [cutoff]") + print("Usage: python pizzly_get_fragment_length.py H5FILE [cutoff]") print("") print("Prints 95 percentile fragment length") print("") @@ -27,5 +28,5 @@ def get_cumulative_dist(fn): else: cutoff = 0.95 y = get_cumulative_dist(fn) - fraglen = np.argmax(y > .95) + fraglen = np.argmax(y > cutoff) print(fraglen)