scirs2-graph 0.4.1

Graph processing module for SciRS2 (scirs2-graph)
Documentation
//! Simple Advanced Mode Validation
//!
//! This example demonstrates and validates basic Advanced mode functionality.

use scirs2_core::random::prelude::*;
use scirs2_graph::{
    algorithms::{connected_components, dijkstra_path},
    generators::erdos_renyi_graph,
    measures::pagerank_centrality,
    Result,
};
use std::time::Instant;

#[allow(dead_code)]
fn main() -> Result<()> {
    println!("๐Ÿงช Simple Advanced Mode Validation");
    println!("====================================");

    // Create a small test graph
    let mut rng = thread_rng();
    let graph = erdos_renyi_graph(100, 0.1, &mut rng)?;

    println!("โœ… Generated test graph:");
    println!("   - Nodes: {}", graph.node_count());
    println!("   - Edges: {}", graph.edge_count());

    // Create advanced processor
    // Advanced processor functionality is not available in this example
    // let mut processor = create_advanced_processor();
    // println!("๐Ÿš€ Advanced processor initialized");

    // Test 1: PageRank with advanced optimization
    println!("\n๐Ÿง  Test 1: PageRank Centrality");
    let start = Instant::now();
    let _pagerank_result = pagerank_centrality(&graph, 0.85, 1e-6)?;
    let duration = start.elapsed();
    println!("   โœ… Completed in {:?}", duration);

    // Test 2: Connected components with advanced optimization
    println!("\n๐Ÿ”— Test 2: Connected Components");
    let start = Instant::now();
    let _components = connected_components(&graph);
    let duration = start.elapsed();
    println!("   โœ… Completed in {:?}", duration);

    // Test 3: Shortest path with advanced optimization
    println!("\n๐Ÿ›ฃ๏ธ  Test 3: Shortest Path");
    let nodes: Vec<_> = graph.nodes().into_iter().collect();
    if nodes.len() >= 2 {
        let start = Instant::now();
        let _path_result = dijkstra_path(&graph, nodes[0], nodes[1])?;
        let duration = start.elapsed();
        println!("   โœ… Completed in {:?}", duration);
    }

    // Get optimization statistics
    // Note: Advanced processor functionality is not available in this example
    // let stats = processor.get_optimization_stats();
    println!("\n๐Ÿ“Š Optimization Statistics:");
    println!("   - Advanced mode not enabled in this example");
    // println!("   - Total optimizations: {}", stats.total_optimizations);
    // println!("   - Average speedup: {:.2}x", stats.average_speedup);
    // println!(
    //     "   - GPU utilization: {:.1}%",
    //     stats.gpu_utilization * 100.0
    // );
    // println!(
    //     "   - Memory efficiency: {:.1}%",
    //     stats.memory_efficiency * 100.0
    // );

    println!("\n๐ŸŽ‰ All advanced mode tests passed!");
    Ok(())
}