pub struct IndependentLineageStore<M: MathsCore, H: Habitat<M>> { /* private fields */ }
Trait Implementations§
source§impl<M: MathsCore, H: Habitat<M>, G: PrimeableRng<M>, X: EmigrationExit<M, H, G, IndependentLineageStore<M, H>>, D: DispersalSampler<M, H, G>, T: TurnoverRate<M, H>, N: SpeciationProbability<M, H>, J: EventTimeSampler<M, H, G, T>> ActiveLineageSampler<M, H, G, IndependentLineageStore<M, H>, X, D, IndependentCoalescenceSampler<M, H>, T, N, IndependentEventSampler<M, H, G, X, D, T, N>, NeverImmigrationEntry> for IndependentActiveLineageSampler<M, H, G, X, D, T, N, J>
impl<M: MathsCore, H: Habitat<M>, G: PrimeableRng<M>, X: EmigrationExit<M, H, G, IndependentLineageStore<M, H>>, D: DispersalSampler<M, H, G>, T: TurnoverRate<M, H>, N: SpeciationProbability<M, H>, J: EventTimeSampler<M, H, G, T>> ActiveLineageSampler<M, H, G, IndependentLineageStore<M, H>, X, D, IndependentCoalescenceSampler<M, H>, T, N, IndependentEventSampler<M, H, G, X, D, T, N>, NeverImmigrationEntry> for IndependentActiveLineageSampler<M, H, G, X, D, T, N, J>
type LineageIterator<'a> = impl Iterator<Item = &'a Lineage> where H: 'a, G: 'a, X: 'a, D: 'a, T: 'a, N: 'a, J: 'a
fn number_active_lineages(&self) -> usize
fn iter_active_lineages_ordered<'a>( &'a self, habitat: &'a H, lineage_store: &'a S ) -> Self::LineageIterator<'a>
fn get_last_event_time(&self) -> NonNegativeF64
§fn pop_active_lineage_and_event_time<P>(
&mut self,
simulation: &mut PartialSimulation<M, H, G, S, X, D, C, T, N, E>,
rng: &mut G,
early_peek_stop: P
) -> Option<(Lineage, PositiveF64)>
fn pop_active_lineage_and_event_time<P>( &mut self, simulation: &mut PartialSimulation<M, H, G, S, X, D, C, T, N, E>, rng: &mut G, early_peek_stop: P ) -> Option<(Lineage, PositiveF64)>
Contracts Read more
§fn push_active_lineage(
&mut self,
lineage: Lineage,
simulation: &mut PartialSimulation<M, H, G, S, X, D, C, T, N, E>,
rng: &mut G
)
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 Read more
source§impl<M: MathsCore, H: Habitat<M>> Backup for IndependentLineageStore<M, H>
impl<M: MathsCore, H: Habitat<M>> Backup for IndependentLineageStore<M, H>
unsafe fn backup_unchecked(&self) -> Self
fn backup(&self) -> BackedUp<Self>
source§impl<M: MathsCore, H: SingletonDemesHabitat<M>> CoalescenceSampler<M, H, IndependentLineageStore<M, H>> for IndependentCoalescenceSampler<M, H>
impl<M: MathsCore, H: SingletonDemesHabitat<M>> CoalescenceSampler<M, H, IndependentLineageStore<M, H>> for IndependentCoalescenceSampler<M, H>
§fn sample_interaction_at_location(
&self,
location: Location,
habitat: &H,
lineage_store: &S,
coalescence_rng_sample: CoalescenceRngSample
) -> (IndexedLocation, LineageInteraction)
fn sample_interaction_at_location( &self, location: Location, habitat: &H, lineage_store: &S, coalescence_rng_sample: CoalescenceRngSample ) -> (IndexedLocation, LineageInteraction)
Contracts Read more
source§impl<M: MathsCore, H: Habitat<M>> CoalescenceSampler<M, H, IndependentLineageStore<M, H>> for IndependentCoalescenceSampler<M, H>
impl<M: MathsCore, H: Habitat<M>> CoalescenceSampler<M, H, IndependentLineageStore<M, H>> for IndependentCoalescenceSampler<M, H>
§fn sample_interaction_at_location(
&self,
location: Location,
habitat: &H,
lineage_store: &S,
coalescence_rng_sample: CoalescenceRngSample
) -> (IndexedLocation, LineageInteraction)
fn sample_interaction_at_location( &self, location: Location, habitat: &H, lineage_store: &S, coalescence_rng_sample: CoalescenceRngSample ) -> (IndexedLocation, LineageInteraction)
Contracts Read more
source§impl<M: MathsCore, H: Habitat<M>> Default for IndependentLineageStore<M, H>
impl<M: MathsCore, H: Habitat<M>> Default for IndependentLineageStore<M, H>
source§impl<M: MathsCore, H: Habitat<M>, C: Decomposition<M, H>, E: EmigrationChoice<M, H>, G: RngCore<M>> EmigrationExit<M, H, G, IndependentLineageStore<M, H>> for IndependentEmigrationExit<M, H, C, E>
impl<M: MathsCore, H: Habitat<M>, C: Decomposition<M, H>, E: EmigrationChoice<M, H>, G: RngCore<M>> EmigrationExit<M, H, G, IndependentLineageStore<M, H>> for IndependentEmigrationExit<M, H, C, E>
§fn optionally_emigrate(
&mut self,
global_reference: GlobalLineageReference,
dispersal_origin: IndexedLocation,
dispersal_target: Location,
prior_time: NonNegativeF64,
event_time: PositiveF64,
simulation: &mut PartialSimulation<M, H, G, S>,
rng: &mut G
) -> Option<(GlobalLineageReference, IndexedLocation, Location, NonNegativeF64, PositiveF64)>
fn optionally_emigrate( &mut self, global_reference: GlobalLineageReference, dispersal_origin: IndexedLocation, dispersal_target: Location, prior_time: NonNegativeF64, event_time: PositiveF64, simulation: &mut PartialSimulation<M, H, G, S>, rng: &mut G ) -> Option<(GlobalLineageReference, IndexedLocation, Location, NonNegativeF64, PositiveF64)>
Contracts Read more
source§impl<M: MathsCore, H: Habitat<M>, G: RngCore<M>, X: EmigrationExit<M, H, G, IndependentLineageStore<M, H>>, D: DispersalSampler<M, H, G>, T: TurnoverRate<M, H>, N: SpeciationProbability<M, H>> EventSampler<M, H, G, IndependentLineageStore<M, H>, X, D, IndependentCoalescenceSampler<M, H>, T, N> for IndependentEventSampler<M, H, G, X, D, T, N>
impl<M: MathsCore, H: Habitat<M>, G: RngCore<M>, X: EmigrationExit<M, H, G, IndependentLineageStore<M, H>>, D: DispersalSampler<M, H, G>, T: TurnoverRate<M, H>, N: SpeciationProbability<M, H>> EventSampler<M, H, G, IndependentLineageStore<M, H>, X, D, IndependentCoalescenceSampler<M, H>, T, N> for IndependentEventSampler<M, H, G, X, D, T, N>
fn sample_event_for_lineage_at_event_time_or_emigrate<Q, Aux, FS, FD, FE>( &mut self, lineage: Lineage, event_time: PositiveF64, simulation: &mut PartialSimulation<M, H, G, S, X, D, C, T, N>, rng: &mut G, handler: EventHandler<FS, FD, FE>, auxiliary: Aux ) -> Q
source§impl<M: MathsCore, H: Habitat<M>> LineageStore<M, H> for IndependentLineageStore<M, H>
impl<M: MathsCore, H: Habitat<M>> LineageStore<M, H> for IndependentLineageStore<M, H>
type LocalLineageReference = GlobalLineageReference
fn with_capacity(habitat: &H, capacity: usize) -> Self
fn get_lineage_for_local_reference( &self, reference: &Self::LocalLineageReference ) -> Option<&Lineage>
source§impl<M: MathsCore, H: Habitat<M>, G: RngCore<M>, X: EmigrationExit<M, H, G, IndependentLineageStore<M, H>>, D: DispersalSampler<M, H, G>, T: TurnoverRate<M, H>, N: SpeciationProbability<M, H>> MinSpeciationTrackingEventSampler<M, H, G, IndependentLineageStore<M, H>, X, D, IndependentCoalescenceSampler<M, H>, T, N> for IndependentEventSampler<M, H, G, X, D, T, N>
impl<M: MathsCore, H: Habitat<M>, G: RngCore<M>, X: EmigrationExit<M, H, G, IndependentLineageStore<M, H>>, D: DispersalSampler<M, H, G>, T: TurnoverRate<M, H>, N: SpeciationProbability<M, H>> MinSpeciationTrackingEventSampler<M, H, G, IndependentLineageStore<M, H>, X, D, IndependentCoalescenceSampler<M, H>, T, N> for IndependentEventSampler<M, H, G, X, D, T, N>
fn replace_min_speciation( &mut self, new: Option<SpeciationSample> ) -> Option<SpeciationSample>
source§impl<M: MathsCore, H: Habitat<M>> RustToCuda for IndependentLineageStore<M, H>
impl<M: MathsCore, H: Habitat<M>> RustToCuda for IndependentLineageStore<M, H>
type CudaRepresentation = IndependentLineageStoreCudaRepresentation<M, H>
type CudaAllocation = NoCudaAlloc
source§impl<M: MathsCore, H: Habitat<M>> RustToCudaAsync for IndependentLineageStore<M, H>
impl<M: MathsCore, H: Habitat<M>> RustToCudaAsync for IndependentLineageStore<M, H>
type CudaAllocationAsync = NoCudaAlloc
source§impl<M: MathsCore, H: Habitat<M>, G: PrimeableRng<M>, X: EmigrationExit<M, H, G, IndependentLineageStore<M, H>>, D: DispersalSampler<M, H, G>, T: TurnoverRate<M, H>, N: SpeciationProbability<M, H>, J: EventTimeSampler<M, H, G, T>> SingularActiveLineageSampler<M, H, G, IndependentLineageStore<M, H>, X, D, IndependentCoalescenceSampler<M, H>, T, N, IndependentEventSampler<M, H, G, X, D, T, N>, NeverImmigrationEntry> for IndependentActiveLineageSampler<M, H, G, X, D, T, N, J>
impl<M: MathsCore, H: Habitat<M>, G: PrimeableRng<M>, X: EmigrationExit<M, H, G, IndependentLineageStore<M, H>>, D: DispersalSampler<M, H, G>, T: TurnoverRate<M, H>, N: SpeciationProbability<M, H>, J: EventTimeSampler<M, H, G, T>> SingularActiveLineageSampler<M, H, G, IndependentLineageStore<M, H>, X, D, IndependentCoalescenceSampler<M, H>, T, N, IndependentEventSampler<M, H, G, X, D, T, N>, NeverImmigrationEntry> for IndependentActiveLineageSampler<M, H, G, X, D, T, N, J>
fn replace_active_lineage( &mut self, active_lineage: Option<Lineage> ) -> Option<Lineage>
Auto Trait Implementations§
impl<M, H> Freeze for IndependentLineageStore<M, H>
impl<M, H> RefUnwindSafe for IndependentLineageStore<M, H>where
M: RefUnwindSafe,
H: RefUnwindSafe,
impl<M, H> Send for IndependentLineageStore<M, H>where
H: Send,
impl<M, H> Sync for IndependentLineageStore<M, H>where
H: Sync,
impl<M, H> Unpin for IndependentLineageStore<M, H>
impl<M, H> UnwindSafe for IndependentLineageStore<M, H>where
M: UnwindSafe,
H: UnwindSafe,
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
§impl<T> ExtractDiscriminant for T
impl<T> ExtractDiscriminant for T
§type Discriminant = <T as ExtractDiscriminantSpec<<T as DiscriminantKind>::Discriminant>>::Ty
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 moresource§impl<T> LendToCuda for Twhere
T: RustToCuda,
impl<T> LendToCuda for Twhere
T: RustToCuda,
source§fn lend_to_cuda<O, E, F>(&self, inner: F) -> Result<O, E>where
E: From<CudaError>,
F: FnOnce(HostAndDeviceConstRef<'_, DeviceAccessible<<T as RustToCuda>::CudaRepresentation>>) -> Result<O, E>,
T: Sync,
fn lend_to_cuda<O, E, F>(&self, inner: F) -> Result<O, E>where
E: From<CudaError>,
F: FnOnce(HostAndDeviceConstRef<'_, DeviceAccessible<<T as RustToCuda>::CudaRepresentation>>) -> Result<O, E>,
T: Sync,
Lends an immutable borrow of
&self
to CUDA: Read moresource§fn lend_to_cuda_mut<O, E, F>(&mut self, inner: F) -> Result<O, E>where
E: From<CudaError>,
F: FnOnce(HostAndDeviceMutRef<'_, DeviceAccessible<<T as RustToCuda>::CudaRepresentation>>) -> Result<O, E>,
T: Sync + SafeMutableAliasing,
fn lend_to_cuda_mut<O, E, F>(&mut self, inner: F) -> Result<O, E>where
E: From<CudaError>,
F: FnOnce(HostAndDeviceMutRef<'_, DeviceAccessible<<T as RustToCuda>::CudaRepresentation>>) -> Result<O, E>,
T: Sync + SafeMutableAliasing,
source§fn move_to_cuda<O, E, F>(self, inner: F) -> Result<O, E>where
E: From<CudaError>,
F: FnOnce(HostAndDeviceOwned<'_, DeviceAccessible<<T as RustToCuda>::CudaRepresentation>>) -> Result<O, E>,
T: Send + RustToCuda,
<T as RustToCuda>::CudaRepresentation: StackOnly,
<T as RustToCuda>::CudaAllocation: EmptyCudaAlloc,
fn move_to_cuda<O, E, F>(self, inner: F) -> Result<O, E>where
E: From<CudaError>,
F: FnOnce(HostAndDeviceOwned<'_, DeviceAccessible<<T as RustToCuda>::CudaRepresentation>>) -> Result<O, E>,
T: Send + RustToCuda,
<T as RustToCuda>::CudaRepresentation: StackOnly,
<T as RustToCuda>::CudaAllocation: EmptyCudaAlloc,
source§impl<T> LendToCudaAsync for Twhere
T: RustToCudaAsync,
impl<T> LendToCudaAsync for Twhere
T: RustToCudaAsync,
source§fn lend_to_cuda_async<'stream, O, E, F>(
&self,
stream: Stream<'stream>,
inner: F
) -> Result<O, E>where
E: From<CudaError>,
F: FnOnce(Async<'_, 'stream, HostAndDeviceConstRef<'_, DeviceAccessible<<T as RustToCuda>::CudaRepresentation>>>) -> Result<O, E>,
T: Sync,
fn lend_to_cuda_async<'stream, O, E, F>(
&self,
stream: Stream<'stream>,
inner: F
) -> Result<O, E>where
E: From<CudaError>,
F: FnOnce(Async<'_, 'stream, HostAndDeviceConstRef<'_, DeviceAccessible<<T as RustToCuda>::CudaRepresentation>>>) -> Result<O, E>,
T: Sync,
Lends an immutable copy of
&self
to CUDA: Read more