import networkx as nx
import matplotlib.pyplot as plt

# === Group Definitions ===
state_groups = {
    "Group 1": ["ME", "NH", "VT", "MA", "RI", "CT", "NY"],
    "Group 2": ["NJ", "DE", "MD", "PA", "VA", "WV", "OH"],
    "Group 3": ["NC", "SC", "GA", "FL", "AL", "TN", "KY"],
    "Group 4": ["MI", "IN", "IL", "WI", "MN", "IA", "MO"],
    "Group 5": ["NE", "KS", "OK", "TX", "AR", "LA", "MS"],
    "Group 6": ["MT", "WY", "CO", "NM", "UT", "ND", "SD"],
    "Group 7": ["ID", "NV", "CA", "OR", "WA", "AZ"]
}

group_colors = {
    "Group 1": '#A9A9A9',
    "Group 2": '#DDA0DD',
    "Group 3": '#6495ED',
    "Group 4": '#FF6347',
    "Group 5": '#20B2AA',
    "Group 6": '#9ACD32',
    "Group 7": '#DAA520'
}

state_to_group = {state: group for group, states in state_groups.items() for state in states}

# === Fixed Layout Positions ===
positions = {
    "WA": (1, 5), "MT": (3, 5), "ND": (4, 6), "MN": (5, 5), "WI": (6, 5), "MI": (7, 5),
    "VT": (10, 6), "NH": (11, 6), "ME": (12, 6), "MA": (11,5),
    "OR": (1, 4), "ID": (2, 4), "WY": (3,4), "NE": (4,4), "SD": (4, 5), "IA": (5, 4), "IL": (6, 4), "IN": (7, 4),
    "OH": (8, 4), "PA": (9, 4), "NY": (10, 5), "NJ": (10, 4), "CT": (11, 4), "RI": (12, 4),
    "CA": (0, 3), "NV": (1, 3), "UT": (2, 3), "CO": (3, 3), "KS": (4, 3), "MO": (5, 3),
    "KY": (7, 3), "WV": (8, 3), "VA": (8, 2), "MD": (9, 3), "DE": (10, 3),
    "AZ": (2, 2), "NM": (3, 2), "OK": (4, 2), "AR": (5, 2), "TN": (7, 2), "NC": (9, 1),
    "TX": (4, 1), "LA": (5, 1), "MS": (6, 1), "AL": (7, 1), "GA": (8, 1),
    "FL": (8, 0), "SC": (9, 0)
}

# === Manual Adjacency ===
manual_adjacency = {
    "AL": ["TN", "GA", "FL", "MS"], "AZ": ["CA", "NV", "UT", "NM"], "AR": ["MO", "TN", "MS", "LA", "TX", "OK"],
    "CA": ["OR", "NV", "AZ"], "CO": ["WY", "NE", "KS", "OK", "NM", "UT"], "CT": ["NY", "MA", "RI"],
    "DE": ["MD", "PA", "NJ"], "FL": ["GA", "AL"], "GA": ["TN", "NC", "SC", "FL", "AL"],
    "IA": ["MN", "WI", "IL", "MO", "NE", "SD"], "ID": ["MT", "WY", "UT", "NV", "WA", "OR"],
    "IL": ["WI", "IA", "MO", "KY", "IN"], "IN": ["MI", "OH", "KY", "IL"], "KS": ["NE", "MO", "OK", "CO"],
    "KY": ["IN", "OH", "WV", "VA", "TN", "MO", "IL"], "LA": ["TX", "AR", "MS"], "MA": ["RI", "CT", "NY", "VT", "NH"],
    "MD": ["VA", "PA", "DE", "WV"], "ME": ["NH"], "MI": ["OH", "IN", "WI"], "MN": ["ND", "SD", "IA", "WI"],
    "MO": ["IA", "IL", "KY", "TN", "AR", "KS", "NE"], "MS": ["LA", "AR", "TN", "AL"], "MT": ["ND", "SD", "WY", "ID"],
    "NC": ["VA", "SC", "GA", "TN"], "ND": ["SD", "MN", "MT"], "NE": ["SD", "IA", "MO", "KS", "CO", "WY"],
    "NH": ["ME", "MA", "VT"], "NJ": ["NY", "PA", "DE"], "NM": ["AZ", "CO", "OK", "TX"], "NV": ["ID", "UT", "AZ", "CA", "OR"],
    "NY": ["PA", "NJ", "CT", "MA", "VT"], "OH": ["PA", "WV", "KY", "IN", "MI"], "OK": ["KS", "MO", "AR", "TX", "NM", "CO"],
    "OR": ["WA", "ID", "NV", "CA"], "PA": ["NY", "NJ", "DE", "MD", "WV", "OH"], "RI": ["CT", "MA"],
    "SC": ["NC", "GA"], "SD": ["ND", "MN", "IA", "NE", "WY", "MT"], "TN": ["KY", "VA", "NC", "GA", "AL", "MS", "AR", "MO"],
    "TX": ["OK", "AR", "LA", "NM"], "UT": ["ID", "WY", "CO", "NM", "AZ", "NV"], "VA": ["NC", "TN", "KY", "WV", "MD"],
    "VT": ["NY", "NH", "MA"], "WA": ["ID", "OR"], "WI": ["MN", "IA", "IL", "MI"], "WV": ["OH", "PA", "MD", "VA", "KY"],
    "WY": ["MT", "SD", "NE", "CO", "UT", "ID"]
}

# === Build and Draw ===
G = nx.Graph()
G.add_nodes_from(positions)

# Add edges
for state, neighbors in manual_adjacency.items():
    for neighbor in neighbors:
        if state in positions and neighbor in positions:
            G.add_edge(state, neighbor)

# Assign node colors
node_colors = [group_colors.get(state_to_group.get(node, 'white'), 'white') for node in G.nodes]

# Draw
plt.figure(figsize=(12, 7))
nx.draw(G, pos=positions, with_labels=True,
        node_color=node_colors, edgecolors='black',
        node_size=1400, font_size=14, font_weight='bold')
#plt.title("US State Groups (Manual Adjacency & Fixed Layout)", fontsize=14)
plt.axis('off')
plt.savefig("us_states_group_graph2.pdf", dpi=300, bbox_inches='tight')
