Skip to main content

ComponentFailureTree

Struct ComponentFailureTree 

Source
pub struct ComponentFailureTree {
    pub root: FailureNode,
    pub minimal_cuts: Vec<Vec<usize>>,
    pub num_edges: usize,
    pub num_nodes: usize,
}
Expand description

Ball-tree style structure for enumerating component failure modes.

Builds a tree where each level introduces one additional edge failure. The tree branches at each node for each remaining edge that could fail. This is useful for computing minimal cuts and identifying the most likely failure scenarios.

Fields§

§root: FailureNode

Root of the failure tree.

§minimal_cuts: Vec<Vec<usize>>

All minimal cuts found during tree construction.

§num_edges: usize

Number of edges.

§num_nodes: usize

Number of nodes.

Implementations§

Source§

impl ComponentFailureTree

Source

pub fn build(adj: &Array2<f64>, max_depth: usize) -> Result<Self>

Build the component failure tree for a network up to max_depth edge failures.

§Arguments
  • adj — weighted adjacency matrix.
  • max_depth — maximum number of simultaneous edge failures to consider.

max_depth should be kept small (≤ 5) for efficiency.

Source

pub fn minimal_cuts(&self) -> &[Vec<usize>]

Return all minimal cuts found during tree construction.

Source

pub fn unreliability_upper_bound(&self) -> f64

Compute total probability of disconnection up to max_depth failures.

This sums probabilities of all failure sets that are cuts, but avoids double-counting by only summing minimal cuts’ exact set probabilities.

Trait Implementations§

Source§

impl Debug for ComponentFailureTree

Source§

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

Formats the value using the given formatter. Read more

Auto Trait Implementations§

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
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> IntoEither for T

Source§

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 more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

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
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

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

Source§

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>,

Source§

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.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V