Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[MNT] Replaced Cognitive Atlas with SNOMED #397

Open
wants to merge 2 commits into
base: main
Choose a base branch
from
Open

[MNT] Replaced Cognitive Atlas with SNOMED #397

wants to merge 2 commits into from

Conversation

rmanaem
Copy link
Collaborator

@rmanaem rmanaem commented Dec 20, 2024

Checklist

This section is for the PR reviewer

  • PR has an interpretable title with a prefix ([ENH], [FIX], [REF], [TST], [CI], [MNT], [INF], [MODEL], [DOC]) (see our Contributing Guidelines for more info)
  • PR has a label for the release changelog or skip-release (to be applied by maintainers only)
  • PR links to GitHub issue with mention Closes #XXXX
  • Tests pass
  • Checks pass
  • If the PR changes the SPARQL query template, the default Neurobagel query file has also been regenerated

For new features:

  • Tests have been added

For bug fixes:

  • There is at least one test that would fail under the original bug conditions.

Summary by Sourcery

Switch from using the Cognitive Atlas to SNOMED CT for assessments.

Copy link

sourcery-ai bot commented Dec 20, 2024

Reviewer's Guide by Sourcery

This pull request replaces the Cognitive Atlas vocabulary with SNOMED for assessments. It updates the API endpoint, data fetching logic, and tests to reflect this change. A local copy of the SNOMED vocabulary is now used for lookups.

Class diagram showing updated vocabulary handling

classDiagram
    class VocabHandler {
        +create_snomed_assessment_lookup(output_path)
        +create_snomed_disorder_lookup(output_path)
        -load_json(path)
    }
    note for VocabHandler "Replaced fetch_and_save_cogatlas with SNOMED handlers"

    class Router {
        +get_vocab()
        +get_instances()
    }

    class RouteFactory {
        +create_get_vocab_handler(external_vocab, vocab_name, namespace_prefix)
    }

    Router --> RouteFactory: uses
    Router --> VocabHandler: uses
Loading

File-Level Changes

Change Details Files
Replaced Cognitive Atlas with SNOMED for assessments
  • Updated the test_stored_vocab_lookup_file_created_on_startup test to use the SNOMED vocabulary.
  • Removed functions related to fetching the Cognitive Atlas vocabulary and added functions to create SNOMED lookup files.
  • Updated tests to use SNOMED URIs and labels.
  • Updated the startup event to create SNOMED lookup files instead of Cognitive Atlas.
  • Updated the assessments router to use SNOMED.
  • Updated the diagnoses router to use the correct SNOMED lookup.
  • Updated the route factory to use a namespace prefix for vocabularies.
  • Updated the default Neurobagel query file.
  • Added a local backup copy of the SNOMED assessment vocabulary file.
tests/test_app_events.py
app/api/utility.py
tests/test_attribute_factory_routes.py
app/main.py
app/api/routers/assessments.py
app/api/routers/diagnoses.py
app/api/routers/route_factory.py
docs/default_neurobagel_query.rq
vocab/backup_external/snomed_assessment.json

Assessment against linked issues

Issue Objective Addressed Explanation
#390 Replace Cognitive Atlas vocabulary with SNOMED in the vocab endpoint and saved vocab file
#390 Replace Cognitive Atlas vocabulary with SNOMED in the query template
#390 Replace Cognitive Atlas vocabulary with SNOMED in the /assessments endpoint

Possibly linked issues


Tips and commands

Interacting with Sourcery

  • Trigger a new review: Comment @sourcery-ai review on the pull request.
  • Continue discussions: Reply directly to Sourcery's review comments.
  • Generate a GitHub issue from a review comment: Ask Sourcery to create an
    issue from a review comment by replying to it.
  • Generate a pull request title: Write @sourcery-ai anywhere in the pull
    request title to generate a title at any time.
  • Generate a pull request summary: Write @sourcery-ai summary anywhere in
    the pull request body to generate a PR summary at any time. You can also use
    this command to specify where the summary should be inserted.

Customizing Your Experience

Access your dashboard to:

  • Enable or disable review features such as the Sourcery-generated pull request
    summary, the reviewer's guide, and others.
  • Change the review language.
  • Add, remove or edit custom review instructions.
  • Adjust other review settings.

Getting Help

Copy link

codecov bot commented Dec 20, 2024

Codecov Report

All modified and coverable lines are covered by tests ✅

Project coverage is 96.94%. Comparing base (8e1c289) to head (2e1d4b3).
Report is 3 commits behind head on main.

Additional details and impacted files
@@            Coverage Diff             @@
##             main     #397      +/-   ##
==========================================
- Coverage   97.09%   96.94%   -0.15%     
==========================================
  Files          24       24              
  Lines         861      819      -42     
==========================================
- Hits          836      794      -42     
  Misses         25       25              

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

@alyssadai alyssadai self-requested a review January 6, 2025 17:13
@rmanaem rmanaem added release Create a release when this PR is merged pr-internal Non-user-facing code improvement, will increment patch version when merged (0.0.+1) pr-minor-breaking Feature or enhancement that breaks compatibility, will increment minor version (0.+1.0) and removed pr-internal Non-user-facing code improvement, will increment patch version when merged (0.0.+1) labels Jan 6, 2025
Copy link
Contributor

@surchs surchs left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

looks good to me @rmanaem, thanks for taking this on. I left some comments for you to look at.

With those 🧑‍🍳

@@ -3,7 +3,7 @@
from ..models import DataElementURI, VocabLabelsResponse
from . import route_factory

EXTERNAL_VOCAB = "snomed"
EXTERNAL_VOCAB = "snomed_disorder"
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

why is the vocab file already renamed in the main branch? Is this from a daisy chained PR?


term_labels = {term["id"]: term["name"] for term in vocab}
term_labels = {term["identifier"][7:]: term["label"] for term in vocab}
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

this double index confuses my brain. On a related note: it seems that we now have two snomed sub-vocabularies with different formats:

snomed disorder:

{
    "sctid": "10007009",
    "preferred_name": "Coffin-Siris syndrome"
  },

and snomed assessment:

[
  {
    "identifier": "snomed:1231439001",
    "label": "Calgary Depression Scale for Schizophrenia"
  },

I think we should make both consistent and I think the assessment shape (identifier + label) is nicer

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
pr-minor-breaking Feature or enhancement that breaks compatibility, will increment minor version (0.+1.0) release Create a release when this PR is merged
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Replace Cognitive Atlas vocab with SNOMED
2 participants