{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(100, 100) 7.12\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "import scipy.sparse as sp\n",
    "\n",
    "def set_seed(seed=0):\n",
    "    np.random.seed(seed)\n",
    "\n",
    "def _symmetrize_simple(W):\n",
    "    W = sp.triu(W, k=1)\n",
    "    W = W + W.T\n",
    "    W.setdiag(0)\n",
    "    W.eliminate_zeros()\n",
    "    return W.tocsr()\n",
    "\n",
    "def _build_er_upper(n, p):\n",
    "    \"\"\"Sample undirected ER on upper triangle.\"\"\"\n",
    "    # number of possible upper-tri edges\n",
    "    mmax = n * (n - 1) // 2\n",
    "    # sample boolean mask for edges\n",
    "    mask = np.random.rand(mmax) < p\n",
    "    # map linear index -> (i,j) in upper triangle\n",
    "    # construct row, col by walking rows\n",
    "    rows, cols = [], []\n",
    "    base = 0\n",
    "    for i in range(n - 1):\n",
    "        L = n - 1 - i\n",
    "        seg = mask[base:base + L]\n",
    "        js = np.where(seg)[0] + (i + 1)\n",
    "        if js.size:\n",
    "            rows.extend([i] * js.size)\n",
    "            cols.extend(js.tolist())\n",
    "        base += L\n",
    "    data = np.ones(len(rows), dtype=np.float64)\n",
    "    W = sp.csr_matrix((data, (np.array(rows), np.array(cols))), shape=(n, n))\n",
    "    return W\n",
    "\n",
    "def _thin_to_m(W, m_target, seed=None):\n",
    "    \"\"\"If too many edges, Bernoulli-thin the strictly upper triangle to reach target m.\"\"\"\n",
    "    if seed is not None:\n",
    "        rng = np.random.default_rng(seed)\n",
    "        rand = rng.random\n",
    "    else:\n",
    "        rand = np.random.random\n",
    "    W_ut = sp.triu(W, k=1).tocoo()\n",
    "    m_now = W_ut.nnz\n",
    "    if m_now <= m_target:\n",
    "        return W\n",
    "    keep_prob = m_target / float(m_now)\n",
    "    keep = rand(m_now) < keep_prob\n",
    "    W_ut2 = sp.coo_matrix((W_ut.data[keep], (W_ut.row[keep], W_ut.col[keep])), shape=W.shape).tocsr()\n",
    "    return _symmetrize_simple(W_ut2)\n",
    "\n",
    "def _add_until_m(W, m_target, seed=None, max_trials=10):\n",
    "    \"\"\"If too few edges, add random missing edges until we reach m_target (upper triangle).\"\"\"\n",
    "    if seed is not None:\n",
    "        rng = np.random.default_rng(seed)\n",
    "        randint = rng.integers\n",
    "    else:\n",
    "        randint = np.random.randint\n",
    "\n",
    "    n = W.shape[0]\n",
    "    W_ut = sp.triu(W, k=1).tocsr()\n",
    "    m_now = W_ut.nnz\n",
    "    need = m_target - m_now\n",
    "    if need <= 0:\n",
    "        return _symmetrize_simple(W_ut)\n",
    "\n",
    "    # use a set to track existing upper-tri edges\n",
    "    W_ut = W_ut.tocoo()\n",
    "    exist = set(zip(W_ut.row.tolist(), W_ut.col.tolist()))\n",
    "    added = 0\n",
    "    tries = 0\n",
    "    rows, cols = [W_ut.row.copy()], [W_ut.col.copy()]  # start with existing\n",
    "    while added < need and tries < max_trials * need:\n",
    "        i = int(randint(0, n - 1))\n",
    "        j = int(randint(i + 1, n)) if i < n - 1 else i  # ensure j>i\n",
    "        if i == j:\n",
    "            continue\n",
    "        e = (i, j)\n",
    "        if e not in exist:\n",
    "            exist.add(e)\n",
    "            rows.append(np.array([i], dtype=int))\n",
    "            cols.append(np.array([j], dtype=int))\n",
    "            added += 1\n",
    "        tries += 1\n",
    "\n",
    "    row_all = np.concatenate(rows) if rows else np.array([], dtype=int)\n",
    "    col_all = np.concatenate(cols) if cols else np.array([], dtype=int)\n",
    "    data = np.ones_like(row_all, dtype=np.float64)\n",
    "    W_ut2 = sp.csr_matrix((data, (row_all, col_all)), shape=(n, n))\n",
    "    return _symmetrize_simple(W_ut2)\n",
    "\n",
    "def generate_sparse_graph(\n",
    "    n=500,\n",
    "    avg_deg=7.0,          # target average degree (≈ 7 or 8 as you want)\n",
    "    d_feat=8,             # feature dimension\n",
    "    K=3,                  # number of labels/classes\n",
    "    seed=0\n",
    "):\n",
    "    \"\"\"\n",
    "    No hub/spoke. Simple sparse random graph with target average degree.\n",
    "    Returns:\n",
    "        W  : scipy.sparse CSR adjacency (undirected, simple)\n",
    "        X  : np.ndarray [n, d_feat] features (standard normal)\n",
    "        y  : np.ndarray [n] labels (uniform random in {0..K-1})\n",
    "    \"\"\"\n",
    "    set_seed(seed)\n",
    "    n = int(n)\n",
    "    avg_deg = float(avg_deg)\n",
    "    m_target = int(round(n * avg_deg / 2.0))  # undirected edges target\n",
    "    p = min(1.0, avg_deg / max(1, n - 1))     # ER probability\n",
    "\n",
    "    # 1) sample ER upper triangle\n",
    "    W_ut = _build_er_upper(n, p)\n",
    "    W = _symmetrize_simple(W_ut)\n",
    "\n",
    "    # 2) adjust edge count to hit target avg degree\n",
    "    m_now = sp.triu(W, k=1).nnz\n",
    "    if m_now > m_target:\n",
    "        W = _thin_to_m(W, m_target, seed=seed)\n",
    "    elif m_now < m_target:\n",
    "        W = _add_until_m(W, m_target, seed=seed)\n",
    "\n",
    "    # 3) features and labels (no structure required)\n",
    "    X = np.random.randn(n, d_feat).astype(np.float64)\n",
    "    labels = np.random.randint(0, K, size=n, dtype=int)\n",
    "\n",
    "    return W.tocsr(), X, labels\n",
    "W, X, labels = generate_sparse_graph(n=100, avg_deg=7, d_feat=16, K=4, seed=42)\n",
    "# If you really need COO:\n",
    "# W = W.tocoo()\n",
    "print(W.shape, W.nnz // 2 * 2 / W.shape[0])  # ~ avg degree\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "from torch_geometric.loader import DataLoader\n",
    "from torch_geometric.datasets import TUDataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Requirement already satisfied: faiss-cpu in /home/accl-ros/anaconda3/envs/myenv/lib/python3.12/site-packages (1.12.0)\n",
      "Requirement already satisfied: numpy<3.0,>=1.25.0 in /home/accl-ros/anaconda3/envs/myenv/lib/python3.12/site-packages (from faiss-cpu) (1.26.4)\n",
      "Requirement already satisfied: packaging in /home/accl-ros/anaconda3/envs/myenv/lib/python3.12/site-packages (from faiss-cpu) (24.1)\n",
      "Note: you may need to restart the kernel to use updated packages.\n"
     ]
    }
   ],
   "source": [
    "pip install faiss-cpu"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[31mERROR: Could not find a version that satisfies the requirement faiss-gpu (from versions: none)\u001b[0m\u001b[31m\n",
      "\u001b[0m\u001b[31mERROR: No matching distribution found for faiss-gpu\u001b[0m\u001b[31m\n",
      "\u001b[0mNote: you may need to restart the kernel to use updated packages.\n"
     ]
    }
   ],
   "source": [
    "pip install faiss-gpu"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "alpha used: [0.5 0.5]\n",
      "Shapes: W_topo (500, 500) | L_mix (500, 500) | Z (500, 32) | M_C nnz = 243082\n"
     ]
    }
   ],
   "source": [
    "# heterophily_mc.py\n",
    "# Minimal, dependency-light reference implementation to:\n",
    "# - build a heterophilous graph\n",
    "# - construct multi-view Laplacians (topology + feature)\n",
    "# - mix them\n",
    "# - compute a heat-kernel diffusion embedding\n",
    "# - build the incompatibility matrix M_C up to Eq. (4) in your algorithm\n",
    "\n",
    "import numpy as np\n",
    "import scipy.sparse as sp\n",
    "import scipy.sparse.linalg as spla\n",
    "from scipy.special import iv as bessel_I  # modified Bessel (first kind)\n",
    "\n",
    "# Optional FAISS kNN (falls back automatically if not present)\n",
    "try:\n",
    "    import faiss  # type: ignore\n",
    "    _HAS_FAISS = True\n",
    "except Exception:\n",
    "    _HAS_FAISS = False\n",
    "\n",
    "# Optional sklearn (falls back to pure numpy if not present)\n",
    "try:\n",
    "    from sklearn.neighbors import NearestNeighbors\n",
    "    _HAS_SKLEARN = True\n",
    "except Exception:\n",
    "    _HAS_SKLEARN = False\n",
    "\n",
    "\n",
    "# ---------------------------\n",
    "# 0) Utilities\n",
    "# ---------------------------\n",
    "\n",
    "def set_seed(seed=0):\n",
    "    np.random.seed(seed)\n",
    "\n",
    "def softmax(x):\n",
    "    x = np.asarray(x, dtype=np.float64)\n",
    "    x = x - x.max()\n",
    "    ex = np.exp(x)\n",
    "    return ex / (ex.sum() + 1e-12)\n",
    "\n",
    "def row_norm_(X, eps=1e-12):\n",
    "    nrm = np.linalg.norm(X, axis=1, keepdims=True)\n",
    "    nrm = np.maximum(nrm, eps)\n",
    "    X /= nrm\n",
    "    return X\n",
    "\n",
    "def to_csr(W):\n",
    "    return W if sp.isspmatrix_csr(W) else sp.csr_matrix(W)\n",
    "\n",
    "\n",
    "# ---------------------------\n",
    "# 1) Heterophilous graph generator (A, B spokes + big hub H)\n",
    "# ---------------------------\n",
    "\n",
    "def generate_heterophilous_graph(\n",
    "    nA=60, nB=60, nH=380,\n",
    "    p_AA=0.02, p_BB=0.02, p_HH=0.05,\n",
    "    p_AH=0.15, p_BH=0.15, p_AB=0.01,\n",
    "    d_feat=8, mu=2.0, seed=0\n",
    "):\n",
    "    \"\"\"\n",
    "    Build a 3-block SBM with strong spokes->hub connectivity and weak spoke intra-connectivity,\n",
    "    plus features that are *anti-correlated* to the topology (heterophily).\n",
    "    \"\"\"\n",
    "    set_seed(seed)\n",
    "    n = nA + nB + nH\n",
    "    idxA = np.arange(0, nA)\n",
    "    idxB = np.arange(nA, nA + nB)\n",
    "    idxH = np.arange(nA + nB, n)\n",
    "\n",
    "    # Block connection probabilities\n",
    "    P = np.zeros((3, 3))\n",
    "    P[0, 0] = p_AA; P[1, 1] = p_BB; P[2, 2] = p_HH\n",
    "    P[0, 1] = p_AB; P[1, 0] = p_AB\n",
    "    P[0, 2] = p_AH; P[2, 0] = p_AH\n",
    "    P[1, 2] = p_BH; P[2, 1] = p_BH\n",
    "\n",
    "    block_sizes = [nA, nB, nH]\n",
    "    cum = np.cumsum([0] + block_sizes)\n",
    "    blocks = [np.arange(cum[i], cum[i+1]) for i in range(3)]\n",
    "\n",
    "    # Sample adjacency (undirected, no self-loops)\n",
    "    rows, cols = [], []\n",
    "    for bi in range(3):\n",
    "        for bj in range(bi, 3):\n",
    "            Ii, Ij = blocks[bi], blocks[bj]\n",
    "            if bi == bj:\n",
    "                # upper triangle only, then mirror\n",
    "                tri = np.triu(np.random.rand(len(Ii), len(Ij)) < P[bi, bj], k=1)\n",
    "                r, c = np.where(tri)\n",
    "                rows.extend(Ii[r]); cols.extend(Ij[c])\n",
    "            else:\n",
    "                mask = (np.random.rand(len(Ii), len(Ij)) < P[bi, bj])\n",
    "                r, c = np.where(mask)\n",
    "                rows.extend(Ii[r]); cols.extend(Ij[c])\n",
    "    rows = np.array(rows); cols = np.array(cols)\n",
    "    data = np.ones_like(rows, dtype=np.float64)\n",
    "\n",
    "    W = sp.csr_matrix((data, (rows, cols)), shape=(n, n))\n",
    "    W = W + W.T  # symmetrize\n",
    "    W.setdiag(0)\n",
    "    W.eliminate_zeros()\n",
    "\n",
    "    # Features: A ~ N(+mu, I), B ~ N(-mu, I), H ~ N(0, I)\n",
    "    X = np.zeros((n, d_feat), dtype=np.float64)\n",
    "    X[idxA] = mu + np.random.randn(nA, d_feat)\n",
    "    X[idxB] = -mu + np.random.randn(nB, d_feat)\n",
    "    X[idxH] = np.random.randn(nH, d_feat)\n",
    "\n",
    "    labels = np.zeros(n, dtype=int)\n",
    "    labels[idxA] = 0; labels[idxB] = 1; labels[idxH] = 2\n",
    "\n",
    "    return W.tocsr(), X, labels, (idxA, idxB, idxH)\n",
    "\n",
    "import numpy as np\n",
    "import scipy.sparse as sp\n",
    "\n",
    "def set_seed(seed=0):\n",
    "    np.random.seed(seed)\n",
    "\n",
    "def _thin_undirected_csr(W: sp.csr_matrix, keep_prob: float, seed: int | None = None) -> sp.csr_matrix:\n",
    "    \"\"\"\n",
    "    Symmetric Bernoulli thinning on undirected simple graph.\n",
    "    Applies mask on strictly upper triangle, then mirrors.\n",
    "    \"\"\"\n",
    "    if seed is not None:\n",
    "        rng = np.random.default_rng(seed)\n",
    "        rand = rng.random\n",
    "    else:\n",
    "        rand = np.random.random\n",
    "\n",
    "    W = sp.triu(W, k=1).tocoo()\n",
    "    if keep_prob >= 1.0:\n",
    "        # Just re-symmetrize and return\n",
    "        W = W.tocsr()\n",
    "        W = W + W.T\n",
    "        return W\n",
    "\n",
    "    m = W.data.shape[0]\n",
    "    mask = rand(m) < keep_prob\n",
    "    W_thin = sp.coo_matrix((W.data[mask], (W.row[mask], W.col[mask])), shape=W.shape).tocsr()\n",
    "    W_thin = W_thin + W_thin.T\n",
    "    W_thin.setdiag(0)\n",
    "    W_thin.eliminate_zeros()\n",
    "    return W_thin\n",
    "\n",
    "def generate_heterophilous_graph(\n",
    "    nA=60, nB=60, nH=380,\n",
    "    p_AA=0.02, p_BB=0.02, p_HH=0.05,\n",
    "    p_AH=0.15, p_BH=0.15, p_AB=0.01,\n",
    "    d_feat=8, mu=2.0, seed=0,\n",
    "    prob_scale: float = 1.0,            # <-- NEW: global probability scaler (<=1 for sparser)\n",
    "    target_avg_deg: float | None = None # <-- NEW: optional avg-degree target via thinning\n",
    "):\n",
    "    \"\"\"\n",
    "    Build a 3-block SBM with spoke–hub heterophily and *sparser* control.\n",
    "\n",
    "    Controls:\n",
    "      - prob_scale in (0,1]: multiplies all base block probabilities\n",
    "      - target_avg_deg: if set, thin the final undirected graph to reach this average degree in expectation\n",
    "    \"\"\"\n",
    "    set_seed(seed)\n",
    "    n = nA + nB + nH\n",
    "    idxA = np.arange(0, nA)\n",
    "    idxB = np.arange(nA, nA + nB)\n",
    "    idxH = np.arange(nA + nB, n)\n",
    "\n",
    "    # Block connection probabilities (apply global sparsity scale)\n",
    "    P = np.zeros((3, 3), dtype=float)\n",
    "    P[0, 0] = p_AA; P[1, 1] = p_BB; P[2, 2] = p_HH\n",
    "    P[0, 1] = p_AB; P[1, 0] = p_AB\n",
    "    P[0, 2] = p_AH; P[2, 0] = p_AH\n",
    "    P[1, 2] = p_BH; P[2, 1] = p_BH\n",
    "    prob_scale = float(prob_scale)\n",
    "    if prob_scale <= 0:\n",
    "        raise ValueError(\"prob_scale must be > 0\")\n",
    "    P = np.clip(P * prob_scale, 0.0, 1.0)\n",
    "\n",
    "    block_sizes = [nA, nB, nH]\n",
    "    cum = np.cumsum([0] + block_sizes)\n",
    "    blocks = [np.arange(cum[i], cum[i+1]) for i in range(3)]\n",
    "\n",
    "    # Sample adjacency (undirected, no self-loops)\n",
    "    rows, cols = [], []\n",
    "    for bi in range(3):\n",
    "        for bj in range(bi, 3):\n",
    "            Ii, Ij = blocks[bi], blocks[bj]\n",
    "            if bi == bj:\n",
    "                # upper triangle only, then mirror\n",
    "                tri = np.triu(np.random.rand(len(Ii), len(Ij)) < P[bi, bj], k=1)\n",
    "                r, c = np.where(tri)\n",
    "                rows.extend(Ii[r]); cols.extend(Ij[c])\n",
    "            else:\n",
    "                mask = (np.random.rand(len(Ii), len(Ij)) < P[bi, bj])\n",
    "                r, c = np.where(mask)\n",
    "                rows.extend(Ii[r]); cols.extend(Ij[c])\n",
    "\n",
    "    rows = np.array(rows); cols = np.array(cols)\n",
    "    data = np.ones_like(rows, dtype=np.float64)\n",
    "    W = sp.csr_matrix((data, (rows, cols)), shape=(n, n))\n",
    "    W = W + W.T\n",
    "    W.setdiag(0)\n",
    "    W.eliminate_zeros()\n",
    "\n",
    "    # Optional: thin edges to hit target average degree\n",
    "    if target_avg_deg is not None:\n",
    "        d = np.asarray(W.sum(axis=1)).ravel()\n",
    "        cur_avg_deg = float(d.mean()) if d.size > 0 else 0.0\n",
    "        if cur_avg_deg > 1e-12 and target_avg_deg < cur_avg_deg:\n",
    "            keep_prob = max(0.0, min(1.0, target_avg_deg / cur_avg_deg))\n",
    "            W = _thin_undirected_csr(W, keep_prob=keep_prob, seed=seed)\n",
    "        # if target >= current, we keep as-is (already sparse enough)\n",
    "\n",
    "    # Features: A ~ N(+mu, I), B ~ N(-mu, I), H ~ N(0, I)\n",
    "    X = np.zeros((n, d_feat), dtype=np.float64)\n",
    "    X[idxA] = mu + np.random.randn(nA, d_feat)\n",
    "    X[idxB] = -mu + np.random.randn(nB, d_feat)\n",
    "    X[idxH] = np.random.randn(nH, d_feat)\n",
    "\n",
    "    labels = np.zeros(n, dtype=int)\n",
    "    labels[idxA] = 0; labels[idxB] = 1; labels[idxH] = 2\n",
    "\n",
    "    return W.tocsr(), X, labels, (idxA, idxB, idxH)\n",
    "\n",
    "# ---------------------------\n",
    "# 2) Laplacians\n",
    "# ---------------------------\n",
    "\n",
    "def normalized_laplacian(W: sp.csr_matrix):\n",
    "    \"\"\" L = I - D^{-1/2} W D^{-1/2} \"\"\"\n",
    "    W = to_csr(W)\n",
    "    d = np.asarray(W.sum(axis=1)).ravel()\n",
    "    d_safe = np.maximum(d, 1e-12)\n",
    "    Dinv_sqrt = sp.diags(1.0 / np.sqrt(d_safe))\n",
    "    N = W.shape[0]\n",
    "    L = sp.eye(N, format='csr') - Dinv_sqrt @ W @ Dinv_sqrt\n",
    "    return L, d\n",
    "\n",
    "\n",
    "def _knn_indices_faiss(X, k):\n",
    "    \"\"\"kNN (indices, distances) using FAISS (L2).\"\"\"\n",
    "    Xf = X.astype(np.float32).copy()\n",
    "    index = faiss.IndexFlatL2(Xf.shape[1])\n",
    "    index.add(Xf)\n",
    "    D, I = index.search(Xf, k+1)   # include self\n",
    "    return I[:, 1:], D[:, 1:]      # drop self\n",
    "\n",
    "def _knn_indices_sklearn(X, k):\n",
    "    nbrs = NearestNeighbors(n_neighbors=k+1, algorithm='auto', metric='euclidean').fit(X)\n",
    "    D, I = nbrs.kneighbors(X)\n",
    "    return I[:, 1:], D[:, 1:]\n",
    "\n",
    "def _knn_indices_numpy(X, k):\n",
    "    # exact pairwise distances; O(n^2) but works without sklearn/faiss\n",
    "    G = np.sum(X**2, axis=1, keepdims=True)\n",
    "    D2 = G + G.T - 2*X@X.T\n",
    "    np.fill_diagonal(D2, np.inf)\n",
    "    I = np.argpartition(D2, kth=k, axis=1)[:, :k]\n",
    "    # sort within top-k for consistency\n",
    "    row_idx = np.arange(X.shape[0])[:, None]\n",
    "    Dsel = D2[row_idx, I]\n",
    "    order = np.argsort(Dsel, axis=1)\n",
    "    I_sorted = I[row_idx, order]\n",
    "    D_sorted = np.sqrt(np.sort(Dsel, axis=1))\n",
    "    return I_sorted, D_sorted\n",
    "\n",
    "def knn_indices(X, k):\n",
    "    \n",
    "        return _knn_indices_faiss(X, k)\n",
    "    \n",
    "\n",
    "def feature_knn_graph(X, k=15, sigma=None):\n",
    "    \"\"\"\n",
    "    Build W_feat from kNN in feature space with heat weights:\n",
    "    w_ij = exp(-||xi-xj||^2 / (2*sigma^2)) for j in Nk(i).\n",
    "    Symmetrize by max.\n",
    "    \"\"\"\n",
    "    n = X.shape[0]\n",
    "    I, D = knn_indices(X, k)\n",
    "    if sigma is None:\n",
    "        # median neighbor distance across all pairs\n",
    "        sigma = np.median(D)\n",
    "    sigma = max(float(sigma), 1e-12)\n",
    "\n",
    "    rows = np.repeat(np.arange(n), k)\n",
    "    cols = I.reshape(-1)\n",
    "    d2 = (D.reshape(-1))**2\n",
    "    weights = np.exp(-d2 / (2.0 * sigma**2))\n",
    "\n",
    "    W = sp.csr_matrix((weights, (rows, cols)), shape=(n, n))\n",
    "    # Symmetrize using max to preserve strong one-sided links\n",
    "    W = W.maximum(W.T)\n",
    "    W.setdiag(0)\n",
    "    W.eliminate_zeros()\n",
    "    return W\n",
    "\n",
    "def build_L_feat_from_features(X, k=15, sigma=None):\n",
    "    Wf = feature_knn_graph(X, k=k, sigma=sigma)\n",
    "    Lf, d_feat = normalized_laplacian(Wf)\n",
    "    return Lf, Wf, d_feat\n",
    "\n",
    "\n",
    "# ---------------------------\n",
    "# 3) Mixed Laplacian L_mix,C  (here C is the full graph, level ℓ=1)\n",
    "# ---------------------------\n",
    "\n",
    "def mix_laplacian(L_top, L_feat, alpha=None):\n",
    "    \"\"\"\n",
    "    L_mix = α1 * L_top + α2 * L_feat\n",
    "    If alpha is None => equal weights (softmax([0,0]) = [0.5,0.5]).\n",
    "    \"\"\"\n",
    "    if alpha is None:\n",
    "        alpha = softmax([0.0, 0.0])  # (0.5, 0.5)\n",
    "    alpha = np.asarray(alpha, dtype=np.float64)\n",
    "    assert len(alpha) == 2 and np.isclose(alpha.sum(), 1.0)\n",
    "    return alpha[0] * L_top + alpha[1] * L_feat, alpha\n",
    "\n",
    "\n",
    "# ---------------------------\n",
    "# 4) Heat-kernel: Y = exp(-t L) @ Omega via Chebyshev (default) or expm_multiply\n",
    "# ---------------------------\n",
    "\n",
    "def heat_kernel_apply(L: sp.csr_matrix, t=0.5, Omega=None, order=30, method=\"chebyshev\"):\n",
    "    \"\"\"\n",
    "    Compute H*Omega where H = exp(-t L), using either:\n",
    "      - \"chebyshev\": truncated Chebyshev expansion (default)\n",
    "      - \"expm\": scipy.sparse.linalg.expm_multiply\n",
    "    L is assumed to be normalized Laplacian (spectrum in [0,2]).\n",
    "    \"\"\"\n",
    "    n = L.shape[0]\n",
    "    if Omega is None:\n",
    "        # random probes\n",
    "        r = 32\n",
    "        Omega = np.random.randn(n, r)\n",
    "\n",
    "    if method == \"expm\":\n",
    "        return spla.expm_multiply((-t) * L, Omega)\n",
    "\n",
    "    # Chebyshev on mapped operator \\tilde{L} = L - I  (since λ_max≈2 => (2/2)L - I = L - I)\n",
    "    # exp(-t L) = exp(-t) * exp(-t (L - I))  with (L - I) having spectrum in [-1, 1]\n",
    "    A = (L - sp.eye(n, format='csr'))\n",
    "    a = t  # scaling parameter\n",
    "    Y = np.zeros_like(Omega, dtype=np.float64)\n",
    "\n",
    "    T0 = Omega.copy()\n",
    "    T1 = A @ Omega\n",
    "\n",
    "    # Coefficients: e^{-a} [ I0(a) T0 + 2 sum_{k>=1} (-1)^k I_k(a) T_k ]\n",
    "    c0 = bessel_I(0, a)\n",
    "    Y += c0 * T0\n",
    "    Tk_minus_1, Tk = T0, T1\n",
    "\n",
    "    for k in range(1, order+1):\n",
    "        ck = 2.0 * ((-1)**k) * bessel_I(k, a)\n",
    "        Y += ck * Tk\n",
    "        # Next Chebyshev term\n",
    "        Tk_plus_1 = 2.0 * (A @ Tk) - Tk_minus_1\n",
    "        Tk_minus_1, Tk = Tk, Tk_plus_1\n",
    "\n",
    "    Y *= np.exp(-t)\n",
    "    return Y\n",
    "\n",
    "\n",
    "def diffusion_embedding(L_mix, t=0.5, r_probes=32, order=30, method=\"chebyshev\"):\n",
    "    n = L_mix.shape[0]\n",
    "    Omega = np.random.randn(n, r_probes)\n",
    "    Y = heat_kernel_apply(L_mix, t=t, Omega=Omega, order=order, method=method)\n",
    "    Z = row_norm_(Y)  # each row ~ node's (compressed) heat distribution\n",
    "    return Z\n",
    "\n",
    "\n",
    "# ---------------------------\n",
    "# 5) Diffusion balls and incompatibility matrix M_C\n",
    "# ---------------------------\n",
    "\n",
    "def diffusion_knn(Z, k_diff=15):\n",
    "    \"\"\"\n",
    "    k-NN in diffusion space (Euclidean) to approximate B_t(i, ε)\n",
    "    Returns neighbor indices and distances.\n",
    "    \"\"\"\n",
    "    return knn_indices(Z, k_diff)\n",
    "\n",
    "def incompatibility_matrix(W_topo: sp.csr_matrix, knn_idx, degree, symmetric=True):\n",
    "    \"\"\"\n",
    "    Build M_C with (M_C)_{ij} = 1/(d_i d_j) if j NOT in diffusion ball of i, else 0.\n",
    "    — diffusion ball approximated by k-NN in Z.\n",
    "    To keep things symmetric, we mark (i,j) incompatible if either i excludes j OR j excludes i.\n",
    "    \"\"\"\n",
    "    n = W_topo.shape[0]\n",
    "    d = np.maximum(np.asarray(degree).ravel(), 1e-12)\n",
    "\n",
    "    # Build boolean mask of \"in-ball\" neighbors\n",
    "    in_ball = [set(knn_idx[i].tolist()) | {i} for i in range(n)]  # include self\n",
    "\n",
    "    rows, cols, vals = [], [], []\n",
    "    # For moderate n (<= ~3-5k), this O(n^2) pass is okay; for larger n, restrict to candidate pairs.\n",
    "    for i in range(n):\n",
    "        ib = in_ball[i]\n",
    "        # everything not in-ball is incompatible\n",
    "        # (vectorized complement)\n",
    "        # We'll do dense complement via range(n) minus ib\n",
    "        out = np.fromiter((j for j in range(n) if j not in ib), dtype=int)\n",
    "        if len(out) == 0:\n",
    "            continue\n",
    "        wij = 1.0 / (d[i] * d[out])\n",
    "        rows.extend([i] * len(out))\n",
    "        cols.extend(out.tolist())\n",
    "        vals.extend(wij.tolist())\n",
    "\n",
    "    M = sp.csr_matrix((vals, (rows, cols)), shape=(n, n))\n",
    "    if symmetric:\n",
    "        M = M.maximum(M.T)\n",
    "    M.setdiag(0)\n",
    "    M.eliminate_zeros()\n",
    "    return M\n",
    "def incompatibility_from_dense_knn(I_knn: np.ndarray, degree: np.ndarray):\n",
    "    n = I_knn.shape[0]\n",
    "    d = np.maximum(degree, 1e-12)\n",
    "    rows, cols, vals = [], [], []\n",
    "    # in-ball = {i} U neighbors in I_knn[i]\n",
    "    in_ball = [set(I_knn[i].tolist() + [i]) for i in range(n)]\n",
    "    for i in range(n):\n",
    "        comp = [j for j in range(n) if j not in in_ball[i]]\n",
    "        if not comp: \n",
    "            continue\n",
    "        wij = (1.0 / d[i]) * (1.0 / d[np.asarray(comp)])\n",
    "        rows.extend([i] * len(comp))\n",
    "        cols.extend(comp)\n",
    "        vals.extend(wij.tolist())\n",
    "    M = sp.csr_matrix((vals, (rows, cols)), shape=(n, n))\n",
    "    M = M.maximum(M.T); M.setdiag(0); M.eliminate_zeros()\n",
    "    return M\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "# ---------------------------\n",
    "# 6) End-to-end: up to M_C for the top cluster C=V\n",
    "# ---------------------------\n",
    "\n",
    "def build_until_M(\n",
    "    nA=60, nB=60, nH=380,\n",
    "    k_feat=7, k_diff=15,\n",
    "    t=0.5, cheb_order=30, heat_method=\"chebyshev\",\n",
    "    alpha=None, sigma=None, seed=0\n",
    "):\n",
    "    # Graph + features\n",
    "    #W_topo, X, labels, blocks = generate_heterophilous_graph(\n",
    "    #    nA=nA, nB=nB, nH=nH, seed=seed\n",
    "    #)\n",
    "    #W_topo=_thin_undirected_csr(W_topo, keep_prob=0.3, seed=seed)\n",
    "    # L_top\n",
    "    W_topo, X, labels = generate_sparse_graph(n=nA+nB+nH, avg_deg=7, d_feat=16, K=4, seed=seed)\n",
    "    L_top, d_top = normalized_laplacian(W_topo)\n",
    "\n",
    "    # L_feat from feature kNN\n",
    "    L_feat, W_feat, d_feat = build_L_feat_from_features(X, k=k_feat, sigma=sigma)\n",
    "\n",
    "    # Mix (top cluster C = V)\n",
    "    L_mix, alpha_used = mix_laplacian(L_top, L_feat, alpha=alpha)\n",
    "\n",
    "    # Diffusion embedding via heat kernel\n",
    "    Z = diffusion_embedding(L_mix, t=t, r_probes=32, order=cheb_order, method=heat_method)\n",
    "\n",
    "    # Diffusion balls via kNN in Z\n",
    "    knn_idx, _ = diffusion_knn(Z, k_diff=k_diff)\n",
    "\n",
    "    # Incompatibility matrix M_C (uses topology degrees in (d_i d_j))\n",
    "    M_C = incompatibility_matrix(W_topo, knn_idx, degree=d_top, symmetric=True)\n",
    "\n",
    "    out = {\n",
    "        \"W_topo\": W_topo,\n",
    "        \"X\": X,\n",
    "        \"labels\": labels,\n",
    "        \"L_top\": L_top,\n",
    "        \"W_feat\": W_feat,\n",
    "        \"L_feat\": L_feat,\n",
    "        \"alpha\": alpha_used,\n",
    "        \"L_mix\": L_mix,\n",
    "        \"Z\": Z,\n",
    "        \"knn_idx\": knn_idx,\n",
    "        \"M_C\": M_C,\n",
    "    }\n",
    "    return out\n",
    "\n",
    "\n",
    "# ---------------------------\n",
    "# 7) Example usage\n",
    "# ---------------------------\n",
    "\n",
    "cfg = dict(\n",
    "        nA=50, nB=50, nH=400,\n",
    "        k_feat=15, k_diff=15,\n",
    "        t=0.6, cheb_order=25, heat_method=\"chebyshev\",\n",
    "        alpha=None, sigma=None, seed=42\n",
    "    )\n",
    "res = build_until_M(**cfg)\n",
    "M = res[\"M_C\"]\n",
    "print(\"alpha used:\", res[\"alpha\"])\n",
    "print(\"Shapes: W_topo\", res[\"W_topo\"].shape,\n",
    "          \"| L_mix\", res[\"L_mix\"].shape,\n",
    "          \"| Z\", res[\"Z\"].shape,\n",
    "          \"| M_C nnz =\", M.nnz)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "U: torch.Size([500, 6]) S: torch.Size([500, 6]) X_next: torch.Size([6, 16])\n",
      "A_next nnz: 36\n"
     ]
    }
   ],
   "source": [
    "# hierarchy_step.py\n",
    "# Requires: torch, scipy, numpy. (Upstream code must have built M_C using FAISS.)\n",
    "\n",
    "import numpy as np\n",
    "import scipy.sparse as sp\n",
    "import torch\n",
    "\n",
    "# ==============================\n",
    "# Sparse helpers (scipy <-> torch)\n",
    "# ==============================\n",
    "\n",
    "def scipy_to_torch_sparse(A: sp.csr_matrix, device=\"cpu\", dtype=torch.float64):\n",
    "    A = A.tocoo()\n",
    "    indices = np.vstack([A.row, A.col])\n",
    "    i = torch.from_numpy(indices).long().to(device)\n",
    "    v = torch.from_numpy(A.data).to(device=device, dtype=dtype)\n",
    "    return torch.sparse_coo_tensor(i, v, size=A.shape, device=device, dtype=dtype).coalesce()\n",
    "\n",
    "def torch_sparse_to_scipy(A: torch.Tensor) -> sp.csr_matrix:\n",
    "    A = A.coalesce()\n",
    "    i = A.indices().cpu().numpy()\n",
    "    v = A.values().cpu().numpy()\n",
    "    n, m = A.size()\n",
    "    return sp.coo_matrix((v, (i[0], i[1])), shape=(n, m)).tocsr()\n",
    "\n",
    "def degree_from_csr(W: sp.csr_matrix):\n",
    "    return np.asarray(W.sum(axis=1)).ravel()\n",
    "\n",
    "# ==============================\n",
    "# Largest eigenvalue estimate (power iteration)\n",
    "# ==============================\n",
    "\n",
    "@torch.no_grad()\n",
    "def estimate_lmax_power_sparse(L_sp: torch.Tensor, iters: int = 20):\n",
    "    \"\"\"\n",
    "    Rough λ_max(L) via power iteration on symmetric PSD torch sparse L.\n",
    "    \"\"\"\n",
    "    n = L_sp.size(0)\n",
    "    x = torch.randn(n, 1, device=L_sp.device, dtype=L_sp.dtype)\n",
    "    x = x / (x.norm() + 1e-12)\n",
    "    lam = None\n",
    "    for _ in range(iters):\n",
    "        y = torch.sparse.mm(L_sp, x)\n",
    "        ny = y.norm()\n",
    "        if ny.item() == 0.0:\n",
    "            return torch.tensor(0.0, device=L_sp.device, dtype=L_sp.dtype)\n",
    "        x = y / ny\n",
    "        lam = (x.t() @ torch.sparse.mm(L_sp, x)).item()\n",
    "    return torch.tensor(lam if lam is not None else 0.0, device=L_sp.device, dtype=L_sp.dtype)\n",
    "\n",
    "# ==============================\n",
    "# Balanced bottom-K eigenspace via subspace iteration\n",
    "# ==============================\n",
    "\n",
    "@torch.no_grad()\n",
    "def block_power_smallest(L_sp: torch.Tensor,\n",
    "                         K: int,\n",
    "                         iters: int = 10,\n",
    "                         deg_C: torch.Tensor | None = None):\n",
    "    \"\"\"\n",
    "    Returns U in R^{|C| x K}: an orthonormal basis approximating the bottom-K eigenspace of L_sp.\n",
    "    Uses B = I - L/λ_max and subspace iteration. Projects out degree-weighted constant each step.\n",
    "    \"\"\"\n",
    "    device, dtype = L_sp.device, L_sp.dtype\n",
    "    nC = L_sp.size(0)\n",
    "\n",
    "    # λ_max estimate and linear map B = I - L/λ_max  (shifts smallest-eigs to largest)\n",
    "    lmax = estimate_lmax_power_sparse(L_sp, iters=12).clamp_min(1e-12)\n",
    "\n",
    "    def apply_B(X):\n",
    "        return X - (1.0 / lmax) * torch.sparse.mm(L_sp, X)\n",
    "\n",
    "    # Degree-weighted constant s^(0) = D^{1/2} 1 / ||.||\n",
    "    if deg_C is None:\n",
    "        deg_C = torch.ones(nC, device=device, dtype=dtype)\n",
    "    s = deg_C.clamp_min(1e-12).sqrt().unsqueeze(1)\n",
    "    s = s / (s.norm() + 1e-12)\n",
    "\n",
    "    # Init and iterate\n",
    "    Q = torch.randn(nC, K, device=device, dtype=dtype)\n",
    "    Q, _ = torch.linalg.qr(Q, mode='reduced')\n",
    "    for _ in range(iters):\n",
    "        Q = apply_B(Q)\n",
    "        # Balance constraint: project out span{s}\n",
    "        Q = Q - s * (s.t() @ Q)                 # Q <- (I - s s^T) Q\n",
    "        Q, _ = torch.linalg.qr(Q, mode='reduced')\n",
    "    return Q  # [nC, K]\n",
    "\n",
    "# ==============================\n",
    "# Heads and assignments\n",
    "# ==============================\n",
    "\n",
    "class SoftmaxHeadK(torch.nn.Module):\n",
    "    \"\"\"U (|C|xK) -> logits -> softmax. Small MLP to resolve rotational ambiguity.\"\"\"\n",
    "    def __init__(self, K, hidden=32, dtype=torch.float64):\n",
    "        super().__init__()\n",
    "        self.net = torch.nn.Sequential(\n",
    "            torch.nn.Linear(K, hidden, dtype=dtype), torch.nn.ReLU(),\n",
    "            torch.nn.Linear(hidden, K, dtype=dtype)\n",
    "        )\n",
    "        for m in self.modules():\n",
    "            if isinstance(m, torch.nn.Linear):\n",
    "                torch.nn.init.xavier_uniform_(m.weight, gain=0.1)\n",
    "                torch.nn.init.zeros_(m.bias)\n",
    "\n",
    "    def forward(self, U):\n",
    "        return self.net(U)\n",
    "def sinkhorn_balanced(logits: torch.Tensor, n_iters=7, tau=1.0):\n",
    "    n, K = logits.shape\n",
    "    P = torch.exp(logits / tau) + 1e-9     # turn logits into positive scores\n",
    "    col_tgt = (n / K) * torch.ones(K, device=logits.device, dtype=logits.dtype)\n",
    "    for _ in range(n_iters):\n",
    "        P = P / (P.sum(dim=1, keepdim=True) + 1e-12)  # rows -> 1\n",
    "        col_sum = P.sum(dim=0) + 1e-12\n",
    "        P = P * (col_tgt / col_sum)                   # cols -> n/K\n",
    "    P = P / (P.sum(dim=1, keepdim=True) + 1e-12)      # final row norm\n",
    "    return P\n",
    "\n",
    "\n",
    "class SinkhornHeadK(torch.nn.Module):\n",
    "    \"\"\"U (|C|xK) -> S (|C|xK) via linear logits + Sinkhorn for (approx) balanced clusters.\"\"\"\n",
    "    def __init__(self, K, hidden=32, tau=1.0, iters=5):\n",
    "        super().__init__()\n",
    "        self.tau = tau\n",
    "        self.iters = iters\n",
    "        self.proj = torch.nn.Sequential(\n",
    "            torch.nn.Linear(K, hidden), torch.nn.ReLU(),\n",
    "            torch.nn.Linear(hidden, K)\n",
    "        )\n",
    "        for m in self.modules():\n",
    "            if isinstance(m, torch.nn.Linear):\n",
    "                torch.nn.init.xavier_uniform_(m.weight, gain=0.1)\n",
    "                torch.nn.init.zeros_(m.bias)\n",
    "    def forward(self, U):\n",
    "        logits = self.proj(U)\n",
    "        return sinkhorn_balanced(logits, n_iters=self.iters, tau=self.tau)\n",
    "def kmeans_logits(U: torch.Tensor, K: int, iters: int = 10):\n",
    "    n, d = U.shape\n",
    "    idx = torch.randperm(n, device=U.device)[:K]\n",
    "    C = U[idx].clone()\n",
    "    for _ in range(iters):\n",
    "        # dist^2 to centers\n",
    "        dist2 = (U[:, None, :] - C[None, :, :]).pow(2).sum(-1)  # [n,K]\n",
    "        assign = dist2.argmin(dim=1)\n",
    "        # update centers\n",
    "        for k in range(K):\n",
    "            mk = (assign == k)\n",
    "            if mk.any():\n",
    "                C[k] = U[mk].mean(dim=0)\n",
    "    # logits = negative squared distances\n",
    "    return - (U[:, None, :] - C[None, :, :]).pow(2).sum(-1)\n",
    "@torch.no_grad()\n",
    "def margin_scaled_soft_assign(U: torch.Tensor, hidden=32, zeta=1e-3):\n",
    "    \"\"\"\n",
    "    α = WU+b ; μ = (α_max - α_2nd) / (|α_max|+|α_2nd|+ζ) ; A_s = softmax( μ * α )\n",
    "    \"\"\"\n",
    "    K = U.size(1)\n",
    "    head = SoftmaxHeadK(K=K, hidden=hidden, dtype=U.dtype).to(U.device)\n",
    "    head1=SinkhornHeadK(K=K, hidden=hidden, tau=1.0, iters=5).to(U.device)\n",
    "    #alpha = head(U)  # logits before softmax\n",
    "    alpha=head(U)\n",
    "    # compute margin per row\n",
    "    top2 = torch.topk(alpha, k=2, dim=1, largest=True, sorted=True).values\n",
    "    num = (top2[:, 0] - top2[:, 1]).clamp_min(0.0)\n",
    "    den = top2.abs().sum(dim=1) + zeta\n",
    "    mu = (num / den).unsqueeze(1)             # [n,1]\n",
    "    S = torch.softmax(mu * alpha, dim=1)      # [n,K]\n",
    "    return S, alpha, mu.squeeze(1)\n",
    "\n",
    "# ==============================\n",
    "# Coarsening: X' = S^T X,  A' = S^T A S\n",
    "# ==============================\n",
    "\n",
    "@torch.no_grad()\n",
    "def coarsen_once(A_sp: torch.Tensor, X: torch.Tensor, S: torch.Tensor):\n",
    "    \"\"\"\n",
    "    A_sp: torch sparse (n x n), X: (n x d), S: (n x K), rows sum to 1\n",
    "    Returns: X_next (K x d), A_next (K x K) as torch sparse\n",
    "    \"\"\"\n",
    "    # Features\n",
    "    X_next = S.t() @ X                   # [K,d]\n",
    "\n",
    "    # Adjacency: S^T A S\n",
    "    AS = torch.sparse.mm(A_sp, S)        # [n,K]\n",
    "    A_next = S.t() @ AS                  # [K,K] dense\n",
    "    # Force symmetry & drop tiny negatives from numerical noise\n",
    "    A_next = 0.5 * (A_next + A_next.t())\n",
    "    A_next = torch.clamp(A_next, min=0.0)\n",
    "    # Convert to sparse (optional)\n",
    "    idx = A_next.nonzero(as_tuple=False).t()\n",
    "    vals = A_next[idx[0], idx[1]]\n",
    "    A_next_sp = torch.sparse_coo_tensor(idx, vals, size=A_next.shape,\n",
    "                                        device=A_next.device, dtype=A_next.dtype).coalesce()\n",
    "    return X_next, A_next_sp\n",
    "@torch.no_grad()\n",
    "def assignments_with_margin(\n",
    "    U: torch.Tensor,\n",
    "    hidden: int = 32,\n",
    "    zeta: float = 1e-3,\n",
    "    method: str = \"sinkhorn\",   # \"sinkhorn\" or \"softmax\"\n",
    "    tau: float = 1.0,\n",
    "    sinkhorn_iters: int = 7,\n",
    "):\n",
    "    K = U.size(1)\n",
    "    head = SoftmaxHeadK(K=K, hidden=hidden, dtype=U.dtype).to(U.device)\n",
    "    logits = head(U)                                # [n,K]  REAL logits\n",
    "    logits = logits - logits.mean(dim=1, keepdim=True)  # center per-row\n",
    "\n",
    "    # Fallback if logits are nearly constant (common at init)\n",
    "    if logits.std().item() < 1e-3:\n",
    "        logits = kmeans_logits(U, K, iters=10)\n",
    "\n",
    "    # margin from LOGITS (not probs)\n",
    "    top2 = torch.topk(logits, 2, dim=1).values\n",
    "    mu = ((top2[:, 0] - top2[:, 1]).clamp_min(0.0) /\n",
    "          (top2.abs().sum(dim=1) + zeta)).unsqueeze(1)  # [n,1]\n",
    "\n",
    "    logits_scaled = mu * logits\n",
    "\n",
    "    if method.lower() == \"sinkhorn\":\n",
    "        S = sinkhorn_balanced(logits_scaled, n_iters=sinkhorn_iters, tau=tau)\n",
    "    else:\n",
    "        S = torch.softmax(logits_scaled, dim=1)\n",
    "    return S, logits, mu.squeeze(1)\n",
    "\n",
    "# ==============================\n",
    "# Main step: from (L_mix, M_C, λ, W_topo, X) -> (L_aug, U, A_s, X_next, A_next)\n",
    "# ==============================\n",
    "\n",
    "@torch.no_grad()\n",
    "def hierarchical_step_until_assign(\n",
    "    L_mix_csr: sp.csr_matrix,\n",
    "    M_C_csr: sp.csr_matrix,\n",
    "    lam: float,\n",
    "    W_topo_csr: sp.csr_matrix,\n",
    "    X_np: np.ndarray,\n",
    "    K: int,\n",
    "    iters_power: int = 10,\n",
    "    device: str = \"cpu\",\n",
    "    dtype = torch.float64,\n",
    "):\n",
    "    \"\"\"\n",
    "    Builds L_C = L_mix + λ M_C (torch sparse), solves balanced relaxation for bottom-K,\n",
    "    computes margin-scaled soft assignments, and coarsens (X, A).\n",
    "    \"\"\"\n",
    "    # torch sparse conversions\n",
    "    Lmix_sp = scipy_to_torch_sparse(L_mix_csr, device=device, dtype=dtype)\n",
    "    MC_sp   = scipy_to_torch_sparse(M_C_csr,  device=device, dtype=dtype)\n",
    "    A_sp    = scipy_to_torch_sparse(W_topo_csr, device=device, dtype=dtype)  # adjacency\n",
    "    # L_aug\n",
    "    L_aug = (Lmix_sp + lam * MC_sp).coalesce()\n",
    "\n",
    "    # degrees and s^(0)\n",
    "    deg = degree_from_csr(W_topo_csr)\n",
    "    deg_t = torch.from_numpy(deg).to(device=device, dtype=dtype)\n",
    "\n",
    "    # bottom-K (balanced) eigen-subspace\n",
    "    U = block_power_smallest(L_aug, K=K, iters=iters_power, deg_C=deg_t)  # [n,K], orthonormal & balanced\n",
    "\n",
    "    # margin-scaled soft assignments\n",
    "    S, alpha_logits, mu = assignments_with_margin(\n",
    "    U, hidden=32, zeta=1e-2,\n",
    "    method=\"sinkhorn\",     # <-- switch here\n",
    "    tau=1.0,               # temperature; lower => sharper columns\n",
    "    sinkhorn_iters=7\n",
    "                    )\n",
    "\n",
    "    # coarsen features & adjacency\n",
    "    X_t = torch.from_numpy(X_np).to(device=device, dtype=dtype)\n",
    "    X_next, A_next_sp = coarsen_once(A_sp, X_t, S)\n",
    "\n",
    "    out = {\n",
    "        \"L_aug_sp\": L_aug,\n",
    "        \"U\": U,                       # spectral coordinates (balanced)\n",
    "        \"S\": S,                       # assignments |C| x K\n",
    "        \"alpha_logits\": alpha_logits, # pre-softmax scores\n",
    "        \"margin\": mu,                 # row-wise μ\n",
    "        \"X_next\": X_next,             # K x d\n",
    "        \"A_next_sp\": A_next_sp,       # K x K (torch sparse)\n",
    "    }\n",
    "    return out\n",
    "\n",
    "# ==============================\n",
    "# Example usage (hook this to your previous res)\n",
    "# ==============================\n",
    "\n",
    "\n",
    "    # -- Example: expects you to pass in objects from your FAISS-only pipeline --\n",
    "    # from heterophily_mc import build_until_M\n",
    "    # res = build_until_M(seed=7, t=0.6, cheb_order=25, heat_method=\"chebyshev\")\n",
    "    # L_mix = res[\"L_mix\"]; M_C = res[\"M_C\"]; W_topo = res[\"W_topo\"]; X = res[\"X\"]\n",
    "\n",
    "    # Dummy stub to show signatures; replace with real ones from your pipeline.\n",
    "\n",
    "\n",
    "out = hierarchical_step_until_assign(\n",
    "    L_mix_csr=res[\"L_mix\"],\n",
    "    M_C_csr=res[\"M_C\"],\n",
    "    lam=0.1,\n",
    "    W_topo_csr=res[\"W_topo\"],\n",
    "    X_np=res[\"X\"],\n",
    "    K=6,\n",
    "    iters_power=20,\n",
    "    device=\"cpu\",\n",
    "    dtype=torch.float64\n",
    ")\n",
    "print(\"U:\", out[\"U\"].shape, \"S:\", out[\"S\"].shape, \"X_next:\", out[\"X_next\"].shape)\n",
    "print(\"A_next nnz:\", out[\"A_next_sp\"]._nnz())\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[0.1667, 0.1664, 0.1666, 0.1664, 0.1668, 0.1671],\n",
       "        [0.1666, 0.1668, 0.1666, 0.1668, 0.1666, 0.1666],\n",
       "        [0.1665, 0.1667, 0.1667, 0.1668, 0.1666, 0.1667],\n",
       "        ...,\n",
       "        [0.1665, 0.1663, 0.1666, 0.1674, 0.1664, 0.1668],\n",
       "        [0.1667, 0.1667, 0.1666, 0.1667, 0.1666, 0.1666],\n",
       "        [0.1667, 0.1666, 0.1666, 0.1667, 0.1666, 0.1667]], dtype=torch.float64)"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "out['S']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "# ==== STRICT FAISS kNN + safe KNN graph (dense per-row) ====\n",
    "import numpy as np\n",
    "import scipy.sparse as sp\n",
    "\n",
    "def _safe_k(n: int, k: int) -> int:\n",
    "    return max(0, min(int(k), max(0, n - 1)))  # at most n-1 neighbors\n",
    "\n",
    "def faiss_knn_dense_strict(X: np.ndarray, k: int):\n",
    "    \"\"\"\n",
    "    Returns dense neighbor arrays I, D with shape (n, k_eff),\n",
    "    where k_eff = min(k, n-1). Self is removed per-row.\n",
    "    Distances D are FAISS L2^2 (squared Euclidean).\n",
    "    \"\"\"\n",
    "    import faiss\n",
    "    Xf = np.ascontiguousarray(X.astype(np.float32))\n",
    "    n = Xf.shape[0]\n",
    "    if n == 0:\n",
    "        return np.empty((0, 0), dtype=int), np.empty((0, 0), dtype=np.float32)\n",
    "    k_eff = _safe_k(n, k)\n",
    "    if k_eff == 0:\n",
    "        return np.empty((n, 0), dtype=int), np.empty((n, 0), dtype=np.float32)\n",
    "\n",
    "    kq = min(n, k_eff + 1)  # include self if possible\n",
    "    index = faiss.IndexFlatL2(Xf.shape[1])\n",
    "    index.add(Xf)\n",
    "    D_full, I_full = index.search(Xf, kq)  # shapes (n, kq); distances are squared L2\n",
    "\n",
    "    I_out = np.empty((n, k_eff), dtype=int)\n",
    "    D_out = np.empty((n, k_eff), dtype=np.float32)\n",
    "\n",
    "    for i in range(n):\n",
    "        rowI, rowD = I_full[i], D_full[i]\n",
    "        # drop self (wherever it appears)\n",
    "        mask = rowI != i\n",
    "        rowI = rowI[mask]\n",
    "        rowD = rowD[mask]\n",
    "        # if still too long, truncate; if too short (weird), pad by best available\n",
    "        if rowI.size >= k_eff:\n",
    "            I_out[i] = rowI[:k_eff]\n",
    "            D_out[i] = rowD[:k_eff]\n",
    "        else:\n",
    "            # pad by repeating the last neighbor (extremely rare on micro-graphs)\n",
    "            need = k_eff - rowI.size\n",
    "            I_out[i] = np.pad(rowI, (0, need), mode='edge')\n",
    "            D_out[i] = np.pad(rowD, (0, need), mode='edge')\n",
    "\n",
    "    return I_out, D_out  # dense (n, k_eff)\n",
    "\n",
    "def feature_knn_graph_faiss_safe(X: np.ndarray, k=15, sigma=None):\n",
    "    \"\"\"\n",
    "    Build symmetric KNN graph W (CSR) with exactly k_eff neighbors per node.\n",
    "    Uses w_ij = exp( - D2_ij / (2 sigma^2) ), where D2 are FAISS squared L2 distances.\n",
    "    \"\"\"\n",
    "    n = X.shape[0]\n",
    "    k_eff = _safe_k(n, k)\n",
    "    if n == 0:\n",
    "        return sp.csr_matrix((0, 0))\n",
    "    if k_eff == 0:\n",
    "        return sp.csr_matrix((n, n))\n",
    "\n",
    "    I, D2 = faiss_knn_dense_strict(X, k_eff)  # shapes (n, k_eff)\n",
    "\n",
    "    # choose sigma from positive distances (fallback to 1.0)\n",
    "    if sigma is None:\n",
    "        flat = D2.ravel()\n",
    "        pos = flat[np.isfinite(flat) & (flat > 0)]\n",
    "        if pos.size == 0:\n",
    "            sigma = 1.0\n",
    "        else:\n",
    "            sigma = float(np.median(pos))\n",
    "            if sigma <= 1e-12:\n",
    "                sigma = 1.0\n",
    "\n",
    "    rows = np.repeat(np.arange(n), k_eff)\n",
    "    cols = I.ravel()\n",
    "    # FAISS already returns squared distances; DO NOT square again\n",
    "    weights = np.exp(-D2.ravel() / (2.0 * (sigma ** 2)))\n",
    "\n",
    "    # Build CSR (all arrays equal length)\n",
    "    W = sp.csr_matrix((weights, (rows, cols)), shape=(n, n))\n",
    "    # symmetrize\n",
    "    W = W.maximum(W.T)\n",
    "    W.setdiag(0); W.eliminate_zeros()\n",
    "    return W\n",
    "\n",
    "def diffusion_knn_faiss_dense(Z: np.ndarray, k=15):\n",
    "    \"\"\"\n",
    "    Dense kNN (n, k_eff) for diffusion space (same behavior as feature_knn...).\n",
    "    Returns I, D2 with shapes (n, k_eff).\n",
    "    \"\"\"\n",
    "    return faiss_knn_dense_strict(Z, k)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "def incompatibility_from_dense_knn(I_knn: np.ndarray, degree: np.ndarray):\n",
    "    n = I_knn.shape[0]\n",
    "    d = np.maximum(degree, 1e-12)\n",
    "    rows, cols, vals = [], [], []\n",
    "    # in-ball = {i} U neighbors in I_knn[i]\n",
    "    in_ball = [set(I_knn[i].tolist() + [i]) for i in range(n)]\n",
    "    for i in range(n):\n",
    "        comp = [j for j in range(n) if j not in in_ball[i]]\n",
    "        if not comp: \n",
    "            continue\n",
    "        wij = (1.0 / d[i]) * (1.0 / d[np.asarray(comp)])\n",
    "        rows.extend([i] * len(comp))\n",
    "        cols.extend(comp)\n",
    "        vals.extend(wij.tolist())\n",
    "    M = sp.csr_matrix((vals, (rows, cols)), shape=(n, n))\n",
    "    M = M.maximum(M.T); M.setdiag(0); M.eliminate_zeros()\n",
    "    return M\n",
    "\n",
    "# use it:\n",
    "#M_C = incompatibility_from_dense_knn(I_diff, degree=deg_top)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "# make_tree_hmh.py\n",
    "# Build a hierarchical tree using mixed Laplacian + incompatibility + spectral bottom-K + Sinkhorn assignments.\n",
    "# Outputs the SAME structure as your Make_tree_real1 (treeG, S_assign_list).\n",
    "#\n",
    "# Requirements: numpy, scipy, torch, faiss (FAISS mandatory for kNN).\n",
    "# This code uses only FAISS for kNN as requested.\n",
    "\n",
    "import numpy as np\n",
    "import scipy.sparse as sp\n",
    "import torch\n",
    "\n",
    "# --------- FAISS kNN (required) ---------\n",
    "try:\n",
    "    import faiss  # type: ignore\n",
    "except Exception as e:\n",
    "    raise ImportError(\"FAISS is required. Please install faiss or faiss-gpu.\") from e\n",
    "\n",
    "# ==============================\n",
    "# Utilities\n",
    "# ==============================\n",
    "\n",
    "def set_seed(seed=0):\n",
    "    np.random.seed(seed)\n",
    "    torch.manual_seed(seed)\n",
    "\n",
    "def scipy_to_torch_sparse(A: sp.csr_matrix, device=\"cpu\", dtype=torch.float64):\n",
    "    A = A.tocoo()\n",
    "    idx = np.vstack([A.row, A.col])\n",
    "    i = torch.from_numpy(idx).long().to(device)\n",
    "    v = torch.from_numpy(A.data).to(device=device, dtype=dtype)\n",
    "    return torch.sparse_coo_tensor(i, v, size=A.shape, device=device, dtype=dtype).coalesce()\n",
    "\n",
    "def degree_from_csr(W: sp.csr_matrix):\n",
    "    return np.asarray(W.sum(axis=1)).ravel()\n",
    "\n",
    "def symmetrize_simple(W: sp.csr_matrix):\n",
    "    W = W.maximum(W.T)\n",
    "    W.setdiag(0)\n",
    "    W.eliminate_zeros()\n",
    "    return W\n",
    "\n",
    "# ==============================\n",
    "# FAISS kNN helpers\n",
    "# ==============================\n",
    "\n",
    "def faiss_knn(X: np.ndarray, k: int):\n",
    "    Xf = X.astype(np.float32).copy()\n",
    "    k = max(0, min(int(k), max(0, Xf.shape[0] - 1)))\n",
    "    index = faiss.IndexFlatL2(Xf.shape[1])\n",
    "    index.add(Xf)\n",
    "    D, I = index.search(Xf, k + 1)  # include self\n",
    "    return I[:, 1:], D[:, 1:]       # drop self\n",
    "\n",
    "def feature_knn_graph_faiss(X: np.ndarray, k=15, sigma=None):\n",
    "    n = X.shape[0]\n",
    "    I, D = faiss_knn(X, k)\n",
    "    if sigma is None:\n",
    "        sigma = np.median(D)\n",
    "    sigma = max(float(sigma), 1e-12)\n",
    "\n",
    "    rows = np.repeat(np.arange(n), k)\n",
    "    cols = I.reshape(-1)\n",
    "    d2 = (D.reshape(-1))**2\n",
    "    weights = np.exp(-d2 / (2.0 * sigma**2))\n",
    "    W = sp.csr_matrix((weights, (rows, cols)), shape=(n, n))\n",
    "    W = W.maximum(W.T)\n",
    "    W.setdiag(0)\n",
    "    W.eliminate_zeros()\n",
    "    return W\n",
    "\n",
    "# ==============================\n",
    "# Laplacians and mixing\n",
    "# ==============================\n",
    "\n",
    "def normalized_laplacian(W: sp.csr_matrix):\n",
    "    W = W.tocsr()\n",
    "    d = np.asarray(W.sum(axis=1)).ravel()\n",
    "    d_safe = np.maximum(d, 1e-12)\n",
    "    Dinv_sqrt = sp.diags(1.0 / np.sqrt(d_safe))\n",
    "    L = sp.eye(W.shape[0], format='csr') - Dinv_sqrt @ W @ Dinv_sqrt\n",
    "    return L, d\n",
    "\n",
    "def mix_laplacian(L_top: sp.csr_matrix, L_feat: sp.csr_matrix, alpha=(0.5, 0.5)):\n",
    "    a = np.asarray(alpha, dtype=float)\n",
    "    a = a / (a.sum() + 1e-12)\n",
    "    return a[0] * L_top + a[1] * L_feat\n",
    "\n",
    "# ==============================\n",
    "# Heat-kernel Chebyshev (for diffusion embedding)\n",
    "# ==============================\n",
    "\n",
    "from scipy.special import iv as bessel_I\n",
    "\n",
    "def heat_kernel_apply(L: sp.csr_matrix, t=0.6, Omega=None, order=25):\n",
    "    n = L.shape[0]\n",
    "    if Omega is None:\n",
    "        Omega = np.random.randn(n, 32)\n",
    "    # Chebyshev on A = L - I  (spectrum ~ [-1,1])\n",
    "    A = (L - sp.eye(n, format='csr'))\n",
    "    a = t\n",
    "    Y = np.zeros_like(Omega, dtype=float)\n",
    "    T0 = Omega.copy()\n",
    "    T1 = A @ Omega\n",
    "    Y += bessel_I(0, a) * T0\n",
    "    Tk_minus_1, Tk = T0, T1\n",
    "    for k in range(1, order + 1):\n",
    "        ck = 2.0 * ((-1)**k) * bessel_I(k, a)\n",
    "        Y += ck * Tk\n",
    "        Tk_plus_1 = 2.0 * (A @ Tk) - Tk_minus_1\n",
    "        Tk_minus_1, Tk = Tk, Tk_plus_1\n",
    "    Y *= np.exp(-t)\n",
    "    # row normalize\n",
    "    nrm = np.linalg.norm(Y, axis=1, keepdims=True) + 1e-12\n",
    "    return Y / nrm\n",
    "\n",
    "def diffusion_knn_faiss(Z: np.ndarray, k=15):\n",
    "    return faiss_knn(Z, k)\n",
    "\n",
    "# ==============================\n",
    "# Incompatibility matrix M_C (sparse)\n",
    "# (M_C)_{ij} = 1/(d_i d_j) if j NOT in diffusion ball of i, else 0; symmetrized by max\n",
    "# ==============================\n",
    "\n",
    "def incompatibility_from_inball(knn_idx: np.ndarray, degree: np.ndarray):\n",
    "    n = knn_idx.shape[0]\n",
    "    d = np.maximum(degree, 1e-12)\n",
    "    in_ball = [set(knn_idx[i].tolist()) | {i} for i in range(n)]\n",
    "\n",
    "    rows, cols, vals = [], [], []\n",
    "    for i in range(n):\n",
    "        ib = in_ball[i]\n",
    "        # complement: all j not in ball\n",
    "        # If n is large, consider restricting to a candidate set.\n",
    "        out = [j for j in range(n) if j not in ib]\n",
    "        if not out:\n",
    "            continue\n",
    "        wij = (1.0 / d[i]) * (1.0 / d[np.array(out)])\n",
    "        rows.extend([i] * len(out))\n",
    "        cols.extend(out)\n",
    "        vals.extend(wij.tolist())\n",
    "\n",
    "    M = sp.csr_matrix((vals, (rows, cols)), shape=(n, n))\n",
    "    M = M.maximum(M.T)\n",
    "    M.setdiag(0)\n",
    "    M.eliminate_zeros()\n",
    "    return M\n",
    "\n",
    "# ==============================\n",
    "# Balanced bottom-K eigenspace (torch)\n",
    "# ==============================\n",
    "\n",
    "@torch.no_grad()\n",
    "def estimate_lmax_power_sparse(L_sp: torch.Tensor, iters: int = 20):\n",
    "    n = L_sp.size(0)\n",
    "    x = torch.randn(n, 1, device=L_sp.device, dtype=L_sp.dtype)\n",
    "    x = x / (x.norm() + 1e-12)\n",
    "    lam = None\n",
    "    for _ in range(iters):\n",
    "        y = torch.sparse.mm(L_sp, x)\n",
    "        ny = y.norm()\n",
    "        if ny.item() == 0.0:\n",
    "            return torch.tensor(0.0, device=L_sp.device, dtype=L_sp.dtype)\n",
    "        x = y / ny\n",
    "        lam = (x.t() @ torch.sparse.mm(L_sp, x)).item()\n",
    "    return torch.tensor(lam if lam is not None else 0.0, device=L_sp.device, dtype=L_sp.dtype)\n",
    "\n",
    "@torch.no_grad()\n",
    "def block_power_smallest(L_sp: torch.Tensor, K: int, iters: int = 10, deg_C: torch.Tensor | None = None):\n",
    "    device, dtype = L_sp.device, L_sp.dtype\n",
    "    nC = L_sp.size(0)\n",
    "    lmax = estimate_lmax_power_sparse(L_sp, iters=12).clamp_min(1e-12)\n",
    "    def apply_B(X):  # B = I - L/lmax\n",
    "        return X - (1.0 / lmax) * torch.sparse.mm(L_sp, X)\n",
    "\n",
    "    if deg_C is None:\n",
    "        deg_C = torch.ones(nC, device=device, dtype=dtype)\n",
    "    s = deg_C.clamp_min(1e-12).sqrt().unsqueeze(1)\n",
    "    s = s / (s.norm() + 1e-12)\n",
    "\n",
    "    Q = torch.randn(nC, K, device=device, dtype=dtype)\n",
    "    Q, _ = torch.linalg.qr(Q, mode='reduced')\n",
    "    for _ in range(iters):\n",
    "        Q = apply_B(Q)\n",
    "        Q = Q - s * (s.t() @ Q)  # balance projection\n",
    "        Q, _ = torch.linalg.qr(Q, mode='reduced')\n",
    "    return Q\n",
    "\n",
    "# ==============================\n",
    "# Margin-scaled assignments (Sinkhorn)\n",
    "# ==============================\n",
    "\n",
    "class LinearHeadK(torch.nn.Module):\n",
    "    def __init__(self, K, hidden=32, dtype=torch.float64):\n",
    "        super().__init__()\n",
    "        self.net = torch.nn.Sequential(\n",
    "            torch.nn.Linear(K, hidden, dtype=dtype), torch.nn.ReLU(),\n",
    "            torch.nn.Linear(hidden, K, dtype=dtype)\n",
    "        )\n",
    "        for m in self.modules():\n",
    "            if isinstance(m, torch.nn.Linear):\n",
    "                torch.nn.init.xavier_uniform_(m.weight, gain=0.1)\n",
    "                torch.nn.init.zeros_(m.bias)\n",
    "    def forward(self, U):\n",
    "        return self.net(U)  # logits\n",
    "\n",
    "def sinkhorn_balanced(logits: torch.Tensor, n_iters=7, tau=1.0):\n",
    "    n, K = logits.shape\n",
    "    P = torch.exp(logits / tau) + 1e-9\n",
    "    col_tgt = (n / K) * torch.ones(K, device=logits.device, dtype=logits.dtype)\n",
    "    for _ in range(n_iters):\n",
    "        P = P / (P.sum(dim=1, keepdim=True) + 1e-12)  # rows -> 1\n",
    "        col_sum = P.sum(dim=0) + 1e-12\n",
    "        P = P * (col_tgt / col_sum)                    # cols -> n/K\n",
    "    P = P / (P.sum(dim=1, keepdim=True) + 1e-12)\n",
    "    return P\n",
    "\n",
    "@torch.no_grad()\n",
    "def assignments_with_margin(U: torch.Tensor, hidden=32, zeta=1e-2,\n",
    "                            method=\"sinkhorn\", tau=1.0, sinkhorn_iters=12):\n",
    "    K = U.size(1)\n",
    "    head = LinearHeadK(K=K, hidden=hidden, dtype=U.dtype).to(U.device)\n",
    "    logits = head(U)                                     # [n,K]\n",
    "    logits = logits - logits.mean(dim=1, keepdim=True)   # center per row\n",
    "\n",
    "    top2 = torch.topk(logits, k=2, dim=1).values\n",
    "    num = (top2[:, 0] - top2[:, 1]).clamp_min(0.0)\n",
    "    den = top2.abs().sum(dim=1) + zeta\n",
    "    mu = (num / den).unsqueeze(1)  # [n,1]\n",
    "\n",
    "    logits_scaled = mu * logits\n",
    "    if method.lower() == \"sinkhorn\":\n",
    "        S = sinkhorn_balanced(logits_scaled, n_iters=sinkhorn_iters, tau=tau)\n",
    "    else:\n",
    "        S = torch.softmax(logits_scaled, dim=1)\n",
    "    return S, logits, mu.squeeze(1)\n",
    "\n",
    "# ==============================\n",
    "# One coarsening step from (A, X) -> (A_next, X_next) with tree info\n",
    "# ==============================\n",
    "\n",
    "def decide_K(N_cur, ratio, last_level):\n",
    "    if N_cur <= 2 or last_level:\n",
    "        return 1\n",
    "    K = int(N_cur * ratio) + 1\n",
    "    return max(1, min(K, N_cur))\n",
    "\n",
    "def coarsen_adj_hard(A: sp.csr_matrix, hard_labels: np.ndarray, K: int):\n",
    "    rr, cc, vv = sp.find(A)\n",
    "    nrr, ncc = hard_labels[rr], hard_labels[cc]\n",
    "    A_coarse = sp.csr_matrix((vv, (nrr, ncc)), shape=(K, K))\n",
    "    A_coarse = symmetrize_simple(A_coarse)\n",
    "    return A_coarse\n",
    "\n",
    "# ==============================\n",
    "# Main tree builder (outputs same structure)\n",
    "# ==============================\n",
    "import numpy as np\n",
    "\n",
    "def _unique_seeds_for_all_clusters(S: np.ndarray) -> np.ndarray:\n",
    "    \"\"\"\n",
    "    Pick one UNIQUE node per cluster (column) maximizing S[i,k] greedily.\n",
    "    Returns seeds: int array of shape (K,), where seeds[k] is the chosen node index for cluster k.\n",
    "    Guarantees all seeds are distinct (if N >= K).\n",
    "    \"\"\"\n",
    "    N, K = S.shape\n",
    "    # each column sorted by score desc → order[n, k] = node index at rank n for column k\n",
    "    order = np.argsort(-S, axis=0)  # shape (N, K)\n",
    "    seeds = -np.ones(K, dtype=int)\n",
    "    used = np.zeros(N, dtype=bool)\n",
    "    ptr = np.zeros(K, dtype=int)  # pointer into each column's ranking\n",
    "\n",
    "    remaining = list(range(K))\n",
    "    guard = 0\n",
    "    while remaining and guard < K * N:\n",
    "        k = remaining.pop(0)\n",
    "        # advance pointer until we find an unused node\n",
    "        while ptr[k] < N and used[order[ptr[k], k]]:\n",
    "            ptr[k] += 1\n",
    "        if ptr[k] < N:\n",
    "            i = order[ptr[k], k]\n",
    "            seeds[k] = i\n",
    "            used[i] = True\n",
    "        else:\n",
    "            # fallback: if K>N, allow reuse (very rare in your setting)\n",
    "            i = int(np.argmin(used))  # pick any\n",
    "            seeds[k] = i\n",
    "            used[i] = True\n",
    "        guard += 1\n",
    "    return seeds\n",
    "\n",
    "def hard_labels_cover_all(S: np.ndarray) -> np.ndarray:\n",
    "    \"\"\"\n",
    "    Robust: ensures EVERY cluster k gets at least one node, without creating new empties.\n",
    "    1) y = argmax row-wise\n",
    "    2) choose UNIQUE seeds per cluster\n",
    "    3) force seeds: y[seed_k] = k\n",
    "    \"\"\"\n",
    "    N, K = S.shape\n",
    "    y = S.argmax(axis=1)\n",
    "\n",
    "    counts = np.bincount(y, minlength=K)\n",
    "    if (counts == 0).any():\n",
    "        seeds = _unique_seeds_for_all_clusters(S)  # shape (K,)\n",
    "        # Force each cluster's seed to belong to that cluster\n",
    "        # (seeds are unique, so no two clusters take the same node)\n",
    "        y[seeds] = np.arange(K, dtype=int)\n",
    "\n",
    "    return y\n",
    "\n",
    "def Make_tree_HMH(\n",
    "    X, A,\n",
    "    levels: int,\n",
    "    ratio: float = 0.2,\n",
    "    lam: float = 0.1,\n",
    "    k_feat: int = 15,\n",
    "    k_diff: int = 15,\n",
    "    t_heat: float = 0.6,\n",
    "    cheb_order: int = 25,\n",
    "    alpha=(0.5, 0.5),\n",
    "    device: str = \"cpu\",\n",
    "    dtype = torch.float64,\n",
    "    assign_method: str = \"sinkhorn\",\n",
    "    tau: float = 1.0,\n",
    "    sinkhorn_iters: int = 7,\n",
    "    seed: int = 0,\n",
    "):\n",
    "    \"\"\"\n",
    "    Hierarchical graph coarsening using L_mix + λ M_C -> balanced bottom-K -> margin-scaled Sinkhorn.\n",
    "    Returns:\n",
    "        treeG: list of dicts with keys {'IDX','clusters','adj','features'} (length = levels)\n",
    "        S_assign_list: list of numpy arrays (soft assignments) of length levels-1\n",
    "    \"\"\"\n",
    "    set_seed(seed)\n",
    "\n",
    "    # Ensure numpy features\n",
    "    if isinstance(X, torch.Tensor):\n",
    "        X = X.detach().cpu().numpy()\n",
    "    A = A.tocsr()\n",
    "    N_start = A.shape[0]\n",
    "\n",
    "    adj_list = [A]\n",
    "    features_list = [X]\n",
    "    parents = []\n",
    "    S_assign_list = []\n",
    "\n",
    "    for level in range(levels - 1):\n",
    "        #print(f\"--- Coarsening Level {level + 1} ---\")\n",
    "        N_cur = A.shape[0]\n",
    "        last_level = (level == levels - 2)\n",
    "        K = decide_K(N_cur, ratio, last_level)\n",
    "        #print(f\"Current nodes: {N_cur}, coarsening to K={K} clusters.\")\n",
    "        if K == 1:\n",
    "            # terminal: one cluster; make trivial S and break after recording\n",
    "            S_triv = np.ones((N_cur, 1), dtype=np.float64)\n",
    "            S_assign_list.append(S_triv)\n",
    "            parents.append(np.zeros(N_cur, dtype=int))\n",
    "            # Coarsen\n",
    "            X = S_triv.T @ X\n",
    "            A = coarsen_adj_hard(A, np.zeros(N_cur, dtype=int), K=1)\n",
    "            adj_list.append(A)\n",
    "            features_list.append(X)\n",
    "            break\n",
    "\n",
    "        # 1) L_top from A\n",
    "        L_top, deg_top = normalized_laplacian(A)\n",
    "\n",
    "        # 2) L_feat from feature kNN (FAISS)\n",
    "        W_feat = feature_knn_graph_faiss_safe(X, k=k_feat, sigma=None)\n",
    "        L_feat, _ = normalized_laplacian(W_feat)\n",
    "\n",
    "        # 3) L_mix\n",
    "        L_mix = mix_laplacian(L_top, L_feat, alpha=alpha)\n",
    "\n",
    "        # 4) diffusion embedding & balls (FAISS in diffusion space)\n",
    "        Z = heat_kernel_apply(L_mix, t=t_heat, order=cheb_order)\n",
    "        I_diff, _ = diffusion_knn_faiss_dense(Z, k=k_diff)\n",
    "\n",
    "        # 5) incompatibility matrix M_C\n",
    "        #M_C = incompatibility_from_inball(knn_idx, degree=deg_top)\n",
    "        M_C = incompatibility_from_dense_knn(I_diff, degree=deg_top)\n",
    "        # 6) L_aug = L_mix + λ M_C  (torch)\n",
    "        Lmix_sp_t = scipy_to_torch_sparse(L_mix, device=device, dtype=dtype)\n",
    "        MC_sp_t   = scipy_to_torch_sparse(M_C,   device=device, dtype=dtype)\n",
    "        L_aug_t   = (Lmix_sp_t + lam * MC_sp_t).coalesce()\n",
    "\n",
    "        # 7) bottom-K (balanced)\n",
    "        deg_t = torch.from_numpy(deg_top).to(device=device, dtype=dtype)\n",
    "        U_t = block_power_smallest(L_aug_t, K=K, iters=12, deg_C=deg_t)  # [N_cur, K]\n",
    "        # 8) assignments (margin-scaled Sinkhorn)\n",
    "        S_t, logits_t, mu_t = assignments_with_margin(\n",
    "            U_t, hidden=32, zeta=1e-3, method=assign_method, tau=tau, sinkhorn_iters=sinkhorn_iters\n",
    "        )\n",
    "        S_np = S_t.detach().cpu().numpy()\n",
    "        \n",
    "        # 9) hard labels for adjacency coarsen\n",
    "        hard_labels = hard_labels_cover_all(S_np) \n",
    "        #print((hard_labels))\n",
    "        # 10) coarsen adjacency via hard labels\n",
    "        A_next = coarsen_adj_hard(A, hard_labels, K)\n",
    "        adj_list.append(A_next)\n",
    "\n",
    "        # 11) coarsen features via soft S: X' = S^T X\n",
    "        X_next = S_np.T @ X\n",
    "        features_list.append(X_next)\n",
    "\n",
    "        # 12) record and update\n",
    "        parents.append(hard_labels)\n",
    "        S_assign_list.append(S_np)\n",
    "\n",
    "        A, X = A_next, X_next\n",
    "        #print(parents)\n",
    "    # 13) build treeG with SAME fields as your reference\n",
    "    L_eff = len(adj_list)  # = 1 + number of coarsenings actually performed\n",
    "    assert len(features_list) == L_eff\n",
    "    assert len(S_assign_list) == L_eff - 1\n",
    "    assert len(parents)        == L_eff - 1\n",
    "\n",
    "    treeG = [None] * L_eff\n",
    "    for lvl in range(L_eff):\n",
    "        if lvl == 0:\n",
    "            idxs = np.arange(N_start)\n",
    "            clusters = [np.array([i], dtype=int) for i in idxs]   # list of arrays\n",
    "            IDX_vec = np.arange(N_start)\n",
    "        else:\n",
    "            pid = parents[lvl - 1]                     # size = |V^(lvl-1)|\n",
    "            K_lvl = S_assign_list[lvl - 1].shape[1]    # number of clusters at this level\n",
    "            # fixed-K buckets (works even if some labels would be empty)\n",
    "            clusters = [np.flatnonzero(pid == k) for k in range(K_lvl)]\n",
    "            IDX_vec = pid\n",
    "\n",
    "        treeG[lvl] = {\n",
    "            'IDX': IDX_vec,\n",
    "            'clusters': clusters,\n",
    "            'adj': adj_list[lvl],\n",
    "            'features': features_list[lvl]\n",
    "        }\n",
    "\n",
    "\n",
    "    return treeG, S_assign_list\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Given initial features X0 (np array) and adjacency A0 (scipy CSR)\n",
    "treeG, S_list = Make_tree_HMH(\n",
    "    X=X, A=W,\n",
    "    levels=4, ratio=0.2,\n",
    "    lam=0.1, k_feat=15, k_diff=15,\n",
    "    t_heat=0.6, cheb_order=25,\n",
    "    alpha=(0.5, 0.5),\n",
    "    device=\"cpu\", dtype=torch.float64,\n",
    "    assign_method=\"sinkhorn\", tau=0.9, sinkhorn_iters=10,\n",
    "    seed=42\n",
    ")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "21"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(treeG[1]['clusters'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "count=0\n",
    "discovered=set()\n",
    "for cluster in treeG[1]['clusters']:\n",
    "    for node in cluster:\n",
    "        if node not in discovered:\n",
    "         count+=1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "100"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "count"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "21"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(treeG[1]['clusters'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "def HaarGOB_with_Sassign(treeG, S_assign_list):\n",
    "    \"\"\"\n",
    "    Generate class-aware Haar basis using soft assignment matrices.\n",
    "    \n",
    "    INPUT:\n",
    "        treeG: Tree structure from Coarsen_tree.\n",
    "        S_assign_list: List of soft assignment matrices from each level.\n",
    "    \n",
    "    OUTPUT:\n",
    "        treeG: Updated with Haar basis vectors at each level.\n",
    "    \"\"\"\n",
    "    Ntr = len(treeG)\n",
    "    \n",
    "    # Step 1: Global basis at top level\n",
    "    clusterJ0 = treeG[Ntr-1]['clusters']\n",
    "    N0 = len(clusterJ0)\n",
    "    chic = np.identity(N0)\n",
    "    uc = [None] * N0\n",
    "    uc[0] = 1 / np.sqrt(N0) * np.ones(N0)\n",
    "\n",
    "    for l in range(1, N0):\n",
    "        uc[l] = np.sqrt((N0 - l) / (N0 - l + 1)) * (\n",
    "            chic[l-1, :] - 1/(N0 - l) * np.sum(chic[l:, :], axis=0)\n",
    "        )\n",
    "    treeG[Ntr-1]['u'] = uc\n",
    "\n",
    "    # Step 2: Propagate basis using S_assign\n",
    "    for j_tr in np.arange(Ntr-2, -1, -1):\n",
    "        N1 = len(treeG[j_tr]['clusters'])\n",
    "        u = [None] * N1\n",
    "        i = N0  # Index for extended basis vectors\n",
    "\n",
    "        # Use S_assign from current level\n",
    "        S_assign = S_assign_list[j_tr]\n",
    "\n",
    "        for l in range(N0): # Iterate over clusters at current level,inter cluster\n",
    "            clusterl = treeG[j_tr+1]['clusters'][l]\n",
    "            kl = len(clusterl)\n",
    "            ucl = uc[l]\n",
    "\n",
    "            # Step 3: Weighted propagation using soft assignment\n",
    "            ul1 = np.zeros(N1)\n",
    "            for j in range(N0):\n",
    "                idxj = treeG[j_tr+1]['clusters'][j]\n",
    "                cluster_weights = S_assign[idxj, l]  # Use S_assign for weighting\n",
    "                ul1[idxj-1] = ucl[j] * (cluster_weights)  # Weighted by class similarity\n",
    "            u[l] = ul1 / np.sqrt(kl)  # Normalize\n",
    "\n",
    "            # Step 4: Localized differences within clusters (intra-cluster)\n",
    "            if kl > 1:\n",
    "                chil = np.zeros((kl, N1))\n",
    "                for k in range(kl):\n",
    "                    idxl = treeG[j_tr+1]['clusters'][l]\n",
    "                    chil[k, idxl[k]] = 1\n",
    "\n",
    "                for k in range(1, kl):\n",
    "                    i += 1\n",
    "                    ulk = np.sqrt((kl - k) / (kl - k + 1)) * (\n",
    "                        chil[k-1, :] - 1/(kl - k) * np.sum(chil[k:, :], axis=0)\n",
    "                    )\n",
    "                    u[i-1] = ulk\n",
    "\n",
    "        # Update basis for next level\n",
    "        treeG[j_tr]['u'] = u # Update Haar basis vectors #shape (N1, N1)\n",
    "        uc = u\n",
    "        N0 = N1\n",
    "\n",
    "    return treeG "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import scipy.sparse as sp\n",
    "\n",
    "def _deg_vec(A):\n",
    "    d = np.asarray(A.sum(axis=1)).ravel().astype(float)\n",
    "    d[d <= 0.0] = 1e-12\n",
    "    return d\n",
    "\n",
    "def _dnorm(u, d):\n",
    "    # degree-weighted L2 norm: sqrt(u^T D u)\n",
    "    return np.sqrt(float((d * (u * u)).sum()) + 1e-24)\n",
    "\n",
    "def HaarGOB_with_Sassign_degree_norm(treeG, S_assign_list):\n",
    "    \"\"\"\n",
    "    Same as your HaarGOB_with_Sassign, but:\n",
    "      - inter-cluster vectors are normalized by degree norm (||u||_D)\n",
    "      - intra-cluster detail vectors also degree-normalized\n",
    "      - uses ul1[idxj] += ... (fixes idx bug)\n",
    "    \"\"\"\n",
    "    Ntr = len(treeG)\n",
    "\n",
    "    # ----- Step 1: Top (coarsest) level basis -----\n",
    "    clusterJ0 = treeG[Ntr-1]['clusters']\n",
    "    N0 = len(clusterJ0)\n",
    "\n",
    "    # build unweighted Haar-like basis as before\n",
    "    chic = np.identity(N0)\n",
    "    uc = [None] * N0\n",
    "    uc[0] = (1.0 / np.sqrt(N0)) * np.ones(N0, dtype=float)\n",
    "    for l in range(1, N0):\n",
    "        uc[l] = np.sqrt((N0 - l) / (N0 - l + 1.0)) * (\n",
    "            chic[l-1, :] - (1.0 / (N0 - l)) * np.sum(chic[l:, :], axis=0)\n",
    "        )\n",
    "\n",
    "    # degree-normalize each top-level vector\n",
    "    A_top = treeG[Ntr-1]['adj'].tocsr()\n",
    "    d_top = _deg_vec(A_top)\n",
    "    for l in range(N0):\n",
    "        nrm = _dnorm(uc[l], d_top)\n",
    "        uc[l] = uc[l] / nrm\n",
    "\n",
    "    treeG[Ntr-1]['u'] = uc\n",
    "\n",
    "    # ----- Step 2: Propagate with S_assign (degree-normalized) -----\n",
    "    for j_tr in np.arange(Ntr-2, -1, -1):\n",
    "        # sizes\n",
    "        N1 = len(treeG[j_tr]['clusters'])\n",
    "        S_assign = np.asarray(S_assign_list[j_tr], dtype=float)  # shape (N1, N0)\n",
    "        assert S_assign.shape[0] == N1, \"Row count mismatch with current level.\"\n",
    "        assert S_assign.shape[1] == N0, \"Col count mismatch with parent level.\"\n",
    "\n",
    "        # degree vector at this level\n",
    "        A_lvl = treeG[j_tr]['adj'].tocsr()\n",
    "        d_lvl = _deg_vec(A_lvl)\n",
    "\n",
    "        u = [None] * N1\n",
    "        i = N0  # write pointer for intra-cluster details placed after inter-cluster ones\n",
    "\n",
    "        # inter-cluster (parent) vectors\n",
    "        for l in range(N0):\n",
    "            cluster_l = np.asarray(treeG[j_tr+1]['clusters'][l], dtype=int)\n",
    "            # propagate uc[l] down using S\n",
    "            ul1 = np.zeros(N1, dtype=float)\n",
    "            for j in range(N0):\n",
    "                idxj = np.asarray(treeG[j_tr+1]['clusters'][j], dtype=int)\n",
    "                if idxj.size == 0:\n",
    "                    continue\n",
    "                w = S_assign[idxj, l]               # weights for col l on nodes of cluster j\n",
    "                ul1[idxj] += uc[l][j] * w           # ACCUMULATE (fixes idx bug)\n",
    "\n",
    "            # degree-normalize this inter-cluster vector\n",
    "            nrm = _dnorm(ul1, d_lvl)\n",
    "            if nrm > 0:\n",
    "                ul1 = ul1 / nrm\n",
    "            u[l] = ul1\n",
    "\n",
    "            # localized intra-cluster details (same construction, then degree-normalize)\n",
    "            kl = int(cluster_l.size)\n",
    "            if kl > 1:\n",
    "                chil = np.zeros((kl, N1), dtype=float)\n",
    "                for k in range(kl):\n",
    "                    chil[k, cluster_l[k]] = 1.0\n",
    "\n",
    "                for k in range(1, kl):\n",
    "                    i += 1\n",
    "                    ulk = np.sqrt((kl - k) / (kl - k + 1.0)) * (\n",
    "                        chil[k-1, :] - (1.0 / (kl - k)) * np.sum(chil[k:, :], axis=0)\n",
    "                    )\n",
    "                    # degree-normalize detail\n",
    "                    nrmk = _dnorm(ulk, d_lvl)\n",
    "                    if nrmk > 0:\n",
    "                        ulk = ulk / nrmk\n",
    "                    u[i-1] = ulk\n",
    "\n",
    "        # store basis for this level and roll\n",
    "        treeG[j_tr]['u'] = u\n",
    "        uc = u\n",
    "        N0 = N1\n",
    "\n",
    "    return treeG\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[{'IDX': array([ 0,  1,  2,  3,  4,  5,  6,  7,  8,  9, 10, 11, 12, 13, 14, 15, 16,\n",
       "         17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33,\n",
       "         34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50,\n",
       "         51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67,\n",
       "         68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82, 83, 84,\n",
       "         85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99]),\n",
       "  'clusters': [array([0]),\n",
       "   array([1]),\n",
       "   array([2]),\n",
       "   array([3]),\n",
       "   array([4]),\n",
       "   array([5]),\n",
       "   array([6]),\n",
       "   array([7]),\n",
       "   array([8]),\n",
       "   array([9]),\n",
       "   array([10]),\n",
       "   array([11]),\n",
       "   array([12]),\n",
       "   array([13]),\n",
       "   array([14]),\n",
       "   array([15]),\n",
       "   array([16]),\n",
       "   array([17]),\n",
       "   array([18]),\n",
       "   array([19]),\n",
       "   array([20]),\n",
       "   array([21]),\n",
       "   array([22]),\n",
       "   array([23]),\n",
       "   array([24]),\n",
       "   array([25]),\n",
       "   array([26]),\n",
       "   array([27]),\n",
       "   array([28]),\n",
       "   array([29]),\n",
       "   array([30]),\n",
       "   array([31]),\n",
       "   array([32]),\n",
       "   array([33]),\n",
       "   array([34]),\n",
       "   array([35]),\n",
       "   array([36]),\n",
       "   array([37]),\n",
       "   array([38]),\n",
       "   array([39]),\n",
       "   array([40]),\n",
       "   array([41]),\n",
       "   array([42]),\n",
       "   array([43]),\n",
       "   array([44]),\n",
       "   array([45]),\n",
       "   array([46]),\n",
       "   array([47]),\n",
       "   array([48]),\n",
       "   array([49]),\n",
       "   array([50]),\n",
       "   array([51]),\n",
       "   array([52]),\n",
       "   array([53]),\n",
       "   array([54]),\n",
       "   array([55]),\n",
       "   array([56]),\n",
       "   array([57]),\n",
       "   array([58]),\n",
       "   array([59]),\n",
       "   array([60]),\n",
       "   array([61]),\n",
       "   array([62]),\n",
       "   array([63]),\n",
       "   array([64]),\n",
       "   array([65]),\n",
       "   array([66]),\n",
       "   array([67]),\n",
       "   array([68]),\n",
       "   array([69]),\n",
       "   array([70]),\n",
       "   array([71]),\n",
       "   array([72]),\n",
       "   array([73]),\n",
       "   array([74]),\n",
       "   array([75]),\n",
       "   array([76]),\n",
       "   array([77]),\n",
       "   array([78]),\n",
       "   array([79]),\n",
       "   array([80]),\n",
       "   array([81]),\n",
       "   array([82]),\n",
       "   array([83]),\n",
       "   array([84]),\n",
       "   array([85]),\n",
       "   array([86]),\n",
       "   array([87]),\n",
       "   array([88]),\n",
       "   array([89]),\n",
       "   array([90]),\n",
       "   array([91]),\n",
       "   array([92]),\n",
       "   array([93]),\n",
       "   array([94]),\n",
       "   array([95]),\n",
       "   array([96]),\n",
       "   array([97]),\n",
       "   array([98]),\n",
       "   array([99])],\n",
       "  'adj': <100x100 sparse matrix of type '<class 'numpy.float64'>'\n",
       "  \twith 712 stored elements in Compressed Sparse Row format>,\n",
       "  'features': array([[-0.55611875, -0.13006029,  1.66906953, ..., -0.84494144,\n",
       "          -1.49901596, -0.09184476],\n",
       "         [-0.08743533,  0.54831963,  0.94959457, ...,  0.17225439,\n",
       "           0.67153117,  1.52803136],\n",
       "         [ 0.88750397,  0.76084665,  0.06008599, ...,  0.91347373,\n",
       "           0.5376299 ,  0.42818625],\n",
       "         ...,\n",
       "         [ 1.70459209, -1.10811246,  0.97604072, ..., -0.02124478,\n",
       "           0.29353753,  0.24941769],\n",
       "         [-0.32667325,  0.1247521 ,  1.51544481, ...,  0.45061305,\n",
       "           0.0827729 ,  0.03678283],\n",
       "         [-2.38430679,  0.74515086,  0.13416642, ..., -0.65167512,\n",
       "          -2.19438247,  1.59947094]]),\n",
       "  'u': [array([0.03747408, 0.03747374, 0.03748126, 0.03747454, 0.03747697,\n",
       "          0.03747322, 0.03747489, 0.03747447, 0.03747047, 0.03747908,\n",
       "          0.03747516, 0.03747385, 0.03747396, 0.03749176, 0.03748511,\n",
       "          0.0374742 , 0.03747375, 0.03747385, 0.03748424, 0.03746634,\n",
       "          0.03747422, 0.03747378, 0.03748178, 0.03746579, 0.03746671,\n",
       "          0.03747347, 0.03747345, 0.03748251, 0.03747551, 0.037468  ,\n",
       "          0.03747364, 0.03747426, 0.03747351, 0.03747419, 0.03747718,\n",
       "          0.0374761 , 0.03748113, 0.03747462, 0.03747024, 0.03747714,\n",
       "          0.03747723, 0.03747295, 0.03748699, 0.03749558, 0.03747322,\n",
       "          0.03746949, 0.03747196, 0.03746559, 0.03747461, 0.03749385,\n",
       "          0.03747408, 0.0374693 , 0.03747545, 0.03747398, 0.03747536,\n",
       "          0.03746977, 0.03746583, 0.03747493, 0.03746738, 0.03748573,\n",
       "          0.03747564, 0.03747521, 0.03746336, 0.03748204, 0.03749494,\n",
       "          0.03747696, 0.03748236, 0.03747437, 0.03747389, 0.03749271,\n",
       "          0.03747674, 0.03749692, 0.03747644, 0.03747424, 0.03748015,\n",
       "          0.03747575, 0.0374731 , 0.03747404, 0.03747411, 0.03747647,\n",
       "          0.03747299, 0.03747922, 0.03747371, 0.03747382, 0.0374726 ,\n",
       "          0.03747671, 0.03748164, 0.03747285, 0.03747698, 0.03747345,\n",
       "          0.03746795, 0.03747406, 0.03747924, 0.03749566, 0.03747689,\n",
       "          0.03748996, 0.03747483, 0.03747435, 0.03747105, 0.03747413]),\n",
       "   array([-0.01771421, -0.01771616,  0.07084594, -0.01771496, -0.0177151 ,\n",
       "          -0.01771337, -0.017713  , -0.01771736, -0.01771454,  0.07084491,\n",
       "          -0.01771239, -0.01771371, -0.01771388,  0.07085745,  0.07085527,\n",
       "          -0.01771394, -0.01771359, -0.01771386,  0.07084073, -0.01771745,\n",
       "          -0.01771397, -0.01771402,  0.07086549, -0.01771026, -0.01771598,\n",
       "          -0.01771432, -0.01771423,  0.07085183, -0.0177144 , -0.01771085,\n",
       "          -0.01771554, -0.01771317, -0.017714  , -0.01771398, -0.01771216,\n",
       "          -0.01771553,  0.07083997, -0.01771381, -0.01771522, -0.01771472,\n",
       "          -0.01771398, -0.01771295,  0.07085064,  0.07085349, -0.01771382,\n",
       "          -0.01771399, -0.01771361, -0.01771594, -0.01771587,  0.0708633 ,\n",
       "          -0.01771329, -0.01771471, -0.01771308, -0.01771238, -0.01771436,\n",
       "          -0.01771035, -0.01771525, -0.01771173, -0.01771507, -0.01771105,\n",
       "          -0.01771381, -0.01771548, -0.01771488,  0.07085383,  0.07086663,\n",
       "          -0.01771317,  0.07084821, -0.01771698, -0.01771336,  0.07086201,\n",
       "          -0.01771312,  0.07086709, -0.01771399, -0.01771371,  0.07084475,\n",
       "          -0.01771357, -0.01771298, -0.01771405, -0.01771365, -0.01771417,\n",
       "          -0.0177149 ,  0.07084099, -0.01771396, -0.01771376, -0.01771403,\n",
       "          -0.01771394,  0.07086178, -0.01771727, -0.01771501, -0.01771326,\n",
       "          -0.01771413, -0.01771365, -0.01771625,  0.07086143, -0.01771428,\n",
       "           0.07085093, -0.01771437, -0.01771392, -0.01771296, -0.01771378]),\n",
       "   array([-0.02984123, -0.02983693,  0.        ,  0.08952082, -0.02983822,\n",
       "          -0.02984102, -0.02984278, -0.02983636, -0.02983441,  0.        ,\n",
       "          -0.02983708, -0.02984042, -0.02984103,  0.        ,  0.        ,\n",
       "          -0.02983907, -0.02984087, -0.029841  ,  0.        , -0.0298415 ,\n",
       "          -0.02984181, -0.0298408 ,  0.        , -0.0298384 , -0.0298466 ,\n",
       "          -0.0298414 , -0.02984857,  0.        ,  0.08952281, -0.02984553,\n",
       "          -0.02983993, -0.02984147,  0.08952356, -0.02984123, -0.02984291,\n",
       "          -0.02983848,  0.        , -0.0298411 ,  0.08952223, -0.02983607,\n",
       "          -0.02983534, -0.02984059,  0.        ,  0.        , -0.02984119,\n",
       "          -0.0298417 , -0.02984232, -0.0298427 , -0.02983937,  0.        ,\n",
       "          -0.02984591, -0.02984366, -0.02983754, -0.02984362, -0.02984155,\n",
       "          -0.02984068, -0.02984593,  0.08953152, -0.02984013, -0.02983565,\n",
       "          -0.02983786, -0.02983669, -0.02984679,  0.        ,  0.        ,\n",
       "          -0.02984274,  0.        ,  0.08951513, -0.0298415 ,  0.        ,\n",
       "           0.08953427,  0.        , -0.02983792, -0.02984183,  0.        ,\n",
       "          -0.02984141, -0.0298443 , -0.02984096, -0.02984086, -0.02983794,\n",
       "          -0.02983618,  0.        , -0.02984081, -0.02984116, -0.02983917,\n",
       "          -0.02983841,  0.        ,  0.08951429,  0.08951985, -0.02984159,\n",
       "          -0.02984122, -0.02984077,  0.08953507,  0.        , -0.02983734,\n",
       "           0.        , -0.02983878, -0.02984021, -0.0298432 , -0.02984126]),\n",
       "   array([-0.0388039 , -0.03881821,  0.        ,  0.        , -0.0388043 ,\n",
       "          -0.03880413, -0.03880298, -0.03881504, -0.03880365,  0.        ,\n",
       "          -0.03880372, -0.03880533, -0.03880431,  0.        ,  0.        ,\n",
       "          -0.03880281, -0.03880431, -0.03880429,  0.        ,  0.07762015,\n",
       "          -0.03880329, -0.03880421,  0.        , -0.03880309,  0.07762525,\n",
       "          -0.03880387, -0.03880597,  0.        ,  0.        ,  0.07761932,\n",
       "          -0.03880319, -0.0388048 ,  0.        , -0.03880422, -0.03880625,\n",
       "          -0.0388057 ,  0.        , -0.03880403,  0.        , -0.03880486,\n",
       "          -0.03880526, -0.03880527,  0.        ,  0.        , -0.03880407,\n",
       "          -0.03881928, -0.0388028 , -0.03882412, -0.03881828,  0.        ,\n",
       "           0.07761358,  0.07760869, -0.03880377, -0.03880512, -0.0388032 ,\n",
       "          -0.0388085 ,  0.07762555,  0.        , -0.03881591, -0.03880645,\n",
       "          -0.03880551, -0.03881884,  0.07762383,  0.        ,  0.        ,\n",
       "          -0.03880059,  0.        ,  0.        , -0.03880414,  0.        ,\n",
       "           0.        ,  0.        , -0.03880408, -0.03880405,  0.        ,\n",
       "          -0.03880643,  0.077611  , -0.03880409, -0.03880419, -0.03880575,\n",
       "          -0.0388155 ,  0.        , -0.03880423, -0.03880416, -0.03880667,\n",
       "          -0.03880439,  0.        ,  0.        ,  0.        , -0.03880457,\n",
       "          -0.03881782, -0.03880453,  0.        ,  0.        , -0.03880541,\n",
       "           0.        , -0.03881771, -0.03880185,  0.07761077, -0.03880394]),\n",
       "   array([-0.04927075,  0.04925113,  0.        ,  0.        , -0.04926722,\n",
       "          -0.04926882, -0.04927083,  0.04925439, -0.04926875,  0.        ,\n",
       "          -0.04926425, -0.04927174, -0.0492699 ,  0.        ,  0.        ,\n",
       "          -0.04926395, -0.04926936, -0.04926958,  0.        ,  0.        ,\n",
       "          -0.04926786, -0.04926976,  0.        , -0.04925052,  0.        ,\n",
       "          -0.04927007, -0.04926869,  0.        ,  0.        ,  0.        ,\n",
       "          -0.04926647, -0.04926979,  0.        , -0.04927021, -0.04927496,\n",
       "          -0.04926624,  0.        , -0.04927052,  0.        , -0.04926596,\n",
       "          -0.04926261, -0.04926854,  0.        ,  0.        , -0.04926885,\n",
       "           0.04926427, -0.04926119,  0.04926428,  0.04925331,  0.        ,\n",
       "           0.        ,  0.        , -0.04926621, -0.04927017, -0.04926993,\n",
       "          -0.04926943,  0.        ,  0.        ,  0.04926276, -0.04927042,\n",
       "          -0.04926713,  0.04925463,  0.        ,  0.        ,  0.        ,\n",
       "          -0.04926919,  0.        ,  0.        , -0.04926931,  0.        ,\n",
       "           0.        ,  0.        , -0.0492686 , -0.04926944,  0.        ,\n",
       "          -0.04927021,  0.        , -0.04926954, -0.04927   , -0.04926707,\n",
       "           0.04924964,  0.        , -0.04926963, -0.04926955, -0.04926797,\n",
       "          -0.04926866,  0.        ,  0.        ,  0.        , -0.04926999,\n",
       "           0.04926228, -0.04926996,  0.        ,  0.        , -0.04926586,\n",
       "           0.        ,  0.04925056, -0.0492686 ,  0.        , -0.04927015]),\n",
       "   array([ 0.        ,  0.        , -0.03360959,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.03361127,\n",
       "           0.        ,  0.        ,  0.        ,  0.16805943, -0.03361313,\n",
       "           0.        ,  0.        ,  0.        , -0.03361668,  0.        ,\n",
       "           0.        ,  0.        , -0.03361966,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.03361453,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.03361204,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.03361467,  0.16808472,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.03361673,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.03361569, -0.03361281,\n",
       "           0.        , -0.03361251,  0.        ,  0.        ,  0.16807601,\n",
       "           0.        , -0.03361199,  0.        ,  0.        , -0.03361359,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.03361375,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.03361871,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.03360723,  0.        ,\n",
       "           0.16807223,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        , -0.03615819,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.03615668,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.03615797,\n",
       "           0.        ,  0.        ,  0.        , -0.03615999,  0.        ,\n",
       "           0.        ,  0.        ,  0.14461714,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.14462601,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.03615458,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.14462187,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.03615942,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.14463358, -0.03615575,\n",
       "           0.        , -0.03614861,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.0361589 ,  0.        ,  0.        , -0.03615733,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.03615957,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.14459803,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.03613821,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        , -0.07433287,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.07433014,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.07434514,\n",
       "           0.        ,  0.        ,  0.        , -0.07433826,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.07433166,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.07432493,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.07433011,\n",
       "           0.        ,  0.22298352,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.07432548,  0.        ,  0.        , -0.07432699,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.0743304 ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.07433616,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        , -0.07371872,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.07371611,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.07372649,\n",
       "           0.        ,  0.        ,  0.        , -0.07371735,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.07371399,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.1474429 ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.14745337,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.14743969,  0.        ,  0.        , -0.07372086,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.07371911,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.14744096,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        , -0.14433388,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.14433406,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.14433511,\n",
       "           0.        ,  0.        ,  0.        ,  0.14434141,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.14433827,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.14434099,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.14434121,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        , -0.05590808,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.16770304,  0.        ,\n",
       "           0.        ,  0.        ,  0.16770548,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.05590481,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.16771256,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.055911  ,  0.        ,  0.        ,\n",
       "           0.16769615,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.05590553,  0.16769758,  0.        ,\n",
       "           0.        ,  0.        , -0.05589148,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        , -0.13019078,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.13018442,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.13014692,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.13018181,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.26040676,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.16903487,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.16904232,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.16900186,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.16903467,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.09015867,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.1803262 ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.09017206,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.09015766, -0.09016969,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.18033003,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.18034909,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.09016306,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.09016521,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.15252071,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.15249355,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.15249271, -0.1524821 ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.15249775,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.15249947,  0.        ]),\n",
       "   array([ 0.        , -0.11867367,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.11867604,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.11868522,  0.        ,  0.11868067, -0.11867655,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.11868005,  0.        ,\n",
       "           0.        , -0.11869882,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.11866913,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.11867757,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.1186682 ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([-0.04065961,  0.        ,  0.        ,  0.        , -0.04065917,\n",
       "          -0.04066021, -0.04065974,  0.        , -0.04065541,  0.        ,\n",
       "          -0.04065312, -0.04066043, -0.04066054,  0.        ,  0.        ,\n",
       "          -0.04065871, -0.04066088, -0.04066094,  0.        ,  0.        ,\n",
       "          -0.04066045, -0.04066024,  0.        , -0.04065301,  0.        ,\n",
       "          -0.04066218, -0.04064407,  0.        ,  0.        ,  0.        ,\n",
       "          -0.04065059, -0.04066117,  0.        , -0.04066015, -0.0406629 ,\n",
       "          -0.0406594 ,  0.        , -0.04065878,  0.        , -0.04065855,\n",
       "          -0.04065601, -0.04066124,  0.        ,  0.        , -0.0406604 ,\n",
       "           0.        , -0.04065749,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.04065825, -0.04065958, -0.04066026,\n",
       "          -0.04065433,  0.        ,  0.        ,  0.        ,  0.20326222,\n",
       "          -0.04065931,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.04066405,  0.        ,  0.        , -0.04066093,  0.        ,\n",
       "           0.        ,  0.        , -0.04065776, -0.04065878,  0.        ,\n",
       "          -0.04065856,  0.        , -0.04066048, -0.04066122, -0.04065771,\n",
       "           0.        ,  0.        , -0.04066058, -0.04066105, -0.04064646,\n",
       "          -0.04065126,  0.        ,  0.        ,  0.        , -0.04066038,\n",
       "           0.        , -0.04066133,  0.        ,  0.        , -0.04066019,\n",
       "           0.        ,  0.        , -0.04066041,  0.        , -0.04066113]),\n",
       "   array([-0.044282  ,  0.        ,  0.        ,  0.        , -0.04428267,\n",
       "          -0.04428139, -0.04428144,  0.        , -0.0442836 ,  0.        ,\n",
       "          -0.04428018, -0.0442835 , -0.04428196,  0.        ,  0.        ,\n",
       "          -0.04428063, -0.04428201, -0.04428198,  0.        ,  0.        ,\n",
       "          -0.04428136, -0.0442823 ,  0.        ,  0.17711778,  0.        ,\n",
       "          -0.04428258, -0.04428843,  0.        ,  0.        ,  0.        ,\n",
       "          -0.04427847, -0.04428254,  0.        , -0.04428214, -0.04428318,\n",
       "          -0.04428096,  0.        , -0.04428211,  0.        , -0.044283  ,\n",
       "          -0.0442811 , -0.04428246,  0.        ,  0.        , -0.04428153,\n",
       "           0.        ,  0.17711588,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.04428205, -0.04427884, -0.04428177,\n",
       "          -0.04427995,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.04428177,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.04428403,  0.        ,  0.        , -0.04428169,  0.        ,\n",
       "           0.        ,  0.        , -0.0442815 , -0.04428227,  0.        ,\n",
       "          -0.04427928,  0.        , -0.04428225, -0.04428206, -0.0442801 ,\n",
       "           0.        ,  0.        , -0.04428222, -0.04428189, -0.04427599,\n",
       "          -0.04428191,  0.        ,  0.        ,  0.        , -0.04428123,\n",
       "           0.        , -0.04428194,  0.        ,  0.        , -0.04428143,\n",
       "           0.        ,  0.        , -0.04428181,  0.        , -0.04428165]),\n",
       "   array([-0.03165418,  0.        ,  0.        ,  0.        ,  0.09496393,\n",
       "          -0.0316552 , -0.03165408,  0.        ,  0.0949653 ,  0.        ,\n",
       "           0.09496405, -0.03165366, -0.03165484,  0.        ,  0.        ,\n",
       "           0.09495922, -0.03165492, -0.03165483,  0.        ,  0.        ,\n",
       "          -0.03165461, -0.03165462,  0.        ,  0.        ,  0.        ,\n",
       "          -0.03165416, -0.03165075,  0.        ,  0.        ,  0.        ,\n",
       "          -0.03165164, -0.03165532,  0.        , -0.0316548 , -0.03165503,\n",
       "           0.09495751,  0.        , -0.0316544 ,  0.        ,  0.09496654,\n",
       "           0.09496515, -0.03165513,  0.        ,  0.        , -0.03165407,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.09496277, -0.03165469, -0.03165482,\n",
       "          -0.03165569,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.09496476,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.03165816,  0.        ,  0.        , -0.03165492,  0.        ,\n",
       "           0.        ,  0.        ,  0.09496036, -0.03165537,  0.        ,\n",
       "          -0.03165493,  0.        , -0.03165469, -0.03165533,  0.09496246,\n",
       "           0.        ,  0.        , -0.03165459, -0.03165488, -0.03165149,\n",
       "           0.09496359,  0.        ,  0.        ,  0.        , -0.03165505,\n",
       "           0.        , -0.03165531,  0.        ,  0.        ,  0.09496598,\n",
       "           0.        ,  0.        , -0.0316544 ,  0.        , -0.0316543 ]),\n",
       "   array([-0.05933924,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.05933922, -0.05933838,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.05933852, -0.05933937,  0.        ,  0.        ,\n",
       "           0.        , -0.05933959, -0.05933944,  0.        ,  0.        ,\n",
       "          -0.05933761, -0.05933948,  0.        ,  0.        ,  0.        ,\n",
       "          -0.05933553,  0.11869255,  0.        ,  0.        ,  0.        ,\n",
       "           0.11868019, -0.05933942,  0.        , -0.05933907, -0.05933483,\n",
       "           0.        ,  0.        , -0.05933972,  0.        ,  0.        ,\n",
       "           0.        , -0.059338  ,  0.        ,  0.        , -0.05933892,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.05933832, -0.05933757,\n",
       "           0.11867168,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.05933153,  0.        ,  0.        , -0.05933937,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.05934046,  0.        ,\n",
       "          -0.05934253,  0.        , -0.05933982, -0.05933867,  0.        ,\n",
       "           0.        ,  0.        , -0.05933949, -0.05933936, -0.05934515,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.05933865,\n",
       "           0.        , -0.05933865,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.05933677,  0.        , -0.05933912]),\n",
       "   array([ 0.06804003,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.06803934,  0.06804527,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.06804448,  0.06804022,  0.        ,  0.        ,\n",
       "           0.        ,  0.06803994,  0.06803988,  0.        ,  0.        ,\n",
       "           0.06803908,  0.0680405 ,  0.        ,  0.        ,  0.        ,\n",
       "           0.06804255,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.06804023,  0.        ,  0.06804073,  0.0680395 ,\n",
       "           0.        ,  0.        ,  0.06804096,  0.        ,  0.        ,\n",
       "           0.        ,  0.06804411,  0.        ,  0.        ,  0.06804216,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.06803399,  0.06804196,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.06803571,  0.        ,  0.        ,  0.06804045,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.06803684,  0.        ,\n",
       "          -0.06804537,  0.        ,  0.06804039,  0.06803951,  0.        ,\n",
       "           0.        ,  0.        ,  0.06804062,  0.06803919, -0.06806739,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.06803963,\n",
       "           0.        ,  0.06803974,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.06803609,  0.        ,  0.06803963]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.29704426,  0.        , -0.09901475,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.09901475,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.09901475,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.36514837,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.18257419,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.18257419,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.23570226,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.23570226,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.38851434,  0.        ,\n",
       "           0.        ,  0.        , -0.09712859,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.09712859,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.09712859,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.09712859,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.27160724,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.09053575,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.09053575,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.09053575,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.37139068,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.18569534,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.18569534,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.33333333,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.33333333,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.32349832,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.10783277,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.10783277,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.10783277,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.28284271,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.14142136,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.14142136,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.26726124,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.26726124,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.28867513,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.28867513,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.39077377,\n",
       "           0.        ,  0.        ,  0.        , -0.03256448,  0.        ,\n",
       "          -0.03256448,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.03256448,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.03256448,  0.        ,  0.        ,  0.        , -0.03256448,\n",
       "          -0.03256448,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.03256448,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.03256448,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.03256448,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.03256448,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.03256448,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.03256448,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.38915203,  0.        ,\n",
       "          -0.03537746,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.03537746,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.03537746,  0.        ,  0.        ,  0.        , -0.03537746,\n",
       "          -0.03537746,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.03537746,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.03537746,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.03537746,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.03537746,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.03537746,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.03537746,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.36131469,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.03613147,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.03613147,  0.        ,  0.        ,  0.        , -0.03613147,\n",
       "          -0.03613147,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.03613147,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.03613147,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.03613147,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.03613147,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.03613147,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.03613147,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.38516444,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.04279605,  0.        ,  0.        ,  0.        , -0.04279605,\n",
       "          -0.04279605,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.04279605,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.04279605,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.04279605,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.04279605,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.04279605,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.04279605,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.35741364,  0.        ,  0.        ,  0.        , -0.04467671,\n",
       "          -0.04467671,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.04467671,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.04467671,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.04467671,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.04467671,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.04467671,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.04467671,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.29040893,\n",
       "          -0.04148699,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.04148699,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.04148699,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.04148699,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.04148699,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.04148699,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.04148699,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.37796447,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.06299408,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.06299408,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.06299408,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.06299408,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.06299408,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.06299408,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.40032038,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.08006408,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.08006408,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.08006408,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.08006408,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.08006408,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.41931393,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.10482848,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.10482848,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.10482848,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.10482848,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.36650833,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.12216944,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.12216944,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.12216944,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.2773501 ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.13867505,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.13867505,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.28867513,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.28867513,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.26846242,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.06711561,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.06711561,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.06711561,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.06711561,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.30942637,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.10314212,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.10314212,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.10314212,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.30499714,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.15249857,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.15249857,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.25819889,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.25819889,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.36760731,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.07352146,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.07352146,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.07352146,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.07352146,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.07352146,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.38138504,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.09534626,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.09534626,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.09534626,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.09534626,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.27617239,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.09205746,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.09205746,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.09205746,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.34299717,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.17149859,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.17149859,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.26726124,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.26726124,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.26490647,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.13245324,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.13245324,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.24253563,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.24253563,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.33129458,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.11043153,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.11043153,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.11043153,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.28571429,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.14285714,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.14285714,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.21821789,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.21821789,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.37139068,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.18569534,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.18569534,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.24253563,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.24253563,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.35355339,  0.        ,  0.        ,  0.        ,\n",
       "          -0.1767767 ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.1767767 ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.28867513,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.28867513,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.34828996,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.01243893, -0.01243893,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.01243893, -0.01243893,  0.        ,  0.        ,\n",
       "           0.        , -0.01243893, -0.01243893,  0.        ,  0.        ,\n",
       "          -0.01243893, -0.01243893,  0.        ,  0.        ,  0.        ,\n",
       "          -0.01243893,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.01243893,  0.        , -0.01243893, -0.01243893,\n",
       "           0.        ,  0.        , -0.01243893,  0.        ,  0.        ,\n",
       "           0.        , -0.01243893,  0.        ,  0.        , -0.01243893,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.01243893, -0.01243893,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.01243893,  0.        ,  0.        , -0.01243893,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.01243893,  0.        ,\n",
       "           0.        ,  0.        , -0.01243893, -0.01243893,  0.        ,\n",
       "           0.        ,  0.        , -0.01243893, -0.01243893,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.01243893,\n",
       "           0.        , -0.01243893,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.01243893,  0.        , -0.01243893]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.39987934, -0.01481035,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.01481035, -0.01481035,  0.        ,  0.        ,\n",
       "           0.        , -0.01481035, -0.01481035,  0.        ,  0.        ,\n",
       "          -0.01481035, -0.01481035,  0.        ,  0.        ,  0.        ,\n",
       "          -0.01481035,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.01481035,  0.        , -0.01481035, -0.01481035,\n",
       "           0.        ,  0.        , -0.01481035,  0.        ,  0.        ,\n",
       "           0.        , -0.01481035,  0.        ,  0.        , -0.01481035,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.01481035, -0.01481035,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.01481035,  0.        ,  0.        , -0.01481035,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.01481035,  0.        ,\n",
       "           0.        ,  0.        , -0.01481035, -0.01481035,  0.        ,\n",
       "           0.        ,  0.        , -0.01481035, -0.01481035,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.01481035,\n",
       "           0.        , -0.01481035,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.01481035,  0.        , -0.01481035]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.43576099,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.01676004, -0.01676004,  0.        ,  0.        ,\n",
       "           0.        , -0.01676004, -0.01676004,  0.        ,  0.        ,\n",
       "          -0.01676004, -0.01676004,  0.        ,  0.        ,  0.        ,\n",
       "          -0.01676004,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.01676004,  0.        , -0.01676004, -0.01676004,\n",
       "           0.        ,  0.        , -0.01676004,  0.        ,  0.        ,\n",
       "           0.        , -0.01676004,  0.        ,  0.        , -0.01676004,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.01676004, -0.01676004,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.01676004,  0.        ,  0.        , -0.01676004,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.01676004,  0.        ,\n",
       "           0.        ,  0.        , -0.01676004, -0.01676004,  0.        ,\n",
       "           0.        ,  0.        , -0.01676004, -0.01676004,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.01676004,\n",
       "           0.        , -0.01676004,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.01676004,  0.        , -0.01676004]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.31201286, -0.01248051,  0.        ,  0.        ,\n",
       "           0.        , -0.01248051, -0.01248051,  0.        ,  0.        ,\n",
       "          -0.01248051, -0.01248051,  0.        ,  0.        ,  0.        ,\n",
       "          -0.01248051,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.01248051,  0.        , -0.01248051, -0.01248051,\n",
       "           0.        ,  0.        , -0.01248051,  0.        ,  0.        ,\n",
       "           0.        , -0.01248051,  0.        ,  0.        , -0.01248051,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.01248051, -0.01248051,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.01248051,  0.        ,  0.        , -0.01248051,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.01248051,  0.        ,\n",
       "           0.        ,  0.        , -0.01248051, -0.01248051,  0.        ,\n",
       "           0.        ,  0.        , -0.01248051, -0.01248051,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.01248051,\n",
       "           0.        , -0.01248051,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.01248051,  0.        , -0.01248051]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.37054867,  0.        ,  0.        ,\n",
       "           0.        , -0.01543953, -0.01543953,  0.        ,  0.        ,\n",
       "          -0.01543953, -0.01543953,  0.        ,  0.        ,  0.        ,\n",
       "          -0.01543953,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.01543953,  0.        , -0.01543953, -0.01543953,\n",
       "           0.        ,  0.        , -0.01543953,  0.        ,  0.        ,\n",
       "           0.        , -0.01543953,  0.        ,  0.        , -0.01543953,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.01543953, -0.01543953,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.01543953,  0.        ,  0.        , -0.01543953,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.01543953,  0.        ,\n",
       "           0.        ,  0.        , -0.01543953, -0.01543953,  0.        ,\n",
       "           0.        ,  0.        , -0.01543953, -0.01543953,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.01543953,\n",
       "           0.        , -0.01543953,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.01543953,  0.        , -0.01543953]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.37024606, -0.01609765,  0.        ,  0.        ,\n",
       "          -0.01609765, -0.01609765,  0.        ,  0.        ,  0.        ,\n",
       "          -0.01609765,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.01609765,  0.        , -0.01609765, -0.01609765,\n",
       "           0.        ,  0.        , -0.01609765,  0.        ,  0.        ,\n",
       "           0.        , -0.01609765,  0.        ,  0.        , -0.01609765,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.01609765, -0.01609765,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.01609765,  0.        ,  0.        , -0.01609765,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.01609765,  0.        ,\n",
       "           0.        ,  0.        , -0.01609765, -0.01609765,  0.        ,\n",
       "           0.        ,  0.        , -0.01609765, -0.01609765,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.01609765,\n",
       "           0.        , -0.01609765,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.01609765,  0.        , -0.01609765]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.43388201,  0.        ,  0.        ,\n",
       "          -0.01972191, -0.01972191,  0.        ,  0.        ,  0.        ,\n",
       "          -0.01972191,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.01972191,  0.        , -0.01972191, -0.01972191,\n",
       "           0.        ,  0.        , -0.01972191,  0.        ,  0.        ,\n",
       "           0.        , -0.01972191,  0.        ,  0.        , -0.01972191,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.01972191, -0.01972191,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.01972191,  0.        ,  0.        , -0.01972191,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.01972191,  0.        ,\n",
       "           0.        ,  0.        , -0.01972191, -0.01972191,  0.        ,\n",
       "           0.        ,  0.        , -0.01972191, -0.01972191,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.01972191,\n",
       "           0.        , -0.01972191,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.01972191,  0.        , -0.01972191]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.39750205, -0.01892867,  0.        ,  0.        ,  0.        ,\n",
       "          -0.01892867,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.01892867,  0.        , -0.01892867, -0.01892867,\n",
       "           0.        ,  0.        , -0.01892867,  0.        ,  0.        ,\n",
       "           0.        , -0.01892867,  0.        ,  0.        , -0.01892867,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.01892867, -0.01892867,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.01892867,  0.        ,  0.        , -0.01892867,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.01892867,  0.        ,\n",
       "           0.        ,  0.        , -0.01892867, -0.01892867,  0.        ,\n",
       "           0.        ,  0.        , -0.01892867, -0.01892867,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.01892867,\n",
       "           0.        , -0.01892867,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.01892867,  0.        , -0.01892867]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.39691604,  0.        ,  0.        ,  0.        ,\n",
       "          -0.0198458 ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.0198458 ,  0.        , -0.0198458 , -0.0198458 ,\n",
       "           0.        ,  0.        , -0.0198458 ,  0.        ,  0.        ,\n",
       "           0.        , -0.0198458 ,  0.        ,  0.        , -0.0198458 ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.0198458 , -0.0198458 ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.0198458 ,  0.        ,  0.        , -0.0198458 ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.0198458 ,  0.        ,\n",
       "           0.        ,  0.        , -0.0198458 , -0.0198458 ,  0.        ,\n",
       "           0.        ,  0.        , -0.0198458 , -0.0198458 ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.0198458 ,\n",
       "           0.        , -0.0198458 ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.0198458 ,  0.        , -0.0198458 ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.32685829,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.01720307,  0.        , -0.01720307, -0.01720307,\n",
       "           0.        ,  0.        , -0.01720307,  0.        ,  0.        ,\n",
       "           0.        , -0.01720307,  0.        ,  0.        , -0.01720307,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.01720307, -0.01720307,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.01720307,  0.        ,  0.        , -0.01720307,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.01720307,  0.        ,\n",
       "           0.        ,  0.        , -0.01720307, -0.01720307,  0.        ,\n",
       "           0.        ,  0.        , -0.01720307, -0.01720307,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.01720307,\n",
       "           0.        , -0.01720307,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.01720307,  0.        , -0.01720307]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.34551554,  0.        , -0.01919531, -0.01919531,\n",
       "           0.        ,  0.        , -0.01919531,  0.        ,  0.        ,\n",
       "           0.        , -0.01919531,  0.        ,  0.        , -0.01919531,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.01919531, -0.01919531,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.01919531,  0.        ,  0.        , -0.01919531,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.01919531,  0.        ,\n",
       "           0.        ,  0.        , -0.01919531, -0.01919531,  0.        ,\n",
       "           0.        ,  0.        , -0.01919531, -0.01919531,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.01919531,\n",
       "           0.        , -0.01919531,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.01919531,  0.        , -0.01919531]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.34514654, -0.02030274,\n",
       "           0.        ,  0.        , -0.02030274,  0.        ,  0.        ,\n",
       "           0.        , -0.02030274,  0.        ,  0.        , -0.02030274,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.02030274, -0.02030274,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.02030274,  0.        ,  0.        , -0.02030274,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.02030274,  0.        ,\n",
       "           0.        ,  0.        , -0.02030274, -0.02030274,  0.        ,\n",
       "           0.        ,  0.        , -0.02030274, -0.02030274,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.02030274,\n",
       "           0.        , -0.02030274,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.02030274,  0.        , -0.02030274]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.36716181,\n",
       "           0.        ,  0.        , -0.02294761,  0.        ,  0.        ,\n",
       "           0.        , -0.02294761,  0.        ,  0.        , -0.02294761,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.02294761, -0.02294761,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.02294761,  0.        ,  0.        , -0.02294761,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.02294761,  0.        ,\n",
       "           0.        ,  0.        , -0.02294761, -0.02294761,  0.        ,\n",
       "           0.        ,  0.        , -0.02294761, -0.02294761,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.02294761,\n",
       "           0.        , -0.02294761,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.02294761,  0.        , -0.02294761]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.32554892,  0.        ,  0.        ,\n",
       "           0.        , -0.02170326,  0.        ,  0.        , -0.02170326,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.02170326, -0.02170326,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.02170326,  0.        ,  0.        , -0.02170326,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.02170326,  0.        ,\n",
       "           0.        ,  0.        , -0.02170326, -0.02170326,  0.        ,\n",
       "           0.        ,  0.        , -0.02170326, -0.02170326,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.02170326,\n",
       "           0.        , -0.02170326,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.02170326,  0.        , -0.02170326]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.42739376,  0.        ,  0.        , -0.03052813,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.03052813, -0.03052813,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.03052813,  0.        ,  0.        , -0.03052813,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.03052813,  0.        ,\n",
       "           0.        ,  0.        , -0.03052813, -0.03052813,  0.        ,\n",
       "           0.        ,  0.        , -0.03052813, -0.03052813,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.03052813,\n",
       "           0.        , -0.03052813,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.03052813,  0.        , -0.03052813]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.3649325 ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.02807173, -0.02807173,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.02807173,  0.        ,  0.        , -0.02807173,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.02807173,  0.        ,\n",
       "           0.        ,  0.        , -0.02807173, -0.02807173,  0.        ,\n",
       "           0.        ,  0.        , -0.02807173, -0.02807173,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.02807173,\n",
       "           0.        , -0.02807173,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.02807173,  0.        , -0.02807173]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.32385155, -0.02698763,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.02698763,  0.        ,  0.        , -0.02698763,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.02698763,  0.        ,\n",
       "           0.        ,  0.        , -0.02698763, -0.02698763,  0.        ,\n",
       "           0.        ,  0.        , -0.02698763, -0.02698763,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.02698763,\n",
       "           0.        , -0.02698763,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.02698763,  0.        , -0.02698763]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.34158855,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.0310535 ,  0.        ,  0.        , -0.0310535 ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.0310535 ,  0.        ,\n",
       "           0.        ,  0.        , -0.0310535 , -0.0310535 ,  0.        ,\n",
       "           0.        ,  0.        , -0.0310535 , -0.0310535 ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.0310535 ,\n",
       "           0.        , -0.0310535 ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.0310535 ,  0.        , -0.0310535 ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.34079909,  0.        ,  0.        , -0.03407991,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.03407991,  0.        ,\n",
       "           0.        ,  0.        , -0.03407991, -0.03407991,  0.        ,\n",
       "           0.        ,  0.        , -0.03407991, -0.03407991,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.03407991,\n",
       "           0.        , -0.03407991,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.03407991,  0.        , -0.03407991]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.36115756,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.04012862,  0.        ,\n",
       "           0.        ,  0.        , -0.04012862, -0.04012862,  0.        ,\n",
       "           0.        ,  0.        , -0.04012862, -0.04012862,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.04012862,\n",
       "           0.        , -0.04012862,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.04012862,  0.        , -0.04012862]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.38490018,  0.        ,\n",
       "           0.        ,  0.        , -0.04811252, -0.04811252,  0.        ,\n",
       "           0.        ,  0.        , -0.04811252, -0.04811252,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.04811252,\n",
       "           0.        , -0.04811252,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.04811252,  0.        , -0.04811252]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.45184806, -0.06454972,  0.        ,\n",
       "           0.        ,  0.        , -0.06454972, -0.06454972,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.06454972,\n",
       "           0.        , -0.06454972,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.06454972,  0.        , -0.06454972]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.30227563,  0.        ,\n",
       "           0.        ,  0.        , -0.05037927, -0.05037927,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.05037927,\n",
       "           0.        , -0.05037927,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.05037927,  0.        , -0.05037927]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.37476584, -0.07495317,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.07495317,\n",
       "           0.        , -0.07495317,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.07495317,  0.        , -0.07495317]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.42640143,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.10660036,\n",
       "           0.        , -0.10660036,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.10660036,  0.        , -0.10660036]),\n",
       "   array([ 0.   ,  0.   ,  0.   ,  0.   ,  0.   ,  0.   ,  0.   ,  0.   ,\n",
       "           0.   ,  0.   ,  0.   ,  0.   ,  0.   ,  0.   ,  0.   ,  0.   ,\n",
       "           0.   ,  0.   ,  0.   ,  0.   ,  0.   ,  0.   ,  0.   ,  0.   ,\n",
       "           0.   ,  0.   ,  0.   ,  0.   ,  0.   ,  0.   ,  0.   ,  0.   ,\n",
       "           0.   ,  0.   ,  0.   ,  0.   ,  0.   ,  0.   ,  0.   ,  0.   ,\n",
       "           0.   ,  0.   ,  0.   ,  0.   ,  0.   ,  0.   ,  0.   ,  0.   ,\n",
       "           0.   ,  0.   ,  0.   ,  0.   ,  0.   ,  0.   ,  0.   ,  0.   ,\n",
       "           0.   ,  0.   ,  0.   ,  0.   ,  0.   ,  0.   ,  0.   ,  0.   ,\n",
       "           0.   ,  0.   ,  0.   ,  0.   ,  0.   ,  0.   ,  0.   ,  0.   ,\n",
       "           0.   ,  0.   ,  0.   ,  0.   ,  0.   ,  0.   ,  0.   ,  0.   ,\n",
       "           0.   ,  0.   ,  0.   ,  0.   ,  0.   ,  0.   ,  0.   ,  0.   ,\n",
       "           0.   ,  0.375,  0.   , -0.125,  0.   ,  0.   ,  0.   ,  0.   ,\n",
       "           0.   , -0.125,  0.   , -0.125]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.34299717,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        , -0.17149859,  0.        , -0.17149859]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.26726124,  0.        , -0.26726124]),\n",
       "   array([ 0.        ,  0.        ,  0.34340141,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.06868028,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.06868028,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.06868028,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.06868028,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.06868028,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.29250897,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.07312724,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.07312724,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.07312724,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.07312724,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.34641016,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.11547005,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.11547005,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.11547005,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.33333333,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.16666667,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.16666667,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.  ,  0.  ,  0.  ,  0.  ,  0.  ,  0.  ,  0.  ,  0.  ,  0.  ,\n",
       "           0.  ,  0.  ,  0.  ,  0.  ,  0.  ,  0.  ,  0.  ,  0.  ,  0.  ,\n",
       "           0.  ,  0.  ,  0.  ,  0.  ,  0.  ,  0.  ,  0.  ,  0.  ,  0.  ,\n",
       "           0.  ,  0.  ,  0.  ,  0.  ,  0.  ,  0.  ,  0.  ,  0.  ,  0.  ,\n",
       "           0.  ,  0.  ,  0.  ,  0.  ,  0.  ,  0.  ,  0.  ,  0.  ,  0.  ,\n",
       "           0.  ,  0.  ,  0.  ,  0.  ,  0.  ,  0.  ,  0.  ,  0.  ,  0.  ,\n",
       "           0.  ,  0.  ,  0.  ,  0.  ,  0.  ,  0.  ,  0.  ,  0.  ,  0.  ,\n",
       "           0.  ,  0.  ,  0.  ,  0.  ,  0.  ,  0.  ,  0.  ,  0.  ,  0.  ,\n",
       "           0.  ,  0.  ,  0.25,  0.  ,  0.  ,  0.  ,  0.  ,  0.  ,  0.  ,\n",
       "          -0.25,  0.  ,  0.  ,  0.  ,  0.  ,  0.  ,  0.  ,  0.  ,  0.  ,\n",
       "           0.  ,  0.  ,  0.  ,  0.  ,  0.  ,  0.  ,  0.  ,  0.  ,  0.  ,\n",
       "           0.  ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.24253563,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.24253563,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.36066785,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.09016696, -0.09016696,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.09016696,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.09016696,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.31448545, -0.10482848,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.10482848,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.10482848,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.29488391,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        , -0.14744196,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.14744196,  0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.31622777,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.31622777,  0.        ])]},\n",
       " {'IDX': array([16,  9, 18, 10,  6, 16, 16,  9,  6, 18,  6, 16, 16,  4, 18,  6, 16,\n",
       "         16, 12, 17, 16, 16,  7,  5, 14, 16, 15,  7,  2, 20, 15, 16,  2, 16,\n",
       "         16,  6, 18, 16, 13,  6,  6, 16,  7,  4, 16,  1,  5,  1,  9, 11, 20,\n",
       "         20,  6, 16, 16, 15, 14,  2,  1,  0,  6,  9, 14,  7, 11, 16,  8, 10,\n",
       "         16,  4,  2, 11,  6, 16, 18, 19, 20, 16, 16,  6,  9, 18, 16, 16, 19,\n",
       "          6,  7, 10,  2, 16,  1, 16,  3, 11,  6,  4,  9, 16, 20, 16]),\n",
       "  'clusters': [array([59]),\n",
       "   array([45, 47, 58, 90]),\n",
       "   array([28, 32, 57, 70, 88]),\n",
       "   array([92]),\n",
       "   array([13, 43, 69, 95]),\n",
       "   array([23, 46]),\n",
       "   array([ 4,  8, 10, 15, 35, 39, 40, 52, 60, 72, 79, 85, 94]),\n",
       "   array([22, 27, 42, 63, 86]),\n",
       "   array([66]),\n",
       "   array([ 1,  7, 48, 61, 80, 96]),\n",
       "   array([ 3, 67, 87]),\n",
       "   array([49, 64, 71, 93]),\n",
       "   array([18]),\n",
       "   array([38]),\n",
       "   array([24, 56, 62]),\n",
       "   array([26, 30, 55]),\n",
       "   array([ 0,  5,  6, 11, 12, 16, 17, 20, 21, 25, 31, 33, 34, 37, 41, 44, 53,\n",
       "          54, 65, 68, 73, 77, 78, 82, 83, 89, 91, 97, 99]),\n",
       "   array([19]),\n",
       "   array([ 2,  9, 14, 36, 74, 81]),\n",
       "   array([75, 84]),\n",
       "   array([29, 50, 51, 76, 98])],\n",
       "  'adj': <21x21 sparse matrix of type '<class 'numpy.float64'>'\n",
       "  \twith 212 stored elements in Compressed Sparse Row format>,\n",
       "  'features': array([[-0.39186728, -0.28049154, -0.6747428 ,  0.15967481,  0.31503553,\n",
       "          -1.10187901, -1.05508399, -1.11734949,  0.4328678 ,  0.09248296,\n",
       "          -0.39841037,  1.07921431,  0.30353466,  0.24776083, -0.01477471,\n",
       "          -0.41271151],\n",
       "         [-0.39182025, -0.28045236, -0.67466415,  0.15965518,  0.31496399,\n",
       "          -1.10187238, -1.05501077, -1.11740696,  0.43288286,  0.09242221,\n",
       "          -0.398382  ,  1.07911784,  0.30358021,  0.24776586, -0.01485701,\n",
       "          -0.4127461 ],\n",
       "         [-0.3919454 , -0.28052719, -0.67470923,  0.15960403,  0.3150587 ,\n",
       "          -1.10204091, -1.05498716, -1.11738323,  0.43280819,  0.09248771,\n",
       "          -0.39849695,  1.07924619,  0.30349299,  0.24778908, -0.01468074,\n",
       "          -0.4126452 ],\n",
       "         [-0.39189103, -0.28045229, -0.67466732,  0.15968744,  0.31503128,\n",
       "          -1.10197631, -1.05506199, -1.11736737,  0.43284023,  0.09240123,\n",
       "          -0.39842955,  1.07917906,  0.30352058,  0.24772236, -0.01480334,\n",
       "          -0.41269522],\n",
       "         [-0.3918689 , -0.28051192, -0.67466433,  0.15965641,  0.31509905,\n",
       "          -1.10200403, -1.05501791, -1.11733941,  0.43281269,  0.09237934,\n",
       "          -0.39845866,  1.07916282,  0.30355279,  0.24777499, -0.01479127,\n",
       "          -0.41269911],\n",
       "         [-0.39184988, -0.28047161, -0.67477629,  0.15958789,  0.31494562,\n",
       "          -1.10206674, -1.05504494, -1.11736064,  0.43282761,  0.09244904,\n",
       "          -0.3984046 ,  1.07919455,  0.30357966,  0.24774621, -0.01472977,\n",
       "          -0.41266789],\n",
       "         [-0.39173517, -0.28029073, -0.67471924,  0.15964019,  0.31491497,\n",
       "          -1.10195816, -1.05507801, -1.11736734,  0.43284742,  0.09252067,\n",
       "          -0.39830856,  1.07910917,  0.30362598,  0.24769047, -0.01492569,\n",
       "          -0.41270415],\n",
       "         [-0.39179525, -0.28053345, -0.67474933,  0.15969447,  0.31497702,\n",
       "          -1.10189999, -1.05515451, -1.11730733,  0.43289742,  0.0924452 ,\n",
       "          -0.3984085 ,  1.07920511,  0.30350601,  0.24780748, -0.01470208,\n",
       "          -0.41274697],\n",
       "         [-0.39186627, -0.28047201, -0.67474163,  0.15962525,  0.31497042,\n",
       "          -1.10198967, -1.05507563, -1.1173679 ,  0.43285548,  0.09248725,\n",
       "          -0.39844286,  1.07915437,  0.30352916,  0.24774403, -0.01475381,\n",
       "          -0.41265571],\n",
       "         [-0.39186088, -0.28039031, -0.67469393,  0.15963267,  0.31498674,\n",
       "          -1.10194064, -1.05512023, -1.11732435,  0.43285775,  0.09244758,\n",
       "          -0.39841909,  1.07914298,  0.30352185,  0.24764869, -0.01486836,\n",
       "          -0.41268015],\n",
       "         [-0.39187533, -0.28049267, -0.67474752,  0.15957984,  0.31499581,\n",
       "          -1.10194452, -1.05511682, -1.11738022,  0.43281398,  0.09243069,\n",
       "          -0.39839995,  1.07916341,  0.30355849,  0.24777763, -0.01483334,\n",
       "          -0.41268539],\n",
       "         [-0.39186337, -0.28048633, -0.67462992,  0.15968473,  0.31499867,\n",
       "          -1.10207392, -1.05506129, -1.11738018,  0.43288739,  0.09245077,\n",
       "          -0.39848487,  1.07913441,  0.30350654,  0.24774884, -0.01470108,\n",
       "          -0.4126146 ],\n",
       "         [-0.39179377, -0.28039945, -0.67472991,  0.15965928,  0.31496716,\n",
       "          -1.10191429, -1.05513223, -1.11734983,  0.43286371,  0.09247778,\n",
       "          -0.39839842,  1.07917046,  0.30350269,  0.24771417, -0.0147998 ,\n",
       "          -0.41270063],\n",
       "         [-0.39188742, -0.28049262, -0.67474569,  0.15964238,  0.31494319,\n",
       "          -1.10196503, -1.05507723, -1.11735805,  0.43281306,  0.09240362,\n",
       "          -0.39842452,  1.07910603,  0.3034851 ,  0.24776044, -0.01477477,\n",
       "          -0.4126622 ],\n",
       "         [-0.39188541, -0.28053997, -0.67475578,  0.15954121,  0.31495031,\n",
       "          -1.10202955, -1.05505222, -1.11738389,  0.43280914,  0.09244776,\n",
       "          -0.39841103,  1.0791121 ,  0.30352153,  0.24780259, -0.01480941,\n",
       "          -0.41268372],\n",
       "         [-0.39194921, -0.28044892, -0.67480739,  0.15955467,  0.3149971 ,\n",
       "          -1.10194565, -1.05499196, -1.11742482,  0.43272625,  0.09244067,\n",
       "          -0.39840933,  1.07913811,  0.30362756,  0.24779229, -0.01479827,\n",
       "          -0.41279426],\n",
       "         [-0.39191038, -0.28039403, -0.67470045,  0.15970263,  0.31495442,\n",
       "          -1.10195355, -1.05509658, -1.1173596 ,  0.43286692,  0.09260124,\n",
       "          -0.39835287,  1.0790914 ,  0.30351456,  0.24770678, -0.01489026,\n",
       "          -0.41262805],\n",
       "         [-0.39183821, -0.28042037, -0.67471356,  0.15962666,  0.31496541,\n",
       "          -1.10193338, -1.0551004 , -1.11733632,  0.43285445,  0.09245208,\n",
       "          -0.39837735,  1.07913544,  0.30362259,  0.24774015, -0.01485202,\n",
       "          -0.4127235 ],\n",
       "         [-0.39184042, -0.28044733, -0.67474641,  0.15968899,  0.31496905,\n",
       "          -1.10193416, -1.05515352, -1.11730388,  0.43285987,  0.0925222 ,\n",
       "          -0.39841111,  1.07918583,  0.30349105,  0.24775124, -0.01473634,\n",
       "          -0.41270625],\n",
       "         [-0.39181765, -0.28041463, -0.67471457,  0.15960009,  0.31496215,\n",
       "          -1.10201855, -1.05505323, -1.11734507,  0.43285477,  0.09241433,\n",
       "          -0.39843092,  1.07919781,  0.30358284,  0.24770846, -0.01481438,\n",
       "          -0.41270121],\n",
       "         [-0.39181253, -0.28050712, -0.67466122,  0.15962654,  0.31506441,\n",
       "          -1.10197075, -1.05511295, -1.11738775,  0.4328089 ,  0.09233512,\n",
       "          -0.39845793,  1.07910787,  0.30349246,  0.24778235, -0.01485709,\n",
       "          -0.41262058]]),\n",
       "  'u': [array([0.04138318, 0.04136953, 0.04137866, 0.04137867, 0.04139656,\n",
       "          0.04137744, 0.04138009, 0.04138513, 0.04138945, 0.04137696,\n",
       "          0.04137817, 0.04140312, 0.04138776, 0.04137787, 0.04136893,\n",
       "          0.0413753 , 0.04137704, 0.04136957, 0.04138353, 0.041378  ,\n",
       "          0.04137453]),\n",
       "   array([-0.01883157, -0.01883298, -0.01883683, -0.01883576,  0.07533883,\n",
       "          -0.01883519, -0.01883415,  0.07533555,  0.07535164, -0.01883663,\n",
       "          -0.01883623,  0.07535057,  0.07532388, -0.01883608, -0.01883546,\n",
       "          -0.01883305, -0.01883342, -0.01883505,  0.07532739, -0.01883317,\n",
       "          -0.01883191]),\n",
       "   array([-0.03195758, -0.03196334,  0.09587274,  0.09587899,  0.        ,\n",
       "          -0.03196085, -0.03195981,  0.        ,  0.        , -0.03195883,\n",
       "           0.09587817,  0.        ,  0.        ,  0.09587991, -0.03196933,\n",
       "          -0.03196226, -0.0319633 , -0.03196574,  0.        , -0.03196178,\n",
       "          -0.03196652]),\n",
       "   array([-0.04311451, -0.04312498,  0.        ,  0.        ,  0.        ,\n",
       "          -0.04311182, -0.04311023,  0.        ,  0.        , -0.043123  ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.08623731,\n",
       "          -0.04311332, -0.04310902,  0.08623293,  0.        , -0.04310942,\n",
       "           0.08621889]),\n",
       "   array([-0.05679997,  0.05679041,  0.        ,  0.        ,  0.        ,\n",
       "          -0.05679469, -0.05679809,  0.        ,  0.        ,  0.05677984,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.05679958, -0.05679987,  0.        ,  0.        , -0.05680149,\n",
       "           0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.1745012 ,\n",
       "           0.        ,  0.        , -0.03490024, -0.03490024,  0.        ,\n",
       "           0.        , -0.03490024, -0.03490024,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.03490024,  0.        ,\n",
       "           0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.15558197, -0.03889549,  0.        ,\n",
       "           0.        , -0.03889549, -0.03889549,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.03889549,  0.        ,\n",
       "           0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.22808578,  0.        ,\n",
       "           0.        , -0.07602859, -0.07602859,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.07602859,  0.        ,\n",
       "           0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.15617376, -0.07808688,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.07808688,  0.        ,\n",
       "           0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.15075567,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        , -0.15075567,  0.        ,\n",
       "           0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.17320508, -0.05773503,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.05773503,  0.        ,  0.        , -0.05773503,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.26490647,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.13245324,  0.        ,  0.        , -0.13245324,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.17407766,  0.        ,  0.        , -0.17407766,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.19518001,\n",
       "           0.        ,  0.        , -0.09759001,  0.        ,  0.        ,\n",
       "          -0.09759001]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.15617376,  0.        ,  0.        ,\n",
       "          -0.15617376]),\n",
       "   array([ 0.        ,  0.12403473,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        , -0.12403473,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ]),\n",
       "   array([ 0.2216211 ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.04432422, -0.04432422,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.04432422, -0.04432422,  0.        ,  0.        , -0.04432422,\n",
       "           0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.20412415, -0.05103104,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.05103104, -0.05103104,  0.        ,  0.        , -0.05103104,\n",
       "           0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.11242975,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "          -0.03747658, -0.03747658,  0.        ,  0.        , -0.03747658,\n",
       "           0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.13671719, -0.06835859,  0.        ,  0.        , -0.06835859,\n",
       "           0.        ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "           0.        ,  0.08276059,  0.        ,  0.        , -0.08276059,\n",
       "           0.        ])]},\n",
       " {'IDX': array([4, 3, 1, 1, 0, 4, 4, 0, 0, 3, 1, 0, 0, 1, 2, 4, 4, 2, 0, 4, 2]),\n",
       "  'clusters': [array([ 4,  7,  8, 11, 12, 18]),\n",
       "   array([ 2,  3, 10, 13]),\n",
       "   array([14, 17, 20]),\n",
       "   array([1, 9]),\n",
       "   array([ 0,  5,  6, 15, 16, 19])],\n",
       "  'adj': <5x5 sparse matrix of type '<class 'numpy.float64'>'\n",
       "  \twith 20 stored elements in Compressed Sparse Row format>,\n",
       "  'features': array([[-1.64579479, -1.17792738, -2.83381613,  0.67047309,  1.32295021,\n",
       "          -4.62826225, -4.43131672, -4.69291672,  1.81793118,  0.38829989,\n",
       "          -1.6733439 ,  4.53245386,  1.27486985,  1.04054699, -0.06215069,\n",
       "          -1.73329447],\n",
       "         [-1.6457948 , -1.17792738, -2.83381613,  0.67047306,  1.3229502 ,\n",
       "          -4.62826225, -4.43131671, -4.69291673,  1.81793117,  0.38829989,\n",
       "          -1.67334389,  4.53245385,  1.27486986,  1.04054699, -0.06215071,\n",
       "          -1.73329447],\n",
       "         [-1.6457948 , -1.17792737, -2.83381614,  0.67047306,  1.32295019,\n",
       "          -4.62826223, -4.43131671, -4.69291673,  1.81793116,  0.38829989,\n",
       "          -1.67334387,  4.53245384,  1.27486986,  1.04054699, -0.06215073,\n",
       "          -1.73329449],\n",
       "         [-1.6457948 , -1.17792737, -2.83381613,  0.67047307,  1.3229502 ,\n",
       "          -4.62826223, -4.43131671, -4.69291673,  1.81793118,  0.38829989,\n",
       "          -1.67334389,  4.53245385,  1.27486986,  1.04054699, -0.06215071,\n",
       "          -1.73329448],\n",
       "         [-1.64579479, -1.17792736, -2.83381614,  0.67047307,  1.32295019,\n",
       "          -4.62826223, -4.43131672, -4.69291673,  1.81793117,  0.38829989,\n",
       "          -1.67334387,  4.53245385,  1.27486987,  1.04054699, -0.06215073,\n",
       "          -1.73329449]]),\n",
       "  'u': [array([0.04735137, 0.04735137, 0.04735137, 0.04735137, 0.04735137]),\n",
       "   array([ 0.08584798, -0.02146199, -0.02146199, -0.02146199, -0.02146199]),\n",
       "   array([ 0.        ,  0.10639904, -0.03546635, -0.03546635, -0.03546635]),\n",
       "   array([ 0.        ,  0.        ,  0.09759001, -0.048795  , -0.048795  ]),\n",
       "   array([ 0.        ,  0.        ,  0.        ,  0.06681531, -0.06681531])]},\n",
       " {'IDX': array([0, 0, 0, 0, 0]),\n",
       "  'clusters': [array([0, 1, 2, 3, 4])],\n",
       "  'adj': <1x1 sparse matrix of type '<class 'numpy.float64'>'\n",
       "  \twith 0 stored elements in Compressed Sparse Row format>,\n",
       "  'features': array([[ -8.22897398,  -5.88963685, -14.16908068,   3.35236534,\n",
       "            6.61475099, -23.1413112 , -22.15658356, -23.46458364,\n",
       "            9.08965586,   1.94149946,  -8.36671942,  22.66226926,\n",
       "            6.37434929,   5.20273494,  -0.31075356,  -8.6664724 ]]),\n",
       "  'u': [array([999999.9999995])]}]"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "HaarGOB_with_Sassign_degree_norm(treeG, S_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "def extract_haar_basis_and_graph_info(tree_real):\n",
    "    \"\"\"\n",
    "    Build U (per level), edge_index per level, node/edge counts, and features list.\n",
    "    \"\"\"\n",
    "    Tree_length = len(tree_real)\n",
    "    num_nodes_tree = np.zeros(Tree_length, dtype=int)\n",
    "    num_edges_tree = np.zeros(Tree_length, dtype=int)\n",
    "    edge_index_list = [None] * Tree_length\n",
    "    U = []\n",
    "    features_list = []\n",
    "    for j in range(Tree_length):\n",
    "        u = tree_real[j]['u']\n",
    "        N = len(u)\n",
    "        N1 = len(tree_real[j+1]['u']) if j < Tree_length - 1 else 1\n",
    "        HaarBases = np.zeros((N, N1), dtype=np.float64)\n",
    "        for k in range(N1):\n",
    "            HaarBases[:, k] = u[k]\n",
    "        U.append(HaarBases)\n",
    "        num_nodes_tree[j] = N\n",
    "        edge_index, _ = adj2edge(tree_real[j]['adj'])\n",
    "        edge_index_list[j] = edge_index\n",
    "        num_edges_tree[j] = edge_index.size(1)\n",
    "        features_list.append(tree_real[j]['features'])\n",
    "    num_nodes_tree[-1] = 1\n",
    "    num_edges_tree[-1] = 1\n",
    "    return U, num_nodes_tree, num_edges_tree, edge_index_list, features_list"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "# ---------- (D) Batch adapter using our tree & degree-Haar ----------\n",
    "import numpy as np\n",
    "import scipy.sparse as sp\n",
    "import torch\n",
    "def to_scipy_sparse_matrix(edge_index, num_nodes: int):\n",
    "    \"\"\"\n",
    "    edge_index: torch.LongTensor [2,E] or np.ndarray (2,E)\n",
    "    Returns symmetric CSR adjacency with 1-weights.\n",
    "    \"\"\"\n",
    "    if isinstance(edge_index, torch.Tensor):\n",
    "        ei = edge_index.detach().cpu().numpy()\n",
    "    else:\n",
    "        ei = np.asarray(edge_index)\n",
    "    r, c = ei\n",
    "    data = np.ones(r.size, dtype=np.float64)\n",
    "    A = sp.coo_matrix((data, (r, c)), shape=(num_nodes, num_nodes)).tocsr()\n",
    "    # symmetrize simple\n",
    "    A = A.maximum(A.T)\n",
    "    A.setdiag(0)\n",
    "    A.eliminate_zeros()\n",
    "    return A\n",
    "\n",
    "def adj2edge(A: sp.coo_matrix):\n",
    "    \"\"\"\n",
    "    scipy sparse -> torch edge_index (2,E) and weights (E,)\n",
    "    \"\"\"\n",
    "    A = A.tocoo()\n",
    "    row = torch.as_tensor(A.row, dtype=torch.long)\n",
    "    col = torch.as_tensor(A.col, dtype=torch.long)\n",
    "    edge_index = torch.stack([row, col], dim=0)\n",
    "    edge_weight = torch.as_tensor(A.data, dtype=torch.float32)\n",
    "    return edge_index, edge_weight\n",
    "def Uext_batch_from_tree_lists_HMH(\n",
    "    X_list, edge_index_list,\n",
    "    levels=5, ratio=0.3,\n",
    "    lam=0.1, k_feat=15, k_diff=15, t_heat=0.6, cheb_order=25,\n",
    "    alpha=(0.5,0.5),\n",
    "    device=\"cpu\", dtype=torch.float64,\n",
    "    assign_method=\"sinkhorn\", tau=0.9, sinkhorn_iters=10,\n",
    "    seed=42\n",
    "):\n",
    "    U_batch = []\n",
    "    edge_index_list_batch = []\n",
    "    num_nodes_tree_batch  = []\n",
    "    num_edges_tree_batch  = []\n",
    "    features_list_batch   = []\n",
    "    treeG_batch           = []\n",
    "    S_assign_List         = []\n",
    "\n",
    "    for X_i, ei_i in zip(X_list, edge_index_list):\n",
    "        A_i = to_scipy_sparse_matrix(ei_i, num_nodes=X_i.shape[0])\n",
    "        treeG_i, S_assign_list = Make_tree_HMH(\n",
    "            X=X_i, A=A_i,\n",
    "            levels=levels, ratio=ratio,\n",
    "            lam=lam, k_feat=k_feat, k_diff=k_diff, t_heat=t_heat, cheb_order=cheb_order,\n",
    "            alpha=alpha, device=device, dtype=dtype,\n",
    "            assign_method=assign_method, tau=tau, sinkhorn_iters=sinkhorn_iters,\n",
    "            seed=seed\n",
    "        )\n",
    "        treeG_i = HaarGOB_with_Sassign_degree_norm(treeG_i, S_assign_list)\n",
    "        U_i, n_nodes_i, n_edges_i, eidx_i, feats_i = extract_haar_basis_and_graph_info(treeG_i)\n",
    "\n",
    "        U_batch.append(U_i)\n",
    "        edge_index_list_batch.append(eidx_i)\n",
    "        num_nodes_tree_batch.append(n_nodes_i)\n",
    "        num_edges_tree_batch.append(n_edges_i)\n",
    "        features_list_batch.append(feats_i)\n",
    "        treeG_batch.append(treeG_i)\n",
    "        S_assign_List.append(S_assign_list)\n",
    "\n",
    "    return (U_batch, edge_index_list_batch, num_nodes_tree_batch,\n",
    "            num_edges_tree_batch, features_list_batch, treeG_batch, S_assign_List)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "import numpy as np\n",
    "import scipy.sparse as sp\n",
    "\n",
    "# ---- utilities ----\n",
    "def _to_dense_torch(mat, device):\n",
    "    \"\"\"numpy or scipy.spmatrix -> torch.float32 on device\"\"\"\n",
    "    if isinstance(mat, np.ndarray):\n",
    "        arr = mat\n",
    "    elif sp.issparse(mat):\n",
    "        arr = mat.toarray()\n",
    "    else:\n",
    "        arr = np.asarray(mat)\n",
    "    return torch.as_tensor(arr, dtype=torch.float32, device=device)\n",
    "\n",
    "def unpool_one_level(H_coarse, clusters, N_fine):\n",
    "    \"\"\"\n",
    "    Scatter coarser features H_coarse [N_coarse, D] to finer level of size N_fine\n",
    "    using 'clusters' (list of child index arrays for each coarse node).\n",
    "    Returns H_fine [N_fine, D].\n",
    "    \"\"\"\n",
    "    device = H_coarse.device\n",
    "    D = H_coarse.size(1)\n",
    "    H_fine = torch.zeros(N_fine, D, device=device)\n",
    "    # clusters length == N_coarse; clusters[i] are indices at the finer level\n",
    "    for i, child_idx in enumerate(clusters):\n",
    "        if len(child_idx) == 0:\n",
    "            continue\n",
    "        idx = torch.as_tensor(child_idx, dtype=torch.long, device=device)\n",
    "        H_fine.index_add_(0, idx, H_coarse[i].expand(idx.numel(), D))\n",
    "    return H_fine\n",
    "\n",
    "def unpool_to_level0(H_l, level_l, treeG):\n",
    "    \"\"\"\n",
    "    Recursively unpool H_l from level 'level_l' down to level 0 using treeG[level]['clusters'].\n",
    "    treeG[level]['clusters'] is a list where element i holds the child indices at level-1.\n",
    "    \"\"\"\n",
    "    H = H_l\n",
    "    for m in range(level_l, 0, -1):\n",
    "        clusters_m = treeG[m]['clusters']           # children at level m-1\n",
    "        N_fine     = treeG[m-1]['adj'].shape[0]\n",
    "        H = unpool_one_level(H, clusters_m, N_fine) # now at level m-1\n",
    "    return H  # now at level 0\n",
    "\n",
    "# ---- spectral block: U @ (diag(lambda) @ (U^T X)) ----\n",
    "class HaarSpectralBlock(nn.Module):\n",
    "    def __init__(self, max_K: int):\n",
    "        super().__init__()\n",
    "        self.lambda_vec = nn.Parameter(torch.randn(max_K))\n",
    "\n",
    "    def forward(self, U: torch.Tensor, X: torch.Tensor):\n",
    "        # U: [N_l, K_l] (dense), X: [N_l, F] -> H: [N_l, F]\n",
    "         # U: [N_l, K_l], X: [N_l, F]\n",
    "        K_l   = U.size(1)\n",
    "        K_cap = min(K_l, self.lambda_vec.size(0))  # <= max_K\n",
    "\n",
    "        Uc    = U[:, :K_cap]                       # [N_l, K_cap]\n",
    "        X_hat = Uc.transpose(0, 1) @ X             # [K_cap, F]\n",
    "        lam   = self.lambda_vec[:K_cap].unsqueeze(1)  # [K_cap, 1]\n",
    "        X_hat = X_hat * lam                         # [K_cap, F]\n",
    "        H     = Uc @ X_hat                          # [N_l, F]\n",
    "        return F.relu(H)\n",
    "\n",
    "# ---- node classifier that aggregates all levels at level 0 ----\n",
    "class NodeHaarUnpoolClassifier(nn.Module):\n",
    "    \"\"\"\n",
    "    For one graph:\n",
    "      - Applies a shared spectral block per level.\n",
    "      - Unpools each level’s features to level 0 using treeG[level]['clusters'].\n",
    "      - Concatenates per-level contributions at level 0 and classifies nodes.\n",
    "    \"\"\"\n",
    "    def __init__(self, in_dim: int, hid_dim: int, num_classes: int, max_K: int, num_levels: int):\n",
    "        super().__init__()\n",
    "        self.num_levels = num_levels    # how many levels to use (typically L-1; skip last 1-node level)\n",
    "        self.pre = nn.Sequential(\n",
    "            nn.Linear(in_dim, hid_dim),\n",
    "            nn.ReLU(),\n",
    "            nn.Linear(hid_dim, hid_dim)\n",
    "        )\n",
    "        self.block = HaarSpectralBlock(max_K=max_K)\n",
    "        self.classifier = nn.Linear(hid_dim * num_levels, num_classes)\n",
    "        self.dropout = nn.Dropout(p=0.3)\n",
    "\n",
    "    def forward(self, U_list, features_list, treeG):\n",
    "        \"\"\"\n",
    "        U_list:        list of [N_l, K_l] (numpy/scipy or torch), usually levels 0..L-2\n",
    "        features_list: list of [N_l, Fin]  (same levels)\n",
    "        treeG:         list of dicts with 'clusters' and 'adj' for levels 0..L-1\n",
    "        Returns: logits over nodes at level 0, shape [N0, num_classes]\n",
    "        \"\"\"\n",
    "        device = _to_dense_torch(features_list[0],'cuda').device\n",
    "        L_eff = min(self.num_levels, len(U_list))   # safety\n",
    "\n",
    "        # Preproject features at each level to hidden, run spectral block\n",
    "        H_per_level = []\n",
    "        for l in range(L_eff):\n",
    "            X_l = _to_dense_torch(features_list[l], device)   # [N_l, Fin]\n",
    "            X_l = self.dropout(self.pre(X_l))        # [N_l, H]\n",
    "            U_l = _to_dense_torch(U_list[l], device)          # [N_l, K_l]\n",
    "            H_l = self.block(U_l, X_l)                        # [N_l, H]\n",
    "            # Unpool to level 0\n",
    "            H0_l = unpool_to_level0(H_l, level_l=l, treeG=treeG)  # [N0, H]\n",
    "            H_per_level.append(H0_l) # H_per_level[l]: [N0, H] for level l\n",
    "\n",
    "        # Concatenate per-level contributions at level 0\n",
    "        H0_cat = torch.cat(H_per_level, dim=1)      # [N0, H * L_eff]\n",
    "        H0_cat = self.dropout(H0_cat) # [N0, H * L_eff]\n",
    "        logits = self.classifier(H0_cat)            # [N0, C]\n",
    "        return logits # return probabilities over classes\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [],
   "source": [
    "def loss_diversity_from_S(S_assign_list, device=None, eps=1e-9):\n",
    "    \"\"\"\n",
    "    L_div = sum_{ℓ} (1/|V^(ℓ)|) * sum_i H(row_i),\n",
    "    where H(p) = - sum_k p_k log p_k.\n",
    "    \"\"\"\n",
    "    L_div = 0.0\n",
    "    for S in S_assign_list:\n",
    "        # S may be np.ndarray; move to torch\n",
    "        if isinstance(S, np.ndarray):\n",
    "            S_t = torch.from_numpy(S)\n",
    "        else:\n",
    "            S_t = S\n",
    "        if device is not None:\n",
    "            S_t = S_t.to(device)\n",
    "        S_t = S_t.clamp_min(eps)\n",
    "        row_entropy = -(S_t * S_t.log()).sum(dim=1)  # [N_l]\n",
    "        L_div = L_div + row_entropy.mean()\n",
    "    return L_div\n",
    "\n",
    "def loss_reconstruction_from_treeG(treeG, device=None):\n",
    "    \"\"\"\n",
    "    L_rec = sum_{levels} || H^(ℓ) - U^(ℓ)^T (U^(ℓ) H^(ℓ)) ||_F^2,\n",
    "    where U^(ℓ) is built from treeG[ℓ]['u'] (list of N_l vectors of length N_l).\n",
    "    \"\"\"\n",
    "    L_rec = 0.0\n",
    "    for lvl in range(len(treeG)):\n",
    "        if 'u' not in treeG[lvl]:\n",
    "            continue\n",
    "        u_list = treeG[lvl]['u']\n",
    "        # Some levels may store None (skip safely)\n",
    "        if u_list is None or any(v is None for v in u_list):\n",
    "            continue\n",
    "\n",
    "        U_np = np.stack(u_list, axis=0)  # [N_l, N_l]\n",
    "        H_np = treeG[lvl]['features']    # [N_l, D]\n",
    "\n",
    "        U = torch.from_numpy(U_np.astype(np.float32))\n",
    "        H = torch.from_numpy(H_np.astype(np.float32))\n",
    "        if device is not None:\n",
    "            U = U.to(device)\n",
    "            H = H.to(device)\n",
    "\n",
    "        H_hat = U.t() @ (U @ H)          # U^T U H\n",
    "        # Frobenius norm squared\n",
    "        L_rec = L_rec + F.mse_loss(H_hat, H, reduction='sum')\n",
    "    return L_rec"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Device: cuda\n",
      "Using 2 GPUs for DataParallel\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/accl-ros/anaconda3/envs/myenv/lib/python3.12/site-packages/torch/nn/parallel/parallel_apply.py:79: FutureWarning: `torch.cuda.amp.autocast(args...)` is deprecated. Please use `torch.amp.autocast('cuda', args...)` instead.\n",
      "  with torch.cuda.device(device), torch.cuda.stream(stream), autocast(enabled=autocast_enabled):\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 01 | train loss 1.1134 acc 0.636 | val loss 1.0708 acc 0.672 | test acc 0.628 | best@val 0.628\n",
      "Epoch 02 | train loss 1.0795 acc 0.677 | val loss 1.0583 acc 0.700 | test acc 0.634 | best@val 0.634\n",
      "Epoch 03 | train loss 1.0688 acc 0.687 | val loss 1.0619 acc 0.707 | test acc 0.648 | best@val 0.648\n",
      "Epoch 04 | train loss 1.0624 acc 0.693 | val loss 1.0536 acc 0.709 | test acc 0.653 | best@val 0.653\n",
      "Epoch 05 | train loss 1.0581 acc 0.699 | val loss 1.0513 acc 0.709 | test acc 0.662 | best@val 0.653\n",
      "Epoch 06 | train loss 1.0563 acc 0.699 | val loss 1.0429 acc 0.709 | test acc 0.671 | best@val 0.653\n",
      "Epoch 07 | train loss 1.0529 acc 0.701 | val loss 1.0439 acc 0.707 | test acc 0.664 | best@val 0.653\n",
      "Epoch 08 | train loss 1.0505 acc 0.706 | val loss 1.0419 acc 0.711 | test acc 0.678 | best@val 0.678\n",
      "Epoch 09 | train loss 1.0486 acc 0.706 | val loss 1.0407 acc 0.716 | test acc 0.680 | best@val 0.680\n",
      "Epoch 10 | train loss 1.0456 acc 0.708 | val loss 1.0415 acc 0.723 | test acc 0.678 | best@val 0.678\n",
      "Epoch 11 | train loss 1.0441 acc 0.713 | val loss 1.0402 acc 0.723 | test acc 0.671 | best@val 0.678\n",
      "Epoch 12 | train loss 1.0426 acc 0.713 | val loss 1.0414 acc 0.723 | test acc 0.674 | best@val 0.678\n",
      "Epoch 13 | train loss 1.0413 acc 0.714 | val loss 1.0413 acc 0.714 | test acc 0.669 | best@val 0.678\n",
      "Epoch 14 | train loss 1.0393 acc 0.716 | val loss 1.0400 acc 0.718 | test acc 0.671 | best@val 0.678\n",
      "Epoch 15 | train loss 1.0387 acc 0.714 | val loss 1.0393 acc 0.727 | test acc 0.671 | best@val 0.671\n",
      "Epoch 16 | train loss 1.0357 acc 0.715 | val loss 1.0349 acc 0.723 | test acc 0.669 | best@val 0.671\n",
      "Epoch 17 | train loss 1.0344 acc 0.718 | val loss 1.0425 acc 0.730 | test acc 0.657 | best@val 0.657\n",
      "Epoch 18 | train loss 1.0342 acc 0.721 | val loss 1.0366 acc 0.730 | test acc 0.667 | best@val 0.657\n",
      "Epoch 19 | train loss 1.0326 acc 0.719 | val loss 1.0355 acc 0.732 | test acc 0.667 | best@val 0.667\n",
      "Epoch 20 | train loss 1.0322 acc 0.722 | val loss 1.0364 acc 0.727 | test acc 0.667 | best@val 0.667\n",
      "Epoch 21 | train loss 1.0318 acc 0.720 | val loss 1.0349 acc 0.727 | test acc 0.674 | best@val 0.667\n",
      "Epoch 22 | train loss 1.0314 acc 0.725 | val loss 1.0379 acc 0.721 | test acc 0.669 | best@val 0.667\n",
      "Epoch 23 | train loss 1.0307 acc 0.722 | val loss 1.0365 acc 0.723 | test acc 0.667 | best@val 0.667\n",
      "Epoch 24 | train loss 1.0300 acc 0.725 | val loss 1.0409 acc 0.725 | test acc 0.660 | best@val 0.667\n",
      "Epoch 25 | train loss 1.0284 acc 0.725 | val loss 1.0322 acc 0.732 | test acc 0.667 | best@val 0.667\n",
      "Epoch 26 | train loss 1.0293 acc 0.724 | val loss 1.0310 acc 0.714 | test acc 0.664 | best@val 0.667\n",
      "Epoch 27 | train loss 1.0275 acc 0.718 | val loss 1.0333 acc 0.709 | test acc 0.662 | best@val 0.667\n",
      "Epoch 28 | train loss 1.0278 acc 0.726 | val loss 1.0340 acc 0.725 | test acc 0.657 | best@val 0.667\n",
      "Epoch 29 | train loss 1.0264 acc 0.722 | val loss 1.0363 acc 0.716 | test acc 0.655 | best@val 0.667\n",
      "Epoch 30 | train loss 1.0263 acc 0.727 | val loss 1.0302 acc 0.721 | test acc 0.662 | best@val 0.667\n",
      "Epoch 31 | train loss 1.0256 acc 0.724 | val loss 1.0353 acc 0.721 | test acc 0.671 | best@val 0.667\n",
      "Epoch 32 | train loss 1.0257 acc 0.726 | val loss 1.0342 acc 0.718 | test acc 0.662 | best@val 0.667\n",
      "Epoch 33 | train loss 1.0249 acc 0.729 | val loss 1.0345 acc 0.716 | test acc 0.664 | best@val 0.667\n",
      "Epoch 34 | train loss 1.0231 acc 0.725 | val loss 1.0375 acc 0.707 | test acc 0.662 | best@val 0.667\n",
      "Epoch 35 | train loss 1.0220 acc 0.727 | val loss 1.0337 acc 0.714 | test acc 0.664 | best@val 0.667\n",
      "Epoch 36 | train loss 1.0207 acc 0.731 | val loss 1.0318 acc 0.721 | test acc 0.662 | best@val 0.667\n",
      "Epoch 37 | train loss 1.0211 acc 0.728 | val loss 1.0334 acc 0.718 | test acc 0.662 | best@val 0.667\n",
      "Epoch 38 | train loss 1.0199 acc 0.734 | val loss 1.0440 acc 0.723 | test acc 0.669 | best@val 0.667\n",
      "Epoch 39 | train loss 1.0190 acc 0.730 | val loss 1.0394 acc 0.704 | test acc 0.678 | best@val 0.667\n",
      "Epoch 40 | train loss 1.0198 acc 0.728 | val loss 1.0354 acc 0.725 | test acc 0.680 | best@val 0.667\n",
      "Epoch 41 | train loss 1.0186 acc 0.726 | val loss 1.0412 acc 0.709 | test acc 0.669 | best@val 0.667\n",
      "Epoch 42 | train loss 1.0170 acc 0.730 | val loss 1.0420 acc 0.709 | test acc 0.676 | best@val 0.667\n",
      "Epoch 43 | train loss 1.0171 acc 0.731 | val loss 1.0402 acc 0.709 | test acc 0.657 | best@val 0.667\n",
      "Epoch 44 | train loss 1.0165 acc 0.733 | val loss 1.0399 acc 0.718 | test acc 0.667 | best@val 0.667\n",
      "Epoch 45 | train loss 1.0161 acc 0.734 | val loss 1.0435 acc 0.709 | test acc 0.667 | best@val 0.667\n",
      "Epoch 46 | train loss 1.0164 acc 0.733 | val loss 1.0397 acc 0.711 | test acc 0.667 | best@val 0.667\n",
      "Epoch 47 | train loss 1.0160 acc 0.735 | val loss 1.0412 acc 0.714 | test acc 0.667 | best@val 0.667\n",
      "Epoch 48 | train loss 1.0165 acc 0.733 | val loss 1.0396 acc 0.707 | test acc 0.664 | best@val 0.667\n",
      "Epoch 49 | train loss 1.0163 acc 0.731 | val loss 1.0413 acc 0.711 | test acc 0.662 | best@val 0.667\n",
      "Epoch 50 | train loss 1.0153 acc 0.735 | val loss 1.0411 acc 0.723 | test acc 0.657 | best@val 0.667\n",
      "Epoch 51 | train loss 1.0155 acc 0.738 | val loss 1.0376 acc 0.723 | test acc 0.669 | best@val 0.667\n",
      "Epoch 52 | train loss 1.0147 acc 0.734 | val loss 1.0414 acc 0.721 | test acc 0.657 | best@val 0.667\n",
      "Epoch 53 | train loss 1.0147 acc 0.733 | val loss 1.0537 acc 0.716 | test acc 0.660 | best@val 0.667\n",
      "Epoch 54 | train loss 1.0166 acc 0.736 | val loss 1.0371 acc 0.716 | test acc 0.660 | best@val 0.667\n",
      "Epoch 55 | train loss 1.0152 acc 0.736 | val loss 1.0404 acc 0.718 | test acc 0.662 | best@val 0.667\n",
      "Epoch 56 | train loss 1.0146 acc 0.737 | val loss 1.0396 acc 0.718 | test acc 0.662 | best@val 0.667\n",
      "Epoch 57 | train loss 1.0137 acc 0.737 | val loss 1.0445 acc 0.704 | test acc 0.676 | best@val 0.667\n",
      "Epoch 58 | train loss 1.0147 acc 0.737 | val loss 1.0412 acc 0.721 | test acc 0.669 | best@val 0.667\n",
      "Epoch 59 | train loss 1.0140 acc 0.740 | val loss 1.0407 acc 0.711 | test acc 0.683 | best@val 0.667\n",
      "Epoch 60 | train loss 1.0147 acc 0.736 | val loss 1.0359 acc 0.723 | test acc 0.680 | best@val 0.667\n",
      "Epoch 61 | train loss 1.0145 acc 0.741 | val loss 1.0404 acc 0.716 | test acc 0.678 | best@val 0.667\n",
      "Epoch 62 | train loss 1.0138 acc 0.743 | val loss 1.0392 acc 0.718 | test acc 0.678 | best@val 0.667\n",
      "Epoch 63 | train loss 1.0141 acc 0.742 | val loss 1.0398 acc 0.700 | test acc 0.669 | best@val 0.667\n",
      "Epoch 64 | train loss 1.0138 acc 0.737 | val loss 1.0429 acc 0.711 | test acc 0.683 | best@val 0.667\n",
      "Epoch 65 | train loss 1.0130 acc 0.739 | val loss 1.0386 acc 0.707 | test acc 0.676 | best@val 0.667\n",
      "Epoch 66 | train loss 1.0132 acc 0.739 | val loss 1.0362 acc 0.714 | test acc 0.669 | best@val 0.667\n",
      "Epoch 67 | train loss 1.0135 acc 0.741 | val loss 1.0330 acc 0.714 | test acc 0.671 | best@val 0.667\n",
      "Epoch 68 | train loss 1.0152 acc 0.738 | val loss 1.0412 acc 0.709 | test acc 0.667 | best@val 0.667\n",
      "Epoch 69 | train loss 1.0142 acc 0.742 | val loss 1.0420 acc 0.709 | test acc 0.669 | best@val 0.667\n",
      "Epoch 70 | train loss 1.0137 acc 0.741 | val loss 1.0349 acc 0.716 | test acc 0.676 | best@val 0.667\n",
      "Epoch 71 | train loss 1.0134 acc 0.742 | val loss 1.0388 acc 0.718 | test acc 0.678 | best@val 0.667\n",
      "Epoch 72 | train loss 1.0141 acc 0.743 | val loss 1.0356 acc 0.721 | test acc 0.680 | best@val 0.667\n",
      "Epoch 73 | train loss 1.0137 acc 0.737 | val loss 1.0337 acc 0.718 | test acc 0.674 | best@val 0.667\n",
      "Epoch 74 | train loss 1.0133 acc 0.741 | val loss 1.0388 acc 0.718 | test acc 0.676 | best@val 0.667\n",
      "Epoch 75 | train loss 1.0135 acc 0.744 | val loss 1.0413 acc 0.714 | test acc 0.678 | best@val 0.667\n",
      "Epoch 76 | train loss 1.0128 acc 0.747 | val loss 1.0383 acc 0.716 | test acc 0.676 | best@val 0.667\n",
      "Epoch 77 | train loss 1.0125 acc 0.742 | val loss 1.0375 acc 0.723 | test acc 0.657 | best@val 0.667\n",
      "Epoch 78 | train loss 1.0120 acc 0.743 | val loss 1.0358 acc 0.718 | test acc 0.671 | best@val 0.667\n",
      "Epoch 79 | train loss 1.0119 acc 0.741 | val loss 1.0365 acc 0.711 | test acc 0.664 | best@val 0.667\n",
      "Epoch 80 | train loss 1.0110 acc 0.741 | val loss 1.0426 acc 0.718 | test acc 0.669 | best@val 0.667\n",
      "Epoch 81 | train loss 1.0110 acc 0.741 | val loss 1.0447 acc 0.714 | test acc 0.676 | best@val 0.667\n",
      "Epoch 82 | train loss 1.0107 acc 0.742 | val loss 1.0440 acc 0.709 | test acc 0.671 | best@val 0.667\n",
      "Epoch 83 | train loss 1.0110 acc 0.743 | val loss 1.0449 acc 0.709 | test acc 0.683 | best@val 0.667\n",
      "Epoch 84 | train loss 1.0108 acc 0.742 | val loss 1.0451 acc 0.718 | test acc 0.685 | best@val 0.667\n",
      "Epoch 85 | train loss 1.0107 acc 0.741 | val loss 1.0420 acc 0.714 | test acc 0.662 | best@val 0.667\n",
      "Epoch 86 | train loss 1.0099 acc 0.740 | val loss 1.0430 acc 0.718 | test acc 0.680 | best@val 0.667\n",
      "Epoch 87 | train loss 1.0116 acc 0.739 | val loss 1.0384 acc 0.721 | test acc 0.676 | best@val 0.667\n",
      "Epoch 88 | train loss 1.0108 acc 0.743 | val loss 1.0433 acc 0.714 | test acc 0.687 | best@val 0.667\n",
      "Epoch 89 | train loss 1.0105 acc 0.741 | val loss 1.0439 acc 0.721 | test acc 0.674 | best@val 0.667\n",
      "Epoch 90 | train loss 1.0099 acc 0.745 | val loss 1.0443 acc 0.721 | test acc 0.680 | best@val 0.667\n",
      "Epoch 91 | train loss 1.0092 acc 0.744 | val loss 1.0352 acc 0.727 | test acc 0.690 | best@val 0.667\n",
      "Epoch 92 | train loss 1.0093 acc 0.744 | val loss 1.0434 acc 0.716 | test acc 0.683 | best@val 0.667\n",
      "Epoch 93 | train loss 1.0088 acc 0.743 | val loss 1.0389 acc 0.716 | test acc 0.697 | best@val 0.667\n",
      "Epoch 94 | train loss 1.0103 acc 0.743 | val loss 1.0460 acc 0.702 | test acc 0.685 | best@val 0.667\n",
      "Epoch 95 | train loss 1.0094 acc 0.748 | val loss 1.0424 acc 0.721 | test acc 0.683 | best@val 0.667\n",
      "Epoch 96 | train loss 1.0102 acc 0.740 | val loss 1.0428 acc 0.718 | test acc 0.697 | best@val 0.667\n",
      "Epoch 97 | train loss 1.0107 acc 0.740 | val loss 1.0436 acc 0.709 | test acc 0.674 | best@val 0.667\n",
      "Epoch 98 | train loss 1.0100 acc 0.741 | val loss 1.0407 acc 0.711 | test acc 0.685 | best@val 0.667\n",
      "Epoch 99 | train loss 1.0110 acc 0.741 | val loss 1.0491 acc 0.704 | test acc 0.687 | best@val 0.667\n",
      "Epoch 100 | train loss 1.0098 acc 0.744 | val loss 1.0527 acc 0.704 | test acc 0.683 | best@val 0.667\n",
      "Epoch 101 | train loss 1.0100 acc 0.744 | val loss 1.0554 acc 0.716 | test acc 0.687 | best@val 0.667\n",
      "Epoch 102 | train loss 1.0109 acc 0.737 | val loss 1.0442 acc 0.721 | test acc 0.687 | best@val 0.667\n",
      "Epoch 103 | train loss 1.0107 acc 0.741 | val loss 1.0349 acc 0.704 | test acc 0.685 | best@val 0.667\n",
      "Epoch 104 | train loss 1.0100 acc 0.742 | val loss 1.0341 acc 0.695 | test acc 0.685 | best@val 0.667\n",
      "Epoch 105 | train loss 1.0109 acc 0.740 | val loss 1.0388 acc 0.721 | test acc 0.692 | best@val 0.667\n",
      "Epoch 106 | train loss 1.0102 acc 0.739 | val loss 1.0327 acc 0.716 | test acc 0.687 | best@val 0.667\n",
      "Epoch 107 | train loss 1.0100 acc 0.739 | val loss 1.0330 acc 0.721 | test acc 0.708 | best@val 0.667\n",
      "Epoch 108 | train loss 1.0105 acc 0.736 | val loss 1.0401 acc 0.704 | test acc 0.692 | best@val 0.667\n",
      "Epoch 109 | train loss 1.0092 acc 0.738 | val loss 1.0403 acc 0.707 | test acc 0.694 | best@val 0.667\n",
      "Epoch 110 | train loss 1.0103 acc 0.736 | val loss 1.0380 acc 0.716 | test acc 0.692 | best@val 0.667\n",
      "Epoch 111 | train loss 1.0099 acc 0.736 | val loss 1.0415 acc 0.725 | test acc 0.678 | best@val 0.667\n",
      "Epoch 112 | train loss 1.0091 acc 0.741 | val loss 1.0385 acc 0.723 | test acc 0.699 | best@val 0.667\n",
      "Epoch 113 | train loss 1.0094 acc 0.740 | val loss 1.0354 acc 0.714 | test acc 0.697 | best@val 0.667\n",
      "Epoch 114 | train loss 1.0092 acc 0.741 | val loss 1.0392 acc 0.714 | test acc 0.692 | best@val 0.667\n",
      "Epoch 115 | train loss 1.0087 acc 0.741 | val loss 1.0384 acc 0.718 | test acc 0.685 | best@val 0.667\n",
      "Epoch 116 | train loss 1.0101 acc 0.741 | val loss 1.0359 acc 0.716 | test acc 0.690 | best@val 0.667\n",
      "Epoch 117 | train loss 1.0083 acc 0.740 | val loss 1.0372 acc 0.711 | test acc 0.680 | best@val 0.667\n",
      "Epoch 118 | train loss 1.0080 acc 0.745 | val loss 1.0327 acc 0.711 | test acc 0.697 | best@val 0.667\n",
      "Epoch 119 | train loss 1.0080 acc 0.741 | val loss 1.0424 acc 0.718 | test acc 0.683 | best@val 0.667\n",
      "Epoch 120 | train loss 1.0077 acc 0.739 | val loss 1.0394 acc 0.711 | test acc 0.683 | best@val 0.667\n",
      "Epoch 121 | train loss 1.0078 acc 0.740 | val loss 1.0397 acc 0.716 | test acc 0.683 | best@val 0.667\n",
      "Epoch 122 | train loss 1.0075 acc 0.741 | val loss 1.0385 acc 0.711 | test acc 0.692 | best@val 0.667\n",
      "Epoch 123 | train loss 1.0062 acc 0.747 | val loss 1.0434 acc 0.702 | test acc 0.694 | best@val 0.667\n",
      "Epoch 124 | train loss 1.0073 acc 0.740 | val loss 1.0438 acc 0.716 | test acc 0.692 | best@val 0.667\n",
      "Epoch 125 | train loss 1.0052 acc 0.744 | val loss 1.0386 acc 0.714 | test acc 0.692 | best@val 0.667\n",
      "Epoch 126 | train loss 1.0067 acc 0.742 | val loss 1.0405 acc 0.714 | test acc 0.706 | best@val 0.667\n",
      "Epoch 127 | train loss 1.0050 acc 0.739 | val loss 1.0512 acc 0.709 | test acc 0.699 | best@val 0.667\n",
      "Epoch 128 | train loss 1.0049 acc 0.741 | val loss 1.0475 acc 0.709 | test acc 0.692 | best@val 0.667\n",
      "Epoch 129 | train loss 1.0047 acc 0.743 | val loss 1.0360 acc 0.711 | test acc 0.697 | best@val 0.667\n",
      "Epoch 130 | train loss 1.0079 acc 0.742 | val loss 1.0436 acc 0.704 | test acc 0.694 | best@val 0.667\n",
      "Epoch 131 | train loss 1.0041 acc 0.746 | val loss 1.0518 acc 0.702 | test acc 0.690 | best@val 0.667\n",
      "Epoch 132 | train loss 1.0045 acc 0.743 | val loss 1.0494 acc 0.716 | test acc 0.685 | best@val 0.667\n",
      "Epoch 133 | train loss 1.0036 acc 0.744 | val loss 1.0447 acc 0.716 | test acc 0.694 | best@val 0.667\n",
      "Epoch 134 | train loss 1.0033 acc 0.739 | val loss 1.0390 acc 0.711 | test acc 0.701 | best@val 0.667\n",
      "Epoch 135 | train loss 1.0021 acc 0.748 | val loss 1.0445 acc 0.718 | test acc 0.699 | best@val 0.667\n",
      "Epoch 136 | train loss 1.0042 acc 0.740 | val loss 1.0473 acc 0.707 | test acc 0.671 | best@val 0.667\n",
      "Epoch 137 | train loss 1.0018 acc 0.743 | val loss 1.0390 acc 0.725 | test acc 0.692 | best@val 0.667\n",
      "Epoch 138 | train loss 1.0031 acc 0.740 | val loss 1.0404 acc 0.702 | test acc 0.692 | best@val 0.667\n",
      "Epoch 139 | train loss 1.0017 acc 0.741 | val loss 1.0448 acc 0.714 | test acc 0.683 | best@val 0.667\n",
      "Epoch 140 | train loss 1.0019 acc 0.741 | val loss 1.0466 acc 0.718 | test acc 0.683 | best@val 0.667\n",
      "Epoch 141 | train loss 1.0035 acc 0.740 | val loss 1.0449 acc 0.714 | test acc 0.687 | best@val 0.667\n",
      "Epoch 142 | train loss 1.0029 acc 0.742 | val loss 1.0401 acc 0.702 | test acc 0.706 | best@val 0.667\n",
      "Epoch 143 | train loss 1.0016 acc 0.742 | val loss 1.0456 acc 0.709 | test acc 0.694 | best@val 0.667\n",
      "Epoch 144 | train loss 1.0018 acc 0.742 | val loss 1.0430 acc 0.707 | test acc 0.683 | best@val 0.667\n",
      "Epoch 145 | train loss 1.0008 acc 0.742 | val loss 1.0436 acc 0.709 | test acc 0.687 | best@val 0.667\n",
      "Epoch 146 | train loss 1.0013 acc 0.741 | val loss 1.0528 acc 0.709 | test acc 0.676 | best@val 0.667\n",
      "Epoch 147 | train loss 1.0009 acc 0.739 | val loss 1.0393 acc 0.718 | test acc 0.708 | best@val 0.667\n",
      "Epoch 148 | train loss 1.0021 acc 0.742 | val loss 1.0434 acc 0.714 | test acc 0.706 | best@val 0.667\n",
      "Epoch 149 | train loss 1.0021 acc 0.741 | val loss 1.0418 acc 0.707 | test acc 0.685 | best@val 0.667\n",
      "Epoch 150 | train loss 1.0007 acc 0.745 | val loss 1.0390 acc 0.709 | test acc 0.692 | best@val 0.667\n",
      "Done.\n"
     ]
    }
   ],
   "source": [
    "# ============================\n",
    "# MUTAG: data, helpers, model, train/eval\n",
    "# (drop this right after Uext_batch_from_tree_lists_HMH)\n",
    "# ============================\n",
    "\n",
    "import os\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from torch_geometric.loader import DataLoader\n",
    "from torch_geometric.datasets import TUDataset\n",
    "import numpy as np\n",
    "\n",
    "# ---- 0) Device ----\n",
    "device = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\n",
    "print(\"Device:\", device)\n",
    "\n",
    "# ---- 1) Load MUTAG ----\n",
    "root = os.path.join(os.path.abspath(''), 'data', 'Mutagenicity')\n",
    "os.makedirs(root, exist_ok=True)\n",
    "dataset = TUDataset(root, name='Mutagenicity').shuffle()\n",
    "\n",
    "# Basic split\n",
    "num_training = int(0.8 * len(dataset))\n",
    "num_val      = int(0.1 * len(dataset))\n",
    "num_test     = len(dataset) - (num_training + num_val)\n",
    "train_set, val_set, test_set = torch.utils.data.random_split(\n",
    "    dataset, [num_training, num_val, num_test],\n",
    "    generator=torch.Generator().manual_seed(42)\n",
    ")\n",
    "\n",
    "# DataLoaders\n",
    "batch_size = 60\n",
    "train_loader = DataLoader(train_set, batch_size=batch_size, shuffle=True)\n",
    "val_loader   = DataLoader(val_set,   batch_size=batch_size, shuffle=False)\n",
    "test_loader  = DataLoader(test_set,  batch_size=batch_size, shuffle=False)\n",
    "\n",
    "# ---- 2) Small helpers ----\n",
    "\n",
    "def split_batch_to_graphs(batch):\n",
    "    \"\"\"\n",
    "    Convert a PyG Batch into lists (X_list, edge_index_list, y_list),\n",
    "    each element corresponds to one graph.\n",
    "    \"\"\"\n",
    "    data_list = batch.to_data_list()\n",
    "    X_list, edge_index_list, y_list = [], [], []\n",
    "    for data in data_list:\n",
    "        x = data.x\n",
    "        if x is None or x.numel() == 0:\n",
    "            # fallback to constant feature (MUTAG has node labels; but be safe)\n",
    "            x = torch.ones(data.num_nodes, 1, dtype=torch.float32)\n",
    "        X_list.append(x)\n",
    "        edge_index_list.append(data.edge_index)\n",
    "        # MUTAG is graph classification; ensure scalar target per graph\n",
    "        y = data.y.view(-1)[0].long()\n",
    "        y_list.append(y)\n",
    "    return X_list, edge_index_list, y_list\n",
    "\n",
    "# ---- 3) Model (using your NodeHaarUnpoolClassifier block) ----\n",
    "\n",
    "# If you already defined NodeHaarUnpoolClassifier, reuse it.\n",
    "# We'll instantiate it here.\n",
    "num_classes = dataset.num_classes\n",
    "in_dim  = dataset.num_features if dataset.num_features > 0 else 1\n",
    "hid_dim = 32\n",
    "max_K   = 8       # upper bound on K_l per level (MUTAG graphs are tiny; 64 is plenty)\n",
    "levels  = 4        # keep consistent with HMH builder\n",
    "num_levels_for_model = levels - 1  # we use levels 0..L-2\n",
    "\n",
    "model2 = NodeHaarUnpoolClassifier(\n",
    "    in_dim=in_dim,\n",
    "    hid_dim=hid_dim,\n",
    "    num_classes=num_classes,\n",
    "    max_K=max_K,\n",
    "    num_levels=num_levels_for_model\n",
    ").to(device)\n",
    "\n",
    "# Important: return raw logits from the model (make sure your NodeHaarUnpoolClassifier.forward\n",
    "# returns logits, not softmax; CE expects logits)\n",
    "if torch.cuda.device_count() > 1:\n",
    "    print(\"Using\", torch.cuda.device_count(), \"GPUs for DataParallel\")\n",
    "    model2 = nn.DataParallel(model2)\n",
    "\n",
    "opt = torch.optim.Adam(model2.parameters(), lr=3e-3, weight_decay=1e-4)\n",
    "\n",
    "# ---- 4) Loss knobs ----\n",
    "lambda_div = 0.1\n",
    "lambda_rec = 0.1\n",
    "\n",
    "# ---- 5) One epoch runner ----\n",
    "\n",
    "def run_one_epoch(loader, train: bool):\n",
    "    if train:\n",
    "        model2.train()\n",
    "    else:\n",
    "        model2.eval()\n",
    "\n",
    "    total_loss = 0.0\n",
    "    total_correct = 0\n",
    "    total_graphs = 0\n",
    "\n",
    "    for batch in loader:\n",
    "        # Split PyG batch into per-graph lists\n",
    "        X_list, edge_index_list, y_list = split_batch_to_graphs(batch)\n",
    "\n",
    "        # Build trees + Haar (FAISS/Laplacian pipeline)\n",
    "        (U_batch, eidx_batch, n_nodes_batch, n_edges_batch,\n",
    "         feats_batch, tree_batch, S_batch) = Uext_batch_from_tree_lists_HMH(\n",
    "            X_list, edge_index_list,\n",
    "            levels=levels, ratio=0.8,\n",
    "            lam=0.1, k_feat=4, k_diff=4, t_heat=0.6, cheb_order=25,\n",
    "            alpha=(0.5,0.5),\n",
    "            device=\"cpu\", dtype=torch.float64,   # compute trees on CPU (safer for scipy)\n",
    "            assign_method=\"sinkhorn\", tau=0.9, sinkhorn_iters=10,\n",
    "            seed=42\n",
    "        )\n",
    "\n",
    "        # For each graph in the mini-batch\n",
    "        for i in range(len(U_batch)):\n",
    "            # Forward: per-level spectral, unpool to level 0, concat, classify\n",
    "            logits_nodes = model2(U_batch[i], feats_batch[i], tree_batch[i])  # [N0, C] logits\n",
    "            # Pool to graph-level (mean over nodes)\n",
    "            logits_graph = logits_nodes.mean(dim=0, keepdim=True)            # [1, C]\n",
    "\n",
    "            # Target\n",
    "            yi = torch.as_tensor([y_list[i].item()], dtype=torch.long, device=logits_graph.device)\n",
    "\n",
    "            # Core CE loss (graph classification)\n",
    "            L_ce = F.cross_entropy(logits_graph, yi)\n",
    "\n",
    "            # Aux: diversity of S and reconstruction of Haar projections\n",
    "            L_div = loss_diversity_from_S(S_batch[i], device=logits_graph.device)\n",
    "            L_rec = loss_reconstruction_from_treeG(tree_batch[i], device=logits_graph.device)\n",
    "\n",
    "            L_total = 0.8 * L_ce + lambda_div * L_div \n",
    "\n",
    "            if train:\n",
    "                opt.zero_grad()\n",
    "                L_total.backward()\n",
    "                opt.step()\n",
    "\n",
    "            total_loss += L_total.item()\n",
    "\n",
    "            # Accuracy\n",
    "            pred = logits_graph.argmax(dim=1)    # [1]\n",
    "            total_correct += int((pred == yi).sum().item())\n",
    "            total_graphs  += 1\n",
    "\n",
    "    avg_loss = total_loss / max(total_graphs, 1)\n",
    "    acc = total_correct / max(total_graphs, 1)\n",
    "    return avg_loss, acc\n",
    "\n",
    "# ---- 6) Train/Eval loop ----\n",
    "\n",
    "epochs = 150\n",
    "best_val = -1.0\n",
    "best_test_at_val = 0.0\n",
    "\n",
    "for epoch in range(1, epochs + 1):\n",
    "    tr_loss, tr_acc = run_one_epoch(train_loader, train=True)\n",
    "    va_loss, va_acc = run_one_epoch(val_loader,   train=False)\n",
    "    te_loss, te_acc = run_one_epoch(test_loader,  train=False)\n",
    "\n",
    "    if va_acc > best_val:\n",
    "        best_val = va_acc\n",
    "        best_test_at_val = te_acc\n",
    "\n",
    "    print(f\"Epoch {epoch:02d} | \"\n",
    "          f\"train loss {tr_loss:.4f} acc {tr_acc:.3f} | \"\n",
    "          f\"val loss {va_loss:.4f} acc {va_acc:.3f} | \"\n",
    "          f\"test acc {te_acc:.3f} | \"\n",
    "          f\"best@val {best_test_at_val:.3f}\")\n",
    "\n",
    "print(\"Done.\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Downloading https://www.chrsmrrs.com/graphkerneldatasets/PROTEINS.zip\n",
      "Processing...\n",
      "Done!\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "PROTEINS {'dataset': 'PROTEINS', 'H_cos': (0.6604845466398486, 0.17948139076981953), 'H_cos01': (0.830242272978523, 0.08974069524560813), 'H_bin_tau': (0.6604845466398486, 0.17948139076981953), 'avg_nodes': 39.05750224618149, 'avg_edges': 145.6316262353998, 'tau': 0.5, 'num_graphs': 1113}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Downloading https://www.chrsmrrs.com/graphkerneldatasets/MUTAG.zip\n",
      "Processing...\n",
      "Done!\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "MUTAG {'dataset': 'MUTAG', 'H_cos': (0.7015631352650359, 0.1359123434315833), 'H_cos01': (0.8507815593100608, 0.0679561711107959), 'H_bin_tau': (0.7015631352650359, 0.1359123434315833), 'avg_nodes': 17.930851063829788, 'avg_edges': 39.58510638297872, 'tau': 0.5, 'num_graphs': 188}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Downloading https://www.chrsmrrs.com/graphkerneldatasets/DD.zip\n",
      "Processing...\n",
      "Done!\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "DD {'dataset': 'DD', 'H_cos': (0.06851618117154758, 0.01573405083077544), 'H_cos01': (0.5342580906806453, 0.007867026148262162), 'H_bin_tau': (0.06851618117154758, 0.01573405083077544), 'avg_nodes': 284.3166383701188, 'avg_edges': 1431.3174872665534, 'tau': 0.5, 'num_graphs': 1178}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Downloading https://www.chrsmrrs.com/graphkerneldatasets/NCI1.zip\n",
      "Processing...\n",
      "Done!\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "NCI1 {'dataset': 'NCI1', 'H_cos': (0.6239765336261178, 0.13175730002050884), 'H_cos01': (0.8119882644818067, 0.06587864994178486), 'H_bin_tau': (0.6239765336261178, 0.13175730002050884), 'avg_nodes': 29.8654501216545, 'avg_edges': 64.6, 'tau': 0.5, 'num_graphs': 4110}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Downloading https://www.chrsmrrs.com/graphkerneldatasets/NCI109.zip\n",
      "Processing...\n",
      "Done!\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "NCI109 {'dataset': 'NCI109', 'H_cos': (0.6222626229525623, 0.1309172306011759), 'H_cos01': (0.8111313087240616, 0.0654586150525133), 'H_bin_tau': (0.6222626229525623, 0.1309172306011759), 'avg_nodes': 29.681124303368065, 'avg_edges': 64.2616913011873, 'tau': 0.5, 'num_graphs': 4127}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Downloading https://www.chrsmrrs.com/graphkerneldatasets/Mutagenicity.zip\n",
      "Processing...\n",
      "Done!\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Mutagenicity {'dataset': 'Mutagenicity', 'H_cos': (0.369589265379243, 0.14320157887731647), 'H_cos01': (0.6847946321136917, 0.07160078782168121), 'H_bin_tau': (0.369589265379243, 0.14320157887731647), 'avg_nodes': 30.317731150564907, 'avg_edges': 61.53885174083468, 'tau': 0.5, 'num_graphs': 4337}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Downloading https://www.chrsmrrs.com/graphkerneldatasets/IMDB-MULTI.zip\n",
      "Processing...\n",
      "Done!\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "IMDB-MULTI {'dataset': 'IMDB-MULTI', 'H_cos': (1.0, 0.0), 'H_cos01': (1.0, 0.0), 'H_bin_tau': (1.0, 0.0), 'avg_nodes': 13.001333333333333, 'avg_edges': 131.87066666666666, 'tau': 0.5, 'num_graphs': 1500}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Downloading https://www.chrsmrrs.com/graphkerneldatasets/REDDIT-MULTI-12K.zip\n",
      "Processing...\n",
      "Done!\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "REDDIT-MULTI-12K {'dataset': 'REDDIT-MULTI-12K', 'H_cos': (1.0, 0.0), 'H_cos01': (1.0, 0.0), 'H_bin_tau': (1.0, 0.0), 'avg_nodes': 391.4088356106966, 'avg_edges': 913.780367172437, 'tau': 0.5, 'num_graphs': 11929}\n",
      "\n",
      "% LaTeX table rows:\n",
      "PROTEINS & 83.0$\\pm$9.0 & 66.0$\\pm$17.9 & 39.06 & 145.63 & 1113 \\\\\n",
      "MUTAG & 85.1$\\pm$6.8 & 70.2$\\pm$13.6 & 17.93 & 39.59 & 188 \\\\\n",
      "DD & 53.4$\\pm$0.8 & 6.9$\\pm$1.6 & 284.32 & 1431.32 & 1178 \\\\\n",
      "NCI1 & 81.2$\\pm$6.6 & 62.4$\\pm$13.2 & 29.87 & 64.60 & 4110 \\\\\n",
      "NCI109 & 81.1$\\pm$6.5 & 62.2$\\pm$13.1 & 29.68 & 64.26 & 4127 \\\\\n",
      "Mutagenicity & 68.5$\\pm$7.2 & 37.0$\\pm$14.3 & 30.32 & 61.54 & 4337 \\\\\n",
      "IMDB-MULTI & 100.0$\\pm$0.0 & 100.0$\\pm$0.0 & 13.00 & 131.87 & 1500 \\\\\n",
      "REDDIT-MULTI-12K & 100.0$\\pm$0.0 & 100.0$\\pm$0.0 & 391.41 & 913.78 & 11929 \\\\\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import numpy as np\n",
    "import torch\n",
    "from torch_geometric.datasets import TUDataset\n",
    "from torch_geometric.utils import to_undirected\n",
    "\n",
    "@torch.no_grad()\n",
    "def _normalize_rows(x: torch.Tensor, eps=1e-12):\n",
    "    n = torch.linalg.norm(x, dim=1, keepdim=True).clamp_min(eps)\n",
    "    return x / n\n",
    "\n",
    "@torch.no_grad()\n",
    "def feature_homophily_one_graph(x: torch.Tensor,\n",
    "                                edge_index: torch.Tensor,\n",
    "                                tau: float = 0.5):\n",
    "    \"\"\"\n",
    "    Returns dict with H_cos (mean), H_cos01 (mapped to [0,1]),\n",
    "    H_bin_tau (fraction of edges with cosine >= tau), and basic counts.\n",
    "    \"\"\"\n",
    "    if x is None or x.numel() == 0:\n",
    "        # fallback: degree as a 1-d feature\n",
    "        N = int(edge_index.max().item()) + 1\n",
    "        deg = torch.bincount(edge_index[0], minlength=N).float().unsqueeze(1)\n",
    "        x = deg\n",
    "\n",
    "    # undirected, drop self-loops, coalesce\n",
    "    ei = to_undirected(edge_index)\n",
    "    mask = ei[0] != ei[1]\n",
    "    ei = ei[:, mask]\n",
    "\n",
    "    x_norm = _normalize_rows(x.float())\n",
    "    u, v = ei[0].long(), ei[1].long()\n",
    "    cos = (x_norm[u] * x_norm[v]).sum(dim=1)                # [|E|], in [-1,1]\n",
    "    H_cos = cos.mean().item()\n",
    "    H_cos01 = ((cos + 1.0) * 0.5).mean().item()             # map to [0,1]\n",
    "    H_bin = (cos >= tau).float().mean().item()\n",
    "    return {\n",
    "        \"H_cos\": H_cos,\n",
    "        \"H_cos01\": H_cos01,\n",
    "        \"H_bin_tau\": H_bin,\n",
    "        \"E\": ei.size(1),\n",
    "        \"N\": int(x.size(0))\n",
    "    }\n",
    "\n",
    "@torch.no_grad()\n",
    "def feature_homophily_dataset(root, name, tau=0.5, seed=42):\n",
    "    torch.manual_seed(seed)\n",
    "    ds = TUDataset(root, name=name)\n",
    "    vals_cos, vals_cos01, vals_bin = [], [], []\n",
    "    n_nodes, n_edges = [], []\n",
    "    for data in ds:\n",
    "        x = data.x\n",
    "        if x is None:\n",
    "            # Some TU sets lack x; fallback to degree\n",
    "            N = data.num_nodes\n",
    "            deg = torch.bincount(data.edge_index[0], minlength=N).float().unsqueeze(1)\n",
    "            x = deg\n",
    "        out = feature_homophily_one_graph(x, data.edge_index, tau=tau)\n",
    "        vals_cos.append(out[\"H_cos\"])\n",
    "        vals_cos01.append(out[\"H_cos01\"])\n",
    "        vals_bin.append(out[\"H_bin_tau\"])\n",
    "        n_nodes.append(out[\"N\"]); n_edges.append(out[\"E\"])\n",
    "    def ms(x): return (float(np.mean(x)), float(np.std(x)))\n",
    "    return {\n",
    "        \"dataset\": name,\n",
    "        \"H_cos\": ms(vals_cos),\n",
    "        \"H_cos01\": ms(vals_cos01),\n",
    "        \"H_bin_tau\": ms(vals_bin),\n",
    "        \"avg_nodes\": float(np.mean(n_nodes)),\n",
    "        \"avg_edges\": float(np.mean(n_edges)),\n",
    "        \"tau\": tau,\n",
    "        \"num_graphs\": len(ds)\n",
    "    }\n",
    "\n",
    "# ---- Run on your graph-classification sets (adjust names as needed) ----\n",
    "root = os.path.join(os.path.abspath(''), 'data')\n",
    "names = [\n",
    "    \"PROTEINS\", \"MUTAG\", \"DD\", \"NCI1\", \"NCI109\", \"Mutagenicity\", \"IMDB-MULTI\", \"REDDIT-MULTI-12K\"\n",
    "]\n",
    "results = []\n",
    "for nm in names:\n",
    "    try:\n",
    "        res = feature_homophily_dataset(root, nm, tau=0.5)\n",
    "        results.append(res)\n",
    "        print(nm, res)\n",
    "    except Exception as e:\n",
    "        print(f\"[WARN] {nm}: {e}\")\n",
    "\n",
    "# Optionally: emit LaTeX rows\n",
    "def latex_row(r):\n",
    "    m1,s1 = r[\"H_cos01\"]; m2,s2 = r[\"H_bin_tau\"]\n",
    "    return (f\"{r['dataset']} & \"\n",
    "            f\"{m1*100:.1f}$\\\\pm${s1*100:.1f} & \"\n",
    "            f\"{m2*100:.1f}$\\\\pm${s2*100:.1f} & \"\n",
    "            f\"{r['avg_nodes']:.2f} & {r['avg_edges']:.2f} & \"\n",
    "            f\"{r['num_graphs']} \\\\\\\\\")\n",
    "print(\"\\n% LaTeX table rows:\")\n",
    "for r in results:\n",
    "    print(latex_row(r))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "            Dataset  H_cos01_mean  H_cos01_std  H_bin_mean  H_bin_std  \\\n",
      "0          PROTEINS      0.830242     0.089741    0.660485   0.179481   \n",
      "1             MUTAG      0.850782     0.067956    0.701563   0.135912   \n",
      "2                DD      0.534258     0.007867    0.068516   0.015734   \n",
      "3              NCI1      0.811988     0.065879    0.623977   0.131757   \n",
      "4            NCI109      0.811131     0.065459    0.622263   0.130917   \n",
      "5      Mutagenicity      0.684795     0.071601    0.369589   0.143202   \n",
      "6        IMDB-MULTI      1.000000     0.000000    1.000000   0.000000   \n",
      "7  REDDIT-MULTI-12K      1.000000     0.000000    1.000000   0.000000   \n",
      "\n",
      "    avg_nodes    avg_edges  num_graphs  tau  \n",
      "0   39.057502   145.631626        1113  0.5  \n",
      "1   17.930851    39.585106         188  0.5  \n",
      "2  284.316638  1431.317487        1178  0.5  \n",
      "3   29.865450    64.600000        4110  0.5  \n",
      "4   29.681124    64.261691        4127  0.5  \n",
      "5   30.317731    61.538852        4337  0.5  \n",
      "6   13.001333   131.870667        1500  0.5  \n",
      "7  391.408836   913.780367       11929  0.5  \n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABDwAAAGTCAYAAADEGAJ/AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8hTgPZAAAACXBIWXMAAA9hAAAPYQGoP6dpAAC/OElEQVR4nOzdd3hTZRsG8Psk3buljFJGy94gS1SQJUO2gGyQIaAIfIiKsssQZKggomxEmVJRkSlTAcGyt1BGaSktLd17JO/3R+lp0rSQpmmSlvt3XV6S55ycPKdP8iZ58p5zJCGEABERERERERFRCaIwdwJERERERERERMbGhgcRERERERERlThseBARERERERFRicOGBxERERERERGVOGx4EBEREREREVGJw4YHEREREREREZU4bHgQERERERERUYnDhgcRERERERERlThseBARERERERFRicOGBxERERERERGVOFbmToCIiIiIiMhUbt68iY8//hhTpkxB69atER4ejhUrVqBatWpQqVR49913AQBr166FWq1GREQE3n33XXh5eWlt59SpU/j7779hZ2eHZs2aoWXLlszZjIrj36g45lzsCCIiIiIiohfIwIEDxbFjx4QQQvTu3VvcvHlTCCHEyJEjxZUrV8SlS5fEoEGDhBBC3L9/X7z99tta909NTRVNmjQRKpVKCCHE66+/LlJSUpizmRXHv1FxzLk44SEtRERERET0QrGxsQEApKWl4eDBg6hVqxYAoH79+vj111+xa9cu1KlTBwDg4+ODY8eOQaVSyff/559/4O7uDoUi6+uUu7s7AgICmLOZFce/UXHMuThhw4OIiIiIiF5I0dHRcHR0lG/b2dnh0aNHCA8Ph4eHhxxXKpWIjIyUb+denn0/5mwZiuPfqDjmXBzwHB5ERERERPRC8vT0RFpamnw7ISEBZcqUAQAkJSXJ8dTUVLi7u8u3y5Ytq7Vc835FrTjmbGrF8W9UHHMuDjjDg4iIiIiIXkjW1tZo164dbt26BQC4du0aevXqhT59+uDChQsAgHv37qF169awtbVFXFwc0tPT0bJlS4SFhUEIAQCIiIjAa6+9xpwtRHH8GxXHnIsDSWT/ZYiIiIiIiEq4Bw8eYODAgejatSsmT56MJ0+eYMWKFahRowYyMzPx3nvvAQCWLVsGR0dHhISEYMyYMahQoQLGjx+P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GNTwOHnyJP766y9cunQJVlY5m1CpVAgLCzNackTPwum2RERERERElB+DGh4ffPABPv/88zzP1/H9998XOikifXC6LREREREREeXHoIZH9+7d5X9HR0fDysoKLi4uAID333/fOJkRERERERERERnIoDM6SpKEn3/+GVWrVkXp0qXh7u6OZs2a4cCBA8bOj4iIiIiIiIiowAya4bFx40aMHj0a3bp1w/Dhw1GuXDlERUXBz88PKSkpeOutt4ydJxERERERERGR3gxqeKxZswYXLlxAgwYNtOKffPIJRo8ezYYHEREREREREZmVQYe0NGvWTKfZAQBKpRIqlarQSRERERERERERFYZBDY/09HSkp6frxH/++WdcvXq10EkRERERERERERWGQYe0DBkyBPXq1UP79u3h6uqKx48f46+//kJISAh27txp7ByJiIiIiIiIiArEoBkeLVu2hL+/PyIjI7F27Vr8/vvvqFGjBo4dO4ZevXoZOUUiIiIiIiIiooIxaIYHADRo0AD+/v468dDQUHh7excqKSIiIiIiIiKiwjC44REbG4s7d+4gNTUVarUaAKBSqbBhwwb89NNPRkuQiIiIiIiIiKigDGp4LFq0CLNmzUJmZiaEEFrLJEliw4OIiIiIiIiIzMqghsf8+fPx8ccfY8iQIbC3t4ckSQAAIQS+/fZboyZIRERERERERFRQBjU8GjVqhA8++ADly5fXWfbhhx8WOikiIiIiIiIiosIw6CotmzZtws8//5znsj179hQqISIiIiIiIiKiwtJrhkfDhg2RkJCgFYuPj8eyZcugUOT0TNRqNcLCwjB27FjjZqkhOjoatWrVws8//4w2bdoAAGJiYjBhwgR4enoiPDwcc+fORY0aNYosByIiIiIiIiKybHo1PFq1aoXHjx+jTp06Wg2O3DIzM/HHH38YLbm8TJkyBZGRkfJtIQS6d++OYcOGYcyYMbhw4QI6dOiAa9euwdnZuUhzISIiIiKyNOnp6Zg6dSrOnDkDNzc37Nq1C7NmzcK2bdtgY2OD5OTkPO+3ZMkSlCpVCqGhoZg0aRI/SxNRsadXw2P8+PFwdnaGt7f3c9ft1KlToZPKz4kTJ+RL4Gbz9/dHQEAADh06BABo3Lgx7O3tsWzZMsycObPIciEiIiIiskQhISGYO3cuHB0d0b59ewQGBuKNN97AokWLAGRd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ePz44486sZSUFPj7+yMxMbHQSRERERERERERFYZBDY/hw4frxKytrVG1alVs2LChsDkRERERERERERWKQQ2PGTNmYM6cOZAkydj5EBEREREREREVmkHn8KhZs2aezY7Dhw8jMjKy0EkRERERERERERWGQQ2PU6dO5Rlv2rQpevbsWaiEiIiIiIiIiIgKS+9DWq5du4b58+cjIiICt2/fxn///aezzoMHD5Cenm7UBImIiIiIiIiICkrvhke9evWwZs0aDBw4EE5OTqhcubLWckmSULduXYwaNcroSRIRERERERERFUSBTlrq4uKCXbt24ccff8To0aN1lqvVaigUBh0lQ0RERERERERkNAXuTtja2ubZ7ACA48ePw9/fv9BJEREREREREREVhkGXpb1x4wbmzp2LJ0+eQK1Wy/EnT54gLCwMffv2NVqCREREREREREQFZVDDY+TIkVAqlShXrhweP36M6tWrAwAiIiIwd+5coyZIRERERERERFRQBjU8ateujY0bNwIAZs2aJTc5fvvtNzx58sR42RERERERERERGcCgM4y6urrK/65YsSJOnz4NAKhatSpneBARERERERGR2Rk0w8PJyQkVKlTA+++/jylTpqB169aoWLEi/vnnH1hbWxs7RyIiIiIiIiKiAjFohse8efOwYMECtG/fHtbW1vj5559hY2ODFi1aYOfOncbOkYiIiIiIiIioQAya4SFJEoYNGyafr6N06dJYt24dbG1tjZocEREREREREZEhDJrhcevWLdSqVQuDBg0CAKhUKqxevRrz5s3TukwtEREREREREZE5GNTw+OCDD+Dj4wMfHx8AgIODAyZOnIiYmBh89tlnxsyPiIiIiIiIiKjADGp4pKenY//+/ahatapWvHr16ti0aZNREiMiIiIiIiIiMpRBDY9mzZpBkiStmEqlwk8//QSFwqBNEhEREREREREZjUHdiZo1a+KPP/6ASqVCREQE9u/fj1atWuHMmTMYP368sXMkIiIiIiIiIioQgxoeY8aMQUxMDDZs2IBy5cqha9euePDgAZYvX47p06cbO0ciIiIiIiIiogIx6LK0ADBs2DAMGzYMKSkpSEtLg5ubmxHTIiIiIiIiIiIynF4Nj8mTJ0OpVKJDhw7o2LGj1jJ7e3vY29sXSXJERERERERERIbQq+Gxdu1anDhxAo0aNQIA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1dx10ozrPJcAqHPFs+pq5jrlimc9lwCRZ1yCMEJdC/KaV6clm71OQMHGiFhJYf46FXSMyKOuRTmWq9OSzV4noGBjhHZdzVSngo4RGnU1yXtuWpLZ66QZ12eMiJUU5q9TQccIPepq1Pfc3HW1kM9GmvHcz6WculrYZ6NnjREadTVm/fJ7bSMtyex1KugYEStJ5q+TTvw5Y4SedTXWe66UnqQVt5TPRkD+Y0ScBPPXSWNv9RojntbV0r7nPiue/f0997K8SEKftSzczp070a9fP+zevRvdu3eX45UqVULt2rVx8OBBrfX9/PwwZ84cU6dJREREREREREYQEhKCChUqPHOdEjHDQ3raVrO3t9eKq1QqWFtb66w/depUTJ48Wb6tVqsRHR2NUqVKyduiohEfH4+KFSsiJCQELi4u5k6HjIR1LZlY15KJdS2ZWNeSiXUtmVjXkol1NR0hBBISElC+fPnnrlsiGh5eXl4Acg5NyZaYmIjSpUvrrG9rawtbW1utmJubW5HlR7pcXFw4EJRArGvJxLqWTKxrycS6lkysa8nEupZMrKtpuLq66rVeiThpae3atWFtbY2IiAg5lpycjPj4eDRv3tyMmRERERERERGROZSIhoeHhwe6dOmCM2fOyLGrV6/CxsZG65weRERERERERPRiKBENDwCYMWMGjhw5guTkZADApk2b8L///e+5JzEh07K1tcXs2bN1Dimi4o11LZlY15KJdS2ZWNeSiXUtmVjXkol1tUwl4iot2X777Tfs2LEDnp6ecHV1xdy5c6FQlJieDhERERERERHpqUQ1PIiIiIiIiIiIgBJ0SAsRERERERERUTY2PIiIiIiIiIioxGHDg4iIiIiIiIhKHDY8iIiIiCycWq02dwpEpIeHDx8iJSXF3GkQ0VNseFChrVu3DgcOHAAAZGZmmjkbMhaVSoW//voLaWlpAACe35jIcqlUKnOnQEUgMjISmzdvRkhICK86R2ThLl68iLfeegt//PEHx+QSKPvzMBU/vEoLGez8+fMYN24czp49C0dHRyQkJJg7JTKS3bt348KFCzh48CB8fX2xdetWc6dERvDDDz8gOTkZaWlpaN68OZo2bQpbW1uo1Wp+mSrGzp49i23btuHdd99FnTp1IISAJEnmTosKad26dThz5gwyMjJw48YN+Pr64vPPP0f16tXNnRoZiVqt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",
      "text/plain": [
       "<Figure size 1100x420 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 620x420 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "         Dataset  H_cos01_mean  H_cos01_std  H_bin_mean  H_bin_std  avg_nodes   avg_edges  num_graphs  tau\n",
      "        PROTEINS      0.830242     0.089741    0.660485   0.179481  39.057502  145.631626        1113  0.5\n",
      "           MUTAG      0.850782     0.067956    0.701563   0.135912  17.930851   39.585106         188  0.5\n",
      "              DD      0.534258     0.007867    0.068516   0.015734 284.316638 1431.317487        1178  0.5\n",
      "            NCI1      0.811988     0.065879    0.623977   0.131757  29.865450   64.600000        4110  0.5\n",
      "          NCI109      0.811131     0.065459    0.622263   0.130917  29.681124   64.261691        4127  0.5\n",
      "    Mutagenicity      0.684795     0.071601    0.369589   0.143202  30.317731   61.538852        4337  0.5\n",
      "      IMDB-MULTI      1.000000     0.000000    1.000000   0.000000  13.001333  131.870667        1500  0.5\n",
      "REDDIT-MULTI-12K      1.000000     0.000000    1.000000   0.000000 391.408836  913.780367       11929  0.5\n",
      "\n",
      "% LaTeX table rows:\n",
      "PROTEINS & 83.0$\\pm$9.0 & 66.0$\\pm$17.9 & 39.06 & 145.63 & 1113 \\\\\n",
      "MUTAG & 85.1$\\pm$6.8 & 70.2$\\pm$13.6 & 17.93 & 39.59 & 188 \\\\\n",
      "DD & 53.4$\\pm$0.8 & 6.9$\\pm$1.6 & 284.32 & 1431.32 & 1178 \\\\\n",
      "NCI1 & 81.2$\\pm$6.6 & 62.4$\\pm$13.2 & 29.87 & 64.60 & 4110 \\\\\n",
      "NCI109 & 81.1$\\pm$6.5 & 62.2$\\pm$13.1 & 29.68 & 64.26 & 4127 \\\\\n",
      "Mutagenicity & 68.5$\\pm$7.2 & 37.0$\\pm$14.3 & 30.32 & 61.54 & 4337 \\\\\n",
      "IMDB-MULTI & 100.0$\\pm$0.0 & 100.0$\\pm$0.0 & 13.00 & 131.87 & 1500 \\\\\n",
      "REDDIT-MULTI-12K & 100.0$\\pm$0.0 & 100.0$\\pm$0.0 & 391.41 & 913.78 & 11929 \\\\\n"
     ]
    }
   ],
   "source": [
    "# ==== Plot feature-homophily metrics ====\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "plt.rcParams.update({\n",
    "    \"font.family\": \"Times New Roman\",\n",
    "    \"font.size\": 12\n",
    "})\n",
    "\n",
    "# 1) Tidy up results into a DataFrame\n",
    "def results_to_df(results):\n",
    "    rows = []\n",
    "    for r in results:\n",
    "        m1, s1 = r[\"H_cos01\"]\n",
    "        m2, s2 = r[\"H_bin_tau\"]\n",
    "        rows.append({\n",
    "            \"Dataset\": r[\"dataset\"],\n",
    "            \"H_cos01_mean\": m1, \"H_cos01_std\": s1,\n",
    "            \"H_bin_mean\": m2,  \"H_bin_std\":  s2,\n",
    "            \"avg_nodes\": r[\"avg_nodes\"], \"avg_edges\": r[\"avg_edges\"],\n",
    "            \"num_graphs\": r[\"num_graphs\"], \"tau\": r[\"tau\"]\n",
    "        })\n",
    "    df = pd.DataFrame(rows)\n",
    "\n",
    "    # Keep a consistent order (same as your 'names' list, where available)\n",
    "    order = [\"PROTEINS\", \"MUTAG\", \"DD\", \"NCI1\", \"NCI109\",\n",
    "             \"Mutagenicity\", \"IMDB-MULTI\", \"REDDIT-MULTI-12K\"]\n",
    "    df[\"__order\"] = df[\"Dataset\"].apply(lambda x: order.index(x) if x in order else 999)\n",
    "    df = df.sort_values(\"__order\").drop(columns=\"__order\").reset_index(drop=True)\n",
    "    return df\n",
    "\n",
    "df = results_to_df(results)\n",
    "print(df)\n",
    "\n",
    "\n",
    "# 2) Grouped bar: H_cos01 and H_bin (both as percentages)\n",
    "def plot_grouped_bars(df, savepath=\"feature_homophily_bars.png\"):\n",
    "    datasets = df[\"Dataset\"].tolist()\n",
    "    x = np.arange(len(datasets))\n",
    "    width = 0.38\n",
    "\n",
    "    # Convert to %\n",
    "    hcos = (df[\"H_cos01_mean\"].values * 100.0)\n",
    "    hcos_std = (df[\"H_cos01_std\"].values * 100.0)\n",
    "    hbin = (df[\"H_bin_mean\"].values * 100.0)\n",
    "    hbin_std = (df[\"H_bin_std\"].values * 100.0)\n",
    "\n",
    "    fig, ax = plt.subplots(figsize=(11, 4.2))\n",
    "    b1 = ax.bar(x - width/2, hcos, width, yerr=hcos_std, capsize=3, label=r\"$H_{\\cos01}$\")\n",
    "    b2 = ax.bar(x + width/2, hbin, width, yerr=hbin_std, capsize=3, label=r\"$H_{\\mathrm{bin}}(\\tau{=}0.5)$\")\n",
    "\n",
    "    ax.set_ylabel(\"Feature homophily (%)\")\n",
    "    ax.set_xticks(x)\n",
    "    ax.set_xticklabels(datasets, rotation=30, ha=\"right\")\n",
    "    ax.set_ylim(0, 100)\n",
    "    ax.grid(axis=\"y\", linestyle=\"--\", alpha=0.4)\n",
    "    ax.legend()\n",
    "\n",
    "    # Annotate bars (optional)\n",
    "    for bars in [b1, b2]:\n",
    "        for rect in bars:\n",
    "            h = rect.get_height()\n",
    "            ax.annotate(f\"{h:.1f}\",\n",
    "                        xy=(rect.get_x() + rect.get_width()/2, h),\n",
    "                        xytext=(0, 3), textcoords=\"offset points\",\n",
    "                        ha=\"center\", va=\"bottom\", fontsize=8)\n",
    "\n",
    "    plt.tight_layout()\n",
    "    fig.savefig(savepath, dpi=200, bbox_inches=\"tight\")\n",
    "    plt.show()\n",
    "\n",
    "plot_grouped_bars(df)\n",
    "\n",
    "# 3) Scatter: avg_nodes vs H_cos01 (size = num_graphs)\n",
    "def plot_scatter_nodes_vs_hcos(df, savepath=\"nodes_vs_hcos01.png\"):\n",
    "    x = df[\"avg_nodes\"].values\n",
    "    y = df[\"H_cos01_mean\"].values * 100.0\n",
    "    sizes = 20 + 2.0 * np.sqrt(df[\"num_graphs\"].values)  # mild scaling\n",
    "\n",
    "    fig, ax = plt.subplots(figsize=(6.2, 4.2))\n",
    "    sc = ax.scatter(x, y, s=sizes)\n",
    "    ax.set_xlabel(\"Average #nodes per graph\")\n",
    "    ax.set_ylabel(r\"$H_{\\cos01}$ (%)\")\n",
    "    ax.grid(True, linestyle=\"--\", alpha=0.4)\n",
    "\n",
    "    # Label points\n",
    "    for _, row in df.iterrows():\n",
    "        ax.annotate(row[\"Dataset\"],\n",
    "                    (row[\"avg_nodes\"], row[\"H_cos01_mean\"] * 100.0),\n",
    "                    textcoords=\"offset points\", xytext=(5, 4), fontsize=8)\n",
    "\n",
    "    plt.tight_layout()\n",
    "    fig.savefig(savepath, dpi=200, bbox_inches=\"tight\")\n",
    "    plt.show()\n",
    "\n",
    "plot_scatter_nodes_vs_hcos(df)\n",
    "\n",
    "# 4) (Optional) Table preview in notebook: requires pandas\n",
    "try:\n",
    "    from caas_jupyter_tools import display_dataframe_to_user as _display_df\n",
    "    _display_df(\"Feature Homophily Summary\", df)\n",
    "except Exception:\n",
    "    print(df.to_string(index=False))\n",
    "\n",
    "# 5) Also print LaTeX rows again (ready to paste)\n",
    "print(\"\\n% LaTeX table rows:\")\n",
    "for _, r in df.iterrows():\n",
    "    print(f\"{r['Dataset']} & \"\n",
    "          f\"{r['H_cos01_mean']*100:.1f}$\\\\pm${r['H_cos01_std']*100:.1f} & \"\n",
    "          f\"{r['H_bin_mean']*100:.1f}$\\\\pm${r['H_bin_std']*100:.1f} & \"\n",
    "          f\"{r['avg_nodes']:.2f} & {r['avg_edges']:.2f} & \"\n",
    "          f\"{int(r['num_graphs'])} \\\\\\\\\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1200x450 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "\n",
    "plt.rcParams.update({\n",
    "    \"font.family\": \"Times New Roman\",\n",
    "    \"font.size\": 12\n",
    "})\n",
    "\n",
    "def plot_subplots(df, savepath=\"feature_homophily_subplots.png\"):\n",
    "    datasets = df[\"Dataset\"].tolist()\n",
    "    x = np.arange(len(datasets))\n",
    "    width = 0.38\n",
    "\n",
    "    # Convert to %\n",
    "    hcos = df[\"H_cos01_mean\"].values * 100.0\n",
    "    hcos_std = df[\"H_cos01_std\"].values * 100.0\n",
    "    hbin = df[\"H_bin_mean\"].values * 100.0\n",
    "    hbin_std = df[\"H_bin_std\"].values * 100.0\n",
    "\n",
    "    fig, axes = plt.subplots(1, 2, figsize=(12, 4.5))\n",
    "\n",
    "    # --- Left: grouped bars ---\n",
    "    ax = axes[0]\n",
    "    b1 = ax.bar(x - width/2, hcos, width, yerr=hcos_std, capsize=3, label=r\"$H_{\\cos01}$\")\n",
    "    b2 = ax.bar(x + width/2, hbin, width, yerr=hbin_std, capsize=3, label=r\"$H_{\\mathrm{bin}}(\\tau{=}0.5)$\")\n",
    "\n",
    "    ax.set_ylabel(\"Feature homophily (%)\")\n",
    "    ax.set_xticks(x)\n",
    "    ax.set_xticklabels(datasets, rotation=30, ha=\"right\")\n",
    "    ax.set_ylim(0, 100)\n",
    "    ax.grid(axis=\"y\", linestyle=\"--\", alpha=0.4)\n",
    "    ax.legend()\n",
    "\n",
    "    # --- Right: scatter avg_nodes vs H_cos01 ---\n",
    "    ax = axes[1]\n",
    "    sizes = 20 + 2.0 * np.sqrt(df[\"num_graphs\"].values)\n",
    "    sc = ax.scatter(df[\"avg_nodes\"], hcos, s=sizes)\n",
    "\n",
    "    ax.set_xlabel(\"Average #nodes per graph\")\n",
    "    ax.set_ylabel(r\"$H_{\\cos01}$ (%)\")\n",
    "    ax.grid(True, linestyle=\"--\", alpha=0.4)\n",
    "\n",
    "    for _, row in df.iterrows():\n",
    "        ax.annotate(row[\"Dataset\"],\n",
    "                    (row[\"avg_nodes\"], row[\"H_cos01_mean\"]*100.0),\n",
    "                    textcoords=\"offset points\", xytext=(5,4), fontsize=9)\n",
    "\n",
    "    plt.tight_layout()\n",
    "    fig.savefig(savepath, dpi=200, bbox_inches=\"tight\")\n",
    "    plt.show()\n",
    "\n",
    "# Call the function with your df\n",
    "plot_subplots(df)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "myenv",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.12.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
