Confidence Regions

One of the primary goals of InformationGeometry.jl is to enable the user to investigate the relationships between different parameters in a model in detail by determining and visualizing the exact confidence regions associated with the best fit parameters. In this context, exact refers to the fact that no simplifying assumptions are made about the shape of the confidence regions.

using InformationGeometry, Plots
DS = DataSet([1,2,3,4], [4,5,6.5,9], [0.5,0.45,0.6,1])
model(x::Real, θ::AbstractVector{<:Real}) = θ[1] * x + θ[2]
DM = DataModel(DS, model)
DataModel containing DataSet. Model jacobian: AutoDiff
Maximal value of log-likelihood: -2.3178
Model Expr:  y(x,θ) = θ₂ + x*θ₁
┌───┬───────────┬─────────────┬───────────┬─────────────┬───────────────────┐
│ i │ Parameter │ Lower Bound │    MLE    │ Upper Bound │ Linear Dependence │
├───┼───────────┼─────────────┼───────────┼─────────────┼───────────────────┤
│ 1 │ θ₁        │    -Inf     │ 1.48±0.31 │     Inf     │       true        │
│ 2 │ θ₂        │    -Inf     │ 2.27±0.69 │     Inf     │       true        │
└───┴───────────┴─────────────┴───────────┴─────────────┴───────────────────┘
plot(DM; Confnum=0)
Example block output

Depending on how the parameters $\theta$ enter into the model, the shapes of confidence regions associated with the model may be distorted. For the linearly parametrized model $y_\text{model}(x;\theta) = \theta_1 \cdot x + \theta_2$ from above, the $1 \sigma$ and $2 \sigma$ confidence regions form perfect ellipses around the maximum likelihood estimate as expected:

sols = ConfidenceRegions(DM, 1:2; tol=1e-9)
VisualizeSols(DM, sols)
Example block output

For a non-linearly parametrized model such as $y_\text{model}(x;\theta) = {\theta_1}^{\!3} \cdot x + \mathrm{exp}(\theta_1 + \theta_2)$ (which also produces a straight line fit!), the confidence regions are no longer ellipsoidal:

model2(x::Real, θ::AbstractVector{<:Real}) = θ[1]^3 * x + exp(θ[1] + θ[2])
DM2 = DataModel(DS, model2)
sols2 = ConfidenceRegions(DM2, 1:2; tol=1e-9)
VisualizeSols(DM2, sols2)
Example block output

Specifically in the case of two-dimensional parameter spaces as shown here, the problem of finding the exact boundaries of the confidence regions is turned into a system of ordinary differential equations and subsequently solved using the DifferentialEquations.jl suite. As a result, the boundaries of the confidence regions are obtained in the form of ODESolution objects, which come equipped with elaborate interpolation methods.

Both finding as well as visualizing exact confidence regions for models depending on more than two parameters (i.e. $\mathrm{dim} \, \mathcal{M} > 2$) is more challenging from a technical perspective. For such models, it is clearly only possible to visualize three-dimensional slices of the parameter space at a time. The easiest way to achieve this is to intersect the confidence region with a family of 2D planes, in which the boundaries of the confidence region are computed using the 2D scheme.

The specific components of $\theta$ to be visualized can be passed as a tuple to ConfidenceRegion() via the keyword argument Dirs=(1,2,3). Also, the keyword N can be used to (approximately) control the number of planes with which the confidence region of interest is intersected.

DM3 = DataModel(DS, (x,θ)-> θ[1]^3 * x + exp(θ[1] + θ[2]) + θ[3] * sin(x))
Planes, sols3 = ConfidenceRegion(DM3, 1; tol=1e-6, Dirs=(1,2,3), N=50)
VisualizeSols(DM3, Planes, sols3)
Example block output

Here, only the $1\sigma$ confidence region is shown. Given the non-linearity of the model, it is of course no surprise that the region is strongly distorted compared with a perfect ellipsoid.

Once the boundary of a confidence region associated with some particular level has been computed, it can be used to establish the most extreme deviations from the maximum likelihood prediction, which are possible at said confidence level. These can then be illustrated as so-called "pointwise confidence bands" around the best fit. For example, given the confidence boundaries of the model DM2 from above, the $2\sigma$ confidence band can be obtained via:

plot(DM2; Confnum=0)
ConfidenceBands(DM2, sols2[2])
Example block output
InformationGeometry.ConfidenceRegionsMethod
ConfidenceRegions(DM::DataModel, Range::AbstractVector)

Computes the boundaries of confidence regions for two-dimensional parameter spaces given a vector or range of confidence levels. A convenient interface which extends this to higher dimensions is currently still under development.

For example,

ConfidenceRegions(DM, 1:3; tol=1e-9)

computes the $1\sigma$, $2\sigma$ and $3\sigma$ confidence regions associated with a given DataModel using a solver tolerance of $10^{-9}$.

Keyword arguments:

  • IsConfVol = true can be used to specify the desired confidence level directly in terms of a probability $p \in [0,1]$ instead of in units of standard deviations $\sigma$,
  • tol can be used to quantify the tolerance with which the ODE which defines the confidence boundary is solved (default tol = 1e-9),
  • meth can be used to specify the solver algorithm (default meth = Tsit5()),
  • ADmode=Val(false) computes the Score by separately evaluating the model as well as the Jacobian dmodel provided in DM. Other choices of ADmode directly compute the Score by differentiating the formula the log-likelihood, i.e. only one evaluation on a dual variable is performed.
  • parallel = true parallelizes the computations of the separate confidence regions provided each process has access to the necessary objects,
  • dof can be used to manually specify the degrees of freedom.
source
InformationGeometry.ConfidenceBandsFunction
ConfidenceBands(DM::DataModel, sol::AbstractODESolution, Xdomain::HyperCube; N::Int=300, plot::Bool=isloaded(:Plots)) -> Matrix

Given a confidence interval sol, the pointwise confidence band around the model prediction is computed for x values in Xdomain by evaluating the model on the boundary of the confidence region.

source