pub struct CartesianTransform { /* private fields */ }
Expand description
Interpretate the origin as with cartesian coordinates and apply transformations. May permute the dimensions if they have same side. May complement the dimensions. Order of composition is: multiplier, shift, permute, complement, project, randomize, pattern. If you need another order you may compose several of them.
Example configuration:
ⓘ
CartesianTransform{
sides: [4,8,8],
multiplier: [1,1,1],//optional
shift: [0,4,0],//optional
permute: [0,2,1],//optional
complement: [false,true,false],//optional
project: [false,false,false],//optional
//random: [false,false,true],//optional
//patterns: [Identity,Identity,Circulant{generators:[1,-1]}]//optional
legend_name: "Some lineal transformation over a 8x8 mesh with 4 servers per router",
}
Trait Implementations§
Source§impl Debug for CartesianTransform
impl Debug for CartesianTransform
Source§impl Pattern for CartesianTransform
impl Pattern for CartesianTransform
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 CartesianTransform
impl Quantifiable for CartesianTransform
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 CartesianTransform
impl !RefUnwindSafe for CartesianTransform
impl !Send for CartesianTransform
impl !Sync for CartesianTransform
impl Unpin for CartesianTransform
impl !UnwindSafe for CartesianTransform
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