Source code for stonesoup.types.particle

# -*- coding: utf-8 -*-

from typing import MutableSequence

import numpy as np

from ..base import Property
from .array import StateVector, StateVectors
from .base import Type
from .numeric import Probability


[docs]class Particle(Type): """ Particle type A particle type which contains a state and weight """ state_vector: StateVector = Property(doc="State vector") weight: float = Property(doc='Weight of particle') parent: 'Particle' = Property(default=None, doc='Parent particle') def __init__(self, state_vector, weight, parent=None, *args, **kwargs): if parent: parent.parent = None if state_vector is not None and not isinstance(state_vector, StateVector): state_vector = StateVector(state_vector) super().__init__(state_vector, weight, parent, *args, **kwargs) @property def ndim(self): return self.state_vector.shape[0]
[docs]class Particles(Type): """ Particle type A collection of particles. Contains a state and weight for each particle """ state_vector: StateVectors = Property(default=None, doc="State vectors of particles") weight: MutableSequence[Probability] = Property(default=None, doc='Weights of particles') parent: 'Particles' = Property(default=None, doc='Parent particles') particle_list: MutableSequence[Particle] = Property(default=None, doc='List of Particle objects') def __init__(self, state_vector=None, weight=None, parent=None, particle_list=None, *args, **kwargs): if (particle_list is not None) and (state_vector is not None or weight is not None): raise ValueError("Use either a list of Particle objects or StateVectors and weights," " but not both.") if particle_list and isinstance(particle_list, list): state_vector = StateVectors([particle.state_vector for particle in particle_list]) weight = np.array([Probability(particle.weight) for particle in particle_list]) parent_list = [particle.parent for particle in particle_list] if parent_list.count(None) == 0: parent = Particles(particle_list=parent_list) elif 0 < parent_list.count(None) < len(parent_list): raise ValueError("Either all particles should have" " parents or none of them should.") if parent: parent.parent = None if state_vector is not None and not isinstance(state_vector, StateVectors): state_vector = StateVectors(state_vector) if weight is not None and isinstance(weight, np.ndarray): weight = np.array(weight) super().__init__(state_vector, weight, parent, particle_list, *args, **kwargs) def __getitem__(self, item): if self.parent: p = self.parent[item] else: p = None particle = Particle(state_vector=self.state_vector[:, item], weight=self.weight[item], parent=p) return particle def __len__(self): return self.state_vector.shape[1] @property def ndim(self): return self.state_vector.shape[0]