Minimal SIR
Do you have questions or comments about this model? Ask them here! (You'll first need to log in.)
WHAT IS IT?
Do you know how an epidemic grows? One infects two, two infect four or three or two or one or none. All with different probabilities and a weighted average of logistic growth.
The Minimal SIR model is a discrete stochastic compartmental model of an epidemic that averages to the (ordinary differential equation) standard SIR model (Kermack-McKendrick, 1927). Each individual within a population is in one of three states known, in epidemic modelling, as compartments:
- S - Susceptible to infection.
- I - Infected and infectious.
- R - Recovered and immune to re-infection.
HOW IT WORKS
Setup
There are sliders to vary:
- The size of the population that will be divided into compartments.
- The proportion of the population that has prior immunity.
- The basic reproduction number.
The basic reproduction number, R0, is defined as the number of individuals that will be infected by one individual in an otherwise susceptible population.
Go
Initially one individual is infected. At each step the simulation proceeds by each infected individual selecting R0 others at random and irrespective of their state - the model is said to be "well mixed". At the end of the step the infected become recovered and those susceptible that were selected become infected. The simulation finishes when there are no longer any infected.
As the simulation progresses lines are drawn between the previous generation of infected and those individuals that they were in contact with. The colour of the individuals changes according to the code:
- Susceptible - Blue.
- Infected - Red.
- Recovered - Green.
There are three plots of how the statistics vary as the iterations proceed. The first shows how the individuals are divided between the three compartments. The second how the reproduction number varies between zero and R0. The third shows how the three compartments vary with respect to each other.
HOW TO USE IT
Move the sliders then press setup. Perform a simulation and note how the epidemic curves vary.
THINGS TO NOTICE
Sigmoid curves
When plotted against time the number of susceptible always decrease. i.e. the curve is monotonic decreasing. Similarly, the number of recovered is monotonic increasing. For the standard SIR model these are both sigmoid (S-shaped) curves. For a given simulation the plots of the minimal SIR model may be more or less sigmoid.
Ternary plot
Since the sum of the number of individuals in the three compartments is constant, they can be plotted within a triangle. Note that the diagonal axis corresponds to the number of infected being zero.
Herd immunity
At the end of a simulation some individuals may still be susceptible. This is because of an effect known as herd immunity. Note that they are not immune and a subsequent outbreak could occur. To demonstrate this re-run with more prior immunity.
Variation of the reproduction number
If this were constant then the epidemic would be growing exponentially. For no prior immunity the initial step plots a value of R0 which matches its definition. Note that, in general, this does not decrease with time. When the reproduction number is equal to one then every infected individual infects only one other and thus there is a peak in the plot of the number of infected versus time.
If this were the standard SIR model instead then it would be the smoothly decreasing function R0 x S / N where S is the number of susceptible and N is the size of the population.
Selecting R0 others
Each infected picking the number of susceptible is equivalent to sampling (without replacement) R0 individuals from a hypergeometric probability distribution.
Exponential growth
Requires that only susceptible are picked. The probability of that happening can then be calculated by forming a fraction where the numerator is the numbers from the size of the population down to one all multiplied together and the denominator is the number of choices multiplied together. e.g. 31 x 30 x 29 x 28 x ... x 1 divided by 31 x 30 x 29 x 30 ... x 29 for a population of 31, no prior immunity and R0 equal to 2.
Evaluating the fraction results in roughly a two in a million million chance. Truncating it to correspond to the first 8 individuals results in roughly an even chance.
Note that at the end of exponential growth all the individuals have been infected.
Actual examples of exponential growth appear to be all man-made:
- Compound interest, which dates back to the Babylonians at least
- Grains of wheat on a chessboard, according to folklore from ancient India and Persia
- Pyramid schemes
THINGS TO TRY
Average behaviour
If you are prepared to alter the code then scale the population to, say, 1000 individuals and run numerous times to create an ensemble of results at each step which are then averaged. Calculate the rate of change of the number of susceptible with respect to the number of recovered. Show that this matches the standard SIR model (Kermack-McKendrick, 1927) in which the infection curve is formed by an imbalance between logistic growth and exponential decay:
dI/dt = (R0 x S / N - 1) x I x gamma
where N = S + I + R and gamma = 1
Epidemiological tag
Take a group of children, tell them that when they are first tagged that they are to tag two others. Choose the first one then see whether, at the end of the game, they can be lined up in columns corresponding to generations of the epidemic.
Epidemic, the card game
Take two packs of playing cards, cut them both down to the same 31 cards. One will be used to shuffle and deal from, the other to track the states. A column of cards is formed by considering all the cards in the previous column. For each of those cards remove the corresponding card from the shuffle, shuffle then deal two cards. If that is the first time that a card has been dealt then add the corresponding card to the new column. Return all three cards to the pack for the next shuffle, if you don't then you'll get exponential growth.
EXTENDING THE MODEL
Social networks
In this model each individual has equal chance to infect every other. i.e. The population forms a complete graph. Extending to a sparse graph, specifically a social network, provides a better model. When performed on a network formed by voles the resultant ensemble average behaviour compared to a complete graph showed a lower number of infections and a greater number of steps. The reader might like to think of what this means in the contexts of lockdowns and of seasons.
Stochastic calculus
Repeated application of the hypergeometric distribution can be approximated by using a logit-normal distribution for the ratio of the reproduction number to the basic reproduction number. As such the model debunks various stochastic models whether they have a normal distribution for the reproduction number, use Gillespie’s algorithm or are based on the Reed-Frost model. The people who claimed that epidemics grow exponentially, however, were debunked in 1840 by Dr Farr if not before - exponential growth takes the number of infected to infinity unless some unspecified change happens at some unspecified time.
CREDITS AND REFERENCES
This software implementation was forked from
- Wilensky, U. (2003). NetLogo Dining Philosophers model. http://ccl.northwestern.edu/netlogo/models/DiningPhilosophers. Center for Connected Learning and Computer-Based Modeling, Northwestern University, Evanston, IL.
Copyright 2003 Uri Wilensky.
HOW TO CITE
If you mention this model or the NetLogo software in a publication, we ask that you include the citations below.
For the model itself: * Mason, Z. W. T. (2025). The minimal SIR model, validated then extended to social networks and stochastic differential equations. https://osf.io/y6ckv/. Stoch Answers Ltd, Sheffield, UK.
Please cite the NetLogo software as:
- Wilensky, U. (1999). NetLogo. http://ccl.northwestern.edu/netlogo/. Center for Connected Learning and Computer-Based Modeling, Northwestern University, Evanston, IL.
COPYRIGHT AND LICENSE
Copyright 2025 Zebedee Mason
This work is licensed under the Creative Commons Attribution-NonCommercial-ShareAlike 3.0 License. To view a copy of this license, visit https://creativecommons.org/licenses/by-nc-sa/3.0/ or send a letter to Creative Commons, 559 Nathan Abbott Way, Stanford, California 94305, USA.
Comments and Questions
extensions [array] globals [reproduction-number old-infected new-infected] breed [individuals individual] individuals-own [ state ;; my current state: "INFECTED", "RECOVERED", or "SUSCEPTIBLE" marked? ;; whether I'm currently marked ] to setup clear-all ;; set up the model make-turtles set reproduction-number basic-reproduction-number set new-infected 1 recolor reset-ticks end ;; create all the turtles, place them, and associate forks with individuals to make-turtles set-default-shape individuals "person torso" ;; create-ordered-equally spaces the headings of the turtles, ;; in who number order create-ordered-individuals population [ set size 0.1 jump 0.35 set state "SUSCEPTIBLE" set marked? false ] ask individual 0 [set state "INFECTED"] if prior-immunity-proportion > 0 [ let index 1 repeat prior-immunity-proportion * population [ ask individual index [set state "RECOVERED"] set index (index + 1) if index >= population [ stop ] ] ] end to go if new-infected > 0 [ a-go ] end to a-go set old-infected new-infected clear-links ask individuals [ infect ] set new-infected 0 ask individuals [ update ] ifelse old-infected = 0 [ set reproduction-number 0 ] [ set reproduction-number (new-infected / old-infected) ] recolor tick end ;; everybody gets a new color. to recolor ask individuals [ ;; look up the color in the colors list indexed by our current state ifelse state = "SUSCEPTIBLE" [ set color blue ] [ ifelse state = "INFECTED" [ set color red ] [ set color green ] ] ] end ;; to infect ;; individual procedure if state = "INFECTED" [ ;; create an array of random numbers let values array:from-list shuffle range (population - 1) let index 0 repeat basic-reproduction-number [ let i2 array:item values index let i3 ((i2 + 1 + who) mod population) ask individual i3 [set marked? true] create-link-with individual i3 set index (index + 1) ] ] end ;; to update ;; individual procedure if state = "INFECTED" [ set state "RECOVERED" ] if marked? and state = "SUSCEPTIBLE" [ set state "INFECTED" set new-infected (new-infected + 1) ] set marked? false end ; Copyright 2025 Zebedee Mason. ; See Info tab for full copyright and license.
There is only one version of this model, created 3 days ago by Zebedee Mason.
Attached files
File | Type | Description | Last updated | |
---|---|---|---|---|
Minimal SIR.png | preview | Preview for 'Minimal SIR' | 3 days ago, by Zebedee Mason | Download |
This model does not have any ancestors.
This model does not have any descendants.