-
Notifications
You must be signed in to change notification settings - Fork 63
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
0 parents
commit 9620e3b
Showing
4 changed files
with
882 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,273 @@ | ||
<h1 align="center"><img width="300px" src="doc/img/isoseq3.png"/></h1> | ||
<h1 align="center">IsoSeq3</h1> | ||
<p align="center">Scalable De Novo Isoform Discovery</p> | ||
|
||
*** | ||
|
||
## Scope | ||
*IsoSeq3* contains the newest tools to identify transcripts in | ||
PacBio single-molecule sequencing data. | ||
Starting in SMRT Link v6.0.0, those tools power the | ||
*IsoSeq3 GUI-based analysis* application. | ||
A composable workflow of existing tools and algorithms, combined with | ||
a new clustering technique, allows to process the ever-increasing yield of PacBio | ||
machines with similar performance to *IsoSeq1* and *IsoSeq2*. | ||
|
||
|
||
## Overview | ||
- [SMRTbell Designs](README.md#smrtbell-designs) | ||
- [Workflow Overview](README.md#workflow) | ||
- [Real-World Example](README.md#real-world-example) | ||
- [FAQ](README.md#faq) | ||
|
||
## Availability | ||
The latest pre-release, developers-only linux binaries can be found under | ||
[releases](https://github.com/PacificBiosciences/IsoSeq3/releases). | ||
These binaries are not ISO compliant. | ||
For research only. | ||
Not for use in diagnostics procedures. | ||
|
||
Official support is only provided for official and stable SMRT Link builds | ||
provided by PacBio. | ||
|
||
Unofficial support for binary pre-releases is provided via github issues, | ||
not via mail to developers. | ||
|
||
## SMRTbell designs | ||
|
||
PacBio supports three out of four different SMRTbell designs. In all designs, | ||
transcripts are labelled with asymmetric primers, whereas the polyA tail is | ||
optional. Barcodes can be attached in three possible ways, but only two are | ||
supported by PacBio. | ||
|
||
<img width="600px" src="doc/img/barcoding.svg"/> | ||
|
||
### (1) Only cDNA primers, not barcoded | ||
A typical single-sample IsoSeq design with no barcodes. | ||
|
||
### (2) UNSUPPORTED: cDNA primers with a 5' barcode | ||
This barcode scheme is not supported, due to the similarities of the cDNA primers. | ||
|
||
### (3) cDNA primers with a 3' barcode | ||
A typical multi-sample barcoding technique. The barcode is attached to the 3' | ||
primer. | ||
|
||
### (4) cDNA primers with a 3' + 5' barcodes | ||
If there is a need to sequence high-plex samples, an asymmetric approach can | ||
be chosen, in which both, the 3' and 5' primers, are barcoded. | ||
|
||
## Workflow | ||
|
||
<img width="1000px" src="doc/img/isoseq3-workflow.png"/> | ||
|
||
### Input | ||
For each cell, the `<movie>.subreads.bam` and `<movie>.subreads.bam.pbi` | ||
are needed for processing. | ||
|
||
### Consensus calling | ||
Each sequencing run is processed by [*ccs*](https://github.com/PacificBiosciences/unanimity) | ||
to generate one representative consensus sequence for each ZMW. Only ZMWs with | ||
at least one full pass, meaning at least each primer has been seen once, are | ||
used for the subsequent analysis. Furthermore, polishing is not necessary | ||
in this step and is deactivated. | ||
|
||
ccs movie.subreads.bam ccs.bam --no-polish --num-passes 1 | ||
|
||
### Primer removal and demultiplexing | ||
Removal of primers and identification of barcodes is performed using [*lima*](https://github.com/pacificbiosciences/barcoding), | ||
which offers a specialized `--isoseq` mode. | ||
Even in the case that your sample is not barcoded, primer removal is performed | ||
by *lima*. | ||
More information about how to name input primer(+barcode) | ||
sequences in this [FAQ](https://github.com/pacificbiosciences/barcoding#how-can-i-demultiplex-isoseq-data). | ||
|
||
lima ccs.bam barcoded_primers.fasta demux.ccs.bam --isoseq --no-pbi | ||
|
||
Example for a `primer.fasta` that is for a single sample, without barcodes: | ||
|
||
>primer_5p | ||
AAGCAGTGGTATCAACGCAGAGTACATGGGG | ||
>primer_3p | ||
AAGCAGTGGTATCAACGCAGAGTAC | ||
|
||
Example for a two barcodes sample: | ||
|
||
>primer_5p | ||
AAGCAGTGGTATCAACGCAGAGTACATGGGG | ||
>sample_brain_3p | ||
AAGCAGTGGTATCAACGCAGAGTACCACATATCAGAGTGCG | ||
>sample_liver_3p | ||
AAGCAGTGGTATCAACGCAGAGTACACACACAGACTGTGAG | ||
|
||
*Lima* will remove unwanted combinations and orient sequences according to | ||
the asymmetry of the primers. | ||
|
||
From here on, execute the following steps for each output BAM file. | ||
|
||
### Clustering and polishing | ||
*IsoSeq3* wraps all tools into one fat binary. | ||
|
||
$ isoseq3 | ||
isoseq3 - De Novo Transcript Reconstruction | ||
|
||
Tools: | ||
cluster - Cluster CCS reads to transcripts | ||
polish - Polish the clustering output | ||
summarize - Create a barcode overview CSV file | ||
|
||
Examples: | ||
isoseq3 cluster movie.consensusreadset.xml unpolished.bam | ||
isoseq3 polish unpolished.bam movie.subreadset.xml polished.bam | ||
isoseq3 summarize polished.bam summary.csv | ||
|
||
#### Clustering and transcript clean up | ||
Compared to previous IsoSeq approaches, *IsoSeq3* performs a single clustering | ||
technique. | ||
Due to the nature of the algorithm, it can't be efficiently chunked | ||
without creating IO bottlenecks; it is advised to give this step as many cores | ||
as possible. The individual steps of *cluster* are as following: | ||
- [Trimming](https://github.com/PacificBiosciences/trim_isoseq_polyA) of polyA tails | ||
- Rapid concatmer [identification](https://github.com/jeffdaily/parasail) and removal | ||
- Clustering using hierarchical n*log(n) [alignment](https://github.com/lh3/minimap2) and iterative cluster merging | ||
- Unpolished [POA](https://github.com/rvaser/spoa) sequence generation | ||
|
||
##### Input | ||
The input file for *cluster* is one demultiplexed CCS file: | ||
- `<demux.ccs.bam>` or `<demux.ccs.consensusreadset.xml>` | ||
|
||
##### Output | ||
The following output files of *cluster* contain unpolished isoforms: | ||
- `<prefix>.bam` | ||
- `<prefix>.flnc.bam` | ||
- `<prefix>.fasta` | ||
- `<prefix>.bam.pbi` <- Only generated with `--pbi` | ||
- `<prefix>.transcriptset.xml` <- Only relevant for pbsmrtpipe | ||
- `<prefix>.consensusreadset.xml` <- Only relevant for pbsmrtpipe | ||
|
||
Example invocation: | ||
|
||
isoseq3 cluster demux.P5--P3.bam unpolished.bam --verbose | ||
|
||
#### Polishing | ||
Polishing via the tool *polish* is an optional step, but highly recommended. | ||
The algorithm behind *polish* is the *arrow* model that also used for CCS | ||
generation and polishing of de-novo assemblies. This step can be massively | ||
parallelized by splitting the `unpolished.bam` file. Split BAM files can be | ||
generated by *cluster*. | ||
|
||
##### Input | ||
The input files for *polish* are: | ||
- `<unpolished>.bam` or `<unpolished>.transcriptset.xml` | ||
- `<movie_name>.subreads.bam` or `<movie_name>.subreadset.xml` | ||
|
||
##### Output | ||
The following output files of *polish* contain polished isoforms: | ||
- `<prefix>.bam` | ||
- `<prefix>.bam.pbi` <- Only generated with `--pbi` | ||
- `<prefix>.transcriptset.xml` | ||
- `<prefix>.hq.fasta.gz` with predicted accuracy ≥ 0.99 | ||
- `<prefix>.lq.fasta.gz` with predicted accuracy < 0.99 | ||
- `<prefix>.hq.fastq.gz` with predicted accuracy ≥ 0.99 | ||
- `<prefix>.lq.fastq.gz` with predicted accuracy < 0.99 | ||
|
||
Example invocation: | ||
|
||
isoseq3 polish unpolished.bam m54020_171110_2301211.subreads.bam polished.bam | ||
|
||
## Installation | ||
- *ccs*: Get it from the official [SMRT Link](https://www.pacb.com/support/software-downloads/) or compile your own from [unanimity](https://github.com/PacificBiosciences/unanimity) | ||
- *lima*: Pre-compiled binary from [barcoding](https://github.com/pacificbiosciences/barcoding) | ||
- *isoseq3*: Pre-compiled binaries from [releases](https://github.com/PacificBiosciences/IsoSeq3/releases) | ||
|
||
## Real-world example | ||
This is an example of an end-to-end cmd-line-only workflow to get from | ||
subreads to polished isoforms; timings are system dependent: | ||
|
||
$ wget https://downloads.pacbcloud.com/public/dataset/RC0_1cell_2017/m54086_170204_081430.subreads.bam | ||
$ wget https://downloads.pacbcloud.com/public/dataset/RC0_1cell_2017/m54086_170204_081430.subreads.bam.pbi | ||
|
||
$ ccs --version | ||
ccs 3.0.0 (commit f9f505c) | ||
|
||
$ time ccs m54086_170204_081430.subreads.bam m54086_170204_081430.ccs.bam \ | ||
--noPolish --minPasses 1 | ||
|
||
real 50m43.090s | ||
user 3531m35.620s | ||
sys 24m36.884s | ||
|
||
$ cat primers.fasta | ||
>primer_5p | ||
AAGCAGTGGTATCAACGCAGAGTACATGGGG | ||
>primer_3p | ||
AAGCAGTGGTATCAACGCAGAGTAC | ||
|
||
$ lima --version | ||
lima 1.6.1 (commit v1.6.1-1-g77bd658) | ||
|
||
$ time lima m54086_170204_081430.ccs.bam primers.fasta demux.bam \ | ||
--isoseq --no-pbi | ||
|
||
real 0m6.543s | ||
user 0m51.170s | ||
|
||
$ ls demux* | ||
demux.json demux.lima.counts demux.lima.report demux.lima.summary demux.primer_5p--primer_3p.bam demux.primer_5p--primer_3p.subreadset.xml | ||
|
||
$ time isoseq3 cluster demux.primer_5p--primer_3p.bam unpolished.bam --verbose | ||
Read BAM : (200740) 8s 313ms | ||
India : (197869) 9s 204ms | ||
Save flnc file : 35s 366ms | ||
Convert to reads : 36s 967ms | ||
Sort Reads : 69ms 756us | ||
Aligning Linear : 42s 620ms | ||
Read to clusters : 7s 506ms | ||
Aligning Linear : 37s 595ms | ||
Merge by mapping : 37s 645ms | ||
Consensus : 1m 47s | ||
Merge by mapping : 8s 861ms | ||
Consensus : 12s 633ms | ||
Write output : 3s 265ms | ||
Complete run time : 5m 12s | ||
|
||
real 5m12.888s | ||
user 58m35.243s | ||
|
||
$ ls unpolished* | ||
unpolished.bam unpolished.bam.pbi unpolished.cluster unpolished.fasta unpolished.flnc.bam unpolished.flnc.bam.pbi unpolished.flnc.consensusreadset.xml unpolished.transcriptset.xml | ||
|
||
$ time isoseq3 polish unpolished.bam m54086_170204_081430.subreads.bam polished.bam --verbose | ||
14561 | ||
|
||
real 60m37.564s | ||
user 2832m8.382s | ||
$ ls polished* | ||
polished.bam polished.bam.pbi polished.hq.fasta.gz polished.hq.fastq.gz polished.lq.fasta.gz polished.lq.fastq.gz polished.transcriptset.xml | ||
|
||
## FAQ | ||
### BAM tags explained | ||
Following BAM tags are being used: | ||
|
||
- `ib` Barcode summary: triplets delimited by semicolons, each triplet contains two barcode indices and the ZMW counts, delimited by comma. Example: `0,1,20;0,3,5` | ||
- `im` Number of ZMWs associated with this isoform | ||
- `is` ZMW names associated with this isoform | ||
- `iz` Maximum number of subreads used for polishing | ||
- `rq` Predicted accuracy for polished isoform | ||
|
||
Quality values are capped at `93`. | ||
|
||
### Which clustering algorithm is used? | ||
In contrast to its predecessors, *IsoSeq3* does not rely on NP-hard clique | ||
finding, but uses a hierarchical alignment strategy with `O(N*log(N))`. | ||
Recent advances in rapid alignment of long reads make this this approach | ||
feasible. | ||
|
||
### How many CCS reads are used for the unpolished cluster sequence representation? | ||
*Cluster* uses up to 10 CCS reads to generate the unpolished cluster consensus. | ||
|
||
### How many subreads are used for polishing? | ||
*Polish* uses up to 60 subreads to polish the cluster consensus. | ||
|
||
## DISCLAIMER | ||
|
||
THIS WEBSITE AND CONTENT AND ALL SITE-RELATED SERVICES, INCLUDING ANY DATA, ARE PROVIDED "AS IS," WITH ALL FAULTS, WITH NO REPRESENTATIONS OR WARRANTIES OF ANY KIND, EITHER EXPRESS OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, ANY WARRANTIES OF MERCHANTABILITY, SATISFACTORY QUALITY, NON-INFRINGEMENT OR FITNESS FOR A PARTICULAR PURPOSE. YOU ASSUME TOTAL RESPONSIBILITY AND RISK FOR YOUR USE OF THIS SITE, ALL SITE-RELATED SERVICES, AND ANY THIRD PARTY WEBSITES OR APPLICATIONS. NO ORAL OR WRITTEN INFORMATION OR ADVICE SHALL CREATE A WARRANTY OF ANY KIND. ANY REFERENCES TO SPECIFIC PRODUCTS OR SERVICES ON THE WEBSITES DO NOT CONSTITUTE OR IMPLY A RECOMMENDATION OR ENDORSEMENT BY PACIFIC BIOSCIENCES. |
Oops, something went wrong.