{
 "cells": [
  {
   "cell_type": "code",
   "id": "initial_id",
   "metadata": {
    "collapsed": true,
    "ExecuteTime": {
     "end_time": "2025-08-15T04:43:06.768392Z",
     "start_time": "2025-08-15T04:43:02.632349Z"
    }
   },
   "source": [
    "import math\n",
    "from random import random\n",
    "\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import scipy.sparse\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import itertools\n",
    "from scipy.linalg import subspace_angles\n",
    "import cvxpy as cp\n",
    "import statsmodels.formula.api as sm\n",
    "from scipy.special.cython_special import binom\n",
    "\n"
   ],
   "outputs": [],
   "execution_count": 2
  },
  {
   "metadata": {},
   "cell_type": "markdown",
   "source": "Generate m matrices",
   "id": "7f57e00c9a4bff56"
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-08-15T04:43:06.779870Z",
     "start_time": "2025-08-15T04:43:06.774571Z"
    }
   },
   "cell_type": "code",
   "source": [
    "def generate_model_single(n, k, a, b):\n",
    "    # initialize sparse matrix\n",
    "    random_mat = np.random.rand(n * k, n * k)\n",
    "    print(\"AA\")\n",
    "    A = np.triu(random_mat)\n",
    "    print(\"A\")\n",
    "    threshold = b / n * np.ones((n * k, n * k))\n",
    "    for i in range(k):\n",
    "        threshold[i * n:(i + 1) * n, i * n:(i + 1) * n] = a / n\n",
    "        \n",
    "    print(\"B\")\n",
    "\n",
    "    A[A >= threshold] = 0\n",
    "    A[A > 0] = 1\n",
    "    print(\"C\")\n",
    "\n",
    "    # ensure symmetry - construct adjacency matrix\n",
    "    A = A + A.T\n",
    "    A[A > 0] = 1\n",
    "    print(\"D\")\n",
    "    return A, threshold\n"
   ],
   "id": "1644dae038db9d6b",
   "outputs": [],
   "execution_count": 3
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-08-15T04:43:06.801661Z",
     "start_time": "2025-08-15T04:43:06.796683Z"
    }
   },
   "cell_type": "code",
   "source": [
    "def reorder_matrix(A, n, threshold, reordering):\n",
    "    result = A[:, reordering]\n",
    "    result = result[reordering, :]\n",
    "\n",
    "    threshold_result = threshold[:, reordering]\n",
    "    threshold_result = threshold_result[reordering, :]\n",
    "    \n",
    "\n",
    "    inverse_reordering = np.argsort(reordering)\n",
    "    correct_partition = [inverse_reordering[0:n], inverse_reordering[n:]]\n",
    "    return result, threshold_result, correct_partition, reordering"
   ],
   "id": "fb4572d837fb40cd",
   "outputs": [],
   "execution_count": 4
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-08-15T04:43:06.817544Z",
     "start_time": "2025-08-15T04:43:06.812509Z"
    }
   },
   "cell_type": "code",
   "source": [
    "def get_eigenvectors_from_A(A):\n",
    "\n",
    "    eigenvalues_A, eigenvectors_A = np.linalg.eig(A)\n",
    "    \n",
    "    # get 2 largest values. Index 0 is the largest EV, index 1 is the second largest\n",
    "    U = eigenvectors_A[:, [0, 1]]\n",
    "\n",
    "    U1 = U[:, 0]\n",
    "    U2 = U[:, 1]\n",
    "\n",
    "    return U1,U2\n"
   ],
   "id": "ab2212d97867312e",
   "outputs": [],
   "execution_count": 5
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-08-15T04:43:06.835360Z",
     "start_time": "2025-08-15T04:43:06.828577Z"
    }
   },
   "cell_type": "code",
   "source": [
    "def find_perp_vector(U1, U2, d, n):\n",
    "\n",
    "    U = np.vstack((U1,U2)).T\n",
    "    all_ones = np.ones([n*2, 1])\n",
    "\n",
    "    # Projection of all ones into the subspace generated by U1 and U2\n",
    "    proj_v1 = np.dot(np.dot(U, U.T), all_ones)\n",
    "    v1 = np.dot(U1, proj_v1)\n",
    "    v2 = np.dot(U2, proj_v1)\n",
    "\n",
    "    # They can't be both zeroes because the eigen vectors then are degenerate\n",
    "    if (v1==0) and (v2==0):\n",
    "        raise(\"The eigen vectors are degenerate. Subspace W only has rank 1\")\n",
    "\n",
    "    # We want t1 and t2 such that t1v1 + t2v2 = 0, t1, t2 not both zero\n",
    "    if (v1==0):\n",
    "        t2 = 0\n",
    "        t1 = 1\n",
    "    elif (v2==0):\n",
    "        t1 = 0\n",
    "        t2 = 1\n",
    "    else:\n",
    "        t1 = -v2\n",
    "        t2 = v1\n",
    "\n",
    "    assert(t1*v1 + t2*v2 == 0)\n",
    "\n",
    "    # Vector perpendicular to proj_v1 but belonging to W is t1U1 + t2U2\n",
    "    perp_v1 = t1*U1 + t2*U2\n",
    "    perp_v1_args = np.argsort(perp_v1)\n",
    "    partition_1 = perp_v1_args[0:n]\n",
    "    partition_2 = perp_v1_args[n:]\n",
    "\n",
    "    return [[partition_1, partition_2], perp_v1]"
   ],
   "id": "d40f1b2a5cf0bed",
   "outputs": [],
   "execution_count": 6
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-08-15T04:43:06.851886Z",
     "start_time": "2025-08-15T04:43:06.847746Z"
    }
   },
   "cell_type": "code",
   "source": [
    "def score_partition(partition, correct_partition, n):\n",
    "    correct = len(set(partition[1]).intersection(correct_partition[1]))\n",
    "    correct_fraction = correct/n\n",
    "    correct_fraction = max(correct_fraction, 1 - correct_fraction)\n",
    "    gamma = 1-correct_fraction\n",
    "    \n",
    "    return gamma\n"
   ],
   "id": "703afeb05ef5f658",
   "outputs": [],
   "execution_count": 7
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-08-15T04:43:06.871292Z",
     "start_time": "2025-08-15T04:43:06.864495Z"
    }
   },
   "cell_type": "code",
   "source": [
    "def get_gamma_for_seed(n, k, a, b):\n",
    "    print(\"xxx\")\n",
    "    A1, threshold = generate_model_single(n=n, k=k, a=a, b=b)\n",
    "    print(\"yyy\")\n",
    "    reordering = np.random.permutation(n * k)\n",
    "    print(\"zzz\")\n",
    "    A1_reordered, threshold_reordered, correct_partition1, _ = reorder_matrix(A=A1, threshold=threshold, reordering=reordering, n=n)\n",
    "    print(\"www\")\n",
    "    \n",
    "    U1, U2 = get_eigenvectors_from_A(A=A1_reordered)\n",
    "    print(\"aaa\")\n",
    "    w1, w2 = get_eigenvectors_from_A(A=threshold_reordered)\n",
    "    print(\"bbb\")\n",
    "    \n",
    "    \n",
    "    partition1, perp1 = find_perp_vector(U1=U1, U2=U2, d=d, n=n)\n",
    "    print(\"ccc\")\n",
    "    #perp1 = perp1 / np.linalg.norm(perp1)\n",
    "\n",
    "    gamma1 = score_partition(partition=partition1, correct_partition=correct_partition1, n=n)\n",
    "    print(\"ddd\")\n",
    "    k = math.floor(gamma1 * n)\n",
    "    \n",
    "    vec_angle = np.arccos(np.dot(perp1, w2) / np.linalg.norm(perp1) / np.linalg.norm(w2))\n",
    "    sin_vector = np.sin(vec_angle)\n",
    "\n",
    "    \n",
    "    return k, sin_vector"
   ],
   "id": "325cb097b7208e19",
   "outputs": [],
   "execution_count": 8
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-08-15T04:43:06.888974Z",
     "start_time": "2025-08-15T04:43:06.885287Z"
    }
   },
   "cell_type": "code",
   "source": [
    "# n = 500\n",
    "# k = 2\n",
    "# m = 2\n",
    "# a = 0.06 * n\n",
    "# b = 0.04 * n\n",
    "# \n",
    "# d = a+b\n",
    "# \n",
    "# np.random.seed(1)\n",
    "# spectral_df = pd.DataFrame(columns=['k', 'sin_theta'])\n",
    "# for this_m in range(m):\n",
    "#     print(\"this m:\", this_m)\n",
    "#     k, sin_angle = get_gamma_for_seed(n=n, k=k, a=a, b=b)\n",
    "#     spectral_df.loc[len(spectral_df)] = [k, sin_angle]\n",
    "#     \n",
    "# \n"
   ],
   "id": "da5971e512e2f062",
   "outputs": [],
   "execution_count": 9
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-08-15T04:59:36.539908Z",
     "start_time": "2025-08-15T04:59:36.521506Z"
    }
   },
   "cell_type": "code",
   "source": [
    "chernoff_df = pd.read_csv('chernoff_df.csv')\n",
    "binomial_df = pd.read_csv('binomial_df.csv')\n",
    "def complex_converter(s):\n",
    "        \"\"\"Converts a string representation of a complex number to a complex object.\"\"\"\n",
    "        try:\n",
    "            # Replace 'i' with 'j' for Python's complex() function\n",
    "            return complex(s.replace('i', 'j'))\n",
    "        except ValueError:\n",
    "            return np.nan\n",
    "        \n",
    "spectral_df = pd.read_csv('spectral_df.csv', converters={'k': complex_converter, 'sin_theta': complex_converter})"
   ],
   "id": "f8e459118076622a",
   "outputs": [],
   "execution_count": 37
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-08-15T04:59:51.119090Z",
     "start_time": "2025-08-15T04:59:51.100634Z"
    }
   },
   "cell_type": "code",
   "source": [
    "n =500\n",
    "spectral_df['sin_theta_real'] = spectral_df['sin_theta'].apply(lambda x: x.real)\n",
    "spectral_df['k_real'] = spectral_df['k'].apply(lambda x: x.real) * n\n",
    "spectral_df"
   ],
   "id": "a794fc464475d362",
   "outputs": [
    {
     "data": {
      "text/plain": [
       "    Unnamed: 0             k           sin_theta  sin_theta_real  k_real\n",
       "0            0  0.162+0.000j  0.687486-0.000000j        0.687486    81.0\n",
       "1            1  0.114+0.000j  0.660059+0.000000j        0.660059    57.0\n",
       "2            2  0.140+0.000j  0.685191-0.000000j        0.685191    70.0\n",
       "3            3  0.152+0.000j  0.709751-0.000000j        0.709751    76.0\n",
       "4            4  0.150+0.000j  0.690363+0.000000j        0.690363    75.0\n",
       "..         ...           ...                 ...             ...     ...\n",
       "95          95  0.152+0.000j  0.705880+0.000000j        0.705880    76.0\n",
       "96          96  0.150+0.000j  0.690097+0.000000j        0.690097    75.0\n",
       "97          97  0.150+0.000j  0.693827+0.000000j        0.693827    75.0\n",
       "98          98  0.166+0.000j  0.713156+0.000000j        0.713156    83.0\n",
       "99          99  0.174+0.000j  0.743552+0.000000j        0.743552    87.0\n",
       "\n",
       "[100 rows x 5 columns]"
      ],
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Unnamed: 0</th>\n",
       "      <th>k</th>\n",
       "      <th>sin_theta</th>\n",
       "      <th>sin_theta_real</th>\n",
       "      <th>k_real</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>0.162+0.000j</td>\n",
       "      <td>0.687486-0.000000j</td>\n",
       "      <td>0.687486</td>\n",
       "      <td>81.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>0.114+0.000j</td>\n",
       "      <td>0.660059+0.000000j</td>\n",
       "      <td>0.660059</td>\n",
       "      <td>57.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\n",
       "      <td>0.140+0.000j</td>\n",
       "      <td>0.685191-0.000000j</td>\n",
       "      <td>0.685191</td>\n",
       "      <td>70.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>3</td>\n",
       "      <td>0.152+0.000j</td>\n",
       "      <td>0.709751-0.000000j</td>\n",
       "      <td>0.709751</td>\n",
       "      <td>76.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>4</td>\n",
       "      <td>0.150+0.000j</td>\n",
       "      <td>0.690363+0.000000j</td>\n",
       "      <td>0.690363</td>\n",
       "      <td>75.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>95</th>\n",
       "      <td>95</td>\n",
       "      <td>0.152+0.000j</td>\n",
       "      <td>0.705880+0.000000j</td>\n",
       "      <td>0.705880</td>\n",
       "      <td>76.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>96</th>\n",
       "      <td>96</td>\n",
       "      <td>0.150+0.000j</td>\n",
       "      <td>0.690097+0.000000j</td>\n",
       "      <td>0.690097</td>\n",
       "      <td>75.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>97</th>\n",
       "      <td>97</td>\n",
       "      <td>0.150+0.000j</td>\n",
       "      <td>0.693827+0.000000j</td>\n",
       "      <td>0.693827</td>\n",
       "      <td>75.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>98</th>\n",
       "      <td>98</td>\n",
       "      <td>0.166+0.000j</td>\n",
       "      <td>0.713156+0.000000j</td>\n",
       "      <td>0.713156</td>\n",
       "      <td>83.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>99</th>\n",
       "      <td>99</td>\n",
       "      <td>0.174+0.000j</td>\n",
       "      <td>0.743552+0.000000j</td>\n",
       "      <td>0.743552</td>\n",
       "      <td>87.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>100 rows × 5 columns</p>\n",
       "</div>"
      ]
     },
     "execution_count": 40,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "execution_count": 40
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-08-15T05:09:03.174139Z",
     "start_time": "2025-08-15T05:09:03.162292Z"
    }
   },
   "cell_type": "code",
   "source": [
    "this_binomial_df = this_binomial_df.reset_index(drop=True)\n",
    "this_binomial_df\n"
   ],
   "id": "798a83de231910ad",
   "outputs": [
    {
     "data": {
      "text/plain": [
       "     Unnamed: 0    k     sin_theta  seed\n",
       "0           500    0  [0.51739994]     2\n",
       "1           501    1  [0.51739994]     2\n",
       "2           502    2  [0.51739994]     2\n",
       "3           503    3  [0.51739994]     2\n",
       "4           504    4  [0.51739994]     2\n",
       "..          ...  ...           ...   ...\n",
       "245         745  245  [0.90333098]     2\n",
       "246         746  246   [0.9048904]     2\n",
       "247         747  247  [0.90643513]     2\n",
       "248         748  248  [0.90796523]     2\n",
       "249         749  249   [0.9094808]     2\n",
       "\n",
       "[250 rows x 4 columns]"
      ],
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Unnamed: 0</th>\n",
       "      <th>k</th>\n",
       "      <th>sin_theta</th>\n",
       "      <th>seed</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>500</td>\n",
       "      <td>0</td>\n",
       "      <td>[0.51739994]</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>501</td>\n",
       "      <td>1</td>\n",
       "      <td>[0.51739994]</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>502</td>\n",
       "      <td>2</td>\n",
       "      <td>[0.51739994]</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>503</td>\n",
       "      <td>3</td>\n",
       "      <td>[0.51739994]</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>504</td>\n",
       "      <td>4</td>\n",
       "      <td>[0.51739994]</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>245</th>\n",
       "      <td>745</td>\n",
       "      <td>245</td>\n",
       "      <td>[0.90333098]</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>246</th>\n",
       "      <td>746</td>\n",
       "      <td>246</td>\n",
       "      <td>[0.9048904]</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>247</th>\n",
       "      <td>747</td>\n",
       "      <td>247</td>\n",
       "      <td>[0.90643513]</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>248</th>\n",
       "      <td>748</td>\n",
       "      <td>248</td>\n",
       "      <td>[0.90796523]</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>249</th>\n",
       "      <td>749</td>\n",
       "      <td>249</td>\n",
       "      <td>[0.9094808]</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>250 rows × 4 columns</p>\n",
       "</div>"
      ]
     },
     "execution_count": 56,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "execution_count": 56
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-08-15T05:05:17.914878Z",
     "start_time": "2025-08-15T05:05:16.353251Z"
    }
   },
   "cell_type": "code",
   "source": [
    "seeds = binomial_df['seed'].unique()\n",
    "seed = 2\n",
    "this_binomial_df = binomial_df[binomial_df['seed'] == seed]\n",
    "this_binomial_df = this_binomial_df.reset_index(drop=True)\n",
    "\n",
    "plt.scatter(chernoff_df['sin_theta'], chernoff_df['k'], color='blue', s=5)\n",
    "plt.scatter(chernoff_df['sin_theta_lemma'], chernoff_df['k'], color='red', s=5)\n",
    "plt.scatter(this_binomial_df['sin_theta'], this_binomial_df['k'], color='green', s=5)\n",
    "plt.scatter(spectral_df['sin_theta_real'], spectral_df['k_real'], color='orange', s=5)\n",
    "\n",
    "plt.show()"
   ],
   "id": "3e789ee5703d56a0",
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ],
      "image/png": "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"
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "execution_count": 51
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 2
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython2",
   "version": "2.7.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
