Skip to main content

Python library for detecting Frequently Interacting REgions (FIREs) from Hi-C data

Project description

Detect Frequently Interacting REgions (FIREs) in Python

PyPI

The project is a port of the R package for detecting frequently interacting regions (FIREs) from Hi-C data to Python. FIRE is described in A Compendium of Chromatin Contact Maps Reveal Spatially Active Regions in the Human Genome paper.

Command line usage

Install the package:

python3 -m pip install FIREcaller

Download some HiC experiment results from the 4D Nucleome database. Choose Contact Matrix (.mcool) as a file type.

Download the mappability file from Yunjiang's website. Ensure the genomic assembly and the bin size matches your HiC files. Add header line chr start end F GC M if missing.

Perform FIRE calling:

FIREcaller \
  --cooler_filenames 4DNFIT5YVTLO.mcool \
  --cooler_filenames 4DNFIJTOIGOI.mcool \
  --mappability_filename F_GC_M_Hind3_10Kb_el.GRCh38.txt \
  --bin_size 10000 \
  --output_filename fires.csv

The output file will consist of the genomic regions and their corresponding FIRE scores and log p-values for each HiC file:

chr start end F GC M 0_count_neig 1_count_neig 0_fire 1_fire 0_logpvalue 1_logpvalue
chr1 1970000 1980000 2000 0.5175 1.0000 5365 2376 0.9515 0.8702 0.5861 0.4317
chr1 2020000 2030000 3000 0.6287 0.9907 4305 2005 0.5806 0.5831 0.1128 0.1144
chr1 2060000 2070000 4000 0.4770 0.9210 4029 2171 0.6880 0.8678 0.1954 0.4277
(...)

{n}_fire column stores the FIIRE score for the n-th cooler file provided as --cooler_filenames argument

{n}_logpvalue column stores the log p-value for the n-th cooler file provided as --cooler_filenames argument

Python usage

Use the FIREcaller.calc_fires() function to perform FIRE calling from your Python program:

calc_fires(mappability_filename, cooler_filenames, bin_size, neighborhood_region, perc_threshold=.25, avg_mappability_threshold=0.9)

mappability_filename : str - Path to mappability file

cooler_filenames : str - List of paths to HiC experiment results in cooler format

bin_size : int - Bin size

neighborhood_region : int - Size of neighbor region

perc_threshold : float - Maximum ratio of "bad" neighbors allowed

avg_mappability_threshold : float - Minimum mappability allowed

The function returns the Pandas DataFrame matrix.

Verification

In order to compare the results derived from this project with the ones obtained from the FIREcaller R package please follow the steps described in the README.md file to produce the FIRE_ANALYSIS_40KB.txt file.

Now download and uncompress the Hippo_Hi-C_inputs_chr1_22.tar.gz and F_GC_M_HindIII_40KB_hg19.txt.gz files.

Convert the HiC files to get the hippo.mcool cooler file using the scripts/build_hippo_cool.py python script:

python scripts/build_hippo_cool.py

Run the FIRE calling:

FIREcaller \
  --cooler_filename hippo.mcool \
  --mappability_filename F_GC_M_HindIII_40KB_hg19.txt \
  --bin_size 40000 \
  --output_filename hippo_fires.csv

Compare the FIRE_ANALYSIS_40KB.txt and fires.csv files.

TODO:

  • Add option to remove the MHC regions
  • Calculate the Super FIREs
  • Convert the script into the Python package

Let me know if you need any of the above and I'll be happy to implement it. I also accept PRs and comments. Enjoy.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

FIREcaller-1.0.0.tar.gz (6.2 kB view hashes)

Uploaded Source

Built Distribution

FIREcaller-1.0.0-py3-none-any.whl (10.9 kB view hashes)

Uploaded Python 3

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page