curare
Curare - A customizable and reproducible analysis pipeline for RNA-Seq experiments
Science Score: 36.0%
This score indicates how likely this project is to be science-related based on various indicators:
-
○CITATION.cff file
-
✓codemeta.json file
Found codemeta.json file -
○.zenodo.json file
-
✓DOI references
Found 2 DOI reference(s) in README -
○Academic publication links
-
✓Committers with academic emails
10 of 11 committers (90.9%) from academic institutions -
○Institutional organization owner
-
○JOSS paper metadata
-
○Scientific vocabulary similarity
Low similarity (14.6%) to scientific vocabulary
Keywords
Repository
Curare - A customizable and reproducible analysis pipeline for RNA-Seq experiments
Basic Info
- Host: GitHub
- Owner: pblumenkamp
- License: gpl-3.0
- Language: Python
- Default Branch: master
- Homepage: https://github.com/pblumenkamp/Curare
- Size: 47.2 MB
Statistics
- Stars: 8
- Watchers: 3
- Forks: 1
- Open Issues: 0
- Releases: 15
Topics
Metadata Files
README.md
Curare - A Customizable and Reproducible Analysis Pipeline for RNA-Seq Experiments
Contents
Description
Curare is a freely available analysis pipeline for reproducible, high-throughput RNA-Seq experiments. Define standardized pipelines customized for your specific workflow without the necessity of installing all the tools by yourself.
Curare is implemented in Python and uses the power of Snakemake and Conda to build and execute the defined workflows. Its modularized structure and the simplicity of Snakemake enables developers to create new and advanced workflow steps.
Features
Curare was developed to simplify the automized execution of RNA-Seq workflows on large datasets. Each workflow can be divided into four steps: Preprocessing, Premapping, Mapping, and Analysis.
Available modules
- Preprocessing
- Trim-Galore
- Fastp
- Premapping
- FastQC
- MultiQC
- Mapping
- Bowtie
- Bowtie2
- BWA-Backtrack
- BWA-MEM
- BWA-MEM2
- BWA-SW
- Minimap2
- Segemehl
- Star
- Analysis
- Count Table (FeatureCounts)
- DGE Analysis (DESeq2)
- Normalized Coverage
Results Report
At the end of a Curare run, you will also get an HTML report containing the most important results and an overview of all used settings. The start page will include Curare statistics, the runtime of this analysis, sample descriptions, and all dependencies of the tools used in this pipeline. From the navigation bar at the top, you can then navigate to the specific reports of each module with detailed charts and many statistics. (Images created with Curare using the data from: Banerjee R et al., "Tailoring a Global Iron Regulon to a Uropathogen.", mBio, 2020 Mar 24;11(2))


Usage
Installation
It is recommended to use mamba for installing curare with all dependencies. Please notice that the channels bioconda and conda-forge are required for installing Curare correctly.
bash
mamba create -n curare -c conda-forge -c bioconda curare
conda activate curare
curare --help
Alternatively, you can install Curare via GitHub release and install all dependencies in conda_environment.yaml manually.
bash
mamba env create -n curare -f /path/to/Curare/conda_environment.yaml
conda activate curare
bin/curare --help
If you want to run Curare completely without Conda, you would also need to install the dependencies of all used Curare modules. You can find the dependencies of every module at curare/snakefiles/<module_category>/<module>/lib/conda_env.yaml. To omit the usage of conda/mamba, use the --no-conda option when starting Curare.
If you want to test Curare, you can download our example dataset with a pre-built configuration.
Creating a pipeline
The easiest way to create a new pipeline is by using the Curare wizard. It will guide through all steps, asks what module you wish to use and creates the two necessary files (samples.tsv and pipeline.yml). These files can then be edited with a standard file editor for customizing your data and analysis.
```bash
Current working directory is inside of tool directory
curarewizard --samples targetdirectory/samples.tsv --pipeline target_directory/pipeline.yml ```
Samples File
The samples file (samples.tsv) is a tab-separated file collecting all necessary information about the used biological samples. This includes a unique identifier (name), a file path to the sequencing data (forward_reads/reverse reads on paired-end data, reads on single-end data), and depending on used modules further information like the condition. Every line starting with a # is a comment line and will be ignored by Curare. These lines are just helpful information for correctly writing this file.
Name column: A unique identifier used throughout the whole pipeline for this sample. To prevent any side-effects on the file system or in the used scripts, only alphanumerical characters and '_' are allowed for sample names.
Reads columns: Here, you define the file path to the responding sequencing data. For paired-end datasets, two columns must be set (forward_reads and reverse_reads), for single-end data only one column (reads). The file path can either be a relative path (relative to this file) or an absolute path (starting with '/').
Additional columns: Every selected module can define additional columns. The Curare wizard automatically creates a samples.tsv containing all required columns. So just fill out all open fields in the generated file, and everything will work. You can find a description of all additional columns in the header of the created file.
Example
```tsv
name: Unique sample name. Only use alphanumeric characters and '_'. [Value Type: String]
forward_reads: File path to fastq file containing forward reads. Either as an absolute path or relative to this file. [Value Type: Path]
reverse_reads: File path to fastq file containing reverse reads. Either as an absolute path or relative to this file. [Value Type: Path]
condition: Condition name of the sequencing run. May contain [A-Z, a-z, 0-9, _;!@^(),.[]-, Whitespace]. [Value Type: String]
name forwardreads reversereads condition wt1 data/wt1R1.fastq data/wt1R2.fastq WT wt2 data/wt2R1.fastq data/wt2R2.fastq WT wt3 data/wt3R1.fastq data/wt3R2.fastq WT heat1 data/wt1R1.fastq data/wt1R2.fastq Heat heat2 data/wt2R1.fastq data/wt2R2.fastq Heat heat3 data/wt3R1.fastq data/wt3R2.fastq Heat starvation1 data/wt1R1.fastq data/wt1R2.fastq Starvation starvation2 data/wt2R1.fastq data/wt2R2.fastq Starvation starvation3 data/wt3R1.fastq data/wt3_R2.fastq Starvation ```
Pipeline File
The pipeline file (pipeline.yml) defines the used modules and their parameters in the newly created workflow. As a typical YAML file, everything is structured in categories. There are categories for each workflow step (preprocessing, premapping, mapping, and analysis) and the main category for the whole pipeline (pipeline). Each of the four workflow categories has a parameter modules defining the used modules in this step. Since many modules need additional information, like a file path to the reference genome or a quality threshold, modules have their own block in their category for specifying these values.
One differentiates between mandatory and optional settings. Mandatory settings follow the structure gff_feature_type: <Insert Config Here>. It is necessary to replace <Insert Config Here> with a real value, e.g. "CDS" (like in the samples.tsv, the file path can either be relative to this file or absolute). Optional settings are commented out with a single #. For using other values than the default value, just remove the # and write your parameter after the colon.
Example
```yaml
Curare Pipeline File
This is an automatically created pipeline file for Curare.
All required parameters must be set (replace with real value).
All optional parameters are commented out with a single '#'. For including these parameters, just remove the '#'.
pipeline: paired_end: true
preprocessing: modules: ["trimgalore"]
trimgalore: ## Choose phred33 (Sanger/Illumina 1.9+ encoding) or phred64 (Illumina 1.5 encoding). [Value Type: Enum] #phredscoretype: "--phred33"
## Trim low-quality ends from reads in addition to adapter removal. (Default: 20). [Value Type: Number]
#quality_threshold: "20"
## Discard reads that became shorter than length INT because of either quality or adapter trimming. (Default: 20). [Value Type: Number]
#min_length: "20"
## Additional options to use in shell command. [Value Type: String]
#additional_parameter: ""
## Adapter sequence to be trimmed. If not specified explicitly, Trim Galore will try to auto-detect whether the Illumina universal, Nextera transposase, or Illumina small RNA adapter sequence was used. [Value Type: String]
#adapter_forward: ""
## adapter sequence to be trimmed off read 2 of paired-end files. [Value Type: String]
#adapter_reverse: ""
premapping: modules: ["multiqc"]
mapping: modules: ["bowtie2"]
bowtie2:
## Path to reference genome fasta file. [Value Type: Fileinput]
genomefasta:
## Choose local or end-to-end alignment. [Value Type: Enum]
## Enum choices: "local", "end-to-end"
alignment_type: <Insert Config Here>
## Additional options to use in shell command. [Value Type: String]
#additional_bowtie2_options: ""
analysis: modules: ["dge_analysis"]
dgeanalysis:
## Used feature type, e.g. gene or exon. [Value Type: String]
gfffeature_type:
## Descriptor for gene name, e.g. ID or gene_id. [Value Type: String]
gff_feature_name: <Insert Config Here>
## File path to gff file. [Value Type: File_input]
gff_path: <Insert Config Here>
## Additional options to use in shell command. [Value Type: String]
#additional_featcounts_options: ""
## Strand specificity of reads. Specifies if reads must lie on the same strand as the feature, the opposite strand, or can be on both. Options: "unstranded, stranded, reversely_stranded"
#strand_specificity: "unstranded"
## GFF attributes to show in the beginning of the xlsx summary (Comma-separated list, e.g. "experiment, product, Dbxref"). [Value Type: String]
#attribute_columns: ""
```
Filled pipeline file
```yaml
Curare Pipeline File
This is an automatically created pipeline file for Curare.
All required parameters must be set (replace with real value).
All optional parameters are commented out with a single '#'. For including these parameters, just remove the '#'.
pipeline: paired_end: true
preprocessing: modules: ["trimgalore"]
trimgalore: ## Choose phred33 (Sanger/Illumina 1.9+ encoding) or phred64 (Illumina 1.5 encoding). [Value Type: Enum] phredscoretype: "--phred64"
## Trim low-quality ends from reads in addition to adapter removal. (Default: 20). [Value Type: Number]
quality_threshold: "35"
## Discard reads that became shorter than length INT because of either quality or adapter trimming. (Default: 20). [Value Type: Number]
#min_length: "20"
## Additional options to use in shell command. [Value Type: String]
#additional_parameter: ""
## Adapter sequence to be trimmed. If not specified explicitly, Trim Galore will try to auto-detect whether the Illumina universal, Nextera transposase, or Illumina small RNA adapter sequence was used. [Value Type: String]
#adapter_forward: ""
## adapter sequence to be trimmed off read 2 of paired-end files. [Value Type: String]
#adapter_reverse: ""
premapping: modules: ["multiqc"]
mapping: modules: ["bowtie2"]
bowtie2: ## Path to reference genome fasta file. [Value Type: Fileinput] genomefasta: "reference/my_genome.fasta"
## Choose local or end-to-end alignment. [Value Type: Enum]
## Enum choices: "local", "end-to-end"
alignment_type: "end-to-end"
## Additional options to use in shell command. [Value Type: String]
#additional_bowtie2_options: ""
analysis: modules: ["dge_analysis"]
dgeanalysis: ## Used feature type, e.g. gene or exon. [Value Type: String] gfffeature_type: "CDS"
## Descriptor for gene name, e.g. ID or gene_id. [Value Type: String]
gff_feature_name: "ID"
## File path to gff file. [Value Type: File_input]
gff_path: "reference/my_genome.gff"
## Additional options to use in shell command. [Value Type: String]
#additional_featcounts_options: ""
## Strand specificity of reads. Specifies if reads must lie on the same strand as the feature, the opposite strand, or can be on both. Options: "unstranded, stranded, reversely_stranded"
strand_specificity: "reversely_stranded"
## GFF attributes to show in the beginning of the xlsx summary (Comma-separated list, e.g. "experiment, product, Dbxref"). [Value Type: String]
#attribute_columns: ""
```
Starting Curare
Curare can be started with this command: ```bash
Current working directory inside of root tool directory
cd curare
conda activate curare
curare --cores
All results, including the conda environments and a final report, will be written in results_directory.
Results
Curare structures all the results by categories and modules. This way each module can create their own structure and is independent from all other modules. For example, the mapping modules generates multiple bam files with various flag filters like unmapped or concordant reads and the differential gene expression module builds large excel files with the most important values and an R object to continue the analysis on your own. (Images: Bowtie2 mapping chart and DESeq2 summary table )
Availability
Available at Bioconda: https://bioconda.github.io/recipes/curare/README.html
Available at PyPI: https://pypi.org/project/Curare/
Example dataset: curare-user-testcase.zip
Citation
Blumenkamp, P., Pfister, M., Diedrich, S., Brinkrolf, K., Jaenicke, S., Goesmann, A. - Curare and GenExVis: a versatile toolkit for analyzing and visualizing RNA-Seq data. BMC Bioinformatics 25, 138 (2024). https://doi.org/10.1186/s12859-024-05761-2
FAQ
Owner
- Name: Patrick Blumenkamp
- Login: pblumenkamp
- Kind: user
- Repositories: 1
- Profile: https://github.com/pblumenkamp
GitHub Events
Total
- Delete event: 2
- Push event: 2
Last Year
- Delete event: 2
- Push event: 2
Committers
Last synced: over 2 years ago
Top Committers
| Name | Commits | |
|---|---|---|
| Patrick Blumenkamp | p****p@c****e | 184 |
| Patrick Blumenkamp | p****p@c****e | 96 |
| Patrick Blumenkamp | p****p@b****e | 70 |
| Christian Blume | c****e@b****e | 24 |
| Sebastian Jaenicke | s****k@C****E | 7 |
| Raphael Mueller | r****r@c****e | 4 |
| mpfister | m****r@b****e | 4 |
| rmueller | r****r@b****e | 3 |
| Patrick Blumenkamp | p****p@c****e | 2 |
| PfisterMaxJLU | M****r@b****e | 1 |
| Raphael Müller | 4****r | 1 |
Committer Domains (Top 20 + Academic)
Issues and Pull Requests
Last synced: 6 months ago
All Time
- Total issues: 42
- Total pull requests: 18
- Average time to close issues: 8 months
- Average time to close pull requests: 7 days
- Total issue authors: 1
- Total pull request authors: 4
- Average comments per issue: 2.33
- Average comments per pull request: 0.06
- Merged pull requests: 15
- Bot issues: 0
- Bot pull requests: 0
Past Year
- Issues: 0
- Pull requests: 0
- Average time to close issues: N/A
- Average time to close pull requests: N/A
- Issue authors: 0
- Pull request authors: 0
- Average comments per issue: 0
- Average comments per pull request: 0
- Merged pull requests: 0
- Bot issues: 0
- Bot pull requests: 0
Top Authors
Issue Authors
- pblumenkamp (42)
Pull Request Authors
- pblumenkamp (11)
- sjaenick (5)
- PfisterMaxJLU (3)
- r-mllr (2)
Top Labels
Issue Labels
Pull Request Labels
Packages
- Total packages: 1
-
Total downloads:
- pypi 23 last-month
- Total dependent packages: 0
- Total dependent repositories: 1
- Total versions: 6
- Total maintainers: 1
pypi.org: curare
Curare: A Customizable and Reproducible Analysis Pipeline for RNA-Seq Experiments
- Homepage: https://github.com/pblumenkamp/Curare
- Documentation: https://curare.readthedocs.io/
- License: GPLv3
-
Latest release: 0.6.0
published almost 2 years ago
Rankings
Maintainers (1)
Dependencies
- PyYAML *
- docopt *
- snakemake *