Question: FastQC with multiple FASTQ files
0
gravatar for m93
4 months ago by
m93100
m93100 wrote:

I have received 384 fastq.gz files. These come from paired-end sequencing so I have 2 files per patient so 192 patients. I am new to NGS data analysis and I wish to start using FastQC. What would be the best way to proceed?

  • I know FastQC can be run graphically but presumably, with that many samples, it would be best to use the command line..
  • I read some places that merging all samples into a single (or 2 with paired-end) files might be the solution. Is that recommended? Or should I just use simple bash scripting in like below (or something similar)?

for i in *fastqc.gz do bsub < fastqc_script_with_commands.sh done

I guess I'm just curious if there is a convention of merging fastq files or keeping them separate (1 or 2 per sample).

Thanks

fastqc multiple ngs • 1.0k views
ADD COMMENTlink modified 4 months ago by drkennetz360 • written 4 months ago by m93100
1

use gnu-parallel or snakemake.

ADD REPLYlink written 4 months ago by cpad01129.8k

or Nextflow. Examples of using FastQC inside a Nextflow pipeline here, here and here

ADD REPLYlink written 4 months ago by steve1.8k
3
gravatar for genomax
4 months ago by
genomax58k
United States
genomax58k wrote:

You would want to do the QC for files individually. When run on the command line with -o option FastQC will write the result files to that directory. A bash loop would work. You can look into MultiQC to aggregate all results.

ADD COMMENTlink modified 4 months ago • written 4 months ago by genomax58k

+1 for MultiQC, I dont even bother to look at the individual output metrics anymore

ADD REPLYlink written 4 months ago by steve1.8k
1
gravatar for drkennetz
4 months ago by
drkennetz360
drkennetz360 wrote:

fastqc.sh:

#!/usr/bin/env bash
RUN_PATH=$1
cd $RUN_PATH
for file in $(ls $RUN_PATH)
do
    SAMPLE=`basename $file`
    fastqc -t 5 ${SAMPLE} -o /path/to/where/you/want/outputs
done

$./fastqc.sh /path/to/fastqs/

If you are running this on a cluster, just add qsub or bsub before the fastqs line (we have ibm):

That line would become:

bsub -P project -q queuename -n 1 -R "rusage[mem=2000]" fastqc -t 5 ${SAMPLE} -o /path/to/where/you/want/outputs

change the queuename to the actual name of the queue you submit jobs to.

ADD COMMENTlink written 4 months ago by drkennetz360
Please log in to add an answer.

Help
Access

Use of this site constitutes acceptance of our User Agreement and Privacy Policy.
Powered by Biostar version 2.3.0
Traffic: 1324 users visited in the last hour