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 September 2025 qualifier 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.3.0.tar.gz (79.7 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.3.0-py3-none-any.whl (90.8 kB view details)

Uploaded Python 3

File details

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

File metadata

File hashes

Hashes for cumulus_library_data_metrics-8.3.0.tar.gz
Algorithm Hash digest
SHA256 f14e98866a64fa178ac2b4b7aa9d5380a8146c22fc1befd83b17cd46526f1f95
MD5 56885ab04d65756d55e0ccb672aaf850
BLAKE2b-256 d88be4c2c9cd347ee98f8a0455e619622a7dc03b1dab45d4ca5c47630631344d

See more details on using hashes here.

Provenance

The following attestation bundles were made for cumulus_library_data_metrics-8.3.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.3.0-py3-none-any.whl.

File metadata

File hashes

Hashes for cumulus_library_data_metrics-8.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 35ccf0c1b433fcbe6edbad6bb3467497245db020a162d32d618538f31d811ce8
MD5 3ff00faf168e56df29b719ac6358cd30
BLAKE2b-256 2e671d2a690d231d158e57036792720ac5971c1efa23ed5639d123fc6df54ffc

See more details on using hashes here.

Provenance

The following attestation bundles were made for cumulus_library_data_metrics-8.3.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