Skip to main content

Common Operations On Lots-of Sequences Tool.

Project description

Common Operations On Lots-of Sequences Tool

The cool-seq-tool provides:

  • Transcript alignment data from the UTA database
  • Fast access to sequence data using SeqRepo
  • Liftover between assemblies (GRCh38 <--> GRCh37) from PyLiftover
  • Lifting over to preferred MANE compatible transcript. See here for more information.

Installation

pip

pip install cool-seq-tool[dev,tests]

Development

Clone the repo:

git clone https://github.com/GenomicMedLab/cool-seq-tool
cd cool_seq_tool

Install Pipenv if necessary.

Install backend dependencies and enter Pipenv environment:

pipenv shell
pipenv update
pipenv install --dev

UTA Database Installation

cool-seq-tool uses intalls local UTA database. For other ways to install, visit biocommons.uta.

Local Installation

The following commands will likely need modification appropriate for the installation environment.

  1. Install PostgreSQL

  2. Create user and database.

    $ createuser -U postgres uta_admin
    $ createuser -U postgres anonymous
    $ createdb -U postgres -O uta_admin uta
    
  3. To install locally, from the cool_seq_tool/data directory:

export UTA_VERSION=uta_20210129.pgd.gz
curl -O http://dl.biocommons.org/uta/$UTA_VERSION
gzip -cdq ${UTA_VERSION} | grep -v "^REFRESH MATERIALIZED VIEW" | psql -h localhost -U uta_admin --echo-errors --single-transaction -v ON_ERROR_STOP=1 -d uta -p 5433
UTA Installation Issues

If you have trouble installing UTA, you can visit these two READMEs.

Connecting to the database

To connect to the UTA database, you can use the default url (postgresql://uta_admin:uta@localhost:5433/uta/uta_20210129).

If you do not wish to use the default, you must set the environment variable UTA_DB_URL which has the format of driver://user:password@host:port/database/schema.

Data Downloads

SeqRepo

cool-seq-tool relies on seqrepo, which you must download yourself.

Use the SEQREPO_ROOT_DIR environment variable to set the path of an already existing SeqRepo directory. The default is /usr/local/share/seqrepo/latest.

From the root directory:

pip install seqrepo
sudo mkdir /usr/local/share/seqrepo
sudo chown $USER /usr/local/share/seqrepo
seqrepo pull -i 2021-01-29  # Replace with latest version using `seqrepo list-remote-instances` if outdated

If you get an error similar to the one below:

PermissionError: [Error 13] Permission denied: '/usr/local/share/seqrepo/2021-01-29._fkuefgd' -> '/usr/local/share/seqrepo/2021-01-29'

You will want to do the following:
(Might not be ._fkuefgd, so replace with your error message path)

sudo mv /usr/local/share/seqrepo/2021-01-29._fkuefgd /usr/local/share/seqrepo/2021-01-29
exit

LRG_RefSeqGene

cool-seq-tool fetches the latest version of LRG_RefSeqGene if the environment variable LRG_REFSEQGENE_PATH is not set. When LRG_REFSEQGENE_PATH is set, cool-seq-tool will look at this path and expect the LRG_RefSeqGene file. This file is found can be found here.

MANE Summary Data

cool-seq-tool fetches the latest version of MANE.GRCh38.*.summary.txt.gz if the environment variable MANE_SUMMARY_PATH is not set. When MANE_SUMMARY_PATH is set, cool-seq-tool will look at this path and expect the MANE Summary Data file. This file is found can be found here.

transcript_mapping.tsv

cool-seq-tool is packaged with transcript mapping data acquired from Ensembl BioMart. If the environment variable TRANSCRIPT_MAPPINGS_PATH is not set, cool-seq-tool will use the built-in file. When TRANSCRIPT_MAPPINGS_PATH is set, cool_seq_tool will look at this path and expect to find the transcript mapping TSV file.

To acquire this data manually from the BioMart, select the Human Genes (GRCh38.p13) dataset and choose the following attributes:

  • Gene stable ID
  • Gene stable ID version
  • Transcript stable ID
  • Transcript stable ID version
  • Protein stable ID
  • Protein stable ID version
  • RefSeq match transcript (MANE Select)
  • Gene name

image

Starting the UTA Tools Service Locally

To start the service, run the following:

uvicorn cool_seq_tool.api:app --reload

Next, view the FastAPI on your local machine: http://127.0.0.1:8000/cool_seq_tool

Init coding style tests

Code style is managed by Ruff and Black, and should be checked prior to commit.

We use pre-commit to run conformance tests.

This ensures:

  • Check code style
  • Check for added large files
  • Detect AWS Credentials
  • Detect Private Key

Before first commit run:

pre-commit install

Testing

From the root directory of the repository:

pytest

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

cool_seq_tool-0.3.0.dev1.tar.gz (4.0 MB view details)

Uploaded Source

Built Distribution

cool_seq_tool-0.3.0.dev1-py3-none-any.whl (4.0 MB view details)

Uploaded Python 3

File details

Details for the file cool_seq_tool-0.3.0.dev1.tar.gz.

File metadata

  • Download URL: cool_seq_tool-0.3.0.dev1.tar.gz
  • Upload date:
  • Size: 4.0 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/4.0.2 CPython/3.11.6

File hashes

Hashes for cool_seq_tool-0.3.0.dev1.tar.gz
Algorithm Hash digest
SHA256 3b2f58210c9d365d0ad03ce5d12a1ca949e0bc47a9c97c7a9261e46b2fcd0c59
MD5 ea046cdb555a688102b73602ca7574a9
BLAKE2b-256 061516e5cca9f95dc7de26e1a161a4d7677d25859ebec664d7057d1b67c362ee

See more details on using hashes here.

File details

Details for the file cool_seq_tool-0.3.0.dev1-py3-none-any.whl.

File metadata

File hashes

Hashes for cool_seq_tool-0.3.0.dev1-py3-none-any.whl
Algorithm Hash digest
SHA256 cae1becc85c228e7479b310546c060c4cb39cfd8f89180e6eb02dd699be275dd
MD5 4ce89835cc724bfdb8e7f56b8282d9ca
BLAKE2b-256 3517eb97835b35fd15e8e67e3fbadaa98f7d7d8ebe880b828cd06cf9359bc23d

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