Skip to main content

Data quality and characterization metrics for Cumulus

Project description

Data Metrics

A Cumulus-based implementation of the qualifier metrics.

Implemented Metrics

The following qualifier metrics are implemented (per February 2025 qualifer definitions).

* These are US Core profile-based metrics, and the following profiles are not yet implemented:

  • Implantable Device (due to the difficulty in identify implantable records)
  • The various Vital Signs sub-profiles like Blood Pressure (just haven't gotten around to them yet)

Installing

pip install cumulus-library-data-metrics

Running the Metrics

These metrics are designed as a Cumulus Library study and are run using the cumulus-library command.

Local Ndjson

First, you'll want to organize your ndjson into the following file tree format:

root/
  condition/
    my-conditions.ndjson
  medicationrequest/
    1.ndjson
    2.ndjson
  patient/
    Patient.ndjson

(This is the same format that Cumulus ETL writes out when using --output-format=ndjson.)

Here's a sample command to run against that pile of ndjson data:

cumulus-library build \
  --db-type duckdb \
  --database output-tables.db \
  --load-ndjson-dir path/to/ndjson/root \
  --target data_metrics

And then you can load output-tables.db in a DuckDB session and see the results. Or read below to export the counts tables.

Athena

Here's a sample command to run against your Cumulus data in Athena:

cumulus-library build \
  --database your-glue-database \
  --workgroup your-athena-workgroup \
  --profile your-aws-credentials-profile \
  --target data_metrics

And then you can see the resulting tables in Athena. Or read below to export the counts tables.

Exporting Counts

For the metrics that have exportable counts (the characterization metrics mostly), you can easily export those using Cumulus Library, by replacing build in the above commands with export ./output-folder. Like so:

cumulus-library export \
  ./output-folder \
  --db-type duckdb \
  --database output-tables.db \
  --target data_metrics

Aggregate counts

This study generates CUBE output by default. If it's easier to work with simple aggregate counts of every value combination (that is, without the partial value combinations that CUBE() generates), run the build step with --option output-mode:aggregate.

That is, run it like:

cumulus-library build --option output-mode:aggregate ...

Bucket sizes

To help preserve privacy, this study ignores any count results of less than ten.

For example, if there are only two male patients that died at age 55, that combination of male & 55 will be dropped from the c_pt_deceased_count table.

This makes it easier to share the count results with other institutions. But if that's not a concern and you want the fine-grained details, you can run the build step with --option min-bucket-size:0 to turn this feature off. Or use another value to change the bucket threshold (the default value is 10).

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

cumulus_library_data_metrics-8.0.0.tar.gz (73.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

cumulus_library_data_metrics-8.0.0-py3-none-any.whl (86.9 kB view details)

Uploaded Python 3

File details

Details for the file cumulus_library_data_metrics-8.0.0.tar.gz.

File metadata

File hashes

Hashes for cumulus_library_data_metrics-8.0.0.tar.gz
Algorithm Hash digest
SHA256 a8fa2ed041f0d651efc2dacb782cc6e8fbff4610ee66f8c7c41f96be6164f58d
MD5 1c7c0b13fe9fd727537b50869d3feab4
BLAKE2b-256 50193e32cb268e57eb8c56c9137df5f13024a2b2c8016d24f9013cd15adb9124

See more details on using hashes here.

Provenance

The following attestation bundles were made for cumulus_library_data_metrics-8.0.0.tar.gz:

Publisher: pypi.yaml on smart-on-fhir/cumulus-library-data-metrics

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file cumulus_library_data_metrics-8.0.0-py3-none-any.whl.

File metadata

File hashes

Hashes for cumulus_library_data_metrics-8.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 77a244fa377244e0cdff6c8504d1b32ecb1f9888bc0b0c86dedc2d6a79329ed8
MD5 bbb666034ec0e8ecb9de1464e49c0b6d
BLAKE2b-256 23888268648f90b2681dde2b3908cf28eb14e5d49338d50ab3720789d7714c18

See more details on using hashes here.

Provenance

The following attestation bundles were made for cumulus_library_data_metrics-8.0.0-py3-none-any.whl:

Publisher: pypi.yaml on smart-on-fhir/cumulus-library-data-metrics

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page