pub struct UndirectedGraph { /* private fields */ }Expand description
Undirected weighted graph for hardware topology and routing
Implementations§
Source§impl UndirectedGraph
impl UndirectedGraph
Sourcepub fn add_edge(&mut self, u: usize, v: usize, weight: f64)
pub fn add_edge(&mut self, u: usize, v: usize, weight: f64)
Add an undirected edge between u and v with the given weight
Sourcepub fn bfs(&self, start: usize) -> Vec<usize>
pub fn bfs(&self, start: usize) -> Vec<usize>
BFS traversal from start. Returns visited nodes in BFS order.
Sourcepub fn dfs(&self, start: usize) -> Vec<usize>
pub fn dfs(&self, start: usize) -> Vec<usize>
DFS traversal from start. Returns visited nodes in DFS order.
Sourcepub fn dijkstra_distances(&self, source: usize) -> HashMap<usize, f64>
pub fn dijkstra_distances(&self, source: usize) -> HashMap<usize, f64>
Dijkstra shortest path from source to all other nodes.
Returns a HashMap<usize, f64> mapping node index to minimum distance.
Unreachable nodes are absent from the map.
Weights are scaled to u64 (multiplied by 1e9) for use in the binary
heap, which requires Ord. This gives nanosecond precision and avoids
pulling in an ordered_float dependency.
Trait Implementations§
Source§impl Clone for UndirectedGraph
impl Clone for UndirectedGraph
Source§fn clone(&self) -> UndirectedGraph
fn clone(&self) -> UndirectedGraph
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreAuto Trait Implementations§
impl Freeze for UndirectedGraph
impl RefUnwindSafe for UndirectedGraph
impl Send for UndirectedGraph
impl Sync for UndirectedGraph
impl Unpin for UndirectedGraph
impl UnsafeUnpin for UndirectedGraph
impl UnwindSafe for UndirectedGraph
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> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
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 moreSource§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<T> PolicyExt for Twhere
T: ?Sized,
impl<T> PolicyExt for Twhere
T: ?Sized,
Source§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
Source§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
The inverse inclusion map: attempts to construct
self from the equivalent element of its
superset. Read moreSource§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
Checks if
self is actually part of its subset T (and can be converted to it).Source§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
Use with care! Same as
self.to_subset but without any property checks. Always succeeds.Source§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
The inclusion map: converts
self to the equivalent element of its superset.