Skip to content

Latest commit

 

History

History
122 lines (87 loc) · 4.55 KB

README.md

File metadata and controls

122 lines (87 loc) · 4.55 KB

Simple (linear) birth and death process

Build Status Coverage

About

This Julia package provides functions for fitting a simple birth and death process (BDP) without migration, also known as the Kendall process [1].

Installation

SimpleBirthDeathProcess can be easily installed from within Julia:

  • Enter the Pkg REPL-mode by pressing ] in the Julia REPL
  • Issue the command add https://github.com/albertopessia/SimpleBirthDeathProcess.jl/
  • Press the Backspace key to return to the Julia REPL

Usage

In what follows we will use the conventions

  • i: initial population size at time 0
  • j: final population size at the end of the observation.
  • t: total amount of time the stochastic process is observed.
  • λ: birth rate
  • μ: death rate
  • η: vector of parameters [λ, μ]

It is assumed that i and j are both integer numbers, with i > 0 and j ≧ 0. Parameters t, λ, and μ are non-negative real numbers.

Transition probability

To evaluate the log-transition probability use

trans_prob(i, j, t, η)

By default, the function returns the logarithm of the transition probability. To obtain the actual probability set to false the keyword log_value:

trans_prob(i, j, t, η, log_value=false)

Simulations

Continuous case

To simulate one simple BDP observed continuously over time, use

rand_continuous(i, t, η)

To simulate n independent and identically distributed simple BDPs observed continuously over time, use

rand_continuous(n, i, t, η)

Discrete case

To simulate one simple BDP observed at k time points, equally spaced with same lag u, use

rand_discrete(i, k, u, η)

To simulate n independent and identically distributed simple BDPs, observed at k time points equally spaced by the same lag u, use

rand_discrete(n, i, k, u, η)

Input data

Continuous case

If your data was observed continuously, denote with s[1], ..., s[h] the exact times at which birth or death events occurred. Denote with x[1], ..., x[h] the corresponding population sizes observed at s[1], ..., s[h]. To create a ObservationContinuousTime object for data analysis use

observation_continuous_time(s, x, t)

where x is the (integer) vector of population sizes of length h, s is the vector of event times of length h, and t is the total time the process was observed.

Discrete case

If your data was observed only at pre-specified fixed points, we need to consider two distinct cases: evenly or unevenly distributed time points. When the time points are evenly distributed define

  • u: non-negative time lag equally separating each observation
  • x: vector of length k (or k-by-n matrix for the case of n i.i.d. simple BDPs) with the observed population sizes

To create a ObservationDiscreteTimeEven object for data analysis use

observation_discrete_time_even(u, x)

When the time points are unevenly distributed, to create a ObservationDiscreteTimeUneven object use instead

observation_discrete_time_uneven(t, x)

where x is the (integer) vector of population sizes of length h and t is the vector of event times of same length h.

log-likelihood function

To evaluate the log-likelihood function you first need to create one of ObservationContinuousTime, ObservationDiscreteTimeEven, ObservationDiscreteTimeUneven as described in the previous sections, either by simulation or by converting pre-existing data. Call such object obs_data.

The value of the log-likelihood function associated with the observed data for a particular combination of parameters η = [λ, μ] can be obtained by

loglik(η, obs_data)

Maximum likelihood estimation

You can compute the maximum likelihood estimator with the function

mle(obs_data)

License

See LICENSE.md

References

[1] Kendall, D. G. (1949). Stochastic Processes and Population Growth. Journal of the Royal Statistical Society: Series B (Methodological), 11(2): 230-264. doi: 10.1111/j.2517-6161.1949.tb00032.x