Class ComparableDiscreteSystem<TShared, TInternal, TData>

Implementation of ComparableSystem for discrete systems, for use with generators which support comparison to data.

Type Parameters

  • TShared

    Values which are shared between all particles in a group and are not mutated by them - the model parameter values for that group

  • TInternal

    Internal state values which can be mutated by generators, used to improve efficiency of the system by e.g. caching calculation results for use by other particles.

  • TData

    Type of each data point which will be compared with system state.

Hierarchy (View Summary)

Implements

Constructors

Accessors

Methods

  • Compares the state of all particles in the syatem with observed data, and returns an NdArray of log likelihoods of each particle state given the data, where the NdArray has shape [nGroups, nParticles]

    Parameters

    • data: TData | TData[]

      Observed data to compare against system state

    Returns NdArray<any[]>

  • Sets new values in the system state

    Parameters

    • newState: SystemSubState

      The new state values for all or part of the state. If partial state, the shape must match the values provided in the indices parameters

    • groupIndices: number[] = []

      The group indices, in order, which the first dimension of newState are setting values for. If empty, this means newState provides values for all groups.

    • particleIndices: number[] = []

      The particle indices, in order, which the second dimension of newState are setting values for. If empty, this means newState provides values for all particles.

    • stateElementIndices: number[] = []

      The state element indices, in order, which the second dimension of newState are setting values for. If empty, this means newState provides values for all state elements.

    Returns void

  • Runs the system from its current time to a series of times given by the parameter times and returns state values for all particles at each of these times.

    Parameters

    • times: number[]

      The times to run to and return state for. Must be in increasing order, with no value less than the current time.

    • stateElementIndices: number[] = []

      Indices of the state elements to return in the result. If an empty array is provided, all values are returned.

    Returns SystemSimulateResult

  • Updates shared (parameter) values for all groups in the system.

    Parameters

    • newShared: TShared[]

      Updated parameter values. The length must match the existing number of groups in the system.

    Returns void