class: center, middle # Thoughts on an Early Warning System for COVID Infections ### Siva Athreya, Deepayan Sarkar, Rajesh Sundaresan
--- layout: true # Background ---
$$ \newcommand{\sub}{_} \newcommand{\confirmed}[1]{x(#1)} \newcommand{\active}[1]{a(#1)} \newcommand{\dactive}[1]{a^{\prime}(#1)} \newcommand{\dconfirmed}[1]{x^{\prime}(#1)} \newcommand{\ractive}[1]{\lambda(#1)} \newcommand{\ractivehat}[1]{\hat{\lambda}(#1)} \newcommand{\rconfirmed}[1]{\gamma(#1)} \newcommand{\rincrement}[1]{\rho(#1)} \newcommand{\rinactive}[1]{\mu(#1)} $$
* Goal: looking at current data, predict time to resource scarcity * Motivation: - Strike balance between normal life and adverse health outcomes - Prevent unnecessary economic slowdown (due to restrictions) - Prevent avoidable deaths (due to lack of basic medical facilities) - Obvious strategies: vaccinate, ramp up healthcare facilities - But need to be prepared for surge (new mutations, loss of immunity, unknown factors) - Late reaction leaves lockdown as only solution, cannot prevent deaths --- * Solution: With advance warning, we can deploy graded response - Communicate greater need for precautions and stricter social distancing - Stop mass gatherings - Close markets, cinema halls, gyms, etc. - Lockdown as extreme measure --- * Proposal: - Simple scheme to predict number of active cases - Warning system based on zonewise ability to handle active cases * Input requirements: - Daily number of confirmed / active cases (available from state bulletins) - Critical number of active cases (to be determined policymakers) --- layout: true # Model --- - $t$ unit of time (in days) - $\confirmed{t}$ is the total number of confirmed cases upto time $t$ - $\active{t}$ is the total number of active cases upto time $t$ -- - $\ractive{t}$ is the _number of new infections per active infection per unit time_ at time $t$ - __Changes with time__ [this is a very important point] - Depends on many factors: virus strain, social behaviour, vaccination - Can be influenced by policy -- - $\rinactive{t}$ is the _number of deaths / recoveries per active infection per unit time_ at time $t$ - Assumed constant: $\rinactive{t} \equiv 1/10$ -- - A simple evolution model: $$ \active{t + h} - \active{t} \approx h \cdot \active{t} \cdot [ \ractive{t} - \rinactive{t} ] $$ --- - This gives an instantaneous definition of $\ractive{t}$ as
\begin{eqnarray*} \ractive{t} &=& \rinactive{t} + \frac{\dactive{t}}{\active{t}} \\ &\approx& \rinactive{t} + \frac{ \active{t + h} - \active{t} }{ h \cdot \active{t} } \end{eqnarray*}
- Smallest possible $h = 1$, but we use $h = 7$ to reduce day-of-the-week patterns - NOTE: This is unrealistic because assumes susceptible population _does not decrease_, but - We are only interested in estimating $\lambda(t)$ locally - The goal is to _warn_ when cases are _low_, when this is a mostly reasonable assumption --- - Prediction equations: Can take $h = 1$ for prediction
\begin{eqnarray*} \active{s} &=& \active{s-h} + h \cdot \active{s-h} \, [ \ractivehat{s-h} - \rinactive{s-h} ] \\ &=& \active{s-h} \left( 1 + h \cdot [ \ractivehat{s-h} - \rinactive{s-h} ] \right) \end{eqnarray*}
- Question: How to estimate $\ractive{s-h}$ a function of $h$? --- layout: true # Results --- - Calculations based on data from [covid19india.org](https://covid19india.org) - $\confirmed{t} = \text{ Confirmed (cumulative)}$ - $\active{t} = \confirmed{t} - \text{ Recovered } - \text{ Deceased }$ .center[ [ Updated: 2021-05-14 ] ] --- layout: true # Example: How does $\ractive{t}$ behave for Delhi? --- data:image/s3,"s3://crabby-images/76da5/76da5190b9b1f205b7631f35ae28cece4429bd3d" alt="plot of chunk delhinumbers" --- data:image/s3,"s3://crabby-images/90995/9099500fcfa21c78bd38daa112bf91e52e7c98d2" alt="plot of chunk delhirates" --- - Observations: - $\ractive{t}$ is __not__ constant (many infection models assume constant) - Shows periodic stretches of growth and decline - No systematic pattern - Likely combination of biological (variants / vaccination) and social (behaviour) factors - Difficult to predict --- layout: false # Predicting $\ractive{s}$ for future time $s$ - Prediction can be meaningful only for short ranges - We estimate $\ractive{s-h}$ as a linear function of $h$: - Start from the last calculated value on date of prediction - Linear slope estimated from the last two changes - For robustness, we take average over last few values - Start from average of last 4 calculated values of $\ractive{t}$ on date of prediction - Linear slope estimated using linear regression of last 5 estimates -- - Note that - $\ractive{s} > 0.1$ implies active cases will _increase_ over time - $\ractive{s} < 0.1$ implies active cases will _decrease_ over time --- layout: true # Example: How soon would this have predicted the Delhi wave? --- data:image/s3,"s3://crabby-images/d8bcd/d8bcd6d8166a8662429b99e0748aed51004eac50" alt="plot of chunk delhipred1" --- data:image/s3,"s3://crabby-images/0297d/0297dff7255fdddaf1f1a7e4f709f5cd4edd2929" alt="plot of chunk delhipred2" --- data:image/s3,"s3://crabby-images/0b320/0b3202a9e46d313a426cd86318a25c44cb3bb8dc" alt="plot of chunk delhipred3" --- data:image/s3,"s3://crabby-images/0c7bd/0c7bdf72d326aa84b534b68b9caba546612f2ea8" alt="plot of chunk delhipred4" --- - Things to keep in mind: - Predictions can change dramatically over the course of a few days - Long-range predictions should _not_ be taken too seriously (linear growth unrealistic) - More important to track $\ractive{t}$ - However, local trends in $\ractive{t}$ __can__ give early warning - Can indicate upcoming surge - Can detect upcoming peaks (inflection points) - Trends easier to spot than from plot of raw active counts - Should be considered an exploratory summary measure to guide policy / behaviour --- layout: true # Early warning: days till "critical" load --- - A possibly more useful daily summary: number of days to reach critical target - Needs more information: zonewise medical capacity - Proxy for illustration: 0.2% of population (1 in 500 active infections) - E.g., for Delhi, this number is [approximately](https://en.wikipedia.org/wiki/Delhi) $0.002 \times 16,787,941 \approx 34000$ - Number of days is capped at 100 (larger values are plotted as 100) --- data:image/s3,"s3://crabby-images/10ab8/10ab8da6aa596fc8d096c1f944597aef1660c4f8" alt="plot of chunk delhipredcritical" --- - Gives early warning, but also lots of false positives - Alternative is to assume that $\ractive{s}$ remains constant in the short run - More conservative predictions, less false alarms --- layout: true # Conservative prediction using constant $\ractive{t}$ --- data:image/s3,"s3://crabby-images/e6e6c/e6e6cece105b65624a29825bb896cbae187237f6" alt="plot of chunk delhipred5" --- data:image/s3,"s3://crabby-images/7af83/7af83c4a794c3fa46b00e492435fa844d016c361" alt="plot of chunk delhipredcriticalconst" --- class: center, middle layout: false # Similar predictions in other states / districts (number of "days to critical" shown only for major cities) --- data:image/s3,"s3://crabby-images/a4b8f/a4b8fe9aa54011136381cc6c173081c58f76a7b7" alt="plot of chunk delhi" --- data:image/s3,"s3://crabby-images/ac57f/ac57f3add77158f6c192dc60764c8f909cade9b6" alt="plot of chunk delhicritical" --- data:image/s3,"s3://crabby-images/8abad/8abad4a08cddd9767b94143d6273fe181b1e3e6e" alt="plot of chunk mumbai" --- data:image/s3,"s3://crabby-images/693b4/693b463748b0ce0b4b2495f4212f3b357fcaa642" alt="plot of chunk mumbaicritical" --- data:image/s3,"s3://crabby-images/6a910/6a910fb8b8d4cef62af67e5b84880e22cc02d6c9" alt="plot of chunk bengaluru" --- data:image/s3,"s3://crabby-images/85451/854511e3ddf3598851db852b247ca68f5fc8cbac" alt="plot of chunk bengalurucritical" --- data:image/s3,"s3://crabby-images/02a84/02a84c9dbe43e4517a5f9a93b7a3133d9d05579f" alt="plot of chunk kolkata" --- data:image/s3,"s3://crabby-images/18294/182944ca31d3d14c9bc870f422cb6fdc160e8772" alt="plot of chunk kolkatacritical" --- data:image/s3,"s3://crabby-images/9f81e/9f81e10c945bd00bff15766aaf39c69177dfc6c5" alt="plot of chunk chennai" --- data:image/s3,"s3://crabby-images/52146/521468f1a6967c29f256e3d6b75c4c4e649999a6" alt="plot of chunk chennaicritical" --- data:image/s3,"s3://crabby-images/ee50d/ee50d6465ea9560116c53015753165b4e5646a64" alt="plot of chunk maharashtra" --- data:image/s3,"s3://crabby-images/f7ed7/f7ed702ad15cd920033d8fe9935818fe23220478" alt="plot of chunk karnataka" --- data:image/s3,"s3://crabby-images/89f62/89f62e56170c97e9a71a1528bad770218d361c17" alt="plot of chunk westbengal" --- data:image/s3,"s3://crabby-images/c52d3/c52d36a3b92801aa85a5809ca34f3324faa9674e" alt="plot of chunk uttarpradesh" --- data:image/s3,"s3://crabby-images/921f1/921f1164cb80aec54454c9a97ebb0e5a5d6c7bf8" alt="plot of chunk andhrapradesh" --- data:image/s3,"s3://crabby-images/488ca/488ca44ffc26bf576947d9520c1e84351720d031" alt="plot of chunk assam" --- data:image/s3,"s3://crabby-images/79fc1/79fc1893ff70565af9dcc5408743351c4955ab5c" alt="plot of chunk bihar" --- data:image/s3,"s3://crabby-images/beefa/beefa75fbf1467166e2eaf043e0a79ef7804673e" alt="plot of chunk chhattisgarh" --- data:image/s3,"s3://crabby-images/afb50/afb50d30f3db8b5d674735cfb4390df514d443b2" alt="plot of chunk goa" --- data:image/s3,"s3://crabby-images/d1602/d16024338277b95d27b27fe6bd0ea99a75803f9e" alt="plot of chunk gujarat" --- data:image/s3,"s3://crabby-images/d0a61/d0a613db58da370fca216d6db32ec6654b1664fe" alt="plot of chunk haryana" --- data:image/s3,"s3://crabby-images/38712/387125d192870fa2838a477a1e71464200f4f489" alt="plot of chunk jammukashmir" --- data:image/s3,"s3://crabby-images/b9d78/b9d783fc1f328dbe6c6e8922cd3fa550ad994d2a" alt="plot of chunk kerala" --- data:image/s3,"s3://crabby-images/abd79/abd792f93ce7f0f6b53ee4b128ef32ddf93c18a5" alt="plot of chunk odisha" --- data:image/s3,"s3://crabby-images/a6ef3/a6ef31896000c6bc3988f64c32000046e620d83d" alt="plot of chunk punjab" --- data:image/s3,"s3://crabby-images/2549a/2549ad705b4bea86305c8e78de449628eef9c04a" alt="plot of chunk rajasthan" --- data:image/s3,"s3://crabby-images/db5a1/db5a1eeda7bcfe4addf9fe2d1ab6e1ecfec58153" alt="plot of chunk jharkhand" --- data:image/s3,"s3://crabby-images/bf719/bf719be9c3c332570ae9ed6b93d3211fc011a7f8" alt="plot of chunk tamilnadu" --- data:image/s3,"s3://crabby-images/2431a/2431a7336df5ee884aff14083b8718429d5f6f98" alt="plot of chunk telangana" --- data:image/s3,"s3://crabby-images/56a0e/56a0eb6fca24373e84e987f1897cfe5d35f8e4d3" alt="plot of chunk uttarakhand"