pub struct UniformDistance { /* private fields */ }
Expand description
Each message gets its destination sampled uniformly at random among the servers attached to neighbour routers.
It may build a pattern either of servers or switches, controlled through the switch_level
configuration flag.
This pattern autoscales if requested a size multiple of the network size.
Example configuration:
ⓘ
UniformDistance{
///The distance at which the destination must be from the source.
distance: 1,
/// Optionally build the pattern at the switches. This should be irrelevant at direct network with the same number of servers per switch.
//switch_level: true,
legend_name: "uniform among neighbours",
}
Trait Implementations§
Source§impl Debug for UniformDistance
impl Debug for UniformDistance
Source§impl Pattern for UniformDistance
impl Pattern for UniformDistance
Source§fn initialize(
&mut self,
source_size: usize,
target_size: usize,
topology: &dyn Topology,
_rng: &mut StdRng,
)
fn initialize( &mut self, source_size: usize, target_size: usize, topology: &dyn Topology, _rng: &mut StdRng, )
Fix the input and output size, providing the topology and random number generator.
Careful with using topology in sub-patterns. For example, it may be misleading to use the dragonfly topology when
building a pattern among groups or a pattern among the routers of a single group.
Even just a pattern of routers instead of a pattern of servers can lead to mistakes.
Read the documentation of the traffic or meta-pattern using the pattern to know what its their input and output.
Source§impl Quantifiable for UniformDistance
impl Quantifiable for UniformDistance
Source§fn total_memory(&self) -> usize
fn total_memory(&self) -> usize
Get the total memory currently being employed by the implementing type. Both stack and heap.
Source§fn print_memory_breakdown(&self)
fn print_memory_breakdown(&self)
Prints by stdout how much memory is used per component.
Source§fn forecast_total_memory(&self) -> usize
fn forecast_total_memory(&self) -> usize
Get an estimation on how much memory the type could reach during the simulation.
Auto Trait Implementations§
impl Freeze for UniformDistance
impl RefUnwindSafe for UniformDistance
impl Send for UniformDistance
impl Sync for UniformDistance
impl Unpin for UniformDistance
impl UnwindSafe for UniformDistance
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
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more