eCQM Measure Content (Using QICore 4.1.1, based on FHIR R4 v4.0.1) - Subset
These draft FHIR-based measures and shared libraries are translated from the QDM-based versions of eCQMs that were published in May 2024 for the 2025 reporting year as they existed in MADiE as of June 2024 or later and may not reflect the current updates from the 2025 AU review cycle of the QDM measures, and have specific versions, especially for the shared libraries, appropriate to the content for that publication update.
In addition, this repository is a subset of the currently available measures that is focused on supporting the representation and testing of a full content release.
Commits to this repository will automatically trigger a build of the continuous integration build, available here:
https://build.fhir.org/ig/cqframework/ecqm-content-qicore-2024-subset
To author content in this implementation guide, you can use the VS Code CQL Plugin. This plugin will enable you to author, validate, and execute FHIR-based eCQM content.
For instructions on setting up your environment to use the VS Code Plugin, see the VS Code CQL Support Readme
Github Codespaces can also be used in this repository.
This repository is setup like any HL7 FHIR IG project but also includes the CQL files and test data which means the file structure will be as follows:
|-- _genonce.bat
|-- _genonce.sh
|-- _refresh.bat
|-- _refresh.sh
|-- _updatePublisher.bat
|-- _updatePublisher.sh
|-- _updateCQFTooling.bat
|-- _updateCQFTooling.sh
|-- ig.ini
|-- bundles
|-- MAT
|-- <bundle files>
|-- measure
|-- <bundles>
|-- input
|-- ecqm-content-qicore-2024.xml
|-- cql
|-- <library name>.cql
|-- pagecontent
|-- resources
|-- library
|-- <library name>.json
|-- measure
|-- <measure name>.json
|-- tests
|-- measure
|-- <measure name>
|-- <test case patient id>
|-- <test case resource files>
|-- ...
|-- vocabulary
|-- valueset
The CQF Tooling provides support for extracting a MAT exported package into the
directories of this repository so that the measure is included in the published
implementation guide. To do this, place the MAT export files (unzipped) in a
directory in the bundles\mat
directory, and then run the following tooling
command:
[tooling-jar] -ExtractMatBundle bundles\mat\[bundle-directory]\[bundle-file]
For example:
input-cache\tooling-cli-3.0.0.jar -ExtractMATBundle bundles\mat\CLONE124_v6_03-Artifacts\measure-json-bundle.json
The CQF Tooling provides "refresh" tooling that performs the following functions:
- Translates and validates all CQL source files
- Packages CQL and ELM content in the corresponding FHIR resources
- Refreshes generated content for each knowledge artifact (Library, Measure, PlanDefinition, ActivityDefinition) including parameters, dependencies, and effective data requirements
Whenever changes are made to the CQL, Library, or Measure resources, run the _refresh
command to refresh the implementation guide content with the new content, and then run _genonce
to run the publication tooling on the implementation guide (the same process that the continuous integration build uses to publish the implementation guide when commits are made to this repository).
The FHIR Validator has functionality to build terminology packages that include full expansions for all the value sets for a given ig, optionally including value sets from any dependencies. The following examples illustrate this usage:
NOTE: These examples assume the validator-cli.jar is available in the input-cache folder (download it here)
To build a tx-pack with expanded value sets for the QICore IG:
java -jar input-cache/validator_cli.jar -ig hl7.fhir.us.qicore#4.1.1 -tx-pack -output "hl7.fhir.us.qicore-tx-4.1.1.zip" -scope ig
To build a tx-pack with expanded value sets for the QICore IG and all dependencies:
java -jar input-cache/validator_cli.jar -ig hl7.fhir.us.qicore#4.1.1 -tx-pack -output "hl7.fhir.us.qicore-tx-all-4.1.1.zip" -scope all
To build a tx-pack for this subset IG, illustrating the creation of the value sets for a measure release and using the VSAC as the terminology server:
java -jar validator_cli.jar -ig input/ecqm-content-qicore-2024-subset.xml -tx-pack -output "ecqm-content-qicore-2024-subset-tx.zip" -scope ig -expansion-parameters "input/manifest.json" -tx https://uat-cts.nlm.nih.gov/fhir/r4
For additional documentation on this use case, see the following: