pub struct GraphMetrics {
pub node_count: usize,
pub edge_count: usize,
pub density: f64,
pub cycle_count: usize,
pub top_hubs: Vec<(PathBuf, usize)>,
pub component_count: usize,
}Expand description
Graph metrics summary — re-exported from sdivi-graph for WASM embedders.
Summary metrics for a DependencyGraph.
§Examples
use sdivi_graph::dependency_graph::build_dependency_graph_from_edges;
use sdivi_graph::metrics::compute_metrics;
let dg = build_dependency_graph_from_edges(&[], &[]);
let m = compute_metrics(&dg);
assert_eq!(m.node_count, 0);
assert_eq!(m.edge_count, 0);Fields§
§node_count: usizeTotal number of nodes (source files).
edge_count: usizeTotal number of directed edges.
density: f64Graph density: edge_count / (node_count * (node_count - 1)).
Zero when node_count < 2.
cycle_count: usizeNumber of directed cycles detected via DFS; self-loops excluded.
top_hubs: Vec<(PathBuf, usize)>Nodes with the highest out-degree, sorted descending.
Contains at most TOP_HUB_COUNT entries.
component_count: usizeNumber of weakly connected components.
Trait Implementations§
Source§impl Clone for GraphMetrics
impl Clone for GraphMetrics
Source§fn clone(&self) -> GraphMetrics
fn clone(&self) -> GraphMetrics
Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreSource§impl Debug for GraphMetrics
impl Debug for GraphMetrics
Source§impl<'de> Deserialize<'de> for GraphMetrics
impl<'de> Deserialize<'de> for GraphMetrics
Source§fn deserialize<__D>(
__deserializer: __D,
) -> Result<GraphMetrics, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(
__deserializer: __D,
) -> Result<GraphMetrics, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
Source§impl PartialEq for GraphMetrics
impl PartialEq for GraphMetrics
Source§fn eq(&self, other: &GraphMetrics) -> bool
fn eq(&self, other: &GraphMetrics) -> bool
Tests for
self and other values to be equal, and is used by ==.Source§impl Serialize for GraphMetrics
impl Serialize for GraphMetrics
Source§fn serialize<__S>(
&self,
__serializer: __S,
) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>where
__S: Serializer,
fn serialize<__S>(
&self,
__serializer: __S,
) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>where
__S: Serializer,
Serialize this value into the given Serde serializer. Read more
impl StructuralPartialEq for GraphMetrics
Auto Trait Implementations§
impl Freeze for GraphMetrics
impl RefUnwindSafe for GraphMetrics
impl Send for GraphMetrics
impl Sync for GraphMetrics
impl Unpin for GraphMetrics
impl UnsafeUnpin for GraphMetrics
impl UnwindSafe for GraphMetrics
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