
One of the Delphi Group’s goals is to create informative tools for healthcare organizations. Tools are only useful, however, if the insights they provide can inform concrete actions. That is to say, these tools must provide actionable intelligence. To address local challenges during the pandemic, we partnered with the Allegheny County Health Department (ACHD). One of our shared worries in early November 2020, as the case rates in the region continued to increase, was if hospitals located in the county would run out of hospital beds for COVID patients (Fig 1).
library(ggplot2)
library(scales)
library(dplyr)
library("ggpubr")
library(scales)
full_df <- tibble(read.csv(file="./c2b/test_and_hosp.csv"))
full_df$collection_date <- as.Date(full_df$collection_date, "%m/%d/%y")
df2 <- data.frame(Key=rep(c("Hospitalization", "Positive Cases"), each=nrow(full_df)),
                CollectionDate=rep(c(full_df$collection_date),2),
                Counts=c(full_df$hospital_flag*7, full_df$test_result*7))
ggplot(data=df2, aes(x=CollectionDate, y=Counts, fill=Key), show.legend = FALSE) +
  geom_bar(stat="identity") +
  labs(x = "", y="",
       title = "New COVID-19 Hospitalizations and Cases in Allegheny County",
       subtitle = "Total Weekly Counts",
       caption = "Delphi Group, delphi.cmu.edu\nData from WPRDC") +
  theme_bw() +
  guides(color = FALSE) + facet_wrap(.~Key, scales = "free") + scale_x_date(name="Specimen Collection Date", date_breaks="1 month", minor_breaks=NULL, date_labels="%b %Y")+ theme(legend.position = "none")Fig. 1: Hospitalizations Due to COVID-19 and New Cases from Positive PCR Tests in Allegheny County (WPRDC Data 1)
Based on its planning, the ACHD needed at least a weeks’ time to open emergency COVID facilities. If the emergency space wasn’t open and hospital beds ran out, mortality rates could soar. But, if we didn’t need the facility, that decision would have stretched already thin resources. Many of the hospitals in Allegheny County were in contact with each other, but each hospital system only had visibility into its own facilities. We wondered if we could offer a higher-level view for ACHD to assist in its planning.
Our early conversations with ACHD revealed two fundamental challenges:
The ACHD team spent a significant amount of time every day examining many data streams and then only had time to look at a handful of the data slices worth monitoring. There was concern that a rise in cases within specific demographic groups would be missed due to the confluence of factors.
As the Delphi Group tried to develop solutions to these problems, we consistently ran into data access challenges and bureaucratic limitations to develop solutions at the granularity needed. Carnegie Mellon University did not have a Business Associates Agreement, or BAA, in place with the ACHD. Due to HIPAA laws, that meant we could only operate on public, aggregated and/or redacted data sets. BAAs are commonplace in healthcare, but are complex legal agreements that can take months to execute, even in normal circumstances. Without a BAA in place, we couldn’t use detailed COVID testing data classified as Protected Health Information (PHI). Intended projects, like determining the best places for mobile testing sites in specific neighborhoods, became impossible because public data is aggregated only to the county level. ACHD was able to do this on its own.
Cases2Beds2 was more feasible than these monitoring projects because we didn’t need full line-level case and test data, and we could provide intelligence at a county level.
To extrapolate beds utilization 1-2 weeks in the future, we needed to estimate:
These values vary by demographic factors, most notably age (Fig 2), and to a lesser extent, sex and race.
df4 <- data.frame(
                Race=c('0-9','10-19','20-29','30-39','40-49','50-59','60-69','70+','Unspec.'),
                Rate=c(0.1*0.01,0.14*0.01, 0.14*0.01, 0.13*0.02, 0.15*0.03, 0.16*0.06, 0.15*0.11, 0.18*0.26, 0.01*0.01 ))
ggplot(data=df4, aes(x=Race, y=Rate)) +
  geom_bar(stat="identity", fill="#FF9999") +
  labs(x = "Age Category", y = "",
       title = "Percent Hospitalized Cases of Total Tested by Age Group ",
       subtitle = "Allegheny County",
       caption = "Delphi Group, delphi.cmu.edu, \nData from Allegheny County Dashboard ") +
  theme_bw() +
  guides(color = FALSE) +
  scale_x_discrete(guide = guide_axis(n.dodge=2)) +scale_y_continuous(labels = scales::percent) 
Fig. 2: Age Group Comparisons based on the Allegheny County COVID-19 Tableau 3
We used public data from Allegheny County about the number of people tested, test positivity rate, and hospitalization rate, broken down by the aforementioned demographic factors.
We also acquired information for two critical parameters: offset and length of stay. Offset is the number of days between the day of testing (called specimen collection date) and the first day of hospitalization. For example, if the test date is around the hospital admit date, the offset would be 0 days (or sometimes -1 or +1 days). Otherwise, if the test date was 5 days before hospitalization, the offset would be 5 days. Notably, the offset can be negative, meaning a person may have been tested some days or weeks after being admitted (presumably for an unrelated reason).
The length of stay is approximately how many days a person uses a bed in the hospital (± 1 day).
Given the hospitalization rate, the offset distribution, and the length of stay distribution, we could simulate multiple futures for any given set of positive cases and their testing dates. This process ultimately shows the distribution of the number of beds needed each day.
Estimating the future given a set of probabilities is a common problem and is possible with an approach called a Monte Carlo simulation.
Monte Carlo simulations involve running a huge number of scenarios based on a set of probabilities. The more scenarios run, the more accurate the model tends to be. For example, if you gave 1000 people one dart to throw at a dart board, even though each individual throw may not be very good, you’d still be able to get a pretty good idea of where the bull’s eye is after 1000 throws. This is the same principle we applied for Cases2Beds – after many simulations, we had a good idea of how many beds might be needed in the next two weeks.
Our prototype Monte Carlo simulation was written in Python and completed in minutes. However, because the simulation works best with probabilities derived from PHI, ACHD needed to run it privately and offline so there would be no data transmission. Thus, any type of web-application (which would transmit data to our servers) was ruled out. Even asking ACHD to run our Python software on their machines fell into a legal grey area. However, Microsoft Excel was easy to use and supported by ACHD. So we converted Cases2Beds into a spreadsheet.
It is relatively straight-forward to port the Python application to VBScript macros for Microsoft Excel. Those macros, however, aren’t designed to run large simulations and we saw that the time required to generate a model was far, far worse, bordering on unusable.
As an alternative, we developed an analytical model for Microsoft Excel that offered a much faster run time compared to full Monte Carlo simulation.
The analytical model had the same idea as the Monte Carlo simulation. Some fraction of individuals who test positive today will be hospitalized after a varying offset (from test date to admit date) and variable duration (from admit date to discharge date) based on their characteristics. In the spreadsheet, anyone can (and should) change these parameters to fit their region.
The characteristics are:
And the parameters are:
The second types of inputs are the daily positive cases split by their traits. This is the input that the user actively changes on their end.
Behind the scenes, we take these parameters (first input) and generate Offset Fractions, which is the probability that a patient with given traits will occupy a bed on k days after the specimen testing date. These Offset Fractions and the daily positive case breakdown (second input) give us the expected mean and variance up to 1 month in the future of the number of patients in the hospital per day based on the cases already seen. This information can be used to generate plots like Fig 3. This graph isn’t to suggest that there won’t be any need for beds after February! It is just that based on the cases we know, very few people will remain hospitalized after a month.
full_df <- tibble(read.csv(file="./c2b/C2B_output.csv"))
full_df$dates <- as.Date(full_df$dates, "%m/%d/%y")
ggplot(data=full_df) +
  geom_ribbon(aes(x = dates, ymin = Q5, ymax = Q95, fill="Q5-Q95"))+
  geom_ribbon(aes(x = dates, ymin = Q25, ymax = Q75, fill="Q25-Q75")) +
  geom_line(aes(x = dates, y = mean,color = "mean"), fill="black") +
  labs(x = "", y = "",
       title = "Cases2Beds Expected Beds Output for Allegheny County",
       subtitle = "Based on Cases Known By 1/21/21 Using Publicly Derived Parameters",
        caption = "Delphi Group, delphi.cmu.edu") +
      scale_colour_manual("",values="black")+
      scale_fill_manual("",values=c(alpha("red", 0.5), alpha("#FF9999", 0.5)))+ theme(legend.position="bottom")
Fig. 3: Output of Cases2Beds using historical data until January 21st for Allegheny County Using Public Parameters
If we assume independence between patients, the mean and variance calculations are exact. However, our quantile estimates are based on approximating the sum of independent binary variables, which is inaccurate near the tails. So the accuracy of the more extreme quantiles (95%+) depends on the number of cases present, which in practice makes them less trustworthy.
By November, we had a prototype Cases2Beds spreadsheet for ACHD that they used. Over the following months, we made various modifications with their feedback. For example, the ACHD staff did not have time to input the case numbers. So, we were able to use the granular public data to give them estimates of future hospital utilization without any inputs on their end. We were also able to showcase the spreadsheet to other health departments and hospitals by generating public parameters for offset and length of stay from different national public resources, like the Florida line-level COVID dataset4. Based on these users’ feedback, we started to use Cases2Beds as an input to hospital utilization forecasting models. Other inputs included current hospital bed utilization (from HHS Protect5), how long current patients are likely to continue to be hospitalized, and how many new cases there will be in the near future. A preliminary evaluation of such a method shows decent predictive power when parameters are tailored to a location.
At the peak of bed utilization, hospital systems themselves increased their COVID beds utilization to 6x more than in October 2020. Fortunately, in Allegheny County, we never reached a point where demand for beds exceeded a somewhat elastic supply. By early January, multiple organizations told us that the pandemic’s most acute problem had changed to vaccine distribution and the number of COVID-19 beds needed dropped. Cases2Beds continues to act as an early warning system if the number of cases rise quickly, but hopefully the worst is now over.
full_df <- tibble(read.csv(file="./c2b/uncensored_HHS.csv"))
full_df$dates <- as.Date(full_df$dates, "%m/%d/%y")
df2 <- data.frame(Key=rep(c("7d-Avg COVID Adult Beds Used"), each=nrow(full_df)),
                Date=rep(c(full_df$dates)),
                Counts=c(full_df$total_adult_covid_avg) + c(full_df$total_pediatric_covid_avg))
ggplot(data=df2, aes(x=Date, y=Counts, fill=Key)) +
  geom_bar(stat="identity", position="identity") + scale_x_date(labels=date_format("%m-%d-%Y"))+
  labs(x = "Dates", y = "",
       title = "Hospital Utilization in Allegheny County",
       subtitle = "7d-Avg COVID Adult Beds Used",
        caption = "Delphi Group, delphi.cmu.edu, \n Data from HHS Protect ") +
  theme_bw() +
  guides(color = FALSE)+ theme(legend.position = "none")Fig. 4: Numbers of staffed COVID beds over time vs. capacity from the HHS Protect Data5
Cases2Beds was a case study about the realities of research institutions offering actionable intelligence in healthcare. While the Cases2Beds tool demonstrated reasonable predictive power, it was difficult deploy this tool in a way that was both timely and actionable.
Research institutions can be effective partners to health organizations, but the next set of challenges of this pandemic–or the next–will require quick action. It is recommended that health organizations establish long-term partnerships so these challenges can be addressed promptly.
Acknowledgements:
Thank you to the Allegheny County Health Department (especially Antony Gnalian, Dr. LuAnn Brink, and Dr. Debra Bogen) for their invaluable feedback, efforts, and shared interest in actionable intelligence.
Many members of the Delphi Group, including Sumit Agrawal, Katie Mazaitis, and Phil McGuinness, met regularly with the Allegheny County Health Department and investigated various solutions other than Cases2Beds. Andrew Chin and Benjamin Smith investigated Cases2Beds alternatives.
Zachary Lipton, Helen Zhou, and Cheng Cheng provided historical data from Florida and valuable support.
Spencer Whitman, Phil McGuinness, and Sam Gratzl helped edit and format this blog post.