pub struct CsrIndex { /* private fields */ }Expand description
Dense integer CSR adjacency index.
Implementations§
Source§impl CsrIndex
impl CsrIndex
pub fn new() -> Self
Sourcepub fn add_edge(&mut self, src: &str, label: &str, dst: &str)
pub fn add_edge(&mut self, src: &str, label: &str, dst: &str)
Add an edge (goes into mutable buffer). Deduplicates.
Sourcepub fn remove_edge(&mut self, src: &str, label: &str, dst: &str)
pub fn remove_edge(&mut self, src: &str, label: &str, dst: &str)
Remove an edge.
Sourcepub fn neighbors(
&self,
node: &str,
label_filter: Option<&str>,
direction: Direction,
) -> Vec<(String, String)>
pub fn neighbors( &self, node: &str, label_filter: Option<&str>, direction: Direction, ) -> Vec<(String, String)>
Get immediate neighbors.
Sourcepub fn neighbors_multi(
&self,
node: &str,
label_filters: &[&str],
direction: Direction,
) -> Vec<(String, String)>
pub fn neighbors_multi( &self, node: &str, label_filters: &[&str], direction: Direction, ) -> Vec<(String, String)>
Get neighbors with multi-label filter. Empty labels = all edges.
pub fn node_count(&self) -> usize
pub fn contains_node(&self, node: &str) -> bool
Sourcepub fn edge_count(&self) -> usize
pub fn edge_count(&self) -> usize
Total edge count (dense + buffer - deleted).
Sourcepub fn estimated_memory_bytes(&self) -> usize
pub fn estimated_memory_bytes(&self) -> usize
Estimated memory usage in bytes.
Source§impl CsrIndex
impl CsrIndex
Sourcepub fn traverse_bfs(
&self,
start_nodes: &[&str],
label_filter: Option<&str>,
direction: Direction,
max_depth: usize,
max_visited: usize,
) -> Vec<String>
pub fn traverse_bfs( &self, start_nodes: &[&str], label_filter: Option<&str>, direction: Direction, max_depth: usize, max_visited: usize, ) -> Vec<String>
BFS traversal. Returns all reachable node IDs within max_depth hops.
max_visited caps the number of nodes visited to prevent supernode fan-out
explosion. Pass DEFAULT_MAX_VISITED for the standard limit.
Sourcepub fn traverse_bfs_with_depth(
&self,
start_nodes: &[&str],
label_filter: Option<&str>,
direction: Direction,
max_depth: usize,
max_visited: usize,
) -> Vec<(String, u8)>
pub fn traverse_bfs_with_depth( &self, start_nodes: &[&str], label_filter: Option<&str>, direction: Direction, max_depth: usize, max_visited: usize, ) -> Vec<(String, u8)>
BFS traversal returning nodes with depth information.
max_visited caps the number of nodes visited to prevent supernode fan-out
explosion. Pass DEFAULT_MAX_VISITED for the standard limit.
Sourcepub fn traverse_bfs_with_depth_multi(
&self,
start_nodes: &[&str],
label_filters: &[&str],
direction: Direction,
max_depth: usize,
max_visited: usize,
) -> Vec<(String, u8)>
pub fn traverse_bfs_with_depth_multi( &self, start_nodes: &[&str], label_filters: &[&str], direction: Direction, max_depth: usize, max_visited: usize, ) -> Vec<(String, u8)>
BFS traversal with multi-label filter. Empty labels = all edges.
max_visited caps the number of nodes visited to prevent supernode fan-out
explosion. Pass DEFAULT_MAX_VISITED for the standard limit.
Sourcepub fn shortest_path(
&self,
src: &str,
dst: &str,
label_filter: Option<&str>,
max_depth: usize,
max_visited: usize,
) -> Option<Vec<String>>
pub fn shortest_path( &self, src: &str, dst: &str, label_filter: Option<&str>, max_depth: usize, max_visited: usize, ) -> Option<Vec<String>>
Shortest path via bidirectional BFS.
max_visited caps the combined forward+backward visited set to prevent
supernode fan-out explosion. Pass DEFAULT_MAX_VISITED for the standard limit.
Sourcepub fn subgraph(
&self,
start_nodes: &[&str],
label_filter: Option<&str>,
max_depth: usize,
max_visited: usize,
) -> Vec<(String, String, String)>
pub fn subgraph( &self, start_nodes: &[&str], label_filter: Option<&str>, max_depth: usize, max_visited: usize, ) -> Vec<(String, String, String)>
Materialize a subgraph as edge tuples within max_depth.
max_visited caps the number of nodes visited to prevent supernode fan-out
explosion. Pass DEFAULT_MAX_VISITED for the standard limit.
Trait Implementations§
Auto Trait Implementations§
impl Freeze for CsrIndex
impl RefUnwindSafe for CsrIndex
impl Send for CsrIndex
impl Sync for CsrIndex
impl Unpin for CsrIndex
impl UnsafeUnpin for CsrIndex
impl UnwindSafe for CsrIndex
Blanket Implementations§
Source§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
Source§type ArchivedMetadata = ()
type ArchivedMetadata = ()
Source§fn pointer_metadata(
_: &<T as ArchivePointee>::ArchivedMetadata,
) -> <T as Pointee>::Metadata
fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata
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
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> LayoutRaw for T
impl<T> LayoutRaw for T
Source§fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
Source§impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
Source§unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
Source§fn resolve_niched(out: Place<NichedOption<T, N1>>)
fn resolve_niched(out: Place<NichedOption<T, N1>>)
out indicating that a T is niched.