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

i2b2 specific: ETL should convert POSITIVE into SNOMED qualifier #231

Closed
comorbidity opened this issue Jun 15, 2023 · 2 comments · Fixed by #232
Closed

i2b2 specific: ETL should convert POSITIVE into SNOMED qualifier #231

comorbidity opened this issue Jun 15, 2023 · 2 comments · Fixed by #232
Assignees

Comments

@comorbidity
Copy link
Contributor

comorbidity commented Jun 15, 2023

https://github.com/smart-on-fhir/cumulus-etl/blob/main/cumulus_etl/loaders/i2b2/external_mappings.py#L57

currently
SNOMED_LAB_RESULT = {"Positive": "10828004", "Negative": "260385009", "Absent": "272519000"}

However there is a case sensitivity issue that sometimes requires

SNOMED_LAB_RESULT = {
"Positive": "10828004", "Negative": "260385009", "Absent": "272519000",
"POSITIVE": "10828004", "NEGATIVE": "260385009"}

comorbidity added a commit to smart-on-fhir/cumulus-library-covid that referenced this issue Jun 15, 2023
define_pcr_negative.sql
define_pcr_positive.sql

todo: need to workaround
"POSITIVE" vs "Positive"
"NEGATIVE" vs "Negative"
i2b2 specific observations that are not translated in transit by ETL
smart-on-fhir/cumulus-etl#231
mikix added a commit that referenced this issue Jun 21, 2023
i.e. map both Positive and POSITIVE to the same snomed code.

Fixes #231
@mikix
Copy link
Contributor

mikix commented Jun 21, 2023

So I have a fix for this (linked above), but just FYI it won't fix the data in Athena at BCH unless I re-run the ETL on our i2b2 labs.

@comorbidity
Copy link
Contributor Author

Related to closing this issue in CORE library in favor of the COVID specific repo.
This issue may be re-opened, as it appears to possibly be NOT specific to COVID but rather CERNER.

smart-on-fhir/cumulus-library-covid#13
smart-on-fhir/cumulus-library-covid#8

dogversioning pushed a commit to smart-on-fhir/cumulus-library-covid that referenced this issue Jul 5, 2023
…se other codes for PCR tests, results, etc. (#12)

* COVID Diagnosis
formal ValueSet for ICD10 : U07.1

* COVID Diagnosis
optional support for SNOMED, in the rare case that ICD10 is not available.
SNOMED also reports for *secondary morbidities caused by COVID*, such as PNA or resp infections, etc.

* COVID PCR test LOINC test codes
qualitiative and quantitative results.
Requires associated "interpretation" of PCR result

* Valusets for lab results POSITIVE or NEGATIVE.
Includes synonyms like "identified", "presence", "weakly-reactive", etc.

* covid_define.sql Diagnosis (DX) defers to covid_symptom__define_dx using define_dx_icd10.sql. Some sites may require instead using SNOMED, which is define_dx_snomed.sql. Note that this SNOMED is not the default because our papers are written with the billing ICD10 diagnosis of U07.1.

* removed any mention of Influenza, potentially confusing/distracting to anyone reading this repository.

* BCH specific age is pediatric, other CDC pilot sites are general population age. Split age definitions into

define_age_pediatric.sql
define_age_general.sql

to use one or the other, toggle the correct target in
manifest.toml

* define PCR tests and results are now externalized to
define_pcr_negative.sql
define_pcr_positive.sql

todo: need to workaround
"POSITIVE" vs "Positive"
"NEGATIVE" vs "Negative"
i2b2 specific observations that are not translated in transit by ETL
smart-on-fhir/cumulus-etl#231

* removed covid_symptom__define_pcr_result
see instead negative and positive SQL definitions (seperate files now)

* simplified covid_symptom__define_symptom_cui to
select distinct cui,pref from covid_symptom__define_symptom

* renamed : removed superfluous study prefix from filenaames, already in the correct folder.

* covid_define.sql was deleted, partitioned into individual SQL files

* covid_symptom__site_pcr is now found in
define_pcr.sql

* renamed covid_define.py to typesystem.py

This file is depended on by other repos for COVID analysis.

* renamed covid_define_symptom.*

* site_define.sql is now deprecated, see instead each "define_***.sql" file.

* count tables are not generated dynamically.

* covid counts now generated dynamically.
only the "table" of COVID data is prepared by hand to support study objectives.

* updated manifest.toml to include new "define" SQL.

updated pyproject.toml to include latest (core) "cumulus-library"

* changed default to GENERAL population, not BCH specific pediatric
#9

* comments only to reference ISSUES open as TODO

* fixed missing comma ","

* manifest.toml restored define_study_period.sql

* removed 2016 retroactive period.
use instead covid_symptom__define_period if modifications are needed to the covid study period.

#11

* renamed covid_symptom__symptom_nlp

removed "influenza" backdating in symptom comparison.

* towards better support of PCR tests and results in different coding systems and EHR support.

#8
#13

* renamed covid_symptom__define_dx_icd10

towards better support of PCR tests and results in different coding systems and EHR support.

#8
#13

* define_ed_note.sql removed "ED Social Work" note type, only ED Note types are supported for COVID symptoms analysis.

* "Observation Interpretation"
added standard POS/NEG FHIR ValueSet

* SNOMED or ICD10 can be used to build DX table_dx.sql

* COVID study period can optionally be extended to before COVID

('before-covid', date('2016-06-01'), date('2020-02-29')),

* MILESTONE: manifest.toml updated and "tested" by executing each SQL one at a time in Athena.

table_prevalence_ed.sql now references renamed
covid_symptom__symptom_nlp

* define_ed_note.sql
fixed column names
AS t (from_system, from_code, from_display, system, code, display);

* table_dx.sql

covid_symptom__dx now contains

    c.recorded_month as cond_month,
    c.recorded_year as cond_year,

* fixed minor issues in counts.py --> counts.sql

* removed start_year counts query
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging a pull request may close this issue.

2 participants