Skip to content

ghutinet/sORTholog

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Snakemake workflow: sORTholog

Snakemake GitHub actions status License: MIT

Aim

This software will produce a table visualization of the presence or absence of encoded proteins in a given set of genomes. Both, the proteins and set of proteomes are required as input by the user.

The primary output will be the table of sORTholog protein data filled using the NCBI Protein Database, as well as PDF and PNG files of the table visualization.


Table of content

  1. Installation and Running
    1. Step 1: install Snakemake and Snakedeploy
    2. Step 2: deploy workflow
    3. Step 3: configure workflow
      1. Taxid file
      2. Seed file
      3. Config file
        1. General settings
        2. Options to download proteomes
        3. Options to add your personal proteome
        4. Speed up options
          1. default psiblast options
          2. default HMM options
        5. Analysis options
          1. default blast options
          2. silix options
        6. Plot settings
        7. Only plot table options
    4. Step 4: run the workflow
    5. Step 5: generate report
  2. Important Notes for running on the UFL cluster
    1. Step C1: log on the cluster
    2. Step C2: load conda
    3. Step C3: configure slurm
    4. Step C4: run the workflow
    5. Additional information
  3. Walk-Through and File Production
    1. Pipeline in image
      1. Only blast and silix behavior
      2. Speedup behavior
    2. Rule descriptions
      1. Rule 1: fetch_fasta_from_seed
      2. Rule 2: fetch_proteins_database
      3. Rule 2.1.1: make_seed_psiblast (optional)
      4. Rule 2.1.2: psiblast (optional)
      5. Rule 2.1.3: read_psiblast (optional)
      6. Rule 2.2.1: hmmsearch (optional)
      7. Rule 2.2.2: read_hmmsearch (optional)
      8. Rule 2.3: merge_hmmsearch_psiblast (optional)
      9. Rule 2.4: make_fasta (optional)
      10. Rule 3: merge_fasta
      11. Rule 4: blast
      12. Rule 5: prepare_for_silix
      13. Rule 6: silix
      14. Rule 7: find_family
      15. Rule 8: make_PA_table
      16. Rule 9: plots
    3. Additional rules
      1. Rule A1: report_threshold
        1. Sub rule A1a: blast2threshold_table
        2. Sub rule A1b: report_threshold
      2. Rule A2: extract_protein
      3. Rule A3: quick_plots
      4. Rule A4: clean

Installation and Running

Step 1: install Snakemake and Snakedeploy

This pipeline uses the Snakemake workflow, that is only available on unix environment. Any linuxOS or MacOS should be able to run sORTholog. Windows users may have access to unix either using a cluster working on unix or using the ubuntu virtual environment.

Snakemake and Snakedeploy are best installed via the Mamba package manager (a drop-in replacement for conda). If you have neither Conda nor Mamba, it can be installed via Mambaforge. For other options see here.

⚠️ Make sure that these instalations are made on your entire system and not a subfolder

To install Mamba by conda, run

conda install mamba -n base -c conda-forge

Given that Mamba is installed, run

mamba create -c bioconda -c conda-forge --name snakemake snakemake snakedeploy

to install both Snakemake and Snakedeploy in an isolated environment.

Notes

For all following commands (step 2 to 5) ensure that this environment is activated via

conda activate snakemake

⚠️ This command has to be used every single time you want to use sORTholog to be able to activate the conda environment that contains snakemake.


Step 2: deploy workflow

Given that Snakemake and Snakedeploy are installed and available (see Step 1: install Snakemake and Snakedeploy), the workflow can be deployed as follows.

First, create an appropriate working directory, in which sORTholog will be deployed, on your system in the place of your choice as follow (note to change the path and file name to the one you want to create):

mkdir path/to/sORTholog-workdir

NB: More on the mkdir command.

Then go to your sORTholog working directory as follow:

cd path/to/sORTholog-workdir

⚠️ You will need to be in this directory every single time you want to run sORTholog. In all following steps, we will assume that you are in that directory.

NB: More on the cd command.

Second, run

snakedeploy deploy-workflow https://github.com/vdclab/sORTholog . --tag 0.4.7

Snakedeploy will create two folders workflow and config. The former contains the deployment of the chosen workflow as a Snakemake module, the latter contains configuration files which will be modified in the next step in order to configure the workflow to your needs. Later, when executing the workflow, Snakemake will automatically find the main Snakefile in the workflow subfolder.


Step 3: configure workflow

The three files described in this section (Taxid file, Seed file, and Config file) can be edited with a text editor. We recommend notepad++ if you do not have already a favorite text editor.


Taxid file

The taxid file is a table, in the format of a tabulated text file (e.g. .txt, .tsv). This table should contain 2 columns: TaxId and NCBIGroups. The TaxId columns should be filled with the TaxId of the genome you want to analyze. You can use any clade TaxId, sORTholog will take care of downloading all the genome of this clade. The NCBIGroups can be left blanked, but knowing this group would make the download of genomes faster. Here a list of accepted terms: all, archaea, bacteria, fungi, invertebrate, metagenomes, plant, protozoa, vertebrate_mammalian, vertebrate_other, viral. This will allow to look in the right folder in the FTP of NCBI to download the proteome. By choosing all, it will look in all folders and slow down the process. Ideally your taxid file should be in your sORTholog working directory or in the config folder. Example provided in the file doc/dummy_taxids.tsv folder in the GitHub page.


Seed file

The seed file contains the list of proteins you want to identify in your genomes. It is a table, in the format of a tabulated text file (e.g. .txt, .tsv). Ideally your seed file should be in your workdir folder or in the config folder. Here is a list of collumns for this file:

  • seed : Mandatory, name of the protein as you want it to appear in the final figure.
  • protein_id: Mandatory, either the NCBI protein id of a protein you are sure have the function you are searching for.
  • hmm: name of the hmm profile file associated with the protein family, including the extension, often .hmm. (no default, if not mentioned, psiBLAST will be triggered instead)
  • evalue: Number between 0 and 1, e-value threshold of blast.
  • pident: Number between 0 and 1, percentage of identity (expressed in frequency) threshold of blast.
  • cov: Number between 0 and 1, coverage threshold (expressed in frequency) for blast results. The coverage is based on the coverage of the query.
  • color: hexadecimal code of the color you want the positive results to be in the final figure for this seed. Example provided in the file doc/dummy_seeds.tsv folder in the GitHub page.

⚠️ Common mistakes:

  • Columns in the seed files should be separated by tabulation, introduction of spaces or other hidden characters might disrupt the reading of the file.
  • Do not introduce empty lines in the seed file.
  • Make sure to have the correct extension for your hmm profile.

Config file

This file is in the config folder, and is named config.yaml. You can edit this file following these instructions (also in comments in the config.yaml file)


General settings
  • seed : path and name of your seed file.
  • taxid: path and name of your taxid file.
  • project_name: Name of your project. This will create a new folder in the folder results that will contains all the files generated during the run, including your final results.
  • output_folder: Name of the folder you want the generated file to be directed to. By default, it is set to ../sORTholog_deployed/results.

⚠️ Common mistake: path in windows uses the backward slash \, but unix uses foreward slash /. Make sure to use the latter.


Options to download proteomes
  • ndg_option:
    • section: refseq (default) or genbank. Database from which you are pulling the proteomes.
    • assembly_levels: all (default), complete, chromosome, scaffold or contig. Type of assembly you want.
    • refseq_categories: reference, all (default). Only refseq reference genomes or all of refseq.
    • groups: all (default), archaea, bacteria, fungi, invertebrate, metagenomes, plant, protozoa, vertebrate_mammalian, vertebrate_other, viral. Set this group if unspecified in the NCBITaxId columns of the Taxid file.
  • update_db: True or False (default). Update the Taxonomy dump, will increase run time.

Options to add your personal proteome
  • perso_database: Path to personal proteome database. It should consist of a multifasta file with all the proteins you want to add to the search.
  • perso_annotation: table in tabulated text format that contains the information of the annotation of the fasta file in perso_database, columns: protein_id, genome_id[, genome_name]

⚠️ Common mistake: path in windows uses the backward slash \, but unix uses foreward slash /. Make ure to use the latter.


Speed up options
  • speedup: True or False. Define if you want to use psi-blast or hmmsearch to filter your proteome before running a blast all vs all. It is recommended on very large amount of genomes.

default psiblast options
  • psiblast_e_val: Number between 0 and 1, default 0.01. E-value used to accept a result in psi-blast. It is recommended to use a high e-value to gather super family related protein rather than being too stringent in this step.
  • iteration: Number between 0 and 5, default 5. Number of iteration of the psi-blast. The more iterations, the more you gather phylogenetically distant proteins.

default HMM options
  • hmm_profiles: path and name of your folder containing all the hmm profiles mentioned in your seed file.
  • e_val: Number between 0 and 1, default 0.0001. E-value default threshold if left empty in the seed file.
  • focus: domain or full (default: full). Analyse the results over the full size of the query or based on domain detection.

Analysis options

default blast options
  • filter: e_value, score or both (default: e_value). Se up if you want to filter your blast results by e-value, bit score or both.
  • e_val: Number between 0 and 1, default 0.0001. E-value default threshold if left empty in the seed file.
  • pid: Number between 0 and 1, default 0.35. Percentage of identity (expressed in frequency) default threshold if left empty in the seed file.
  • cov: Number between 0 and 1, default 0.8. Coverage of the query (expressed in frequency) default threshold if left empty in the seed file.

silix options
  • cov_min: mean, subject, query, shortest or longest (default: mean). Source or the length divider to calculate the coverage (from query, subject or an average of both)
  • pid_min: mean, subject, query, shortest, longest or HSP (default: mean). Source or the length divider to calculate the percentage of identity (from query, subject or an average of both)
  • length_min: positive number, default 100. Mininimum length to accept partial sequences in families

Plot settings

default_values_plot:

  • color: hexadecimal color, (default: #131516)
  • colored_border: True or False (default). Turn the color of the border a darker shade inferred from the background.

Here a comparison of the two behaviours:

  • round_border: True or False (default). Turn border to roundish shape.

Here a comparison of the two behaviours:


Only plot table options
  • PAtab_table: Path of the table you want to use to transform it into the plot figure. The table has to be a tabulated text file of a table that has the seeds in columns, the genomes in lines.

Step 4: run the workflow

Given that the workflow has been properly deployed and configured, it can be executed as follows.

For running the workflow while deploying any necessary software via conda, run Snakemake with

snakemake --cores 1 --use-conda 

If you want to run the workflow with the additional step to speedup the analysis that contains a big dataset you can either:

  • Change in the config.yaml the parameter speedup and change the value to True
  • Run the workflow adding -C speedup=True to the command line as follow
snakemake --cores 1 --use-conda -C speedup=True

⚠️ **Snakemake require that your computer and terminal stays open while the pipeline is running to start the subsequent rules. More info on Snakemake.

You can have access to your result following the path:

[path/to/sORTholog-workdir]/results/[project-name]/results

You will find the table of presence of absence patab_table.tsv, the melt version of this table patab_melt.tsv and a folder plots containing the figure representing the table.


Step 5: generate report

After finalizing your data analysis, you can automatically generate an interactive visual HTML report for inspection of results together with parameters and code inside of the browser via

snakemake --report report.zip --report-stylesheet config/report.css

The resulting report.zip file can be passed on to collaborators, provided as a supplementary file in publications.


Important Notes for running on the UFL cluster


Step C1: log on the cluster [UFL users]

  1. To work on the HiPerGator server, user must first open a terminal (for unix) or command prompt (for windows).
    User must access the server by entering the following command:
ssh (GatorLink ID)@hpg.rc.ufl.edu

User will be required to enter their GatorLink account password, then asked to be verified by dual push.

  1. User will require access to files on the server. To access these files via command line, use the following:
cd /blue/(your group)/(GatorLink ID)

You can access to the files of this folder on your computer by adding a server. The address for Windows is as follow: \\exasmb.rc.ufl.edu, for Unix (Linux or MacOS) the address: smb://exasmb.rc.ufl.edu.
More info here.


Step C2: load conda

Before starting the installation of the program, you will need to load conda; this required software is listed as follows:

module load conda

⚠️ This step will be necessary each time you want to use sORTholog on HiPergator. After that the step are the same as in Step 1: install Snakemake and Snakedeploy, Step 2: deploy workflow, and Step 3: configure workflow.


Step C3: configure slurm

Before running the workflow, another config file need to be assessed to configure the slurm on HiPerGator. This file is config/slurm/cluster-config.yaml Here are the options:

  • account: account linked to your HiPerGator. (insert your account here)

the subsequent options can be left by default:

  • qos: qos account name for HiPerGator.
  • time: time per rule in minutes.
  • nodes: number of nodes to use per rules.
  • ntasks: number of simultaneous tasks.
  • cpus-per-task: number of CPU per tasks on HiPerGator.
  • mem: memory allocated per rule if not indicated elsewhere.
  • output: destination of the output log.
  • error: destination of the error log.
  • job-name: name of the job on HiPerGator.

Step C4: run the workflow

Given that the workflow has been properly deployed and configured, it can be executed as follows.

For running the workflow while deploying any necessary software via conda and running on the cluster, run Snakemake with

snakemake -j 5 --use-conda --profile config/slurm

As previously, if you want to run the workflow with the additional step to speedup the analysis that contains a big dataset you can either:

  • Change in the config.yaml the parameter speedup and change the value to True
  • Run the workflow adding -C speedup=True to the command line as follow:
snakemake -j 5 --use-conda --profile config/slurm -C speedup=True 

As previously you can also generate a report following Step 5: Generate report.


Additional information

If you want to run it as a job,

  1. make sure that the pipeline is deploy where you are and that you change the config/config.yaml accordingly to your needs
  2. create a file name, for exemple my_project.sh, and copy and paste the following, changing your e-mail address and other relevant parameters:
#!/bin/sh
#SBATCH [email protected]              # Where to send mail
#SBATCH --mail-type=ALL                       # Mail events (NONE, BEGIN, END, FAIL, ALL)
#SBATCH --job-name=sbatch_snakemake           # Name of the job in slurm 
#SBATCH --cpus-per-task=1                     # Use 1 core
#SBATCH --mem=4G                              # Memory allocated to run the workflow
#SBATCH --time=7-0:00:00                      # Time for the workflow to run, format DD-HH:MM:SS
#SBATCH --nodes=1                             # Number of node to start the workflow
#SBATCH --output=logs/sbatch_snakemake-%j.out # Output of the sbatch job
#SBATCH --error=logs/sbatch-snakemake-%j.err  # Error log of the sbatch job, including the snakemake workflow notifications

echo "Date start $(date)"

# activate a specific conda environment, if you so choose
module load conda
conda activate snakemake 

# make things fail on errors
set -o nounset
set -o errexit
set -x

### run your commands here!
snakemake --cores 1 --use-conda --profile config/slurm
snakemake --report report.zip --report-stylesheet config/report.css

echo "Date end $(date)"
  1. run the following command
sbatch my_project.sh

Walk-Through and File Production

This pipeline consists of 9/12 steps called rules that take input files and create output files. Here is a description of the pipeline.

  1. As snakemake is set up, there is a last rule, called all, that serves to call the last output files and make sure they were created.

  2. A folder containing your work will be created:

   [project_name]/                           <- top-level project folder (your project_name)
   │
   │
   ├── report.html                           <- This report file      
   │
   ├── logs                                  <- Collection of log outputs, e.g. from cluster managers
   │
   ├── databases                             <- Generated analysis database related files
   │   ├── all_taxid                         
   │   │   ├─ protein_table.tsv              <- Table with the informations about the proteins of the downloaded taxid
   │   │   ├─ summary_assembly_taxid.tsv     <- Table with the informations about the downloaded genome from NCBI
   │   │   ├─ taxid_all_together.fasta       <- Fasta file of the downloaded taxid
   │   │   └─ taxid_checked.txt              <- List of the downloaded taxid
   │   │
   │   ├── merge_fasta                       
   │   │   └─ taxid_checked.txt              <- Fasta with the concatenation of the genome of interest and seeds
   │   │
   │   └── seeds                             
   │       ├─ seeds.fasta                    <- Fasta file of the seeds
   │       └─ new_seeds.tsv                  <- Table with the informations about the seeds
   │
   ├── analysis_thresholds                   <- (Optional) Generate by the rule report_thresholds
   │   ├── tables                         
   │   │   └─ table--seed.tsv                <- (Optional) Table with the information of each pair of hits in for the seed family (one per seed)
   │   │
   │   └── report_figure_thresholds.html     <- (Optional) HTML report with the plots made by report_thresholds                  
   │
   └── results                               <- Final results for sharing with collaborators, typically derived from analysis sets
       ├── fasta                             <- (Optional) folder with the fasta file of the orthologs of the seeds
       ├── patab_melt.tsv                    <- Table with the information of sORTholog one information by line
       ├── patab_table.tsv                   <- Table with the information of presence absence with genome in index and seeds in columns and proteins Id in the cell
       └── plots                             <- Plots and table on which the plot are created

  1. Before starting the pipeline, your taxids will be checked and updated for the lowest descendant levels. This will create a file of checked taxids. It will skip this step if this file already exists.

  2. When restarting the pipeline, the software will check if you made any changes in the seed file before running. If changes have been made, it will run what is necessary, else nothing will happen.


Pipeline in image


only blasta and silix behavior


Speedup behavior


Rule desciptions


Rule 1: fetch_fasta_from_seed

Rule description: Fetch the fasta protein sequence of the seed from the seed table. Then they are writen in the output file.

· input file: 
    - seed file: type = str
                 format = seed name | protein id | hmm | e-value | percentage of identity | coverage | color
                 description: seed file input by user

· output files: 
    - multi fasta file: type = str
	                    description = multifasta output of the seed protein sequences 
    - new seed file: type = str
                     columns = seed name | protein id | hmm | e-value | percentage of identity | coverage | color      
                     description = Same file as input but the 'protein id' of each file is changed to match the fasta file                

Rule 2: fetch_proteins_database

Rule description: Fetch the information for each protein of each genome in the taxid list. That includes: the protein ncbi id, sequence, length and annotation, as well as in which genome it is found. Information for the genome include genome ncbi id, name, taxid and if complete or partial.

· input file: 
    - taxid file: type = str
                  description = list of taxid in column, second additional column for teh Taxid NCBI group

  
· output files: 
    - multi fasta file: type = str
                        description = multifasta output of the genome proteomes in one file 
    - table of genomes informations: type = str
                                     format = assembly_accession | bioproject | biosample | wgs_master | excluded_from_refseq | refseq_category | relation_to_type_material | taxid | species_taxid | organism_name | infraspecific_name | isolate | version_status | assembly_level | release_type | genome_rep | seq_rel_date | asm_name | submitter | gbrs_paired_asm | paired_asm_comp | ftp_path
                                     description = table of the information collected from the NCBI Assembly.
    - table of protein informations: type = str
                                     format = protein id | protein name | genome name | genome id | length
                                     description = table of the information collected on the proteins.
    - new taxid file: type = str
                      description = list of taxid downloaded in column
                      

Rule 2.1.1: make_seed_psiblast (optional)

Rule description: filter the seed fasta to keep only the seed that do not have a hmm profile associated with them in the seed initial seed file

· input file:
    - fasta seed: type = str
                  description = multifasta of the seed sequences
                  
· output file:    
    - fasta: type = str
             description = multifasta of the seed sequences that do not have a hmm profile associated with 
             

Rule 2.1.2: psiblast (optional)

Rule description: Use the seed protein sequences to make a psi-BLAST against all the taxid proteome.

· input files:
    - seed fasta: type = str
                  description = multifasta of the seed sequences that do not have a hmm profile associated with
    - taxid fasta: type = str 
                   description = multifasta of the genome sequences
        
· output file:  
    - blast out: type = str
                 format = query accession | query length | query sequence | query start position | querry end position | subject accession | subject length | subject sequence| subject start position | subject end position | length of alignment | percentage of identity | e-value | bitscore | querry coverage
                 description = blast out format 6 in tabulation, no header

Rule 2.1.3: read_psiblast (optional)

Rule description: Read the psiBLAST output, remove unwanted lines and extract the list of protein matches.

· input files: 
    - psiblast output: type = str
                       format = query accession | query length | query sequence | query start position | querry end position | subject accession | subject length | subject sequence| subject start position | subject end position | length of alignment | percentage of identity | e-value | bitscore | querry coverage
                       description = blast out format 6 in tabulation, no header
               
· output files:
    - list all prot: type = str
                     description = list of all potein identifications gathered in the psiBLAST in column

Rule 2.2.1: hmmsearch (optional)

Rule description: Use hmm profile(s) provided to fetch similar proteins in the taxid proteome using hmmsearch from hmmer

· input file: 
    - hmm: type = list of str
           description = list of hmm profile provided in the hmm folder and indictaed in the seed table
    - taxid db: type = str
                description = multifasta of the taxid proteome
               
· output file:
    - domtblout: type = str
                 format = protein id | protein accession | protein length | query | query accession | query length | full evalue | full score | full bias | domain number | domain of | domain c-evalue | domain c-evalue | domain score | domain_bias | query from | query to | ali from | ali to | env from | env to | target description
                 description = domtblout output format of hmmsearch
    - seed hmm: type = str
                description = merge file of the hmm profile provided


Rule 2.2.2: read_hmmsearch (optional)

Rule description: Read the hmmsearch output and extract the list of protein matches.

· input file: 
    - hmm out: type = str
               format = protein id | protein accession | protein length | query | query accession | query length | full evalue | full score | full bias | domain number | domain of | domain c-evalue | domain c-evalue | domain score | domain_bias | query from | query to | ali from | ali to | env from | env to | target description
               description = domtblout output format of hmmsearch
               
· output file:
    - list all prot: type = str
                     description = list of all potein identifications gathered in the hmmsearch in column

Rule 2.3: merge_hmmsearch_psiblast (optional)

Rule description: merge the list of proteines from both the psiBLAT and hmmsearch results.

· input files: 
    - list hmmsearch: type = str
                      description = list of all potein identifications gathered in the hmmsearch in column
    - list psiblast: type = str
                     description = list of all potein identifications gathered in the psiBLAST in column             
               
· output file:
    - list all prot: type = str
                     description = list of all potein identifications gathered in both the psiblast and the hmmsearch in column

Rule 2.4: make_fasta (optional)

Rule description: Create a fasta file from the psiblast results and the result of the protein information in the rule cat_proteins_info.

· input files:
    - protein table: type = str
                     format = protein id | protein name | genome name | genome id | length
                     description = table of protein information 
    - list all prot: type = str
                     description = list of all potein identifications gathered in both the psiblast and the hmmsearch in column
  
· output file: 
    - multifasta: type = str
                  description = multifasta file of all the unique protein ids.

Rule 3: merge_fasta

Rule description: Merge the proteome of interest with the seeds

· input files:
    - taxid fasta: type = str
                     description =   all proteome multifasta or multifasta file of all the unique protein ids if speedup true
    - seed fasta: type = str
                  description = multifasta file of all the seeds from the rule fetch_fasta_from_seed
  
· output file:
    - fasta for blast: type = str
                       description = concatenation of the 2 input multifasta files

Rule 4: blast

Rule description: Blast all versus all of the fasta of all proteins.

· input file:
    - fasta for blast: type = str
                       description = concatenation of the the proteome taxid and seeds multifasta files
  
· output file:
    - blast out: type = str
                 format = query id | subject id | percentage of identity | length of match  | mismatch | gapopen | query start position | query end position | subject start position | subject end position | e-value | bitscore
                 description = output format 6 of blast, no header

Rule 5: prepare_for_silix

Rule description: Filter the blast results from the rule blast with the threshold specified for each seed in the seed file. Filters include the identity score, coverage and e-value, decided by the user. Create one new filtered blast result for each seed.

· input files: 
    - seed file: type = str
                 format = seed name | protein id | hmm | e-value | percentage of identity | coverage | color
                 description: seed file input by user           
    - blast out: type = str
                 format = query id | subject id | percentage of identity | length of match  | mismatch | gapopen | query start position | query end position | subject start position | subject end position | e-value | bitscore
                 description =  blast output 6 from the rule blast  
  
· output files: 
    - blast output to send to silix: type = list of str
                                     format = query id | subject id | percentage of identity | length of match  | mismatch | gapopen | query start position | query end position | subject start position | subject end position | e-value | bitscore
                                     description = list of blast output filtered for each seed.
                                   

Rule 6: silix

Rule description: Uses Silix to create a network of protein and give a file of the protein segregated in groups. If the blast output file is empty, just create an empty file.

· input files:
    - blast out: type = str
                 format = query id | subject id | percentage of identity | length of match  | mismatch | gapopen | query start position | query end position | subject start position | subject end position | e-value | bitscore
                 description = blast output filtered for a specific seed from the rule prepare_for_silix.
    - fasta: type = str
             description = multifasta of proteins with seed from the rule merge fasta
  
· output file:
    - fnodes: type = str 
              format = family | protein id
              description = fnodes file, table of protein id and family number, without headers.        

Rule 7: find_family

Rule description: Find the group of each seed in each individual seed and record it.

· input files:
    - fnodes: type = str
              format = family | protein id
              description = fnodes file, table of protein id and family number, without headers from the rule silix.
    - seed file: type = str
                 format = seed name | protein id | hmm | e-value | percentage of identity | coverage | color
                 description: seed file input by user  
  
· output file:
    - updadted fnodes: type = str
                       format = family | protein id | seed
                       description = updated fnodes with only the family of the seed.

Rule 8: make_PA_table

Rule description: Check the presence of protein similar to the seed in each taxid and create a table of presence abscence. This table will be plotted in a colored table.

· input files:
    - seed file: type = str
                 format = seed name | protein id | hmm | e-value | percentage of identity | coverage | color
                 description: seed file input by user  
    - protein table: type = str
                     format =  protein id | protein name | genome name | genome id | length
                     description = final table of protein information
    - updadted fnodes: type = str
                       format = family | protein id | seed
                       description =  updated fnodes with only the family of the seed
  
· output files:
    - final table melt: type = str
                        format = genome_id | genome_name | seed | PA | color | protein_id
                        description = presence/abscence table, with header. Each line is a protein information
    - final table crosstab: type = str
                            format = row = genome_id, columns = seed 1 | seed 2 .. seed x
                            description = presence/abscence table, with header. Each line is a genome, each column is a seed.                   

Rule 9: plots

Rule description: Plot the table from make_PA_table in a colored table.

· input file:
    - final table melt : type = str
                         format = genome_id | genome_name | seed | PA | color | protein_id
                         description = presence/abscence table, with header. Each line is a protein information
  
· output files:
    - pdf: type = list of str
           description = plots in pdf of the final table centered on one seed 
    - png: type = list of str
           description = plots in png of the final table centered on one seed

Additional rules


Rule A1: report_threshold

Rule description: Pair of rules that works together. From the blast output, create a report containing 2 scatter plots: one comparing the coverage and percentage identity of the hits and the other adding the evalue to the comparaison.

To run the rules do

snakemake report_threshold --cores 1 --use-conda

Sub rule A1a: blast2threshold_table
· input files:
    - seed file: type = str
                 format = seed name | protein id | hmm | e-value | percentage of identity | coverage | color
                 description: seed file input by user  
    - protein table: type = str
                     format =  protein id | protein name | genome name | genome id | length
                     description = final table of protein information.
    - updadted fnodes: type = str
                       format = family | protein id | seed
                       description =  updated fnodes with only the family of the seed
    - blast out: type = str
                 format = query id | subject id | percentage of identity | length of match  | mismatch | gapopen | query start position | query end position | subject start position | subject end position | e-value | bitscore
                 description = output format of blast                                 
  
· output file:
    - table_thresholds : type = str
                         format = protein1 | protein 2 | pident | coverage | evalue | length
                         description = table with the columns from the blast output of only the pairs containing at least one member of the seed family.

Sub rule A1a: report_threshold
· input file:
    - tables_thresholds : type = list of str
                          format = protein1 | protein 2 | pident | coverage | evalue | length
                          description = table with the columns from the blast output of only the pairs containing at least one member of the seed family.                               
  
· output file:
    - report_html : type = str
                    description = report in html that contains the figure made using the coverage/percentage identity/evalue of all hits for each seeds family


Rule A2: extract_protein

Rule description: Create a fasta for each orthologs found (one fasta file per seed)

To run the rule do

snakemake extract_protein --use_conda --cores 1

or if on the cluster, do

snakemake extract_protein --use_conda --cores 1 --profile config/slurm
· input files:
    - final table melt : type = str
                         format = genome_id | genome_name | seed | PA | color | protein_id
                         description = presence/abscence table, with header. Each line is a protein information
    - prot sequence: type = str
                     description =  multifasta file of all the unique protein ids                         
  
· output file:
    - fasta files : type = list of str
                    description = name of all the fasta output with the format [name of the seed].fasta

Rule A3: quick_plots

Rule description: Plot a presence absence table that you may have edited in pdf and png.

To run the rule do

snakemake quick_plots -C PAtab_table=path/to/pa_table.tsv --use_conda --cores 1

or if on the cluster, do

snakemake quick_plots -C PAtab_table=path/to/pa_table.tsv --use_conda --cores 1 --profile config/slurm

Example of the presence/absence table in the doc folder in the GitHub page

· input files:
    - PA table : type = str
                 format = genome_id in the first column and the next columns are annotation columns
                 description = presence/abscence table, with header.
  
· output files:
    - pdf: type = list of str
           description = plots in pdf of the final table centered on one seed 
    - png: type = list of str
           description = plots in png of the final table centered on one seed

Rule A4: clean

Rule description: Remove the folder database, logs and processing_files to only keep results

To run the rule do

snakemake clean --cores 1
· input files:
    - database, logs and processing_files directory

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Python 90.8%
  • CSS 9.2%