/
LRII Bioinformatics

LRII Bioinformatics

Assign reads and otus to samples:

/project/microbiome/data_queue/seq/LowReadII/rawdata salloc --account=microbiome -t 0-06:00 mkdir -p /gscratch/grandol1/LowReadII/rawdata cd /gscratch/grandol1/LowReadII/rawdata unpigz --to-stdout /project/microbiome/data_queue/seq/LowReadII/rawdata/Low-Read-II_S1_L001_R1_001.fastq | split -l 1000000 -d --suffix-length=3 --additional-suffix=.fastq - LowReadII_R1_ ;unpigz --to-stdout /project/microbiome/data_queue/seq/LowReadII/rawdata/Low-Read-II_S1_L001_R2_001.fastq | split -l 1000000 -d --suffix-length=3 --additional-suffix=.fastq - LowReadII_R2_ //project/microbiome/data_queue/seq/LowReadII/rawdata/run_parse_count_onSplitInput.pl cd /project/microbiome/data_queue/seq/LowReadII/rawdata ./run_splitFastq_fwd.sh ./run_splitFastq_rev.sh ./run_aggregate.sh cd /project/microbiome/data_queue/seq/LowReadII/tfmergedreads ./run_slurm_mergereads.pl cd /project/microbiome/data_queue/seq/LowReadII/otu ./run_slurm_mkotu.pl

 

vsearch -sintax OTUFILE -db REFERENCEDATABASE -tabbedout OUTPUT -sintax_cutoff 0.8 -strand both -threads 32

 

 

Assign taxonomy

salloc --account=microbiome -t 0-02:00 --mem=500G module load swset/2018.05  gcc/7.3.0 module load vsearch/2.15.1 vsearch --sintax zotus.fa --db /project/microbiome/users/grandol1/ref_db/gg_16s_13.5.fa -tabbedout LRII.sintax -sintax_cutoff 0.8

Output:

Reading file /project/microbiome/users/grandol1/ref_db/gg_16s_13.5.fa 100%  

1769520677 nt in 1262986 seqs, min 1111, max 2368, avg 1401

Counting k-mers 100% 

Creating k-mer index 100% 

Classifying sequences 100%   

Classified 4038 of 4042 sequences (99.90%)

Convert into useful form:

 

awk -F "\t" '{OFS=","} NR==1 {print "OTU_ID","SEQS","SIZE","DOMAIN","KINGDOM","PHYLUM","CLASS","ORDER","FAMILY","GENUS","SPECIES"} {gsub(";", ","); gsub("centroid=", ""); gsub("seqs=", ""); gsub("size=", ""); match($4, /d:[^,]+/, d); match($4, /k:[^,]+/, k); match($4, /p:[^,]+/, p); match($4, /c:[^,]+/, c); match($4, /o:[^,]+/, o); match($4, /f:[^,]+/, f); match($4, /g:[^,]+/, g); match($4, /s:[^,]+/, s); print $1, d[0]=="" ? "NA" : d[0], k[0]=="" ? "NA" : k[0], p[0]=="" ? "NA" : p[0], c[0]=="" ? "NA" : c[0], o[0]=="" ? "NA" : o[0], f[0]=="" ? "NA" : f[0], g[0]=="" ? "NA" : g[0], s[0]=="" ? "NA" : s[0] }' LRII.sintax > LRIItaxonomy.csv

 


LowReadII Analysis

This experiment intended to answer the questions below.

Questions:

  1. How can we best accommodate low concentration input DNAs?

  2. Concentrate input DNAs?

  3. Concentrate/normalize low yield products based off qPCR?

  4. Both?

  5. Just put more volume of original DNA in?

The questions actually probed are 1, 5, and 3. Though, one could argue that 2 and 5 are similar enough, without doing a cleanup of the DNA as well.

Based off 2-step prep sample sequence outputs, we selected 4 average read samples and 8 low read samples. We used our 1-step prep for this experiment though. All samples were normalized to 10 ng/ul or less. 2 ul of each average read sample was used for the 1-step PCR. The low read samples were repeated 3 times at different volumes (2ul, 4ul, and 8ul). 2 ul of 10ng/ul Zymo Mock Community (consisting of Listeria monocytogenes - 12%, Pseudomonas aeruginosa - 12%, Bacillus subtilis - 12%, Escherichia coli - 12%, Salmonella enterica - 12%, Lactobacillus fermentum - 12%, Enterococcus faecalis - 12%, Staphylococcus aureus - 12%, Saccharomyces cerevisiae - 2%, and Cryptococcus neoformans - 2%) was used as a positive control in quadruplicate, and 2 ul of ultra pure water was used as a negative control. After pcr and cleanup, 2 ul from each of these was pooled. All samples have "_2", "_4", or "_8" appended to the sample name to indicate DNA volume used in PCR.

The whole above setup was repeated with the same samples with the intention of addressing question 3. After pcr and cleanup, these preps were all quantified via qPCR and various volumes were combined to have each prep equimolar in the pool. These sample names have "_N" appended to them for normalized.

Both pools were then quantified via qPCR, adjusted to 1 nMolar and combined in equal amounts to maintain 1 nMolar concentration. After dilution to 50pM, this was the pool used for sequencing on the iSeq

Read in otu table. Transpose it. Remove added values to front of sample names (mid assignments). Sort by samplename and remove extraneous text, "centroid="

 

Looking at total reads, qPCR normalization and DNA volume used does not appear to have a consistent impact. Why does there appear to be a disconnect between qPCR results and Reads? We separated out each sample and compared it to itself under the different conditions.

 

There still appears to be a disconnect, though from 2 to 4 ul there is a more consistent increase for the non-normalized. Reads do not consistently go up with increased DNA starting Volume. So, is there a problem with our sample setup? Is our demux key incorrect? Are blanks largely ISD?

[1] "Blank1_2" "Blank1_2" "Blank2_2" "Blank2_2" "Blank3_2" "Blank3_2" "Blank4_2" "Blank4_2"
[9] "SAG_S30P2R_8" "SAG_S30P2R_8" "SAG_S38P1R_8" "SAG_S38P1R_8" "Blank1_2_N" "Blank1_2_N" "Blank2_2_N" "Blank2_2_N"
[17] "Blank3_2_N" "Blank3_2_N" "Blank4_2_N" "Blank4_2_N" "SAG_S15P4R_8_N" "SAG_S38P1R_8_N" "SAG_S38P1R_8_N"

All of the 8 ul iterations of SAG_S38P1R appear to be largely ISD. All of the samples appearing in the Blank range are 8 ul samples. Does too much DNA or too much inhibitor(s) in DNA favor the ISD?

Blanks look good excluding one suspect at only 67% ISD. what about the Mock Community? Is Mock Community largely the 8 expected taxa? (Listeria monocytogenes, Pseudomonas aeruginosa, Bacillus subtilis, Escherichia coli, Salmonella enterica, Lactobacillus fermentum, Enterococcus faecalis, Staphylococcus aureus)

[1] NA "f:mitochondria" "f:Lactobacillaceae" "f:Pseudomonadaceae" "f:Enterobacteriaceae"
[6] "f:Bacillaceae" "f:Staphylococcaceae" "f:Listeriaceae" "f:Enterococcaceae" "f:[Chthoniobacteraceae]"

So, there are some contaminants that should not be in the Mock Community.

[1] "otu31" "otu18" "otu51" "otu1443" "otu1766" "otu2540" "otu3273" "otu3278"

Are these contaminants present in the blanks? 4 of them are

The Mock Community appears to be as expected with some contamination. How do the samples look? Could any of them be MC or blanks remembering that some 8 ul DNA samples are showing high ISD.

0.9532478

Less than 5% of the reads for the non control samples are from the contaminants present in the blanks. How does this carry over per sample?

OTUID

<chr>

*PercDiff

<dbl>

NewReads

<dbl>

PercISD

<dbl>

reads

<dbl>

otu1

<dbl>

OTUID

<chr>

*PercDiff

<dbl>

NewReads

<dbl>

PercISD

<dbl>

reads

<dbl>

otu1

<dbl>

SAG_S30P2R_2

0.3068182

610

0.0750000000

880

66

SAG_S30P2R_4

0.1120219

650

0.3360655738

732

246

SAG_S38P1R_2

0.3333333

2

0.0000000000

3

0

SAG_S44P2R_2

0.1930036

669

0.0024125452

829

2

SAG_S44P2R_2

0.3133940

528

0.0494148244

769

38

SAG_S44P2R_2_N

0.1647915

2524

0.0274652548

3022

83

SAG_S44P2R_2_N

0.2193375

4360

0.0044762757

5585

25

SAG190238_4_N

0.1249619

2871

0.0262115209

3281

86

SAG191508_2

0.1002424

5197

0.0001731302

5776

1

SAG191508_2

0.1058133

4876

0.0001833853

5453

1

*PercDiff is the percent of reads coming from the contaminants in the blanks.

Graph is all samples having more than 10% of the reads from blank contaminants.

 

We should repeat the normalization after qPCR part of this experiment because our qPCR machine needed recalibration and the redone results are much different for the "normalized" samples. Increasing DNA into the PCR rxn does not seem to have the desired impact though.