This app allows exploration of a basic virus infection model, with compartments for uninfected cells, infected cells and (free) virus. Read about the model in the “Model” tab. Then do the tasks described in the “What to do” tab.
This model consists of 3 compartments and can capture some of the basic dynamics of viral infections. In this model, we track the following entities, by assigning each to a compartment:
In addition to specifying the compartments of a model, we need to specify the dynamics determining the changes for each compartment. Broadly speaking, there are processes that increase the numbers in a given compartment/stage, and processes that lead to a reduction. Those processes are sometimes called in-flows and out-flows.
For our system, we specify the following processes/flows:
The diagram illustrating this compartmental model is shown in the figure.
Flow diagram for a simple virus infection model.
Implementing this model as a continuous-time, deterministic model leads to the following set of ordinary differential equations.
\[\dot U = n - d_U U - bUV\] \[\dot I = bUV - d_I I\] \[\dot V = pI - d_V V - gb UV\]
The tasks below are described in a way that assumes everything is in units of days (rate parameters, therefore, have units of inverse days). If any quantity is not given in those units, you need to convert it first (e.g. if it says a week, you need to convert it to 7 days).
You should get a single, acute infection with virus and infected cells rising and declining. At the end you should be left with around 11068 uninfected cells (and no infected cells and virus).
A well-studied quantity in infectious disease epidemiology is the basic reproductive number (R0), which determines if a pathogen can cause an outbreak at the population level. An equivalent R0 can be defined for a within-host model to determine if you get an infection or not. For this virus model (with no births and deaths of uninfected cells, i.e. n=dU=0), R0 = bpU0/(dV dI).
To learn more about R0, see e.g. (Heffernan, Smith, and Wahl 2005; Roberts 2007; C. A. A. Beauchemin et al. 2008). Some of those references describe R0 in the context of infectious disease epidemiology, but if you replace humans/hosts with cells, the same concepts apply at the within-host level.
Without birth/production of new uninfected cells, the most you can get is a single acute infection (or no infection at all). To convince yourself that it is impossible to produce a chronic infection, play around with the model, try all kinds of parameter values (but keep n=0).
Production of new uninfected cells is an example of resource replenishment. This is needed to allow a steady state/chronic infection, and this concept applies in general (e.g. on the population level, new susceptible individuals need to be created either through birth or through losing immunity).
Let’s explore the model with uninfected cell prodution, i.e. resource replenishment.
Now we’ll explore an infection in the presence of uninfected cell birth and death.
It is useful to note that while the total numbers for each variable do not change at steady state, this is a dynamic equilibrium. There are still constantly cells and virus being produced and destroyed, it just so happens that the production and destruction mechanisms are equally strong and thus the overall numbers do not change.
While solving algebraic equations, like the one above where you were asked to find U, I and V at steady state can be done by hand, it’s often tedious. Modern computer software helps. R cannot solve such equations analytically, but other software packages can. The main ones are Mathematica and Maple. Both are powerful and expensive. If you only need one occasionally, there is Maxima, which is free. Note that once you go beyond 4-5 variables, the steady state equations are usually very complicated, often so much so that they are not useful anymore. And once you go beyond 5 variables, in most cases your software will struggle to give you something meaningful. Fortunately, while it is less quick and elegant, you can always simulate your model and see what (if any) steady state it reaches.
Continue to explore the model. Even though it’s a fairly simple model, you can get interesting dynamics from it, such as acute infections and chronic infections. Contemplate what specific pathogens this model could represent. Also note that you can get all this dynamics without any immune response present. The interaction between cells and virus are enough to produce patterns of infection dynamics that broadly agree with patterns we can see for real infections. This of course does not mean the immune response is not important. But it does illustrate that if all we have is (noisy) virus kinetics data, we are likely able to capture that dynamics with many different types of models, incuding a simple one like this that is likely not too realistic for any given pathogen.
simulate_basicvirus.R. You can call these functions directly, without going through the shiny app. Type ?simulate_basicvirus into the R console for more information on how to use the functions directly. If you go that route, you need to use the results returned from this function and produce useful output (such as a plot) yourself.Beauchemin, Catherine A A, James J McSharry, George L Drusano, Jack T Nguyen, Gregory T Went, Ruy M Ribeiro, and Alan S Perelson. 2008. “Modeling Amantadine Treatment of Influenza a Virus in Vitro.” Journal of Theoretical Biology 254 (2): 439–51. doi:10.1016/j.jtbi.2008.05.031.
Beauchemin, Catherine AA, and Andreas Handel. 2011. “A Review of Mathematical Models of Influenza a Infections Within a Host or Cell Culture: Lessons Learned and Challenges Ahead.” BMC Public Health 11 (1). BioMed Central: S7.
Chatterjee, Anushree, Jeremie Guedj, and Alan S Perelson. 2012. “Mathematical Modelling of Hcv Infection: What Can It Teach Us in the Era of Direct-Acting Antiviral Agents?” Antiviral Therapy 17 (6 Pt B): 1171–82. doi:10.3851/IMP2428.
Guedj, J, L Rong, H Dahari, and A S Perelson. 2010. “A Perspective on Modelling Hepatitis c Virus Infection.” Journal of Viral Hepatitis 17 (12): 825–33. doi:10.1111/j.1365-2893.2010.01348.x.
Heffernan, J M, R J Smith, and L M Wahl. 2005. “Perspectives on the Basic Reproductive Ratio.” Journal of the Royal Society, Interface 2 (4): 281–93. doi:10.1098/rsif.2005.0042.
Perelson, Alan S, and Ruy M Ribeiro. 2013. “Modeling the Within-Host Dynamics of Hiv Infection.” BMC Biology 11 (1). BioMed Central: 96.
Roberts, M G. 2007. “The Pluses and Minuses of R0.” Journal of the Royal Society, Interface 4 (16): 949–61. doi:10.1098/rsif.2007.1031.
Smith, Amber M, and Alan S Perelson. 2011. “Influenza a Virus Infection Kinetics: Quantitative Data and Models.” Wiley Interdiscip Rev Syst Biol Med 3 (4). Theoretical Biology; Biophysics, Los Alamos National Laboratory, Los Alamos, NM, USA.: 429–45. doi:10.1002/wsbm.129.