Skip to main content

tincheck

Project description

Tincheck

Tincheck is a python package to calculate transcript Integrity Number (TIN) and Transcription overlap.

Transcripts with transcription overlap or uneven coverage can result in false positives in differential expression analysis. Transcript Integrity Number is a metric that calculates coverage evenness and can be used as a filtering criteria in RNA-Seq studies to improve the accuracy of results.

Transcript Integrity Number (TIN) calculation

TIN denotes how evenly a feature is covered by reads. By default, the script calculate the coverage evenness across a gene by considering the coverage across all exons. However, the script can calculate coverage evenness across a transcript or any other feature that is in the annotation file.

Inputs

  1. Alignment file in bam format
  2. Annotation file in GTFor GFF3 format

Output

Tab delimited textfile with TIN score calculated for each gene/transcript/any other feature specified in the input. An example is given below.

target_id       eff_length  S1_count    S1_exp_tin  S1_obs_tin
PF3D7_0102700	1683	    670	        100.0	    70.9
PF3D7_0103700	1624	    135	        100.0	    72.8
PF3D7_0107300	1581	    4508        100.0	    70.4
PF3D7_0107600	5702	    4979        100.0	    74.9
PF3D7_0107800	4424	    924	        100.0	    78.8

How to install the script?

pip install tincheck --upgrade

Install additional requirements

conda install --file conda-requirements.txt

How to run the script?

The required inputs to the script is bam file(s) and annotation file in GTF or GFF format.

The annotation file should have a gene feature row present in it.

Given a bam file and an annotation file, the simplest way to run the script is

tincheck tin --ann data/ann.gtf data/sample.bam 

How to calculate TIN across coding regions of a gene?

tincheck tin  --ann data/ann.gtf --feat CDS data/sample.bam

How is tin calculated

Overlapping features specified by --feat are merged together and coverage evenness is captured using Shannon's entropy formula (H). This is then convered into TIN Score as

TIN = (100*exp(H))⁄length  where H= Shannon's entropy formula.

Transcription overlaps

Transcription overlaps are flagged using overlap.py script.

tincheck overlap --ann data/ann.gtf data/sample.bam >sample_overlap.txt

By default, genes are checked for overlap only if

gene-tin < tin-cutoff and gene-count > count-cutoff

ie, genes with enough counts but low tins are checked for transcription overlap

A gene is flagged to have a transcription overlap if either of its neighboring genes and the corresponding inter-genic region have a higher tin-score and read count than the gene of interest.

In stranded mode, if the count and tin values of neighboring genes and the intergenic region in the gene sense strand is comparable to the gene count and tin, then that gene is considered to have an overlap from neighboring transcripts.

More specifically in stranded mode, a gene is considered to have a neighboring transcript overlap, if either of the following conditions are satisfied.

1. left gene tin in gene sense strand >= gene tin and left intergenic tin in gene sense strand >=gene-tin
2. right gene tin in gene sense strand >= gene tin and right intergenic tin in gene sense strand >=gene-tin

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

tincheck-0.2.0.tar.gz (15.5 kB view details)

Uploaded Source

Built Distribution

tincheck-0.2.0-py3-none-any.whl (18.4 kB view details)

Uploaded Python 3

File details

Details for the file tincheck-0.2.0.tar.gz.

File metadata

  • Download URL: tincheck-0.2.0.tar.gz
  • Upload date:
  • Size: 15.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.8.17

File hashes

Hashes for tincheck-0.2.0.tar.gz
Algorithm Hash digest
SHA256 bc065430169cd0711699724b16cb9bf98f71ae70ff87e9a73282f2f1bd1cc68c
MD5 588e183c5d87be69a395703c832154cc
BLAKE2b-256 afb8fbf8495429d12e471ec40b881373c78e8b8b380e6f6366b10602a11e6b77

See more details on using hashes here.

File details

Details for the file tincheck-0.2.0-py3-none-any.whl.

File metadata

  • Download URL: tincheck-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 18.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.8.17

File hashes

Hashes for tincheck-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 b4497d34d38a23c43ceffd718ae253c875efe4808806d0faecc78718a765a629
MD5 670b412ad684b1de6bf3a9b2ebeb7d59
BLAKE2b-256 11537f0f82073a43b3e5c79738e5bae71a4850c5b0975ebfe62f8a45c780f11a

See more details on using hashes here.

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