Skip to content

Latest commit

 

History

History
374 lines (290 loc) · 30.9 KB

Daijin_tutorial.spombe.rst

File metadata and controls

374 lines (290 loc) · 30.9 KB

Tutorial for Daijin

This tutorial will guide you through the task of configuring and running the whole Daijin pipeline on a S. pombe dataset, using one aligner (HISAT) and two assemblers (Stringtie and CLASS2) as chosen methods. A modern desktop computer with a multicore processor and 4GB of RAM or more should suffice to execute the pipeline.

Overview

The tutorial will guide you through the following tasks:

  1. Configuring Daijin to analyse the chosen data
  2. Running the alignment and assemblies using daijin assemble
  3. Running the Mikado analysis using daijin mikado
  4. Comparing the results against the reference transcriptome

Required software

Mikado should be installed and configured properly (see our :ref:`installation instructions <Installation>`). Additionally, you should have the following software tools at disposal (between brackets is indicated the version used at the time of the writing):

  • BLAST+ (v2.3.0)
  • TransDecoder (v3.0.0)
  • Portcullis (v0.17.2)
  • HISAT2 (v2.0.4)
  • Stringtie (v1.2.4)
  • CLASS2 (v2.12)
  • SAMtools (v1.2)

Input data

Throughout this tutorial, we will use data coming from release 32 of EnsEMBL and from the SRR1617247 experiment on ENA. In particular, we will need:

  • the genome FASTA file of Schizosaccharomyces pombe
  • its relative genome annotation
  • RNA-Seq from the SRR1617247 experiment: left and right.
  • the SwissProt fungi database (downloaded from here, using Uniprot release 2016-07)

Uncompress the genome, the annotation GFF3 and the Uniprot DAT files using GUNZip. The protein database must be converted into FASTA format, and we should remove the Sc. pombe proteins to avoid biasing our results. To do so, use the script remove_from_embl.py (included in Mikado):

remove_from_embl.py --format fasta -o "Schizosaccharomyces pombe" uniprot_sprot_fungi.dat uniprot_sprot_fungi.fasta

It is possible to have a feel for the annnotation of this species - the size of its genes and transcripts, the average number of exons per transcript, etc - by using mikado util stats; just issue the following command:

mikado util stats Schizosaccharomyces_pombe.ASM294v2.32.gff3 Schizosaccharomyces_pombe.ASM294v2.32.gff3.stats

The file Schizosaccharomyces_pombe.ASM294v2.32.gff3.stats contains the following information:

Stat Total Average Mode Min 1% 5% 10% 25% Median 75% 90% 95% 99% Max
Number of genes 7014 NA NA NA NA NA NA NA NA NA NA NA NA NA
Number of genes (coding) 5145 NA NA NA NA NA NA NA NA NA NA NA NA NA
Number of monoexonic genes 4461 NA NA NA NA NA NA NA NA NA NA NA NA NA
Transcripts per gene 7015 1.00 1 1 1 1 1 1 1 1 1 1 1 2
Coding transcripts per gene 5146 0.73 1 0 0 0 0 0 1 1 1 1 1 2
CDNA lengths 12586389 1,794.21 72 47 72 185 448 922 1,549 2,363 3,400 4,151 5,894 15,022
CDNA lengths (mRNAs) 10592917 2,058.48 1315 75 283 546 753 1,201 1,792 2,613 3,675 4,425 6,404 15,022
CDS lengths 7178717 1,023.34 0 0 0 0 0 0 795 1,500 2,339 3,045 4,994 14,775
CDS lengths (mRNAs) NA 1,023.34 0 0 0 0 0 0 795 1,500 2,339 3,045 4,994 14,775
CDS/cDNA ratio NA 67.48 100.0 5 15 28 37 53 70 84 93 100 100 100
Monoexonic transcripts 4461 1,745.01 72 47 72 100 336 811 1,489 2,344 3,432 4,179 6,019 14,362
MonoCDS transcripts 2753 1,485.99 4002;375;432 93 218 332 418 732 1,191 1,806 2,849 3,784 5,875 14,154
Exons per transcript 12379 1.76 1 1 1 1 1 1 1 2 4 4 7 16
Exons per transcript (mRNAs) 3081 2.03 1 1 1 1 1 1 1 3 4 5 7 16
Exon lengths NA 1,016.75 72 2 25 61 83 184 561 1,502 2,548 3,326 5,015 14,362
Exon lengths (mRNAs) NA 1,013.39 106 3 24 59 86 175 499 1,516 2,605 3,414 5,117 14,362
Intron lengths NA 83.69 49 1 17 38 41 46 56 85 162 226 411 2,526
Intron lengths (mRNAs) NA 84.16 46 1 36 39 41 46 56 86 162 227 412 2,526
CDS exons per transcript 2091 1.46 1 0 0 0 0 0 1 2 3 4 7 16
CDS exons per transcript (mRNAs) 2091 1.99 1 1 1 1 1 1 1 3 4 5 7 16
CDS exon lengths 7178717 702.76 69;99 1 8 29 49 106 307 990 1,797 2,474 4,370 14,154
CDS Intron lengths 414501 81.77 44;45 0 35 38 40 45 55 84 157 220 395 2,525
5'UTR exon number 5146 0.95 1 0 0 0 1 1 1 1 1 1 2 3
3'UTR exon number 5146 0.93 1 0 0 0 1 1 1 1 1 1 2 3
5'UTR length 1372304 266.67 0 0 0 0 17 71 154 309 586 932 1,935 4,397
3'UTR length 2041896 396.79 0 0 0 0 46 126 243 441 865 1,386 2,644 5,911
Stop distance from junction NA 7.58 0 0 0 0 0 0 0 0 0 0 23 3,385
Intergenic distances NA -59.13 -66 -9,461 -3,779 -2,220 -1,425 -188 80 383 857 1,303 2,734 31,961
Intergenic distances (coding) NA 297.72 -66 -7,815 -3,477 -1,598 -440 -32 176 600 1,302 1,913 3,924 78,421

From this summary it is quite apparent that the Sc. pombe genome preferentially encodes single-exon transcripts, and that the multiexonic transcripts have relatively short introns (average of 84 bps, median of 56 bps).

Step 1: configuring Daijin

The first task is to create a configuration file for Daijin using daijin configure. On the command line, we have to configure the following:

  • name of the configuration file (daijin.yaml)
  • number of threads per process (5)
  • reference genome and the name of the species (without spaces or non-ASCII/special characters)
  • reads to use, with their strandedness and the name of the sample
  • aligners (HISAT2) and assemblers (Stringtie, CLASS2) to use
  • output directory (daijin_spombe)
  • the scoring file to use for Mikado pick; we will ask to copy it in-place to have a look at it (spombe.yaml)
  • the protein database for homology searches for Mikado (uniprot_sprot.fungi.fasta)
  • (optional) the scheduler to use for the cluster (we will presume SLURM, but we also support LSF and PBS)
  • (optional) name of the cluster configuration file, which will have to be edited manually.

This can all be specified with the following command line:

daijin configure \
    -o daijin.yaml \
    --threads 5 \
    --genome Schizosaccharomyces_pombe.ASM294v2.dna.toplevel.fa --name "Sc_pombe" \
    -od daijin_spombe \
    -r1 SRR1617247_1.fastq.gz -r2 SRR1617247_2.fastq.gz --strandedness fr-secondstrand -s SRR1617247 \
    -al hisat -as stringtie class \
    --scoring spombe.yaml --copy-scoring spombe.yaml \
    --prot-db uniprot_sprot_fungi.fasta \
    --scheduler SLURM \
    -c slurm.yaml;

This will produce a file, daijin.yaml, which should specify the same parameters as :download:`this preformed example <daijin.yaml>`.

If you are executing this program on a cluster, you will have to modify the "load" section and specify for each software which operations should be performed to make the tool available to the submitted script (eg. "source mikado-1.0.0" to make Mikado available). For example, this is how our load section looks like after editing:

load:
    #  Commands to use to load/select the versions of the programs to use. Leave an empty
    #  string if no loading is necessary.
    blast: 'source blast-2.3.0'
    class: 'source class-2.12'
    cufflinks: ''
    gmap: ''
    hisat: 'source HISAT-2.0.4'
    mikado: 'source mikado-devel'
    portcullis: 'source portcullis-0.17.2'
    samtools: 'source samtools-1.2'
    star: ''
    stringtie: 'source stringtie-1.2.4'
    tophat: ''
    transdecoder: 'source transdecoder-3.0.0'
    trinity: ''

Also, if you are operating on a cluster, you might want to edit the cluster configuration file "slurm.conf". This is how it appears:

.. literalinclude:: ../Usage/hpc.yaml

The most important parameter to modify is the queue to use - set it according to the configuration of your own cluster.

Step 2: running the assemble part

Now that we have created a proper configuration file, it is time to launch Daijin assemble and inspect the results. Issue the command:

daijin assemble -c slurm.yaml daijin.yaml

After checking that the configuration file is valid, Daijin will start the alignment and assembly of the dataset. On a normal desktop computer, this should take ~2 hours. Before launching the pipeline, you can obtain a graphical representation of the steps with:

daijin assemble -c slurm.yaml --dag daijin.yaml | dot -Tsvg > assemble.svg

You can also ask Daijin to display the steps to be executed, inclusive of their command lines, by issuing the following command:

daijin assemble -c slurm.yaml --dryrun daijin.yaml

When Daijin is finished, have a look inside the folder daijin_spombe/3-assemblies/output/; you will find the following two GTF files:

  • class-0-hisat-SRR1617247-0.gtf
  • stringtie-0-hisat-SRR1617247-0.gtf

These are standard GTF files reporting the assembled transcripts for each method. We can have a feel for how they compare with our reference annotation by, again, using mikado util stats. Conveniently, Daijin has already performed this analysis for us, and the files will be present in the same folder:

  • class-0-hisat-SRR1617247-0.gtf**.stats**
  • stringtie-0-hisat-SRR1617247-0.gtf**.stats**
File genes monoexonic_genes transcripts transcripts_per_gene transcript_len_mean monoexonic_transcripts exons exons_per_transcript exon_len_mean
class-0-hisat-SRR1617247-0.gtf.stats 4148 781 4415 1.05 1604.63 781 10944 2.48 647.34
stringtie-0-hisat-SRR1617247-0.gtf.stats 11062 7938 12625 1.11 1188.7 8236 21427 1.7 700.39

From this quick analysis, it seems that Stringtie has assembled - correctly - mostly monoexonic transcripts, but has probably massively overestimated the number of genes (11,062, almost 50% more than those found in the reference annotation). CLASS2 has been more conservative, but contrary to Stringtie it has assembled mostly multiexonic transcripts. Stringtie transcripts are also much shorter than CLASS2 transcripts, suggesting that this tool might have reported many fragmentary loci.

It is possible to compare them to the current annotation by using :ref:`Mikado compare <compare>`. To do so, issue the following commands:

mikado compare -r Schizosaccharomyces_pombe.ASM294v2.32.gff3 -p daijin_spombe/3-assemblies/output/stringtie-0-hisat-SRR1617247-0.gtf -o daijin_spombe/3-assemblies/output/stringtie-0-hisat-SRR1617247-0.compare -l daijin_spombe/3-assemblies/output/stringtie-0-hisat-SRR1617247-0.compare.log;
mikado compare -r Schizosaccharomyces_pombe.ASM294v2.32.gff3 -p daijin_spombe/3-assemblies/output/class-0-hisat-SRR1617247-0.gtf -o daijin_spombe/3-assemblies/output/class-0-hisat-SRR1617247-0.compare -l daijin_spombe/3-assemblies/output/class-0-hisat-SRR1617247-0.compare.log;

The analysis will produce TMAP, REFMAP and STATS files for each of the two assemblies. This is the report of the stats file for the CLASS2 assembly:

/tgac/software/testing/bin/core/../..//mikado/devel/x86_64/bin/mikado compare -r Schizosaccharomyces_pombe.ASM294v2.32.gff3 -p daijin_spombe/3-assemblies/output/class-0-hisat-SRR1617247-0.gtf -o daijin_spombe/3-assemblies/output/class-0-hisat-SRR1617247-0.compare -l daijin_spombe/3-assemblies/output/class-0-hisat-SRR1617247-0.compare.log
7015 reference RNAs in 7014 genes
4415 predicted RNAs in  4148 genes
--------------------------------- |   Sn |   Pr |   F1 |
                        Base level: 34.43  69.23  45.98
            Exon level (stringent): 19.11  22.61  20.72
              Exon level (lenient): 81.19  65.65  72.60
                      Intron level: 86.12  74.36  79.81
                Intron chain level: 68.68  48.21  56.65
      Transcript level (stringent): 0.00  0.00  0.00
  Transcript level (>=95% base F1): 3.12  4.92  3.82
  Transcript level (>=80% base F1): 17.01  26.66  20.77
         Gene level (100% base F1): 0.00  0.00  0.00
        Gene level (>=95% base F1): 3.12  5.21  3.90
        Gene level (>=80% base F1): 17.01  28.28  21.24

#   Matching: in prediction; matched: in reference.

            Matching intron chains: 1752
             Matched intron chains: 1753
   Matching monoexonic transcripts: 310
    Matched monoexonic transcripts: 326
        Total matching transcripts: 2062
         Total matched transcripts: 2079

          Missed exons (stringent): 10012/12378  (80.89%)
           Novel exons (stringent): 8097/10463  (77.39%)
            Missed exons (lenient): 1490/7923  (18.81%)
             Novel exons (lenient): 3366/9799  (34.35%)
                    Missed introns: 744/5361  (13.88%)
                     Novel introns: 1592/6209  (25.64%)

                Missed transcripts: 2937/7015  (41.87%)
                 Novel transcripts: 3/4415  (0.07%)
                      Missed genes: 2936/7014  (41.86%)
                       Novel genes: 3/4148  (0.07%)

and this instead for Stringtie:

Command line:
/tgac/software/testing/bin/core/../..//mikado/devel/x86_64/bin/mikado compare -r Schizosaccharomyces_pombe.ASM294v2.32.gff3 -p daijin_spombe/3-assemblies/output/stringtie-0-hisat-SRR1617247-0.gtf -o daijin_spombe/3-assemblies/output/stringtie-0-hisat-SRR1617247-0.compare -l daijin_spombe/3-assemblies/output/stringtie-0-hisat-SRR1617247-0.compare.log
7015 reference RNAs in 7014 genes
12625 predicted RNAs in  11062 genes
--------------------------------- |   Sn |   Pr |   F1 |
                        Base level: 70.12  67.71  68.89
            Exon level (stringent): 19.88  12.74  15.53
              Exon level (lenient): 68.66  60.10  64.10
                      Intron level: 88.73  70.16  78.36
                Intron chain level: 73.81  42.99  54.34
      Transcript level (stringent): 0.00  0.00  0.00
  Transcript level (>=95% base F1): 25.69  14.51  18.55
  Transcript level (>=80% base F1): 47.68  27.84  35.16
         Gene level (100% base F1): 0.00  0.00  0.00
        Gene level (>=95% base F1): 25.69  16.14  19.82
        Gene level (>=80% base F1): 47.69  30.69  37.35

#   Matching: in prediction; matched: in reference.

            Matching intron chains: 1890
             Matched intron chains: 1884
   Matching monoexonic transcripts: 1739
    Matched monoexonic transcripts: 1746
        Total matching transcripts: 3629
         Total matched transcripts: 3630

          Missed exons (stringent): 9917/12378  (80.12%)
           Novel exons (stringent): 16857/19318  (87.26%)
            Missed exons (lenient): 3027/9658  (31.34%)
             Novel exons (lenient): 4402/11033  (39.90%)
                    Missed introns: 604/5361  (11.27%)
                     Novel introns: 2023/6780  (29.84%)

                Missed transcripts: 523/7015  (7.46%)
                 Novel transcripts: 9/12625  (0.07%)
                      Missed genes: 523/7014  (7.46%)
                       Novel genes: 9/11062  (0.08%)

These comparisons suggest the following:

  1. Most of the transcripts reconstructed by both assemblers are near enough known genes so as not to be categorised as completely novel. Only 3 genes for CLASS2 and 9 genes for Stringtie are in non-annotated genomic loci.
  2. CLASS2 has performed worse than Stringtie for this particular species - the number of reconstructed transcript is lower, and so is the F1 at the transcript and gene level.
  3. Gene precision is pretty low for Stringtie - 30% - suggesting that the assembler has probably detected many spurious loci near annotated ones.

Step 3: running the Mikado steps

Now that we have created the input assemblies, it is time to run Mikado. First of all, let us have a look at the spombe.yaml file, which we have conveniently copied to our current directory:

.. literalinclude:: spombe.yaml

With this file, we are telling Mikado that we are looking for transcripts with a low number of exons ("exon_num: {rescaling: min}"), with a ratio of CDS/UTR of ~80% ("selected_cds_fraction: {rescaling: target, value: 0.8}") and good homology support ("blast_score: {rescaling: max}"). We are also rewarding long cDNAs ("cdna_length: {rescaling: max}") with a good homology to known proteins ("blast_score: {rescaling: max}") and only one ORF ("cds_not_maximal: {rescaling: min}"; "number_internal_orfs: {rescaling: target, value: 1}"). This set of rules is tailored for compact fungal genomes, where this kind of models is expected at a much higher rate than in other eukaryotes (eg plants or mammals).

Before launching daijin mikado, we can have a look at the BLAST and TransDecoder sections. It is advisable to modify the number of chunks for BLASTX to a high number, eg. 100, if you are using a cluster. Please note that now we are going to use a different configuration file, daijin_spombe/mikado.yaml, which Daijin created as last step in the assembly pipeline.

Issue the command:

daijin mikado -c slurm.yaml daijin_spombe/mikado.yaml

This part of the pipeline should be quicker than the previous stage. After the pipeline is finished, Daijin will have created the final output files in daijin_spombe/5-mikado/pick/. As we requested only for the permissive mode, we only have one output - daijin_spombe/5-mikado/pick/mikado-permissive.loci.gff3. These are basic statistics on this annotation:

File genes monoexonic_genes transcripts transcripts_per_gene transcript_len_mean monoexonic_transcripts exons exons_per_transcript exon_len_mean
mikado-permissive.loci.stats 5633 2915 6054 1.07 1642.08 3095 11850 1.96 838.92

Mikado has created an annotation that is in between those produced by Stringtie and CLASS2. Compared to CLASS2, the Mikado assembly is probably more comprehensive, given the higher number of genes. Half the genes are monoexonic, an improvement compared to CLASS2, and at the same time the number of genes is much lower than in Stringtie, with a higher average cDNA length. These statistics suggest that the Mikado filtered annotation has been able to retain most of the real genes, while discarding many of the fragments present in either assembly. We can verify this by comparing the Mikado results against the reference annotation:

mikado compare -r Schizosaccharomyces_pombe.ASM294v2.32.gff3 -p daijin_spombe/5-mikado/pick/permissive/mikado-permissive.loci.gff3 -o daijin_spombe/5-mikado/mikado_prepared.compare -l daijin_spombe/5-mikado/mikado_prepared.compare.log

A cursory look at the STATS file confirms the impression; the Mikado annotation has removed many of the spurious transcripts and is both more sensitive and more precise than either of the input assemblies:

/tgac/software/testing/bin/core/../..//mikado/devel/x86_64/bin/mikado compare -r Schizosaccharomyces_pombe.ASM294v2.32.gff3 -p daijin_spombe/5-mikado/pick/permissive/mikado-permissive.loci.gff3 -o daijin_spombe/5-mikado/mikado_prepared.compare -l daijin_spombe/5-mikado/mikado_prepared.compare.log
7015 reference RNAs in 7014 genes
6054 predicted RNAs in  5633 genes
--------------------------------- |   Sn |   Pr |   F1 |
                        Base level: 64.04  85.97  73.40
            Exon level (stringent): 20.37  21.96  21.13
              Exon level (lenient): 70.61  81.36  75.61
                      Intron level: 88.21  87.03  87.61
                Intron chain level: 79.58  68.60  73.68
      Transcript level (stringent): 0.09  0.10  0.09
  Transcript level (>=95% base F1): 24.55  28.51  26.38
  Transcript level (>=80% base F1): 47.04  54.64  50.56
         Gene level (100% base F1): 0.09  0.11  0.09
        Gene level (>=95% base F1): 24.55  30.64  27.26
        Gene level (>=80% base F1): 47.05  58.73  52.24

#   Matching: in prediction; matched: in reference.

            Matching intron chains: 2030
             Matched intron chains: 2030
   Matching monoexonic transcripts: 1688
    Matched monoexonic transcripts: 1690
        Total matching transcripts: 3718
         Total matched transcripts: 3720

          Missed exons (stringent): 9857/12378  (79.63%)
           Novel exons (stringent): 8960/11481  (78.04%)
            Missed exons (lenient): 2822/9602  (29.39%)
             Novel exons (lenient): 1553/8333  (18.64%)
                    Missed introns: 632/5361  (11.79%)
                     Novel introns: 705/5434  (12.97%)

                Missed transcripts: 1745/7015  (24.88%)
                 Novel transcripts: 1/6054  (0.02%)
                      Missed genes: 1745/7014  (24.88%)
                       Novel genes: 1/5633  (0.02%)

We suggest to visualise assemblies with one of the many tools currently at disposal, such as eg WebApollo [Apollo]_. Mikado files are GFF3-compliant and can be loaded directly into Apollo or similar tools. GTF files can be converted into proper GFF3 files using the convert utility:

mikado util convert <input gtf> <output GFF3>