After downloading data on 20230515 (notebook) and then reorganizing the E5 coral RNA-seq data from Azenta project 30-789513166 (notebook), and after testing some trimming options for sRNA-seq data (notebook), I opted to use the trimming software flexbar
. I ran FastQC for initial quality checks, followed by trimming with flexbar
, and then final QC with FastQC/MultiQC. This was performed on all three species in the data sets: A.pulchra, P.evermanni, and P.meandrina. All aspects were run on Mox. Final trimming length was set to 35bp.
Skip to RESULTS.
SLURM Script (GitHub):
#!/bin/bash
## Job Name
#SBATCH --job-name=20230620-E5_coral-fastqc-flexbar-multiqc-sRNAseq
## Allocation Definition
#SBATCH --account=srlab
#SBATCH --partition=srlab
## Resources
## Nodes
#SBATCH --nodes=1
## Walltime (days-hours:minutes:seconds format)
#SBATCH --time=10-00:00:00
## Memory per node
#SBATCH --mem=500G
##turn on e-mail notification
#SBATCH --mail-type=ALL
#SBATCH --mail-user=samwhite@uw.edu
## Specify the working directory for this job
#SBATCH --chdir=/gscratch/scrubbed/samwhite/outputs/20230620-E5_coral-fastqc-flexbar-multiqc-sRNAseq
### FastQC and flexbar trimming of E5 coral species sRNA-seq data from 202230515.
### flexbar expects input FastQ files to be in format: sRNA-ACR-178-S1-TP2_R1_001.fastq.gz
### Adapter trimming and read length trimming is based off of NEB nebnext-small-rna-library-prep-set-for-illumina kit.
###################################################################################
# These variables need to be set by user
## Assign Variables
# Set FastQ filename patterns
fastq_pattern='*.fastq.gz'
R1_fastq_pattern='*_R1_*.fastq.gz'
R2_fastq_pattern='*_R2_*.fastq.gz'
# Set number of CPUs to use
threads=40
# Set maximum read length
max_read_length=35
# Input/output files
trimmed_checksums=trimmed_fastq_checksums.md5
fastq_checksums=input_fastq_checksums.md5
NEB_adapters_fasta=NEB-adapters.fasta
## NEB nebnext-small-rna-library-prep-set-for-illumina adapters
first_adapter="AGATCGGAAGAGCACACGTCTGAACTCCAGTCAC"
second_adapter="GATCGTCGGACTGTAGAACTCTGAACGTGTAGATCTCGGTGGTCGCCGTATCATT"
# Data directories
reads_dir=/gscratch/srlab/sam/data
# Species array (must match directory name usage)
species_array=("A_pulchra" "P_evermanni" "P_meandrina")
## Inititalize arrays
raw_fastqs_array=()
R1_names_array=()
R2_names_array=()
fastq_array_R1=()
fastq_array_R2=()
# Paths to programs
fastqc=/gscratch/srlab/programs/fastqc_v0.11.9/fastqc
multiqc=/gscratch/srlab/programs/anaconda3/bin/multiqc
# Programs associative array
declare -A programs_array
programs_array=(
[fastqc]="${fastqc}" \
[multiqc]="${multiqc}" \
[flexbar]="flexbar"
)
###################################################################################
# Exit script if any command fails
set -e
# Load Anaconda
# Uknown why this is needed, but Anaconda will not run if this line is not included.
. "/gscratch/srlab/programs/anaconda3/etc/profile.d/conda.sh"
# Activate flexbar environment
conda activate flexbar-3.5.0
# Capture date
timestamp=$(date +%Y%m%d)
# Create adapters FastA for use with flexbar trimming
echo "Creating adapters FastA."
echo ""
adapter_count=0
for adapter in "${first_adapter}" "${second_adapter}"
do
adapter_count=$((adapter_count + 1))
printf ">%s\n%s\n" "adapter_${adapter_count}" "${adapter}"
done >> "${NEB_adapters_fasta}"
echo "Adapters FastA:"
echo ""
cat "${NEB_adapters_fasta}"
echo ""
# Set working directory
working_dir=$(pwd)
for species in "${species_array[@]}"
do
## Inititalize arrays
raw_fastqs_array=()
R1_names_array=()
R2_names_array=()
fastq_array_R1=()
fastq_array_R2=()
trimmed_fastq_array=()
echo "Creating ${species} directory and subdirectories..."
mkdir --parents "${species}/raw_fastqc" "${species}/trimmed"
# Change to raw_fastq directory
cd "${species}/raw_fastqc"
# FastQC output directory
output_dir=$(pwd)
echo "Now in ${PWD}."
# Sync raw FastQ files to working directory
echo ""
echo "Transferring files via rsync..."
rsync --archive --verbose \
${reads_dir}/${species}/sRNAseq/${fastq_pattern} .
echo ""
echo "File transfer complete."
echo ""
### Run FastQC ###
### NOTE: Do NOT quote raw_fastqc_list
# Create array of trimmed FastQs
raw_fastqs_array=(${fastq_pattern})
# Pass array contents to new variable as space-delimited list
raw_fastqc_list=$(echo "${raw_fastqs_array[*]}")
echo "Beginning FastQC on raw reads..."
echo ""
# Run FastQC
${programs_array[fastqc]} \
--threads ${threads} \
--outdir ${output_dir} \
${raw_fastqc_list}
echo "FastQC on raw reads complete!"
echo ""
### END FASTQC ###
### RUN MULTIQC ###
echo "Beginning MultiQC on raw FastQC..."
echo ""
${multiqc} .
echo ""
echo "MultiQC on raw FastQ complete."
echo ""
### END MULTIQC ###
# Create arrays of fastq R1 files and sample names
# Do NOT quote R1_fastq_pattern variable
for fastq in ${R1_fastq_pattern}
do
fastq_array_R1+=("${fastq}")
# Use parameter substitution to remove all text up to and including last "." from
# right side of string.
R1_names_array+=("${fastq%%.*}")
done
# Create array of fastq R2 files
# Do NOT quote R2_fastq_pattern variable
for fastq in ${R2_fastq_pattern}
do
fastq_array_R2+=("${fastq}")
# Use parameter substitution to remove all text up to and including last "." from
# right side of string.
R2_names_array+=("${fastq%%.*}")
done
# Create MD5 checksums for raw FastQs
for fastq in ${fastq_pattern}
do
echo "Generating checksum for ${fastq}"
md5sum "${fastq}" | tee --append ${fastq_checksums}
echo ""
done
### RUN FLEXBAR ###
# Uses parameter substitution (e.g. ${R1_sample_name%%_*})to rm the _R[12]
# Uses NEB adapter file
# --adapter-pair-overlap ON: Recommended by NEB sRNA kit
# --qtrim-threshold 25: Minimum quality
# --qtrim-format i1.8: Sets sequencer as illumina
# --post-trim-length: Trim reads from 3' end to max length
# --target: Sets file naming patterns
# --zip-output GZ: Sets type of compression. GZ = gzip
# Run flexbar on files
echo "Beginning flexbar trimming."
echo ""
for index in "${!fastq_array_R1[@]}"
do
R1_sample_name="${R1_names_array[index]}"
R2_sample_name="${R2_names_array[index]}"
# Begin flexbar trimming
flexbar \
--reads ${fastq_array_R1[index]} \
--reads2 ${fastq_array_R2[index]} \
--adapters ../../${NEB_adapters_fasta} \
--adapter-pair-overlap ON \
--qtrim-format i1.8 \
--qtrim-threshold 25 \
--post-trim-length ${max_read_length} \
--threads ${threads} \
--target "../trimmed/${R1_sample_name%%_*}.flexbar_trim.${timestamp}" \
--zip-output GZ
# Move to trimmed directory
# This is done so checksums file doesn't include excess path
cd ../trimmed
echo "Moving to ${PWD}."
echo ""
# Generate md5 checksums for newly trimmed files
{
md5sum "${R1_sample_name%%_*}.flexbar_trim.${timestamp}_1.fastq.gz"
md5sum "${R2_sample_name%%_*}.flexbar_trim.${timestamp}_2.fastq.gz"
} >> "${trimmed_checksums}"
# Go back to raw reads directory
cd ../raw_fastqc
echo "Moving to ${PWD}"
echo ""
# Remove original FastQ files
echo ""
echo " Removing ${fastq_array_R1[index]} and ${fastq_array_R2[index]}."
rm "${fastq_array_R1[index]}" "${fastq_array_R2[index]}"
done
echo ""
echo "flexbar trimming complete."
echo ""
### END FLEXBAR ###
### RUN FASTQC ON TRIMMED READS ###
### NOTE: Do NOT quote ${trimmed_fastqc_list}
# Moved to trimmed reads directory
cd ../trimmed
echo "Moving to ${PWD}"
echo ""
# FastQC output directory
output_dir=$(pwd)
# Create array of trimmed FastQs
trimmed_fastq_array=(*flexbar_trim*.fastq.gz)
# Pass array contents to new variable as space-delimited list
trimmed_fastqc_list=$(echo "${trimmed_fastq_array[*]}")
# Run FastQC
echo "Beginning FastQC on trimmed reads..."
echo ""
${programs_array[fastqc]} \
--threads ${threads} \
--outdir ${output_dir} \
${trimmed_fastqc_list}
echo ""
echo "FastQC on trimmed reads complete!"
echo ""
### END FASTQC ###
### RUN MULTIQC ###
echo "Beginning MultiQC on trimmed reads data..."
echo ""
${multiqc} .
echo ""
echo "MultiQC on trimmed reads data complete."
echo ""
### END MULTIQC ###
cd "${working_dir}"
done
####################################################################
# Capture program options
if [[ "${#programs_array[@]}" -gt 0 ]]; then
echo "Logging program options..."
for program in "${!programs_array[@]}"
do
{
echo "Program options for ${program}: "
echo ""
# Handle samtools help menus
if [[ "${program}" == "samtools_index" ]] \
|| [[ "${program}" == "samtools_sort" ]] \
|| [[ "${program}" == "samtools_view" ]]
then
${programs_array[$program]}
# Handle DIAMOND BLAST menu
elif [[ "${program}" == "diamond" ]]; then
${programs_array[$program]} help
# Handle NCBI BLASTx menu
elif [[ "${program}" == "blastx" ]]; then
${programs_array[$program]} -help
# Handle fastp menu
elif [[ "${program}" == "[`fastp`](https://github.com/OpenGene/fastp)" ]]; then
${programs_array[$program]} --help
else
${programs_array[$program]} -h
fi
echo ""
echo ""
echo "----------------------------------------------"
echo ""
echo ""
} &>> program_options.log || true
# If MultiQC is in programs_array, copy the config file to this directory.
if [[ "${program}" == "multiqc" ]]; then
cp --preserve ~/.multiqc_config.yaml multiqc_config.yaml
fi
done
fi
# Document programs in PATH (primarily for program version ID)
{
date
echo ""
echo "System PATH for $SLURM_JOB_ID"
echo ""
printf "%0.s-" {1..10}
echo "${PATH}" | tr : \\n
} >> system_path.log
RESULTS
Run time was relatively quick; a little less than 1hr 30mins:
Output folder:
A.pulchra
#### Raw FastQs:
MultiQC Report (HTML)
MD5 checksums (text)
#### Trimmed FastQs:
MultiQC Report (HTML)
FastQ (gzipped)
sRNA-ACR-140-S1-TP2.flexbar_trim.20230621_1.fastq.gz (285M)
- MD5:
bc9dfcac504fa9f54414666222c231ee
- MD5:
sRNA-ACR-140-S1-TP2.flexbar_trim.20230621_2.fastq.gz (288M)
- MD5:
787108939a905fbba8ca1afa2d1d6584
- MD5:
sRNA-ACR-145-S1-TP2.flexbar_trim.20230621_1.fastq.gz (320M)
- MD5:
7ecbac6b60a9a0fa4ac8c9c7dbc84aaa
- MD5:
sRNA-ACR-145-S1-TP2.flexbar_trim.20230621_2.fastq.gz (320M)
- MD5:
3c128af4fb73b180ebd4116740f62f3d
- MD5:
sRNA-ACR-150-S1-TP2.flexbar_trim.20230621_1.fastq.gz (338M)
- MD5:
5084ae9dd5d94000ae5c50c26f81961b
- MD5:
sRNA-ACR-150-S1-TP2.flexbar_trim.20230621_2.fastq.gz (341M)
- MD5:
e320774cfc8150a23bcf57458a47afb1
- MD5:
sRNA-ACR-173-S1-TP2.flexbar_trim.20230621_1.fastq.gz (296M)
- MD5:
14db8b0e55941025ffddecdd84609901
- MD5:
sRNA-ACR-173-S1-TP2.flexbar_trim.20230621_2.fastq.gz (299M)
- MD5:
3731817b3e0c0c48e22123245b50998a
- MD5:
sRNA-ACR-178-S1-TP2.flexbar_trim.20230621_1.fastq.gz (265M)
- MD5:
9a128ada9b1b2aa8b9e691be465d4c25
- MD5:
sRNA-ACR-178-S1-TP2.flexbar_trim.20230621_2.fastq.gz (266M)
- MD5:
51cca9edaf909a34e5b90c3e05bcd275
- MD5:
P.evermanni
#### Raw FastQs:
MultiQC Report (HTML)
MD5 checksums (text)
#### Trimmed FastQs:
MultiQC Report (HTML)
FastQs (gzipped)
sRNA-POR-73-S1-TP2.flexbar_trim.20230621_1.fastq.gz (219M)
- MD5:
3849770b95a8a255e9583dfdb8b62803
- MD5:
sRNA-POR-73-S1-TP2.flexbar_trim.20230621_2.fastq.gz (219M)
- MD5:
d7dc9f9e757415f69fb09ed80132635c
- MD5:
sRNA-POR-79-S1-TP2.flexbar_trim.20230621_1.fastq.gz (240M)
- MD5:
94a55da7bc0081cdebe8e77cf6c9d82d
- MD5:
sRNA-POR-79-S1-TP2.flexbar_trim.20230621_2.fastq.gz (239M)
- MD5:
e87d8f2cf923e195d25c0207d96126f5
- MD5:
sRNA-POR-82-S1-TP2.flexbar_trim.20230621_1.fastq.gz (268M)
- MD5:
0c7b8bf7726112c21bebad8bd4f44914
- MD5:
sRNA-POR-82-S1-TP2.flexbar_trim.20230621_2.fastq.gz (266M)
- MD5:
f83c5157ddee1b97c5e9fc29350b67cf
- MD5:
P.meandrina
#### Raw FastQs:
MultiQC Report (HTML)
MD5 checksums (text)
#### Trimmed FastQs:
MultiQC Report (HTML)
FastQs (gzipped)
sRNA-POR-73-S1-TP2.flexbar_trim.20230621_1.fastq.gz (219M)
- MD5:
3849770b95a8a255e9583dfdb8b62803
- MD5:
sRNA-POR-73-S1-TP2.flexbar_trim.20230621_2.fastq.gz (219M)
- MD5:
d7dc9f9e757415f69fb09ed80132635c
- MD5:
sRNA-POR-79-S1-TP2.flexbar_trim.20230621_1.fastq.gz (240M)
- MD5:
94a55da7bc0081cdebe8e77cf6c9d82d
- MD5:
sRNA-POR-79-S1-TP2.flexbar_trim.20230621_2.fastq.gz (239M)
- MD5:
e87d8f2cf923e195d25c0207d96126f5
- MD5:
sRNA-POR-82-S1-TP2.flexbar_trim.20230621_1.fastq.gz (268M)
- MD5:
0c7b8bf7726112c21bebad8bd4f44914
- MD5:
sRNA-POR-82-S1-TP2.flexbar_trim.20230621_2.fastq.gz (266M)
- MD5:
f83c5157ddee1b97c5e9fc29350b67cf
- MD5: