AHRQ Measures
Overview
The Agency for Healthcare Research and Quality (AHRQ) develops and maintains various measures to assess the quality, safety, and effectiveness of healthcare services (AHRQ QIs). These measures include the Prevention Quality Indicators (PQIs), Inpatient Quality Indicators (IQIs), Patient Safety Indicators (PSIs), and Pediatric Quality Indicators (PDIs). They are used by healthcare providers, policymakers, and researchers to identify issues, monitor progress, and compare performance to improve patient outcomes and reduce costs.
The PQIs are available now in The Tuva Project. The individual measures and definitions as of the 2023 update are:
PQI Number | PQI Name | PQI Description |
---|---|---|
01 | Diabetes Short-Term Complications Admission Rate | Hospitalizations for a principal diagnosis of diabetes with short-term complications (ketoacidosis, hyperosmolarity, or coma) per 100,000 population, ages 18 years and older. |
03 | Diabetes Long-Term Complications Admission Rate | Hospitalizations for a principal diagnosis of diabetes with long-term complications (renal, eye, neurological, circulatory, other specified, or unspecified) per 100,000 population, ages 18 years and older. |
05 | Chronic Obstructive Pulmonary Disease (COPD) or Asthma in Older Adults | Hospitalizations with a principal diagnosis of chronic obstructive pulmonary disease (COPD) or asthma per 100,000 population, ages 40 years and older. |
07 | Hypertension Admission Rate | Hospitalizations with a principal diagnosis of hypertension per 100,000 population, ages 18 years and older. |
08 | Heart Failure Admission Rate | Hospitalizations with a principal diagnosis of heart failure per 100,000 population, ages 18 years and older. |
11 | Community Acquired Pneumonia Admission Rate | Hospitalizations with a principal diagnosis of community-acquired bacterial pneumonia per 100,000 population, ages 18 years or older. |
12 | Urinary Tract Infection Admission Rate | Hospitalizations with a principal diagnosis of urinary tract infection per 100,000 population, ages 18 years and older. |
14 | Uncontrolled Diabetes Admission Rate | Hospitalizations for a principal diagnosis of uncontrolled diabetes without mention of short-term (ketoacidosis, hyperosmolarity, or coma) or long-term (renal, eye, neurological, circulatory, other specified, or unspecified) complications per 100,000 population, ages 18 years and older. |
15 | Asthma in Younger Adults Admission Rate | Hospitalizations for a principal diagnosis of asthma per 100,000 population, ages 18 to 39 years. |
16 | Lower-Extremity Amputation Among Patients with Diabetes Rate | Hospitalizations for diabetes and a procedure of lower-extremity amputation (except toe amputations) per 100,000 population, ages 18 years and older. |
Instructions
Data Requirements
The AHRQ mart runs on claims data, and requires both the medical_claim and eligibility tables in the input layer to be populated. It requires the following fields to be populated with valid values:
- ICD 10 diagnosis codes
- ICD 10 procedure codes
- MS_DRG codes
- HCPC codes
- Admit source codes
- Facility_ID
- Member birth date
- Member sex
The mart creates and uses the following seed files:
- ahrq_measurse._value_set_pqi
- ahrq_measures._value_set_pqi_measures
dbt Examples
# Runs all marts
dbt build
# Runs only the AHRQ mart.
dbt build --select tag:ahrq_measures
Data Dictionary
pqi_denom_long
This model contains a row for each patient and data_source combination that is eligible for each pqi each year.
Primary Key:
- patient_id
- data_source
- pqi_number
- year_number
Column | Data Type | Description | Terminology |
---|
pqi_exclusion_long
This model contains a list of all the exclusions an encounter qualified for. An encounter can qualify for multiple exclusions for each pqi, which are listed here. Qualifying for an exclusion does not necessarily mean the encounter would have been in the numerator for the pqi, simply that it is excluded from being eligible to be in the numerator.
Primary Key:
- data_source
- encounter_id
- exclusion_number
- pqi_number
Column | Data Type | Description | Terminology |
---|
pqi_num_long
This model contains a list of all encounters that qualified for a pqi. The patient_id and data_source are brought in for reference as well.
Primary Key:
- data_source
- encounter_id
- pqi_number
Column | Data Type | Description | Terminology |
---|
pqi_rate
This model pre calculates the rate (as a per 100,000 members) for each pqi and year. The rate equals the numerator divided by denominator multiplied by 100,000. The AHRQ software typically calculates these as a per 100,000 population in a metropolitan area or county. However, when calculating for a population in a claims dataset, it can be useful to view the rates as a "per 100,000 members" instead.
Primary Key:
- data_source
- year_number
- pqi_number
Column | Data Type | Description | Terminology |
---|
pqi_summary
This model is designed to be useful for analytics on pqis in your claims data set. It joins in data about the encounter for summarization, such as facility, drg, encounter start date etc...
Primary Key:
- data_source
- encounter_id
- pqi_number
- year_number
Column | Data Type | Description | Terminology |
---|
Analytics
PQIs Summary
To summarize and view the various locations of encounters that qualify for each PQI measure, we can start with the summary table below:
Summary Encounters
select *
from ahrq_measures.pqi_summary
Summary by Name and Description
We can aggregate across years and join in the name and description of each measure.
select p.data_source
, p.pqi_number
, m.pqi_name
, m.pqi_description
, sum(num_count) as pqi_encounters
from ahrq_measures.pqi_rate p
left join ahrq_measures._value_set_pqi_measures m on p.pqi_number = m.pqi_number
group by
p.data_source
, p.pqi_number
, m.pqi_name
, m.pqi_description
order by pqi_encounters desc
Summary by Facility
To view the number of PQIs at each facility in our claims dataset, we can group the summary table by facility.
select p.data_source
, p.facility_npi
, l.name
, count(*) as pqi_encounters_count
from ahrq_measures.pqi_summary p
left join core.location l on p.facility_npi = l.npi
group by
p.data_source
, p.facility_npi
, l.name
order by pqi_encounters_count desc
PQIs by Rate
When calculated as a rate, PQIs are typically calculated per 100,000 population in a metropolitan area or county. When used on a claims dataset, it can be helpful to view the rates per 100,000 members instead. The numerator and denominator for each measure and year is precalculated as shown below.
Rate
select *
from ahrq_measures.pqi_rate
Aggregate by Rate
If you would like to aggregate the rate to a different level, we can use the numerator and denominator tables and calculate the rate.
with num as (
select
data_source
, year_number
, pqi_number
, count(encounter_id) as num_count
from ahrq_measures.pqi_num_long
group by
data_source
, year_number
, pqi_number
)
, denom as (
select
data_source
, year_number
, pqi_number
, count(patient_id) as denom_count
from ahrq_measures.pqi_denom_long
group by
data_source
, year_number
, pqi_number
)
select
d.data_source
, d.year_number
, d.pqi_number
, d.denom_count
, coalesce(num.num_count, 0) as num_count
, coalesce(num.num_count, 0) / d.denom_count * 100000 as rate_per_100_thousand
from denom as d
left join num
on d.pqi_number = num.pqi_number
and d.year_number = num.year_number
and d.data_source = num.data_source
order by d.data_source
, d.year_number
, d.pqi_number
Exclusions
Each of the PQI measures has a list of codes that exclude a encounter from a the measure. These codes are summarized in value sets which can be queried as well.
Exclusion Value Sets
To view the list of value sets that are excluded in each of the measures, we can query the value set table.
select distinct value_set_name
, pqi_number
from ahrq_measures._value_set_pqi
order by pqi_number
Exclusions by PQI Number
To summarize the number of encounters excluded by each measure, use the code below. Note that if in encounter was excluded in this logic it does not necessarily mean that it would have been in the numerator, just that it is excluded regardless of whether or not the encounter qualified for each measure.
select data_source
, pqi_number
, count(*) as excluded_encounters
from ahrq_measures.pqi_exclusion_long
group by data_source
, pqi_number
order by pqi_number