import matplotlib.pyplot as plt
import networkx as nx
import numpy as np

def plot_save_hypergraph(edges, k, lambda_param, min_subset_size, max_subset_size, k_hop, path):
    """
    Plot a hypergraph based on Densest Overlapping subgraphs using matplotlib
    
    Args:
        edges (Dictionary): A dictionary that contains subgraph's name as a key and set of nodes as a value
        k (int): Number of subgraphs
        lambda_param (float): Lambda parameter
        min_subset_size (int): Minimum subset size
        max_subset_size (int): Maximum subset size
        k_hop (int): K-hop parameter
        path (str): Path to save the plot
        
    Returns:
        A hypergraph plot as a matplotlib figure
    """
    
    # Create a simple visualization of the hypergraph
    fig, ax = plt.subplots(figsize=(10, 8))
    
    # Get all unique nodes
    all_nodes = set()
    for nodes in edges.values():
        all_nodes.update(nodes)
    
    # Create positions for nodes in a circle
    n_nodes = len(all_nodes)
    node_positions = {}
    for i, node in enumerate(all_nodes):
        angle = 2 * np.pi * i / n_nodes
        x = np.cos(angle)
        y = np.sin(angle)
        node_positions[node] = (x, y)
    
    # Draw nodes
    for node, pos in node_positions.items():
        ax.scatter(pos[0], pos[1], c='blue', s=100, zorder=3)
        ax.annotate(str(node), (pos[0], pos[1]), xytext=(5, 5), 
                   textcoords='offset points', fontsize=8)
    
    # Draw hyperedges as colored regions
    colors = plt.cm.Set3(np.linspace(0, 1, len(edges)))
    
    for i, (name, nodes) in enumerate(edges.items()):
        if len(nodes) > 0:
            # Create convex hull of nodes in this hyperedge
            points = np.array([node_positions[node] for node in nodes])
            if len(points) >= 3:
                from scipy.spatial import ConvexHull
                try:
                    hull = ConvexHull(points)
                    hull_points = points[hull.vertices]
                    # Close the polygon
                    hull_points = np.vstack([hull_points, hull_points[0]])
                    ax.fill(hull_points[:, 0], hull_points[:, 1], 
                           alpha=0.3, color=colors[i], label=f'Subgraph {i+1}')
                except:
                    # Fallback if convex hull fails
                    ax.scatter(points[:, 0], points[:, 1], 
                             c=[colors[i]], s=50, alpha=0.5, marker='o')
            else:
                # For small hyperedges, just connect the nodes
                ax.scatter(points[:, 0], points[:, 1], 
                          c=[colors[i]], s=50, alpha=0.5, marker='o')
    
    ax.set_xlim(-1.2, 1.2)
    ax.set_ylim(-1.2, 1.2)
    ax.set_aspect('equal')
    ax.set_title(f"Hypergraph k={k}, λ={lambda_param}, min={min_subset_size}, max={max_subset_size}")
    ax.legend()
    ax.grid(True, alpha=0.3)
    
    plt.tight_layout()
    plt.savefig(f"{path}/hypergraph_minimum={min_subset_size}_maximum={max_subset_size}_hop={k_hop}.png", 
                dpi=300, bbox_inches='tight')
    plt.close()
