Skip to main content

Extract terminal repeats from retrotransposons (LTRs) or DNA transposons (TIRs). Compose synthetic MITES from complete DNA transposons.

Project description

License: GPL v3 PyPI version codecov Downloads

tSplit the TE-splitter

Extract terminal repeats from retrotransposons (LTRs) or DNA transposons (TIRs). Returns compontent segments of the element for use with transposon mapping tools.

Optionally, tsplit TIR can also compose synthetic MITES from complete DNA transposons.

Table of contents

Algorithm overview

tSplit attempts to identify terminal repeats in transposable elements by first aligning each element to itself using blastn or nucmer, and then applying a set of tuneable heuristics to select an alignment pair most likely to represent an LTR or TIR, as follows:

  1. Exclude all diagonal/self-matches
  2. If tsplit LTR: Retain only alignment pairs on the same strand (tandem repeats)
  3. If tsplit TIR: Retain only alignment pairs on opposite strands (inverse repeats)
  4. Retain pairs for which the 5' match begins within x bases of element start and whose 3' match ends within x bases of element end
  5. If multiple candidates remain select alignment pair with largest internal segment (i.e. closest to element ends)

Options and usage

Installing tSplit

Requirements:

You can create a Conda environment with these dependencies using the YAML file in this repo.

conda env create -f environment.yml

conda activate tsplit

After activating the tsplit environment you can use pip to install the latest version of tsplit.

Installation options:

  1. Install from PyPi. This will get you the latest stable release.
pip install tsplit
  1. Pip install directly from this git repository.

This is the best way to ensure you have the latest development version.

pip install git+https://github.com/Adamtaranto/tSplit.git

Example usage

tSplit can be run in two modes: tsplit LTR and tsplit TIR, for extracting long terminal repeats or terminal inverted repeats, respectively.

Options are the same for each.

tsplit TIR

For each element in TIR_element.fa split into internal and external (TIR) segments.

Split segments will be written to TIR_split_tsplit_output.fasta with suffix "_I" for internal or "_TIR" for external segments.

TIRs must be at least 10bp in length and share 80% identity and occur within 10bp of each end of the input element.

tsplit TIR -i tests/data/TIR_element.fa -p TIR_split

# Equivalet to defaults
tsplit TIR -i tests/data/TIR_element.fa -p TIR_split --maxdist 10 --minid 80.0 --minterm 10 --method blastn --splitmode split
# Use '--both' if you want to report both left and right TIRs

Output: TIR_split_tsplit_output.fasta

Visualise annotated dotplot

tsplit TIR -i tests/data/TIR_element.fa -d results --splitmode split --paf --gff

flexidot -i tests/data/TIR_element.fa -a results/TIR_element.paf -m 2 -o results/blast_dotplot --gff results/TIR_element.gff3

Output: TIR element blastn self-align dotplot with detected TIRs highlighted in red on the diagonal.

tsplit LTR

For each element in LTR_retrotransposon.fa split into internal and external segments.

Split segments will be written to LTR_split_tsplit_output.fasta with suffix "_I" for internal or "_LTR" for external segments.

LTRs must be at least 10bp in length and share 80% identity and occur within 10bp of each end of the input element.

tsplit LTR -i tests/data/LTR_retrotransposon.fa -p LTR_split

Output: LTR_split_tsplit_output.fasta

License

Software provided under GPL-3 license.

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

tsplit-0.3.0.tar.gz (89.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

tsplit-0.3.0-py3-none-any.whl (36.6 kB view details)

Uploaded Python 3

File details

Details for the file tsplit-0.3.0.tar.gz.

File metadata

  • Download URL: tsplit-0.3.0.tar.gz
  • Upload date:
  • Size: 89.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for tsplit-0.3.0.tar.gz
Algorithm Hash digest
SHA256 5837537108f52b8605921bda527a328cb58f7e691c4f666b8e15f64302175f1c
MD5 b111ae6d610573a0d1f718073f70c29a
BLAKE2b-256 25bbb0945c6e436fb84a96c14806db9079b5740c763b0df16c97091a911e3828

See more details on using hashes here.

Provenance

The following attestation bundles were made for tsplit-0.3.0.tar.gz:

Publisher: publish.yml on Adamtaranto/tSplit

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file tsplit-0.3.0-py3-none-any.whl.

File metadata

  • Download URL: tsplit-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 36.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for tsplit-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 fad832e05f123a9f88b261d6e68b97ee5a2587ff3ad3678821c50d63c0d072e2
MD5 258a24ed986ca01e38fd2253f77378e0
BLAKE2b-256 911b912e1cf569c9cf72ce3f7201dda3e4edbca8e013159c482637efc297e15e

See more details on using hashes here.

Provenance

The following attestation bundles were made for tsplit-0.3.0-py3-none-any.whl:

Publisher: publish.yml on Adamtaranto/tSplit

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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