Oyster TagSeq Pipeline

Oyster (Crassostrea virgninca) TagSeq Bioinformatics

Table of Contents

Initial diagnostics upon sequence upload to HPC


Count the number of read files

ls -1 | wc -l

should equal XXX seq samples

  • XX lanes per sample + 1 md5 = XXX

run checksum

nano transfer_checks.sh
#!/bin/bash
#SBATCH -t 120:00:00
#SBATCH --nodes=1 --ntasks-per-node=10
#SBATCH --mem=500GB
#SBATCH --account=putnamlab
#SBATCH --export=NONE
#SBATCH -D /data/putnamlab/KITT/hputnam/20201217_Geoduck_TagSeq/
#SBATCH -p putnamlab
#SBATCH --cpus-per-task=3

# load modules needed

# generate md5
md5sum /data/putnamlab/KITT/hputnam/20201217_Geoduck_TagSeq/*.gz > /data/putnamlab/KITT/hputnam/20201217_Geoduck_TagSeq/URI.md5

# Count the number of sequences per file

zcat /data/putnamlab/KITT/hputnam/20201217_Geoduck_TagSeq/*fastq.gz | echo $((`wc -l`/4)) > /data/putnamlab/KITT/hputnam/20201217_Geoduck_TagSeq/rawread.counts.txt
sbatch transfer_checks.sh
  • check the digital fingerprint of the files with md5sum
  • compare md5sum of our output URI.md5 file to the UT Library Information pdf; okay the upload - move forward

Quality check of raw reads


NOTE: H.Putnam ran fastqc_raw.sh and output into the 20201217_Geoduck_TagSeq/ folder

shell script: fastqc_raw.sh

#!/bin/bash
#SBATCH -t 120:00:00
#SBATCH --nodes=1 --ntasks-per-node=10
#SBATCH --mem=500GB
#SBATCH --account=putnamlab
#SBATCH --export=NONE
#SBATCH -D /data/putnamlab/KITT/hputnam/20201217_Geoduck_TagSeq/
#SBATCH -p putnamlab
#SBATCH --cpus-per-task=3

# load modules needed
module load all/FastQC/0.11.9-Java-11
module load MultiQC/1.9-intel-2020a-Python-3.8.2

for file in /data/putnamlab/KITT/hputnam/20201217_Geoduck_TagSeq/*gz
do
fastqc $file
done

multiqc /data/putnamlab/KITT/hputnam/20201217_Geoduck_TagSeq/

Run the sbatch

sbatch fastqc_raw.sh

Export multiqc report

exit bluewaves and run from terminal

  • save to gitrepo as multiqc_clean.html
    scp samuel_gurr@bluewaves.uri.edu:/data/putnamlab/sgurr/Geoduck_TagSeq/output/fastp_mutliQC/multiqc_report.html  C:/Users/samjg/Documents/My_Projects/Pgenerosa_TagSeq_Metabolomics
    

IMPORTANT! Quality check multiqc.html before you proceed!

  • view the multiqc.html report and note observations to guide trimming!
    • Per Sequence GC Content: double peak of ~0-10% GC and 30-40% GC To do: initial peak due to polyA tail?

    • *Mean Quality Scores&: >22-2; To do: trim base calls < 30

    • Per Base Sequence Content: 15-25% C and G, 25-28% T, 35-40+% A

    • Adapter Content: high adapters present, 1-6% of sequences; To do: trim adapter sequence

Trimming and post-trim quality check of ‘clean’ reads


Trimming-polyA-tail

  • Remember that TagSeq involves priming from the polyA tail of mRNA sequences! Thus, we will need to trim mononnucleotide sequence of As using fastp (in addition to threshold quality score and adapter(s)!)

What this script will do…

  • --adapter_sequence =
    • trim adapter sequence AGATCGGAAGAGCACACGTCTGAACTCCAGTCA
    • common single-end adapter in Illumina. You can run a test on a fastq.gz to count
  • --adapter_fasta = polyA_tail.fasta
    • create ‘polyA_tail.fasta’ to call here
    • important! --adapter_sequence is called by fastp before --adapter_fasta and will call each adapter in the .fasta one-by-one
    • the sequence distribution of trimmed adapters can be found in the HTML/JSON report
  • multiqc ./ = outputs mutliqc report of the ‘clean’ reads in the current directory

shell script: fastp_mutliqc.sh

#!/bin/bash
#SBATCH -t 120:00:00
#SBATCH --nodes=1 --ntasks-per-node=20
#SBATCH --mem=100GB
#SBATCH --account=putnamlab
#SBATCH --export=NONE
#SBATCH --mail-type=BEGIN,END,FAIL
#SBATCH --mail-user=samuel_gurr@uri.edu
#SBATCH --output="%x_out.%j"
#SBATCH --error="%x_err.%j"
#SBATCH -D /data/putnamlab/sgurr/Geoduck_TagSeq/output/fastp_multiQC

# load modules needed
module load fastp/0.19.7-foss-2018b
module load FastQC/0.11.8-Java-1.8
module load MultiQC/1.7-foss-2018b-Python-2.7.15

# symbolically link 'clean' reads to hisat2 dir
ln -s ../../../../KITT/hputnam/20201217_Geoduck_TagSeq/*.fastq.gz ./

# Make an array of sequences to trim
array1=($(ls *.fastq.gz))

# fastp loop; trim the Read 1 TruSeq adapter sequence; trim poly x default 10 (to trim polyA)
for i in ${array1[@]}; do
	fastp --in1 ${i} --out1 clean.${i} --adapter_sequence=AGATCGGAAGAGCACACGTCTGAACTCCAGTCA --trim_poly_x 6 -q 30 -y -Y 50
        fastqc clean.${i}
done

echo "Read trimming of adapters complete." $(date)

# Quality Assessment of Trimmed Reads

multiqc ./ #Compile MultiQC report from FastQC files

echo "Cleaned MultiQC report generated." $(date)

EXPORT MUTLIQC REPORT

exit bluewaves and run from terminal

  • save to gitrepo as multiqc_clean.html
    scp samuel_gurr@bluewaves.uri.edu:/data/putnamlab/sgurr/Geoduck_TagSeq/output/clean/multiqc_report.html  C:/Users/samjg/Documents/My_Projects/Geoduck_TagSeq
    

Alignment of cleaned reads to reference


Reference genome upload to HPC

exit bluewaves and run from terminal

scp C:/Users/samjg/Documents/Bioinformatics/genomes/Panopea-generosa-v1.0.fa samuel_gurr@bluewaves.uri.edu:/data/putnamlab/sgurr/refs/
  • file name: Panopea-generosa-genes.fna
  • reference genome file size: 368MB
  • uploaded to sgurr/refs/

HISAT2 alignment

About: HISAT2 is a sensitive alignment program for mapping sequencing reads. In our case here, we will use HISAT2 to (1) index our P. generosa reference genome (2) align our clean TagSeq reads to the indexed reference genome.

More information on HISAT2 can be read here!

Main arguments used below:

(1) Index the reference genome

hisat2-build = builds a HISAT2 index from a set of DNA sequences. Outputs 6 files that together consitute the index. ALL output files are needed to slign reads to the reference genome and the original sequence FASTA file(s) are no longer used for th HISAT2 alignment

-f <reads.fasta> = the reads (i.e , , ) FASTA files usually have extension .fa, .fasta, .mfa, .fna or similar. FASTA files do not have a way of specifying quality values, so when -f is set, the result is as if --ignore-quals is also set

Note: other options for your reads are -q for FASTQ files, --qseq for QSEQ files, etc. - check here for more file types

(2) align reads to reference

-x <hisat2-indx> = base name for the index reference genome, first looks in the current directory then in the directory specified in HISAT_INDEXES environment variable

--dta = important! reports the alignments tailored for StringTie assembler. With this option, HISAT2 requires longer anchor lengths for de novo discovery of splice sites. This leads to fewer alignments with short-anchors, which helps transcript assemblers improve significantly in computation and memory usage.

This is important relative to Cufflinks --dta-cufflinks in which HISAT2 looks for novel splice sites with three signals (GT/AG, GC/AG, AT/AC)

-U <r> = Comma-separated list of files contained unparied reads to be aligned. In other words…, our array of post-trimmed ‘clean’ TagSeq reads

-p NTHREADS = Runs on separate processors, increasing -p increases HISAT2’s memory footprint, increasing -p from 1 to 8 increased the footprint by a few hundred megabytes

Note: Erin Chile from Putnam Lab ran -p 8 for HISAT2 alignment of Montipora here

-S <hit> = file to write SAM alignments to. By default, alignments are written to the “standard out” or “stdout” filehandle (i.e. the console).

Note: HISAT2 also has several criteria to trim such as the phred score and base count 5’ (left) and 3’ (right) Since we already assessed quality and trimmed, we will not use these commands

samtools

About: used to manipuate alignments to a binary BAM format - files contain the spliced reads alignemnts sorted by the reference position with a tag to indicate the genomic strand that produced the RNA from which the read was sequenced. samtools quickly extracts alignments overlapping particular genomic regions - outputs allow viewers to quickly display alignments in each genomic region note: the SAM format output by HISAT2 must be sorted and converted to BAM format using the samtools program

sort = sorts the alignments by the leftmost coordinates

-o <out.bam = outputs as a specified .bam file

-@ threads = Set number of sorting and compression threads. By default, operation is single-threaded

more information on samtools commands here

HPC Job: HISAT2 Index Reference and Alignment


  • create directory output\hisat2

mkdir HISAT2

  • index reference and alignment

input

  • Panopea-generosa-genes.fna = reference genome
  • clean/.fastq.gz *= all clean TagSeq reads

ouput

  • Pgenerosa_ref = indexed reference by hisat2-build; stored in the output/hisat2 folder as 1.hy2, 2.ht2… 8.ht2
  • .sam *=hisat2 output, readable text file; removed at the end of the script*
  • .bam *=converted binary file complementary to the hisat sam files*

shell script: HISAT2.sh

#!/bin/bash
#SBATCH -t 120:00:00
#SBATCH --nodes=1 --ntasks-per-node=10
#SBATCH --mem=200GB
#SBATCH --account=putnamlab
#SBATCH --export=NONE
#SBATCH --mail-type=BEGIN,END,FAIL
#SBATCH --mail-user=samuel_gurr@uri.edu
#SBATCH --output="%x_out.%j"
#SBATCH --error="%x_err.%j"
#SBATCH -D /data/putnamlab/sgurr/Geoduck_TagSeq/output/HISAT2

#load packages
module load HISAT2/2.1.0-foss-2018b #Alignment to reference genome: HISAT2
module load SAMtools/1.9-foss-2018b #Preparation of alignment for assembly: SAMtools

# symbolically link 'clean' reads to hisat2 dir
ln -s ../fastp_multiQC/clean*.fastq.gz ./

# index the reference genome for Panopea generosa output index to working directory
hisat2-build -f ../../../refs/Panopea-generosa-v1.0.fa ./Pgenerosa_ref # called the reference genome (scaffolds)
echo "Referece genome indexed. Starting alingment" $(date)

# This script exports alignments as bam files
# sorts the bam file because Stringtie takes a sorted file for input (--dta)
# removes the sam file because it is no longer needed
array=($(ls *.fastq.gz)) # call the symbolically linked sequences - make an array to align
for i in ${array[@]}; do
        sample_name=`echo $i| awk -F [.] '{print $2}'`
	hisat2 -p 8 --dta -x Pgenerosa_ref -U ${i} -S ${sample_name}.sam
        samtools sort -@ 8 -o ${sample_name}.bam ${sample_name}.sam
    		echo "${i} bam-ified!"
        rm ${sample_name}.sam
done
  • HISAT2 complete with format prepared for StringTie assembler!

IMPORTANT: merge lanes here (.bam stage)

  • enter interactive mode
interactive
  • load samtools
    module load SAMtools/1.9-foss-2018b
    
  • ID file lists the sample ID characters (i.e. SG9_S108) - sample .bam file SG98_S144_L002_R1_001.bam
    ls *R1_001.bam | awk -F '[_]' '{print $1"_"$2}' | sort | uniq > ID
    
  • for loop using samtools to merge bam files together by sample ID (‘ID’ created above)
  • example of files to merge: SG98_S144_L001_R1_001.bam and SG98_S144_L002_R1_001.bam - where ‘L001’ and ‘L002’ are the lanes and the ID called SG9_S108 as $i below… (note: all .gz file names end with ‘001.fasta.gz’ no matter the lane)
    for i in `cat ./ID`;
      do samtools merge $i\.bam $i\_L001_R1_001.bam $i\_L002_R1_001.bam;
      done
    
  • when run in interactive mode, this loop takes up to ~1-2 hours

Assembly and quantification


Upload annotation reference .gff or .gff3 to HPC

  • Sam White and Steven Roberts completed the annotation with open resources available for download

exit bluewaves and run from terminal

  • “one file to rule them all” (- Sam W.) with the CDS, mRNA, exon, and genes
    scp C:/Users/samjg/Documents/Bioinformatics/genomes/Pgenerosa_annotations/Panopea-generosa-vv0.74.a3-merged-2019-09-03-6-14-33.gff3 samuel_gurr@bluewaves.uri.edu:/data/putnamlab/sgurr/refs/
    
  • mRNA only
    scp C:/Users/samjg/Documents/Bioinformatics/genomes/Pgenerosa_annotations/Panopea-generosa-v1.0.a4.gene.gff3 samuel_gurr@bluewaves.uri.edu:/data/putnamlab/sgurr/refs/
    
  • mRNA annotation with ‘m01, m02, m03, m04… m10’ removed from gene.ID to match IDs
scp C:/Users/samjg/Documents/Bioinformatics/genomes/Pgenerosa_annotations/Panopea-generosa-v1.0.a4.mRNA_SJG.gff3 samuel_gurr@bluewaves.uri.edu:/data/putnamlab/sgurr/refs/

StringTie


About: StringTie is a fast and efficient assembler of RNA-Seq alignments to assemble and quantitate full-length transcripts. putative transcripts. For our use, we will input short mapped reads from HISAT2. StringTie’s ouput can be used to identify DEGs in programs such as DESeq2 and edgeR

More information on StringTie can be read here!

Cufflinks is another assembler option we will not use. Read this

Main StringTie arguments used below:

-p = specify the number of threads (CPUs). Note that a single node has at least 8 CPUs or ‘threads’ to call here

-A = Gene abundances will be reported (tab delimited format) in the output file with the given name.

-e = Limits the processing of read alignments to only estimate and output the assembled transcripts matching the reference transcripts given with the -G option (requires -G, recommended for -B/-b). With this option, read bundles with no reference transcripts will be entirely skipped, which may provide a considerable speed boost when the given set of reference transcripts is limited to a set of target genes, for example.

-G <ref_ann.gff> = Use the reference annotation file (in GTF or GFF3 format) to guide the assembly process. The output will include expressed reference transcripts as well as any novel transcripts that are assembled. This option is required by options -B, -b, -e, -C.

-o = Sets the name of the output GTF file where StringTie will write the assembled transcripts

--merge = StringTie takes as input a list of GTF/GFF files and merges/assembles these transcripts into a non-redundant set of transcripts. This mode is used in the new differential analysis pipeline to generate a global, unified set of transcripts (isoforms) across multiple RNA-Seq samples. If the -G option (reference annotation) is provided, StringTie will assemble the transfrags from the input GTF files with the reference transcripts.

  • merge commands

-G <guide_gff> reference annotation to include in the merging (GTF/GFF3)

-o <out_gtf> output file name for the merged transcripts GTF (default: stdout)

gffcompare


About: gffcompare is used to estimate the accuracy of one or more GFF query files compared to a reference annotation

Main gffcompare arguments used below:

-r = reference annotation GFF file - each file is matched against it and tagged as overlapping, matching, or novel where appropriate. outputs .refmap and .tmap files

-G =

-o <outprefix> = give a prefix for output files created by gffcompare (i.e. merged)

Python step prepDE.py


About: in preparation for differential expression analysis using Bioconductor packages in R (i.e. DESeq2, edgeR, WGCNA), we will need to first aquire a matrix of read counts to particular genomic features (i.e. genes). prepDE.py is a Python call to extract hypothetical read counts for each transcript from the files generated by -e using StringTie (here as ${i}.gtf from .bam files by HISAT2)

prepDE.py = .py found here - add to scripts folder to call using python prepDE.py, builds the matrix of read counts

-g = where to ouput the gene count matrix (defaults as gene_count_matrix.csv) -i INPUT = a folder containing all sample sub-directories; Alternatively can provide a text file (i.e. sample_list.tct) with sample ID and path to its GTF file on each line (default ‘.’ meaning the working directory is the subdirectory with all GTF files) Alternatively call a listGTF.txt file… this file has two columns with the sample ID and the for the .gtf files run the following:


gtf_list.txt run…

  • ls .gtf > gtf_list.txt
  • --merge requires a list file to call each of the gtf files

listGTF.txt run…

  • for filename in *.gtf; do echo $filename $PWD/$filename; done > listGTF.txt
  • call this text file -i in python prepDE.py in the job merge_prepDEpy.sh

HPC job: Assembly


shell script: Stringtie2.sh

#!/bin/bash
#SBATCH -t 120:00:00
#SBATCH --nodes=1 --ntasks-per-node=10
#SBATCH --mem=200GB
#SBATCH --account=putnamlab
#SBATCH --export=NONE
#SBATCH --mail-type=BEGIN,END,FAIL
#SBATCH --mail-user=samuel_gurr@uri.edu
#SBATCH --output="%x_out.%j"
#SBATCH --error="%x_err.%j"
#SBATCH -D /data/putnamlab/sgurr/Geoduck_TagSeq/output/Stringtie2

#load packages
module load StringTie/2.1.1-GCCcore-7.3.0 #Transcript assembly: StringTie

array=($(ls ../HISAT2/*.bam)) #Make an array of sequences to assemble

for i in ${array[@]}; do #Running with the -e option to compare output to exclude novel genes. Also output a file with the gene abundances
        sample_name=`echo $i| awk -F [_] '{print $1"_"$2"_"$3}'`
	stringtie -p 8 -e -B -G ../../../refs/Panopea-generosa-v1.0.a4.mRNA_SJG.gff3 -A ../Stringtie2/${sample_name}.gene_abund.tab -o ../Stringtie2/${sample_name}.gtf ${i}
        echo "StringTie assembly for seq file ${i}" $(date)
done
echo "StringTie assembly COMPLETE, starting assembly analysis" $(date)

HPC job: Merge and Build Read Count Matrix for DEG analysis


  • NOTE: you will need the files gtf_list.txt and listGTF.txt to in your -D working directory (i.e. output/stringtie) to run this job (described above)

shell script: mergeStringtie2_gffcompare_prepDE

#!/bin/bash
#SBATCH -t 120:00:00
#SBATCH --nodes=1 --ntasks-per-node=10
#SBATCH --mem=200GB
#SBATCH --account=putnamlab
#SBATCH --export=NONE
#SBATCH --mail-type=BEGIN,END,FAIL
#SBATCH --mail-user=samuel_gurr@uri.edu
#SBATCH --output="%x_out.%j"
#SBATCH --error="%x_err.%j"
#SBATCH -D /data/putnamlab/sgurr/Geoduck_TagSeq/output/Stringtie2

#load packages
module load Python/2.7.15-foss-2018b #Python
module load StringTie/2.1.1-GCCcore-7.3.0 #Transcript assembly: StringTie
module load gffcompare/0.11.5-foss-2018b #Transcript assembly QC: GFFCompare

stringtie --merge -p 8 -G ../../../refs/Panopea-generosa-v1.0.a4.mRNA_SJG.gff3 -o Pgenerosa_merged.gtf gtf_list.txt #Merge GTFs to form $
echo "Stringtie merge complete" $(date)

gffcompare -r ../../../refs/Panopea-generosa-v1.0.a4.mRNA_SJG.gff3 -G -o merged Pgenerosa_merged.gtf #Compute the accuracy and pre$
echo "GFFcompare complete, Starting gene count matrix assembly..." $(date)

python ../../scripts/prepDE.py -g Pgenerosa_gene_count_matrix.csv -i listGTF.txt #Compile the gene count matrix
echo "Gene count matrix compiled." $(date)

exit bluewaves and run from terminal

  • save the read count matrix to local pc
    scp  samuel_gurr@bluewaves.uri.edu:/data/putnamlab/sgurr/Geoduck_TagSeq/output/stringtie/lanes_merged/transcript_count_matrix.csv C:/Users/samjg/Documents/My_Projects/Pgenerosa_TagSeq_Metabolomics/TagSeq/HPC_Bioinf