Skip to main content

VICC normalization routine for diseases

Project description

Disease Normalization

Services and guidelines for normalizing disease terms

Developer instructions

Following are sections include instructions specifically for developers.

Installation

For a development install, we recommend using Pipenv. See the pipenv docs for direction on installing pipenv in your compute environment.

Once installed, from the project root dir, just run:

pipenv sync

Deploying DynamoDB Locally

We use Amazon DynamoDB for our database. To deploy locally, follow these instructions.

Init coding style tests

Code style is managed by flake8 and 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

Running unit tests

Running unit tests is as easy as pytest.

pipenv run pytest

Updating the disease normalization database

Before you use the CLI to update the database, run the following in a separate terminal to start DynamoDB on port 8000:

java -Djava.library.path=./DynamoDBLocal_lib -jar DynamoDBLocal.jar -sharedDb

To change the port, simply add -port value.

Update source(s)

The sources we currently use are: OncoTree, OMIM, Disease Ontology, and Mondo.

The application will automatically retrieve input data for all sources but OMIM, for which a source file must be manually acquired and placed in the disease/data/omim folder within the library root. In order to access OMIM data, users must submit a request here. Once approved, the relevant OMIM file (mimTitles.txt) should be renamed according to the convention omim_YYYYMMDD.tsv, where YYYYMMDD indicates the date that the file was generated, and placed in the appropriate location.

To update one source, simply set --normalizer to the source you wish to update. Accepted source names are DO (for Disease Ontology), Mondo, OncoTree, and OMIM.

From the project root, run the following to update the Mondo source:

python3 -m disease.cli --normalizer="Mondo"

To update multiple sources, you can use the normalizer flag with the source names separated by spaces.

python3 -m disease.cli --normalizer="Mondo OMIM DO"

Update all sources

To update all sources, use the --update_all flag.

From the project root, run the following to update all sources:

python3 -m disease.cli --update_all

Create Merged Concept Groups

The normalize endpoint relies on merged concept groups.

To create merged concept groups, use the --update_merged flag with the --update_all flag.

python3 -m disease.cli --update_all --update_merged

Specifying the database URL endpoint

The default URL endpoint is http://localhost:8000.

There are two different ways to specify the database URL endpoint.

The first way is to set the --db_url flag to the URL endpoint.

python3 -m disease.cli --update_all --db_url="http://localhost:8001"

The second way is to set the DISEASE_NORM_DB_URL to the URL endpoint.

export DISEASE_NORM_DB_URL="http://localhost:8001"
python3 -m disease.cli --update_all

Starting the disease normalization service

From the project root, run the following:

uvicorn disease.main:app --reload

Next, view the OpenAPI docs on your local machine:

http://127.0.0.1:8000/disease

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

disease-normalizer-0.2.10.tar.gz (26.2 kB view details)

Uploaded Source

Built Distribution

disease_normalizer-0.2.10-py3-none-any.whl (32.9 kB view details)

Uploaded Python 3

File details

Details for the file disease-normalizer-0.2.10.tar.gz.

File metadata

  • Download URL: disease-normalizer-0.2.10.tar.gz
  • Upload date:
  • Size: 26.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.2 CPython/3.9.6

File hashes

Hashes for disease-normalizer-0.2.10.tar.gz
Algorithm Hash digest
SHA256 9c0df097bb735c81efe870a6b39edcd7d6cee00199ee8eb015ff1ceb78b1a7ed
MD5 ee56ecf90e0f2abe134cbfc0328de85a
BLAKE2b-256 ba15ca1b7d27208178e6acd7de107f4bd4e41084c003fdaa716ea85ef4143169

See more details on using hashes here.

File details

Details for the file disease_normalizer-0.2.10-py3-none-any.whl.

File metadata

  • Download URL: disease_normalizer-0.2.10-py3-none-any.whl
  • Upload date:
  • Size: 32.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.2 CPython/3.9.6

File hashes

Hashes for disease_normalizer-0.2.10-py3-none-any.whl
Algorithm Hash digest
SHA256 abf96b4467b9da5880136e6b02a231f7048145a1fbe9b8679d429bbc34dfa93a
MD5 5fe5b3c529d746d07b1e35dbb79086e1
BLAKE2b-256 ca9e53dcca6f8c34d533b401faa1436fda65ceb817d06d956cae1f0183048a60

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