pub struct RestartFixUpActiveLineageSampler<M: MathsCore, H: Habitat<M>, G: RngCore<M>, S: LineageStore<M, H>, X: EmigrationExit<M, H, G, S>, D: DispersalSampler<M, H, G>, C: CoalescenceSampler<M, H, S>, T: TurnoverRate<M, H>, N: SpeciationProbability<M, H>, E: EventSampler<M, H, G, S, X, D, C, T, N>, I: ImmigrationEntry<M>, A: ActiveLineageSampler<M, H, G, S, X, D, C, T, N, E, I>> { /* private fields */ }

Implementations§

source§

impl<M: MathsCore, H: Habitat<M>, G: RngCore<M>, S: LineageStore<M, H>, X: EmigrationExit<M, H, G, S>, D: DispersalSampler<M, H, G>, C: CoalescenceSampler<M, H, S>, T: TurnoverRate<M, H>, N: SpeciationProbability<M, H>, E: EventSampler<M, H, G, S, X, D, C, T, N>, I: ImmigrationEntry<M>, A: ActiveLineageSampler<M, H, G, S, X, D, C, T, N, E, I>> RestartFixUpActiveLineageSampler<M, H, G, S, X, D, C, T, N, E, I, A>

source

pub fn new( active_lineage_sampler: A, fixable_lineages: Vec<Lineage>, restart_time: PositiveF64 ) -> Self

Trait Implementations§

source§

impl<M: MathsCore, H: Habitat<M>, G: RngCore<M>, S: LineageStore<M, H>, X: EmigrationExit<M, H, G, S>, D: DispersalSampler<M, H, G>, C: CoalescenceSampler<M, H, S>, T: TurnoverRate<M, H>, N: SpeciationProbability<M, H>, E: EventSampler<M, H, G, S, X, D, C, T, N>, I: ImmigrationEntry<M>, A: ActiveLineageSampler<M, H, G, S, X, D, C, T, N, E, I>> ActiveLineageSampler<M, H, G, S, X, D, C, T, N, E, I> for RestartFixUpActiveLineageSampler<M, H, G, S, X, D, C, T, N, E, I, A>

source§

fn pop_active_lineage_and_event_time<F: FnOnce(PositiveF64) -> ControlFlow<(), ()>>( &mut self, simulation: &mut PartialSimulation<M, H, G, S, X, D, C, T, N, E>, rng: &mut G, early_peek_stop: F ) -> Option<(Lineage, PositiveF64)>

§Contracts

Post-condition - debug: removes an active lineage if Some(_) returned

  • match ret { Some(_) => { self.number_active_lineages() == old(self.number_active_lineages()) - 1 }, None => { self.number_active_lineages() == old(self.number_active_lineages()) }, }

Post-condition - debug: returns None if no lineages are left

  • old(self.number_active_lineages()) != 0 || ret.is_none()

Post-condition - debug: updates the time of the last event

  • if let Some((ref _lineage, event_time)) = ret { self.get_last_event_time() == event_time } else { true }
source§

fn push_active_lineage( &mut self, lineage: Lineage, simulation: &mut PartialSimulation<M, H, G, S, X, D, C, T, N, E>, rng: &mut G )

§Contracts

Post-condition - debug: adds an active lineage

  • self.number_active_lineages() == old(self.number_active_lineages()) + 1

Post-condition - debug: updates the time of the last event

  • self.get_last_event_time() == old(lineage.last_event_time)
§

type LineageIterator<'a> = impl Iterator<Item = &'a Lineage> where H: 'a, G: 'a, S: 'a, X: 'a, D: 'a, C: 'a, T: 'a, N: 'a, E: 'a, I: 'a, A: 'a

source§

fn number_active_lineages(&self) -> usize

source§

fn iter_active_lineages_ordered<'a>( &'a self, habitat: &'a H, lineage_store: &'a S ) -> Self::LineageIterator<'a>

source§

fn get_last_event_time(&self) -> NonNegativeF64

source§

impl<M: MathsCore, H: Habitat<M>, G: RngCore<M>, S: LineageStore<M, H>, X: EmigrationExit<M, H, G, S>, D: DispersalSampler<M, H, G>, C: CoalescenceSampler<M, H, S>, T: TurnoverRate<M, H>, N: SpeciationProbability<M, H>, E: EventSampler<M, H, G, S, X, D, C, T, N>, I: ImmigrationEntry<M>, A: ActiveLineageSampler<M, H, G, S, X, D, C, T, N, E, I>> Backup for RestartFixUpActiveLineageSampler<M, H, G, S, X, D, C, T, N, E, I, A>

§

unsafe fn backup_unchecked(&self) -> Self

§

fn backup(&self) -> BackedUp<Self>

source§

impl<M: Debug + MathsCore, H: Debug + Habitat<M>, G: Debug + RngCore<M>, S: Debug + LineageStore<M, H>, X: Debug + EmigrationExit<M, H, G, S>, D: Debug + DispersalSampler<M, H, G>, C: Debug + CoalescenceSampler<M, H, S>, T: Debug + TurnoverRate<M, H>, N: Debug + SpeciationProbability<M, H>, E: Debug + EventSampler<M, H, G, S, X, D, C, T, N>, I: Debug + ImmigrationEntry<M>, A: Debug + ActiveLineageSampler<M, H, G, S, X, D, C, T, N, E, I>> Debug for RestartFixUpActiveLineageSampler<M, H, G, S, X, D, C, T, N, E, I, A>

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl<M, H, G, S, X, D, C, T, N, E, I, A> Freeze for RestartFixUpActiveLineageSampler<M, H, G, S, X, D, C, T, N, E, I, A>
where A: Freeze,

§

impl<M, H, G, S, X, D, C, T, N, E, I, A> RefUnwindSafe for RestartFixUpActiveLineageSampler<M, H, G, S, X, D, C, T, N, E, I, A>

§

impl<M, H, G, S, X, D, C, T, N, E, I, A> Send for RestartFixUpActiveLineageSampler<M, H, G, S, X, D, C, T, N, E, I, A>
where A: Send, H: Send, S: Send, X: Send, D: Send, C: Send, T: Send, N: Send, E: Send, I: Send,

§

impl<M, H, G, S, X, D, C, T, N, E, I, A> Sync for RestartFixUpActiveLineageSampler<M, H, G, S, X, D, C, T, N, E, I, A>
where A: Sync, H: Sync, G: Sync, S: Sync, X: Sync, D: Sync, C: Sync, T: Sync, N: Sync, E: Sync, I: Sync,

§

impl<M, H, G, S, X, D, C, T, N, E, I, A> Unpin for RestartFixUpActiveLineageSampler<M, H, G, S, X, D, C, T, N, E, I, A>
where A: Unpin, M: Unpin, H: Unpin, G: Unpin, S: Unpin, X: Unpin, D: Unpin, C: Unpin, T: Unpin, N: Unpin, E: Unpin, I: Unpin,

§

impl<M, H, G, S, X, D, C, T, N, E, I, A> UnwindSafe for RestartFixUpActiveLineageSampler<M, H, G, S, X, D, C, T, N, E, I, A>

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
§

impl<T> ExtractDiscriminant for T

§

type Discriminant = <T as ExtractDiscriminantSpec<<T as DiscriminantKind>::Discriminant>>::Ty

The type of the discriminant, which must satisfy the trait bounds required by core::mem::Discriminant. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<T> Erased for T