Nextflow DRAGEN Pipeline
In this tutorial, we will demonstrate how to create and launch a simple DRAGEN pipeline using the Nextflow language in ICA GUI. More information about Nextflow on ICA can be found here. For this example, we will implement the alignment and variant calling example from this DRAGEN support page for Paired-End FASTQ Inputs.
Linking a DRAGEN bundle
You need a project in which the pipeline will reside. You can choose an existing project or create a new one. See the Projects page for information on how to create a project. For this tutorial, we will use a project called Getting Started.
Once you have selected or created your project, you need to link a DRAGEN bundle to it give the project access to the DRAGEN docker image. Open your project and navigate to Projects > your_project > Project settings > Details > Edit. From here, select the + symbol next to linked bundles and select a DRAGEN Demo Tool bundle to add to the project. For this tutorial, link DRAGEN Demo Bundle 4.0.3.
Once the bundle has been linked to your project, you can access the docker image by navigating to the main level and opening System Settings > Docker Repository. There, click the docker image dragen-ica-4.0.3. At the bottom of the screen, you will see the regions where this bundle is available.
The URL presented here will be used later in the container directive for your Nextflow DRAGEN process.
Creating the pipeline
Select Projects > your_project > Flow > Pipelines. From the Pipelines view, click +Create > Nextflow > JSON based to start creating a Nextflow pipeline.

Details
In the Nextflow pipeline creation view, use the Details tab to add information about the pipeline. Add values for the required Code (pipeline name) and Description fields. Nextflow Version and Storage size defaults to preassigned values.

Main.nf
Next, add the Nextflow pipeline definition by navigating to the Nextflow files > main files > main.nf. You will see a text editor. Copy and paste the following definition into the text editor. Modify the container directive by replacing the current URL with the URL found in the docker image dragen-ica-4.0.3. (System Settings > Docker Repository > your_docker_image > Regions).
This pipeline performs the following actions:
Accepts one paired FASTQ, one compressed reference file and a sample name
Schedules a FPGA‑backed Kubernetes pod on ICA
Unpacks the reference to local scratch
Runs DRAGEN with variant calling
Uploads all outputs to ICA cloud storage
Refer to the ICA help page for details on ICA specific attributes within the Nextflow definition.
To specify a compute type for a Nextflow process, use the pod directive within each process.
Outputs for Nextflow pipelines are uploaded from the
outfolder in the attached shared filesystem. The publishDir directive specifies the output folder for a given process. Only data moved to the out folder using thepublishDirdirective will be uploaded to the ICA project after the pipeline finishes executing.
Input Form
Next, we create the input form used for the pipeline. This is done on the Inputform files tab. More information on the specifications for the input form can be found in Input Form page.
This pipeline takes two FASTQ files, one reference file and one sample_id parameter as input.
Paste the following JSON input form into the inputForm.json text editor.
Click the Simulate button (bottom left) to preview the launch form fields.

Click the Save button (top right) to save the changes.
Running the pipeline
If you have no test data available, you need to link the Dragen Demo Bundle to your project at Projects > your_project > Project Settings > Details > Linked Bundles.
Go to the projects > your_project > flow > pipelines > your_pipeline and click Start Analysis.
Fill in the required fields and click on Start Analysis button.

Results
You can monitor the run from the Projects > your_project > Flow > analysis page. Once the Status changes to Succeeded, you can click on the run to access the results.
Useful Links
Last updated
Was this helpful?
