Skip to main content

CathPy - Python Bioinformatics Toolkit for CATH (Protein Classification).

Project description

cathpy

Documentation Status Build Status

cathpy is a Bioinformatics toolkit written in Python. It is developed and maintained by the Orengo Group at UCL and is used for maintaining the CATH protein structure database (and associated research).

Getting Started

The easiest way to use this code is by installing the latest version into a virtual environment via pip:

$ python3 -m venv venv
$ source venv/bin/activate
$ pip install cathpy

If everything is installed and working properly then the following should work:

$ cath-align-summary -d tests/data/funfams/
file aln_len seq_count dops gap_per
tests/data/funfams/1.10.8.10-ff-14534.reduced.sto                          69     51  61.53  12.53
tests/data/funfams/1.10.8.10-ff-15516.reduced.sto                          66    429 100.00  13.04
tests/data/funfams/1.10.8.10-ff-5069.reduced.sto                           59     14   7.81   3.15
tests/data/funfams/1.10.8.10-ff-15593.reduced.sto                          63    203  95.88  17.70

Now go and have a look at the documentation.

Contributing

There are many ways to contribute, all of which are most welcome.

  • If something is not clear then you have identified a gap in the documentation, please let us know by raising a new issue
  • If it looks like you should be able to do something that you can't then you've either identified a new feature request or a documentation gap - please let us know by raising a new issue
  • If you have noticed some unexpected behaviour, you may have found a bug - please let us know by raising a new issue

When you do raise an issue, it is extremely helpful if you first check that a similar issue has not already been registered. It would also be great if you can be as clear, concise and specific as possible. If you are reporting a potential bug, please try to provide steps that will allow us to reproduce the unexpected behaviour.

If you accompany your issue with a Pull Request that actually solves the documentation / feature request / bug fix then you may well be eligible for doughnuts.

Development

If you are developing, then this is the general recommended flow:

Get access to the latest version of the code and create a new branch (with a descriptive summary of your new feature/bugfix):

$ git clone git@github.com:UCL/cathpy.git
$ cd cathpy
$ git checkout -b my-awesome-new-feature

Install the code (as editable package) into virtual environment

$ python3 -m venv venv
$ source venv/bin/activate
$ pip install -e .

Write your tests, make your changes then make sure your tests (and all the other tests) still pass:

$ vim tests/my_new_feature_test.py
$ vim cathpy/my_new_feature.py
$ pytest

Then push your changes back to GitHub and raise a pull request through the web pages.

$ git push

FAQ

What is cathpy?

cathpy is a python package that contains bioinformatics tools and libraries used in CATH (protein structure classification resource at UCL).

Hmmm.. that sounds like Yet Another Python Bioinformatics Toolkit?

Well it is... sort of.

Should I be using it?

If you are looking for a general Bioinformatics toolkit, you should look at BioPython first.

The cathpy project does contain some generic functionality that may overlap with BioPython, however we are definitely not trying to rewrite that library. It has been published mainly for internal use (within CATH), however it has been released as open source in case others find the tools helpful.

External software

This code base contains external tools that are not written and maintained by the authors of this project. If you use the results of these tools, please reference the relevant papers.

GroupSim

Characterization and Prediction of Residues Determining Protein Functional Specificity. Capra JA and Singh M (2008).
Bioinformatics, 24(13): 1473-1480, 2008.

Scorecons

Scoring residue conservation. Valdar WSJ (2002)
Proteins: Structure, Function, and Genetics. 43(2): 227-241, 2002.

References

The most recent paper describing the CATH protein structure database:

CATH: expanding the horizons of structure-based functional annotations for genome sequences. Sillitoe I, et al (2018)
Nucleic Acids Research, Volume 47, Issue D1, 08 January 2019, Pages D280–D284, https://doi.org/10.1093/nar/gky1097

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

cathpy-0.1.14.tar.gz (444.1 kB view details)

Uploaded Source

Built Distribution

cathpy-0.1.14-py3-none-any.whl (482.2 kB view details)

Uploaded Python 3

File details

Details for the file cathpy-0.1.14.tar.gz.

File metadata

  • Download URL: cathpy-0.1.14.tar.gz
  • Upload date:
  • Size: 444.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.19.1 setuptools/39.0.1 requests-toolbelt/0.9.1 tqdm/4.28.1 CPython/3.6.5

File hashes

Hashes for cathpy-0.1.14.tar.gz
Algorithm Hash digest
SHA256 cba32bcd869b6a29501a6d180adccc51afe6dd20c85667dfe41512d3525362fd
MD5 2b7cd2572015e4f6ca41c7ffc101cc9e
BLAKE2b-256 34f3b110b380cb99b62b170d7b64f2c2a7e01cdbdec16574641bf83b0af6c4fc

See more details on using hashes here.

File details

Details for the file cathpy-0.1.14-py3-none-any.whl.

File metadata

  • Download URL: cathpy-0.1.14-py3-none-any.whl
  • Upload date:
  • Size: 482.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.19.1 setuptools/39.0.1 requests-toolbelt/0.9.1 tqdm/4.28.1 CPython/3.6.5

File hashes

Hashes for cathpy-0.1.14-py3-none-any.whl
Algorithm Hash digest
SHA256 6342046caeda931f862cd8e1e581f291117e9d6a4bfb1801efdadc4407add878
MD5 5251b072dba3aa0e24e939fbd8d5a6f4
BLAKE2b-256 23260213c2a7535289d0c7f108574c0bf979bcebab8e3b6f90e5e1fab67d584d

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