Skip to main content

DNA curvature analysis

Project description

Dnacurve is a Python library, console script, and web application to calculate the global 3D structure of a B-DNA molecule from its nucleotide sequence according to the dinucleotide wedge model. Local bending angles and macroscopic curvature are calculated at each nucleotide.

Author:

Christoph Gohlke

License:

BSD-3-Clause

Version:

2025.5.8

DOI:

10.5281/zenodo.7135499

Quickstart

Install the dnacurve package and all dependencies from the Python Package Index:

python -m pip install -U "dnacurve[all]"

Print the console script usage:

python -m dnacurve --help

Run the web application:

python -m dnacurve --web

See Examples for using the programming interface.

Source code and support are available on GitHub.

Requirements

This revision was tested with the following requirements and dependencies (other versions may work):

Revisions

2025.5.8

  • Remove deprecated save functions (breaking).

  • Remove doctest command line option.

2025.1.1

  • Improve type hints.

  • Drop support for Python 3.9, support Python 3.13.

2024.5.24

  • Fix docstring examples not correctly rendered on GitHub.

2024.5.10

  • Fix mypy errors.

2023.8.30

  • Fix linting issues.

  • Add py.typed marker.

2023.4.30

  • Improve type hints.

  • Drop support for Python 3.8 and numpy < 1.21 (NEP29).

2022.10.4

  • Rename dnacurve_web.py to web.py (breaking).

  • Deprecate save functions (use write functions).

  • Add options to specify URL of web application and not opening web browser.

  • Run web application using Flask if installed.

  • Convert to Google style docstrings.

  • Add type hints.

  • Drop support for Python 3.7 and numpy < 1.19 (NEP29).

2021.6.29

  • Improve export to PDB.

2021.6.18

  • Drop support for Python 3.6 (NEP 29).

  • Fix dnacurve_web.py failure on WSL2.

2021.3.6

  • Update copyright and formatting.

2020.1.1

  • Drop support for Python 2.7 and 3.5.

  • Update copyright.

2018.8.15

  • Move modules into dnacurve package.

2018.5.29

  • Add option to start web interface from console.

  • Use matplotlib OOP interface.

2018.5.25

  • Add functions to return PDB and CSV results as string.

2018.2.6

  • Style and doctest fixes.

2014.6.16

  • DNAse I Consensus model.

2013.11.21

  • Overlapping chunks iterator.

2013.11.17

  • Limit maximum sequence length to 510 nucleotides.

  • Read simple FASTA sequence files.

  • Save positive coordinates to PDB files.

  • Fix sequence display for matplotlib 1.3.

2005.x.x

  • Initial release.

Notes

The algorithms, plots, and PDB format are not meant to be used with very long sequences. By default, sequences are truncated to 510 nucleotides, which can be overridden by the user.

The generated PDB files can be visualized interactively using UCSF Chimera.

Dnacurve.py was derived from DNACG.PAS (c) 1993, and DNACURVE.CPP (c) 1995.

References

  1. Bending and curvature calculations in B-DNA. Goodsell DS, Dickerson RE. Nucleic Acids Res 22, 5497-503, 1994. See also http://mgl.scripps.edu/people/goodsell/research/bend/index.html.

  2. Curved DNA without A-A: experimental estimation of all 16 DNA wedge angles. Bolshoy A et al. Proc Natl Acad Sci USA 88, 2312-6, 1991.

  3. A comparison of six DNA bending models. Tan RK and Harvey SC. J Biomol Struct Dyn 5, 497-512, 1987.

  4. Curved DNA: design, synthesis, and circularization. Ulanovsky L et al. Proc Natl Acad Sci USA 83, 862-6, 1986.

  5. The ten helical twist angles of B-DNA. Kabsch W, Sander C, and Trifonov EN. Nucleic Acids Res 10, 1097-1104, 1982.

  6. Rod models of DNA: sequence-dependent anisotropic elastic modelling of local bending phenomena. Munteanu MG et al. Trends Biochem Sci 23(9), 341-7, 1998.

Examples

>>> from dnacurve import CurvedDNA
>>> cdna = CurvedDNA('ATGCAAATTG' * 5, 'trifonov', name='Example')
>>> cdna.curvature[:, 18:22]
array([[0.58061616, 0.58163338, 0.58277938, 0.583783  ],
       [0.08029914, 0.11292516, 0.07675816, 0.03166286],
       [0.57923902, 0.57580064, 0.57367815, 0.57349872]])
>>> cdna.write_csv('_test.csv')
>>> cdna.write_pdb('_test.pdb')
>>> cdna.plot('_test.png', dpi=120)

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

dnacurve-2025.5.8.tar.gz (26.9 kB view details)

Uploaded Source

Built Distribution

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

dnacurve-2025.5.8-py3-none-any.whl (27.6 kB view details)

Uploaded Python 3

File details

Details for the file dnacurve-2025.5.8.tar.gz.

File metadata

  • Download URL: dnacurve-2025.5.8.tar.gz
  • Upload date:
  • Size: 26.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.3

File hashes

Hashes for dnacurve-2025.5.8.tar.gz
Algorithm Hash digest
SHA256 a06bed98d33bbff71b015d60ca0dd18cc3ef90f425f9d2365b021a37edcaab3c
MD5 79aedf3304f405236ad5d11e937baa78
BLAKE2b-256 5502f1ec3e0695e3746c9854553129d8699b9ccc0ff35a8717fe526dda124d6e

See more details on using hashes here.

File details

Details for the file dnacurve-2025.5.8-py3-none-any.whl.

File metadata

  • Download URL: dnacurve-2025.5.8-py3-none-any.whl
  • Upload date:
  • Size: 27.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.3

File hashes

Hashes for dnacurve-2025.5.8-py3-none-any.whl
Algorithm Hash digest
SHA256 91a0e62642f5145de701f2c0727537a857a2bf6b9336b7aed77a6281439e6bb0
MD5 090c26e345c126bf28f367418f17464d
BLAKE2b-256 22e8dbb38b218439f1f5552033d2bbdb78b7ff4a139e9276905abe3e68c35fa8

See more details on using hashes here.

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