Home About
umbralcalculations: Technical Article Repository



Mean-field inference of multi-state models with a counting memory: applications to pneumococcus



Author. Hardwick, Robert J
Date. 2021-05-25
Concept. To study a type of multi-state models (stochastic processes occupying one of a finite set of states at each moment in time) which exhibit a memory of past occurances through a counting variable. The statistical inference (or selection) of these models for real-world applications frequently involves data in the form of a sequence of individual state observations, which are often coupled with some diagnostic uncertainty (as is the case for pneumococcus). In this post, we are able to demonstrate an ODE mean-field description for these types of system is valid and can be used to accelerate the statistical inference from this type of data. The model case study we use is for systems which simulate the spread of pneumococcus in human populations.


Motivating background

Multi-state models (stochastic processes occupying one of a finite set of states at each moment in time) appear to describe many natural phenomena, but are probably most frequently used in the mathematical modelling of population health. The statistical inference (or selection) of these models for real-world applications frequently involves data in the form of a sequence of individual state observations, which are often coupled with some diagnostic uncertainty.

There are over 90 known capsular serotypes of Streptococcus pneumoniae, which persist despite their mutual competition for the same ecological niche (the nasopharynx) and a known fitness gradient. Motivated by the global pneumococcal disease burden, a specific class of multi-state models has been developed to describe the carriage dynamics which offers a neat explanation of this persistence through immunity-driven stabilisation effects (see [1]). This class of model typically uses a counting memory of past state (or serotype) occupations (or colonisations) as a model for human immunity (see, e.g., [2] for an alternative formulation and [3] for a general review of the carriage transmission models). Building from these mathematical models, a range of statistical approaches have also been used to infer the pneumococcal carriage through a given population from nasopharyngeal swab sample data (e.g., [4] and [5]). All of this is obviously really important, e.g., to understanding more precisely how a vaccine covering a restricted range of serotypes can impact colonisation in a given community or region.

The design of policies for gathering data will always have a direct impact on the quality and utility of information that can be learned about a model via statistical inference. Therefore, it’s typically useful to know a priori the fundamental constraints a given policy might impose on this procedure. The purpose of the pneumoinfer class is to provide researchers with a rigorous framework to investigate these limitations for the inference of multi-state models with a counting memory - which are structurally inspired by the pneumococcus carriage models of [1] and [4]. The framework should also useful in model inference with real data.

In this post, we’re going to analyse the master equation of a stochastic model which includes memory effects from individual immunity and investigate a novel (to our knowledge) approximate ODE description for the dynamics, while assessing its validity. By then exploiting the new efficient ODE description, we will be able to develop a new method of inference that is very rapid in comparison to simulated likelihoods (or even ABC/likelihood-free inference methods). This is the main inference method that is implemented in the pneumoinfer class.

The fixed \(\Lambda_i\) model

Let’s now construct a multi-state model which incorporates a counting memory of past state occupations. This will include: an event rate of state clearance \(\tilde{\mu}_i\) - the rate at which an individual occupying the \(i\)-th indexed state returns to the null state; an event rate of susceptibility \(\tilde{\Lambda}_i\) for an individual moving to the \(i\)-th state from the null state; and a state-specific factor matrix \(f_{ii'}\) which rescales \(\tilde{\Lambda}_{i'}\) to create an event rate for an individual moving directly between the \(i\)-th and \(i'\)-th states.

Now consider \(\tilde{\mu}_i=\tilde{\mu}_i( \dots, n_{i}, \dots )\), i.e., a function of all previous state occupations by the individual, where \(n_i\) are the state-specific counts of past occupations. The rate \(\tilde{\mu}_i\) hence maintains a ‘record’ of past state occupations and updates accordingly through this memory. Additionally, we will make each rate \(\tilde{\Lambda}_i=\tilde{\Lambda}_i(n_{i})\), i.e., a function only of the state-specific count associated to each rate, respectively. The choice in the latter case comes from interpreting the counting memory as a model for capsular immunity - this will also turn out to be quite important for our approximation further on.

Note that in [1], the models of nonspecific and specific immunity suggest choosing the following functions

\[ \begin{align} \tilde{\mu}_i( \dots, n_{i}, \dots ) &= \mu_{\rm max} + (\mu_i - \mu_{\rm max})\exp \bigg( -\epsilon \sum_{\forall i'}n_{i'} \bigg) \\ \tilde{\Lambda}_i(n_i) &= \Lambda_{i}{\bf 1}_{n_i=0} + \sigma \Lambda_{i}{\bf 1}_{n_i>0} \,. \end{align} \]

In the expressions above: \(\epsilon\) governs the level of (immune system maturation) with respect to the number of past state occupations; \({\bf 1}_A\) denotes an indicator function whose argument is unity when \(A\) is satisfied, else \(0\); and the susceptibility of an individual is assumed to be reduced by a constant factor of \(\sigma\) after having occupied that state once or more.

The multi-state process that we’re going to consider would be normally be described as a non-Markovian phenomenon. However, the modelling approach we will take is instead a bit more similar to the formal concept of a Markov embedding (as studied, e.g., recently in [6]). By creating a binary state occupation variable \(x_i\) for the \(i\)-th serotype, and the probability of occupying state \((\dots , x_i , \dots , n_i , \dots )\) at time \(t\) as \(P(\dots , x_i , \dots , n_i , \dots , t)\), we may write a Markovian master equation for the process. Let’s now define

\[ \begin{align} p_i(\dots ,n_i,\dots ,t) &\equiv P(\dots, x_{i}=1, x_{i'}=0, \dots ,n_{i},\dots ,t)\quad \forall i'\neq i \\ q(\dots ,n_i,\dots ,t) &\equiv P(\dots, x_{i}=0, \dots ,n_{i},\dots ,t) \quad \forall i\,. \end{align} \]

Using these definitions, it is straightforward to show that the master equation satisfies

\[ \begin{align} \frac{{\rm d}}{{\rm d}t}p_i(\dots ,n_i,\dots ,t) &= \tilde{\Lambda}_i(n_i-1)q(\dots ,n_{i}-1,\dots ,t) + \sum_{\forall i' \neq i}f_{i'i}\tilde{\Lambda}_i (n_i-1)p_{i'}(\dots ,n_{i'}, n_i-1,\dots ,t) \\ &\quad - \tilde{\mu}_i( \dots, n_{i}, \dots ) p_i(\dots ,n_i,\dots ,t) - \sum_{\forall i'\neq i}f_{ii'}\tilde{\Lambda}_{i'} (n_{i'}) p_i(\dots ,n_i,\dots ,t) \\ \frac{{\rm d}}{{\rm d}t}q(\dots ,n_i,\dots ,t) &= \sum_{\forall i}\tilde{\mu}_i( \dots, n_{i}, \dots )p_i(\dots ,n_i,\dots ,t) - \sum_{\forall i}\tilde{\Lambda}_i(n_i) q(\dots ,n_i,\dots ,t) \,. \end{align} \]

By defining the state space to encode the memory of past state occupations using the \(n_i\) values themselves, the process is Markovian over the full \((\dots , x_i,\dots ,n_i,\dots)\) space. Note also that one may obtain the time-dependent joint distribution over the \((\dots ,n_i,\dots)\) space, i.e., \(P(\dots, n_i, \dots, t)\), through marginalisation at any time

\[ \begin{equation} P(\dots, n_i, \dots, t) = q(\dots, n_i, \dots, t) + \sum_{\forall i} p_i(\dots, n_i, \dots, t) \,. \end{equation} \]

Though we intend our analysis of this class of multi-state models to apply more generally beyond immediate applications to pneumococcus, it also is worth noting that restricting individuals to occupy a single state at a time only approximates the full pneumococcal carriage dynamics. The true process actually allows for some individuals to carry more than one serotype at at time. However, due to the relatively low and variable reported prevalence of simultaneous serotype carriers (or ‘co-colonised’ individuals) across different studies (see, e.g., [7], [8] and many others…), the single-state occupation model should still a good tracer model of the underlying dynamical behaviour of the system. Note also that this additional complexity in the dynamics should be straightforward to incorporate into our framework for future analyses.

Let’s now try an approximation for the joint distributions of \(p_i(\dots, n_i, \dots, t)\) and \(q(\dots, n_i, \dots, t)\) which assumes separability, such that

\[ \begin{align} \ p_i(\dots, n_i, \dots, t) &\simeq p_i(t)P(\dots, n_i, \dots, t) \\ \ q(\dots, n_i, \dots, t) &\simeq q(t)P(\dots, n_i, \dots, t) \,. \end{align} \]

We shall evaluate the quality of this approximation later on (so don’t worry) under different parametric conditions, but for now, let’s just treat it as an ansatz.

By marginalising over states in the master equation, then substituting in the approximations above, and finally marginalising (each a summation from \(n_{i'}=0\) to \(\infty\)) over the resulting relation \(\forall n_{i'} \,\, i'\neq i\), one finds that the following time evolution equation is separately satisfied by each marginal \(P(n_i,t)\) distribution

\[ \begin{align} \frac{{\rm d}}{{\rm d}t}P(n_i,t) &= \bigg[ \tilde{\Lambda}_i(n_i-1)q(t) + \sum_{\forall i'\neq i} f_{i'i}\tilde{\Lambda}_{i} (n_{i}-1) p_{i'}(t) \bigg] P(n_{i}-1,t) \\ &\quad - \bigg[ \tilde{\Lambda}_i(n_i)q(t) + \sum_{\forall i'\neq i} f_{ii'}\tilde{\Lambda}_{i'} (n_{i'}) p_i(t)\bigg] P(n_i,t) \,. \end{align} \]

In addition to the separability assumption, the key point which allowed us to derive this one-step marginal master equation was the dependence of \(\tilde{\Lambda}_i\) on only \(n_i\); in contrast to all of the past recorded states \((\dots, n_i, \dots)\) like \(\tilde{\mu}_i\).

From this point on we’ll focus on the specific pneumococcus model by inserting the rate function definitions from [1] that we introduced at the start into the marginal master equation for \(P(n_i,t)\). The pneumoinfer class is currently written for only these models (i.e., with just these choices of function), but it’s useful to see how the steps above could be performed for more general models too. The solution to the marginal master equation with these function substitutions is simply a Poisson distribution \(P(n_i,t) = {\rm Poisson}[n_i;{\rm E}_t(n_i)]\), where

\[ \begin{equation} {\rm E}_t (n_i) = {\rm E}_{t_{\rm init}}(n_i) + \int^t_{t_{\rm init}}{\rm d}t'\bigg[ \sigma \Lambda_iq(t') +\sum_{\forall i'\neq i} f_{i'i}\sigma \Lambda_{i} p_{i'}(t')\bigg] \,. \end{equation} \]

Exploiting the properties of this Poisson distribution, if we now return to the full master equation and marginalise them over all \(n_i\), while noting that

\[ \begin{align} \ p_i(t) &= \sum_{\forall n_i}\sum_{n_{i}=0}^\infty p_i(\dots, n_i, \dots, t) \\ \ q(t) &= \sum_{\forall n_i}\sum_{n_{i}=0}^\infty q(\dots, n_i, \dots, t) \,, \end{align} \]

one arrives at the following finite (implicitly integro-differential) system

\[ \begin{align} \frac{{\rm d}}{{\rm d}t}p_i(t) &= \Lambda_iF_{it} q(t) + \sum_{\forall i'\neq i} f_{i'i} \Lambda_iF_{it} p_{i'}(t) - \mu_iG_{it} p_i(t)-\sum_{\forall i'\neq i}f_{ii'}\Lambda_{i'}F_{i't} p_i(t) \\ \frac{{\rm d}}{{\rm d}t}q(t) &= \sum_{\forall i}\mu_iG_{it}p_i(t) - \sum_{\forall i}\Lambda_iF_{it}q(t)\,, \end{align} \]

where, to avoid repetition, we have defined

\[ \begin{align} \ F_{it} &= P(n_i=0,t)+\sigma P(n_i>0,t) = e^{-{\rm E}_t(n_i)}+\sigma \big[ 1-e^{-{\rm E}_t(n_i)}\big] \\ \ G_{it} &= \frac{\mu_{\rm max}}{\mu_i} + \bigg( 1-\frac{\mu_{\rm max}}{\mu_i}\bigg) e^{\sum_{\forall i}{\rm E}_t(n_i)(e^{-\epsilon}-1)}\,, \end{align} \]

where to derive \(G_{it}\) we have had to assume conditional independence between \(n_i\) and \(n_{i'}\,\,\forall i'\neq i\). The equation for \({\rm E}_t (n_i)\) can be differentiated to provide an equation for the time derivative of \({\rm E}_t(n_i)\) - evolving this equation alongside the system defined above yields an explicit finite ODE system. Note also that this approximation technique should apply to other forms of memory functions used for \(\tilde{\mu}_i(\dots, n_i, \dots)\) and \(\tilde{\Lambda}_i(n_i)\) by simply marginalising over their \(n_i\) values, and so this approximate approach appears to be quite generalisable to other simlar systems.

In order to analyse the system properties and check the validity of the approach above, we’re now going to make some decisions about the parameter space to explore. Let’s independently draw the \((\mu_i,\Lambda_i)\) values from Gamma distributions with shapes \((\mu_\alpha,\Lambda_\alpha)\) and rates \((\mu_\beta,\Lambda_\beta)\). Let’s also constrain the matrix values \(f_{ii'}=f_{i}{\bf I}_{i'}\) (where \({\bf I}_{i'}\) denotes the elements of a simple vector of ones) which also happens to be consistent with pneumococcus data anyway (see, e.g., [4]). We’ll also need a metric of comparison between the marginalised distribution outputs from the fully simulated master equation and our approximation. To this end, it probably makes sense to look at the Kullback-Leibler divergence [9] between the marginal distributions for \(x_i\) and \(n_i\) in a full stochastic simulation and our approximation. In other words

\[ \begin{align} \ D^{(x)}_{{}_{\rm KL}} &= \sum_{\forall i} p_{i, {\rm sim}}(t) \ln \Bigg[ \frac{p_{i, {\rm sim}}(t)}{p_i(t)} \Bigg] \\ &\simeq - \sum_{\forall i} \frac{\ln Z_{\rm sim}(x_i, t)}{Z_{\rm sim}(x_i, t)} -\sum_{\forall i} \frac{\ln p_i(t)}{Z_{\rm sim}(x_i, t)} \\ \ D^{(n_i)}_{{}_{\rm KL}} &= \sum_{n_i=0}^{\infty} P_{\rm sim}(n_i, t) \ln \Bigg[ \frac{P_{\rm sim}(n_i, t)}{P(n_i,t)} \Bigg] \\ &\simeq - \sum_{n_i=0}^{\infty}\frac{\ln Z_{\rm sim}(n_i, t)}{Z_{\rm sim}(n_i, t)} - \sum_{n_i=0}^{\infty} \frac{\ln {\rm Poisson}[n_i;{\rm E}_t(n_i)]}{Z_{\rm sim}(n_i, t)} \\ &\simeq - \sum_{n_i=0}^{\infty}\frac{\ln Z_{\rm sim}(n_i, t)}{Z_{\rm sim}(n_i, t)} - \sum_{n_i=0}^{\infty} \bigg[ \frac{n_i\ln {\rm E}_t(n_i) - {\rm E}_t(n_i) - \ln \Gamma (n_i+1)}{Z_{\rm sim}(n_i, t)} \bigg] \,, \end{align} \]

where \(Z_{\rm sim}(x_i, t)\) and \(Z_{\rm sim}(n_i, t)\) denote the marginal frequency counts in each state space derived from a stochastic simulation of the master equation. Note that for the whole \((\dots, n_i, \dots)\) space, a better comparison would involve Monte Carlo integration of the joint counts \(Z_{\rm sim}(\dots, n_i, \dots, t)\). However, this is quite a lot more challenging with many dimensions (usually necessitating nested sampling) and so we’ll consider it to be beyond the present scope.

Using the .run_sim method of the pneumoinfer class, and the equations above, we can generate numerically-approximate plots of the Kullback-Leibler divergence on the marginal distributions over a range of numbers of states, parameters and points in time.

The value of \(D_{{}_{\rm KL}}^{(x)}\) generally stays small (and stable) throughout for most parameter choices. Interestingly, the same cannot be said for the \(D_{{}_{\rm KL}}^{(n_i)}\) values, which appear to tend towards a deviation which is linearly proportional in time. If we now plot the time evolution of each set of quantities explicitly in time, we can see this is consistent with the observed deviations between the simulation and the ODE approximation.

A varying \(\Lambda_{iu}\) model

We’re now ready to introduce an alternative model which accounts for a stochastically-varying susceptibility \(\Lambda_{iu}\) (a possible model for community exposure to infectious individuals), which is now additionally indexed by ‘\(u\)’ which corresponds to each individual. In this model, we have

\[ \begin{equation} \Lambda_{iu} = \Lambda_{\rm min} + \lambda\sum_{\forall u'\neq u}\beta_{uu'} \frac{x_{iu'}}{N_{\rm p}}\,, \end{equation} \]

where: the total population number is \(N_{\rm p}\); \(\beta_{uu'}\) are elements of a ‘contact matrix’ which rescales the event rate according to the spreading behaviour between the \(u\)-th and \(u'\)-th individuals; \(\lambda\) is a constant normalisation for \(\beta_{uu'}\); and \(x_{iu'}\) records the state of the \(u'\)-th individual.

Extending the master equation we introduced in the previous section to include the susceptibility above and the states of \(N_{\rm p}\) individuals, one can easily adapt the argument of the previous section to arrive at the following generalisation of the ODE system we found earlier

\[ \begin{align} \frac{{\rm d}}{{\rm d}t}p_{iu}(t) &= {\rm E}_t(\Lambda_{iu})F_{it} q_u(t) + \sum_{\forall i'\neq i} f_{i'i} {\rm E}_t(\Lambda_{iu})F_{it} p_{i'u}(t) - \mu_iG_{it} p_{iu}(t)-\sum_{\forall i'\neq i}f_{ii'}{\rm E}_t(\Lambda_{i'u})F_{i't} p_{iu}(t) \\ \frac{{\rm d}}{{\rm d}t}q_u(t) &= \sum_{\forall i}\mu_iG_{it}p_{iu}(t) - \sum_{\forall i}{\rm E}_t(\Lambda_{iu})F_{it}q_u(t)\,. \end{align} \]

In the equations above, the state occupation probabilities of separate \(u\)-indexed individuals (or \(u\)-indexed categories of individual) are \(p_{iu}(t)\) and \(q_u(t)\), and we’ve also computed the expectation

\[ \begin{equation} {\rm E}_t(\Lambda_{iu}) = \Lambda_{\rm min} + \lambda\sum_{\forall u'\neq u}\beta_{uu'} \frac{p_{iu'}(t)}{N_{\rm p}}\,. \end{equation} \]

The pneumoinfer class also implements ODE and full simulations for the varying \(\Lambda_{iu}\) model, and we plot an example run of this method below.

Computing the log-likelihood for inference

We’re now ready to apply our ODE approximation to the statistical inference of the full simulation. We’re going to assume that all data sets considered come in the form of a sequence of state observations (or longitudinally-monitored swab samples if you’re talking about pneumococcus) for each sampled individual from the population which takes the form of counts, times and associated sample sizes \({\cal D}\equiv \{d_c,d_t,d_s\}\) (where \(d_c=\{c_{ij}\}\), \(d_t=\{t_j \, : \, t_{\rm init}<t_j\leq t_{\rm end}\}\) and \(d_s=\{s_j\}\)). Note that this sequence of state observations may also be regarded as a form of filtration of the underlying stochastic process. Given a likelihood \({\cal L}\) of \({\cal D}\), these time intervals are independent of each other and so one may decompose \({\cal L}\) for the whole population as follows

\[ \begin{equation} \ {\cal L}({\cal D} \vert \Theta ) = \prod_{\forall j \, : \, t_j\,\in \,d_t}{\cal L}( t_j \vert \Theta ) \,. \end{equation} \]

Assuming here the fixed \(\Lambda_i\) model, the ODE solution then allows us to easily compute the multinomial likelihoods for the initial condition and into the future

\[ \begin{equation} {\cal L}( t_j \vert \Theta ) = \frac{\Gamma (s_j+1)}{\prod_{\forall i}\Gamma (c_{ij}+1)}q(t_j)^{s_j-\sum_{\forall i}c_{ij}} \prod_{\forall i}p_i(t_j)^{c_{ij}} \,. \end{equation} \]

Note that the independence of the expression above with respect to previous timepoints is not trivial and relies on the Markovian embedding of the system that we have already discussed. Note also that the above relations can be easily adapted to accomodate the varying \(\Lambda_{iu}\) model (and these are also implemented in the pneumoinfer log-likelihood code).

Let’s now run a full simulation using the fixed \(\Lambda_i\) model and use its output at different timepoints to construct a mock data set of state observations. Given this mock data set, we can then verify that the log-likelihood of pneumoinfer correctly identifies the maximum (up to some observation noise).

A method to compute the gradient of the log-likelihood

The current version of pneumoinfer does not support a gradient calculation for the log-likelihood (mainly because this post is already a bit long!). However, to assist anyone wanting to implement this themselves, it makes sense to go through a sketch of the calculation which computes the gradient (in principle) without resorting to numerical derivatives. This makes use of the ‘multiple-adjoint’ method as implemented in [10]. Consider the following ‘data Lagrangian’

\[ \begin{align} L &= \sum_{\forall j \, : \, t_j\,\in \,d_t} L_j\\ L_j &= \ln{\cal L}( t_j \vert \Theta ) + \int^{t_{j}}_{t_{j-1}}{\rm d}t \,{\sf h}(t)^{\rm T}\bigg[ \frac{{\rm d}}{{\rm d}t}{\sf V}(t) - {\sf M}_\Theta (t)\bigg] \\ &= \ln{\cal L}( t_j \vert \Theta) + {\sf h}(t_j)^{\rm T}{\sf V}(t_j)-{\sf h}(t_{j-1})^{\rm T}{\sf V}(t_{j-1}) - \int^{t_{j}}_{t_{j-1}}{\rm d}t \bigg[\frac{{\rm d}}{{\rm d}t}{\sf h}(t)^{\rm T} {\sf V}(t) + {\sf h}(t)^{\rm T}{\sf M}_\Theta (t)\bigg] \,, \end{align} \]

where \({\sf V}(t)=[\dots, {\rm E}_t(n_i),\dots, p_i(t), \dots , q(t)]^{\rm T}\), \({\sf h}(t)\) is a dynamical vector of Lagrange multipliers and \({\sf M}_\Theta (t)\) is just compact notation for the vector of ODE terms on the RHS. Varying \(L_j\) with respect to the boundary condition \({\sf V}(t_j)\) and \({\sf V}(t)\), we obtain the constraints

\[ \begin{align} \frac{\partial L_j}{\partial {\sf V}(t_j)} &= 0 \quad \Longleftrightarrow \quad \frac{\partial}{\partial {\sf V}(t_j)}\ln{\cal L}( t_j \vert \Theta ) + {\sf h}(t_j ) = 0 \\ \frac{\delta L_j}{\delta {\sf V}(t)} &= 0 \quad \Longleftrightarrow \quad \frac{{\rm d}}{{\rm d}t}{\sf h}(t) + \bigg[\frac{\partial}{\partial {\sf V}(t)}{\sf M}_\Theta (t)\bigg]^{\rm T}{\sf h}(t) = 0\,, \end{align} \]

Let us also note that if we vary \(L_j\) with respect to \(\Theta\) and optimise the likelihood, one obtains

\[ \begin{align} \frac{\partial L_j}{\partial \Theta} &= \frac{\partial}{\partial \Theta}\ln{\cal L}( t_j \vert \Theta ) - \int^{t_{j}}_{t_{j-1}}{\rm d}t \,{\sf h}(t)^{\rm T}\frac{\partial}{\partial \Theta}{\sf M}_\Theta (t) \\ &\underset{{\rm opt}}{\longrightarrow} \int_{t_{j}}^{t_{j-1}}{\rm d}t \,{\sf h}(t)^{\rm T}\frac{\partial}{\partial \Theta}{\sf M}_\Theta (t)\,. \end{align} \]

The method proposed from here would be something like:

Seems like overkill, but could be interesting to implement in future if a large number of states/parameters are varied, e.g., for HMC sampling of the model posterior from a decent data set.

References

[1]
S. Cobey and M. Lipsitch, “Niche and neutral effects of acquired immunity permit coexistence of pneumococcal serotypes,” Science, vol. 335, no. 6074, pp. 1376–1380, 2012.
[2]
S. Flasche, W. J. Edmunds, E. Miller, D. Goldblatt, C. Robertson, and Y. H. Choi, “The impact of specific and non-specific immunity on the ecology of streptococcus pneumoniae and the implications for vaccination,” Proceedings of the Royal Society B: Biological Sciences, vol. 280, no. 1771, p. 20131939, 2013.
[3]
A. Løchen and R. Anderson, “Dynamic transmission models and economic evaluations of pneumococcal conjugate vaccines: A quality appraisal and limitations,” Clinical Microbiology and Infection, vol. 26, no. 1, pp. 60–70, 2020.
[4]
M. Lipsitch et al., “Estimating rates of carriage acquisition and clearance and competitive ability for pneumococcal serotypes in kenya with a markov transition model,” Epidemiology, vol. 23, no. 4, pp. 510–519, 2012.
[5]
E. Numminen, L. Cheng, M. Gyllenberg, and J. Corander, “Estimating the transmission dynamics of streptococcus pneumoniae from strain prevalence data,” Biometrics, vol. 69, no. 3, pp. 748–757, 2013.
[6]
K. Kanazawa and D. Sornette, “Ubiquitous power law scaling in nonlinear self-excited hawkes processes,” Physical review letters, vol. 127, no. 18, p. 188301, 2021.
[7]
M. Gratten et al., “Multiple colonization of the upper respiratory tract of papua new guinea children with haemophilus influenzae and streptococcus pneumoniae.” The Southeast Asian journal of tropical medicine and public health, vol. 20, no. 4, pp. 501–509, 1989.
[8]
R. E. Huebner, R. Dagan, N. Porath, A. D. Wasas, K. P. Klugman, et al., “Lack of utility of serotyping multiple colonies for detection of simultaneous nasopharyngeal carriage of different pneumococcal serotypes,” The Pediatric infectious disease journal, vol. 19, no. 10, pp. 1017–1020, 2000.
[9]
S. Kullback and R. A. Leibler, “On information and sufficiency,” The annals of mathematical statistics, vol. 22, no. 1, pp. 79–86, 1951.
[10]
J. Zhuang, N. Dvornek, X. Li, S. Tatikonda, X. Papademetris, and J. Duncan, “Adaptive checkpoint adjoint method for gradient estimation in neural ode,” in International conference on machine learning, PMLR, 2020, pp. 11639–11649.

Cite. You can cite this article using the following BibTeX:
@article{pneumoinfer-2021,
  title = {Mean-field inference of multi-state models with a counting memory: applications to pneumococcus},
  author = {Hardwick, Robert J},
  journal = {umbralcalculations (umbralcalc.github.io/posts/pneumoinfer.html)},
  year = {2021},
}
Code. The code for this article was developed here: https://github.com/umbralcalc/pneumoinfer.
License. This article is shared by the author under an MIT License.