{
 "cells": [
  {
   "cell_type": "code",
   "id": "initial_id",
   "metadata": {
    "collapsed": true,
    "ExecuteTime": {
     "end_time": "2025-07-24T03:57:29.352804Z",
     "start_time": "2025-07-24T03:57:29.331678Z"
    }
   },
   "source": [
    "from random import random\n",
    "\n",
    "import numpy as np\n",
    "import scipy.sparse\n",
    "import matplotlib.pyplot as plt\n",
    "import itertools\n",
    "from scipy.linalg import subspace_angles\n",
    "\n"
   ],
   "outputs": [],
   "execution_count": 171
  },
  {
   "metadata": {},
   "cell_type": "markdown",
   "source": "Generate the matrices for m samples\n",
   "id": "1f2305809c78623d"
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-24T03:57:31.724545Z",
     "start_time": "2025-07-24T03:57:31.717824Z"
    }
   },
   "cell_type": "code",
   "source": [
    "def generate_model_single(n, k, a, b):\n",
    "    # initialize sparse matrix\n",
    "    A = np.triu(np.random.rand(n * k, n * k))\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",
    "    A[A >= threshold] = 0\n",
    "    A[A > 0] = 1\n",
    "\n",
    "    # ensure symmetry - construct adjacency matrix\n",
    "    A = A + A.T\n",
    "    A[A > 0] = 1\n",
    "    return A, threshold\n"
   ],
   "id": "412ef3eafca44ab7",
   "outputs": [],
   "execution_count": 172
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-24T03:57:42.326781Z",
     "start_time": "2025-07-24T03:57:42.152048Z"
    }
   },
   "cell_type": "code",
   "source": [
    "n = 500\n",
    "k = 2\n",
    "m = 2\n",
    "a = 0.06 * n\n",
    "b = 0.04 * n\n",
    "\n",
    "np.random.seed(1)\n",
    "A1, threshold = generate_model_single(n=n, k=k, a=a, b=b)\n",
    "np.random.seed(2)\n",
    "A2, _ = generate_model_single(n=n, k=k, a=a, b=b)\n",
    "np.random.seed(3)\n",
    "A3, _ = generate_model_single(n=n, k=k, a=a, b=b)"
   ],
   "id": "cf44f4b795ca8dc7",
   "outputs": [],
   "execution_count": 173
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-24T03:57:46.365938Z",
     "start_time": "2025-07-24T03:57:46.353620Z"
    }
   },
   "cell_type": "code",
   "source": [
    "A1_deg = np.sum(A1, axis=0)\n",
    "#plt.bar(range(n*k), np.sort(A1_deg), label='U1', color='blue')\n",
    "#A1_hist = np.histogram(A1_deg)\n",
    "#plt.bar(A1_hist[1][1:], A1_hist[0])\n",
    "print(scipy.stats.skew(A1_deg))\n",
    "print(scipy.stats.kurtosis(A1_deg))"
   ],
   "id": "93f95b95f11f07da",
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.1380632210842431\n",
      "-0.06716869286135019\n"
     ]
    }
   ],
   "execution_count": 174
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-24T03:57:50.174476Z",
     "start_time": "2025-07-24T03:57:50.169123Z"
    }
   },
   "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\n"
   ],
   "id": "fc5c737928ff8609",
   "outputs": [],
   "execution_count": 175
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-24T03:57:52.978904Z",
     "start_time": "2025-07-24T03:57:52.834487Z"
    }
   },
   "cell_type": "code",
   "source": [
    "np.random.seed(1)\n",
    "reordering = np.random.permutation(n * k)\n",
    "A1_reordered, threshold_reordered, correct_partition1, _ = reorder_matrix(A=A1, threshold=threshold, reordering=reordering, n=n)\n",
    "A2_reordered, threshold_reordered, correct_partition2, _ = reorder_matrix(A=A2, threshold=threshold, reordering=reordering, n=n)\n",
    "A3_reordered, threshold_reordered, correct_partition3, _ = reorder_matrix(A=A3, threshold=threshold, reordering=reordering, n=n)"
   ],
   "id": "aa63cdf862582fa4",
   "outputs": [],
   "execution_count": 176
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-24T03:57:55.188160Z",
     "start_time": "2025-07-24T03:57:55.183122Z"
    }
   },
   "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": "5ad41871b7e2d03e",
   "outputs": [],
   "execution_count": 177
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-24T03:58:35.675802Z",
     "start_time": "2025-07-24T03:58:30.041381Z"
    }
   },
   "cell_type": "code",
   "source": [
    "U1_1, U2_1 = get_eigenvectors_from_A(A=A1_reordered)\n",
    "U1_2, U2_2 = get_eigenvectors_from_A(A=A2_reordered)\n",
    "U1_3, U2_3 = get_eigenvectors_from_A(A=A3_reordered)\n",
    "\n",
    "w1, w2 = get_eigenvectors_from_A(A=threshold_reordered)\n",
    "\n",
    "U1_1_orig, U2_1_orig = get_eigenvectors_from_A(A=A1)\n",
    "w1_orig, w2_orig = get_eigenvectors_from_A(A=threshold)\n"
   ],
   "id": "ee746738c6c8edf8",
   "outputs": [],
   "execution_count": 178
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-24T04:02:23.005476Z",
     "start_time": "2025-07-24T04:02:20.027611Z"
    }
   },
   "cell_type": "code",
   "source": [
    "# plt.bar(range(len(w2)), w2_orig)\n",
    "# plt.show()\n",
    "# plt.bar(range(len(w2)), np.sort(U2_1))\n",
    "# plt.show()\n",
    "plt.bar(range(n), np.sort(U2_1_orig[0:n]))\n",
    "plt.show()\n",
    "plt.bar(range(n), np.sort(U2_1_orig[n:]))\n",
    "plt.show()\n"
   ],
   "id": "8c861aad02aa3d96",
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ],
      "image/png": "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k3H48GGjoqLCmDJlinHrrbcaX375pa8O89w+tm3bZrz99ttGVVWVUVVVZSxevNgIDw83Dh8+bBgG82yGPXv2GPHx8cZdd91lPPHEE75y5vrGLV261Pj+979vnDp1ynfU1NT4zgfbHBNw2tHo0aONjIwMv7LBgwcbixYt6qQehbZvB5wrV64YMTExxvLly31lX3/9teFwOIx169YZhmEY586dM8LDw43Nmzf76nz22WdGt27djMLCwg7reyipqakxJBnFxcWGYTDPZuvbt6/xwgsvMM8mqKurM+644w6jqKjIGDdunC/gMNftY+nSpcbw4cMDngvGOeYWVTtpaGjQvn37lJaW5leelpamkpKSTuqVtVRXV8vtdvvNsd1u17hx43xzvG/fPl28eNGvTmxsrIYOHco/h2Z4PB5JUr9+/SQxz2a5fPmyNm/erK+++kopKSnMswn+4R/+QVOmTNE999zjV85ct5+PPvpIsbGxSkhI0KxZs/TJJ59ICs457pI/tmmGs2fP6vLly3I6nX7lTqdTbre7k3plLY3zGGiOjx075qvTo0cP9e3bt0kd/jk0ZRiGsrKy9MMf/lBDhw6VxDy3t0OHDiklJUVff/21vvOd76igoEBDhgzx/R8689w+Nm/erP379+uDDz5oco5/p9tHcnKyXn75Zd155506ffq0nnnmGaWmpurIkSNBOccEnHZms9n8PhuG0aQMN+Z65ph/DoHNmzdPBw8e1Pvvv9/kHPPcPgYNGqSKigqdO3dOW7du1c9+9jMVFxf7zjPPN+7EiRN64okntGPHDkVERDRbj7m+MZMnT/b992HDhiklJUUDBw7Uxo0bNWbMGEnBNcfcomonUVFR6t69e5MUWlNT0yTR4vo07tZvaY5jYmLU0NCg2traZuvgqvnz52vbtm169913dcstt/jKmef21aNHD91+++0aNWqUcnNzNXz4cP3rv/4r89yO9u3bp5qaGiUlJSksLExhYWEqLi7W6tWrFRYW5psr5rp99e7dW8OGDdNHH30UlP8+E3DaSY8ePZSUlKSioiK/8qKiIqWmpnZSr6wlISFBMTExfnPc0NCg4uJi3xwnJSUpPDzcr86pU6d0+PBh/jn8f4ZhaN68eXrjjTf0zjvvKCEhwe8882wuwzBUX1/PPLeju+++W4cOHVJFRYXvGDVqlP72b/9WFRUVGjBgAHNtgvr6elVWVqp///7B+e9zu29b7sIaHxPfsGGD8eGHHxqZmZlG7969jaNHj3Z210JGXV2dUV5ebpSXlxuSjFWrVhnl5eW+R+2XL19uOBwO44033jAOHTpkPPTQQwEfQ7zllluMnTt3Gvv37zd+8pOf8KjnN/z93/+94XA4jPfee8/vcc/z58/76jDP7SM7O9v4y1/+YlRXVxsHDx40Fi9ebHTr1s3YsWOHYRjMs5m++RSVYTDX7eGXv/yl8d577xmffPKJUVZWZkydOtWIjIz0/Y0Ltjkm4LSzNWvWGLfddpvRo0cPY+TIkb5Hb9E67777riGpyfGzn/3MMIyrjyIuXbrUiImJMex2u/GjH/3IOHTokN81Lly4YMybN8/o16+f0bNnT2Pq1KnG8ePHO2E0wSnQ/Eoy/vSnP/nqMM/t4xe/+IXv/w+++93vGnfffbcv3BgG82ymbwcc5vrGNb7XJjw83IiNjTVmzJhhHDlyxHc+2ObYZhiG0f7rQgAAAJ2HPTgAAMByCDgAAMByCDgAAMByCDgAAMByCDgAAMByCDgAAMByCDgAAMByCDgAAMByCDgAAMByCDgAAMByCDgAAMByCDgAAMBy/h912gttC2uvawAAAABJRU5ErkJggg=="
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ],
      "image/png": "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"
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "execution_count": 184
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-23T06:41:56.230221Z",
     "start_time": "2025-07-23T06:41:52.064077Z"
    }
   },
   "cell_type": "code",
   "source": [
    "U2_1_rederived = np.real(np.matmul(A1_reordered, w2)/(a-b))\n",
    "\n",
    "U2_1_rederived = U2_1_rederived / np.linalg.norm(U2_1_rederived)\n",
    "\n",
    "print(np.sum(U2_1_rederived))\n",
    "print(np.sum(U2_1_rederived**2))\n",
    "print(np.sum(w2))\n",
    "print(np.sum(w2**2))\n",
    "print(np.sum(U2_1))\n",
    "print(np.sum(U2_1**2))\n",
    "print(\"***\")\n",
    "\n",
    "plt.bar(range(n*k), np.sort(U2_1), label='U1', color='blue')\n"
   ],
   "id": "55a36a1c661041e0",
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-0.024574122354240446\n",
      "1.0\n",
      "(-3.858025010572419e-15+0j)\n",
      "(1.0000000000000002+0j)\n",
      "-0.008044362702534558\n",
      "0.9999999999999999\n",
      "***\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<BarContainer object of 2000 artists>"
      ]
     },
     "execution_count": 149,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ],
      "image/png": "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I2VlZfqLv/gLpaSkKC0tTbNnz9bBgwfD+tx3331yuVxhy0033RTWp6WlRQ899JBSU1M1ZMgQzZo1S//3f//Xl6VEVVpaGrHv6enpofXGGJWWliozM1ODBw/W1KlTtX///rBt2LW2DqNHj46o0eVyacGCBZLi7/j993//t26//XZlZmbK5XLprbfeClsfq2N28uRJFRYWyuPxyOPxqLCwUKdOnbK4urO6qrGtrU1Lly7VddddpyFDhigzM1P33HOPjh49GraNqVOnRhzXefPmhfXprxq7O4axek3atb5o70eXy6Vnnnkm1MfOx68nnwt2fx8ScGJkw4YNKikp0fLly1VTU6P8/HzNmDFDDQ0N/b1r3dq6dasWLFig6upqVVVV6fTp0yooKNBXX30V1m/69OlqbGwMLRUVFWHrS0pKtGnTJr3xxhv64IMP9Mc//lEzZ85Ue3t7X5YT1Xe/+92wfd+3b19o3apVq7R69WqVl5dr165dSk9P17Rp00LfWSbZuzZJ2rVrV1h9VVVVkqQf/OAHoT7xdPy++uor3XDDDSovL4+6PlbHbP78+aqtrVVlZaUqKytVW1urwsJCy+uTuq7x66+/1ocffqgnnnhCH374od5880198sknmjVrVkTfoqKisOP64osvhq3vrxq7O4ZSbF6Tdq3v3LoaGxu1fv16uVwuzZkzJ6yfXY9fTz4XbP8+NIiJG2+80RQXF4e1jR071jz22GP9tEcXrqmpyUgyW7duDbXde++95o477uh0zKlTp0xSUpJ54403Qm1ffPGFueSSS0xlZaWVu9utJ5980txwww1R1505c8akp6ebX/7yl6G2b7/91ng8HrN27VpjjL1r68zDDz9sxowZY86cOWOMie/jJ8ls2rQp9PdYHbPf//73RpKprq4O9fH5fEaSOXDggMVVhTu/xmh27txpJJnDhw+H2qZMmWIefvjhTsfYpcZo9cXiNWnn+s53xx13mFtuuSWsLV6OnzGRnwvx8D5kBicGWltbtWfPHhUUFIS1FxQUaPv27f20VxcuEAhIkq644oqw9vfff19paWm65pprVFRUpKamptC6PXv2qK2tLex3kJmZqQkTJtjid3Do0CFlZmYqKytL8+bN02effSZJqq+vl9/vD9tvt9utKVOmhPbb7rWdr7W1Vf/6r/+qv//7vw/7Mtl4Pn7nitUx8/l88ng8ysnJCfW56aab5PF4bFezdPZ96XK5dNlll4W1v/baa0pNTdV3v/tdPfLII2H/erZ7jRf7mrR7fR2OHTumt99+W/fff3/Eung5fud/LsTD+zAhv2wz1o4fP6729nZ5vd6wdq/XK7/f3097dWGMMVqyZIn+6q/+ShMmTAi1z5gxQz/4wQ80atQo1dfX64knntAtt9yiPXv2yO12y+/3a9CgQbr88svDtmeH30FOTo5effVVXXPNNTp27Jj++Z//WXl5edq/f39o36Idu8OHD0uSrWuL5q233tKpU6d03333hdri+fidL1bHzO/3Ky0tLWL7aWlptqv522+/1WOPPab58+eHfXHh3XffraysLKWnp+vjjz/WsmXLtHfv3tApSjvXGIvXpJ3rO9crr7yilJQU3XnnnWHt8XL8on0uxMP7kIATQ+f+a1k6+6I4v83uFi5cqI8++kgffPBBWPvcuXNDf54wYYImT56sUaNG6e233454057LDr+DGTNmhP583XXXKTc3V2PGjNErr7wSuqjxQo6dHWqLZt26dZoxY4YyMzNDbfF8/DoTi2MWrb/dam5ra9O8efN05swZrVmzJmxdUVFR6M8TJkzQ1VdfrcmTJ+vDDz/UpEmTJNm3xli9Ju1a37nWr1+vu+++W8nJyWHt8XL8OvtckOz9PuQUVQykpqZqwIABEWmzqakpIt3a2UMPPaTNmzfrvffe0/Dhw7vsm5GRoVGjRunQoUOSpPT0dLW2turkyZNh/ez4OxgyZIiuu+46HTp0KHQ3VVfHLp5qO3z4sN555x395Cc/6bJfPB+/WB2z9PR0HTt2LGL7X375pW1qbmtr0w9/+EPV19erqqoqbPYmmkmTJikpKSnsuNq9xg4X8pqMh/q2bdumgwcPdvuelOx5/Dr7XIiH9yEBJwYGDRqk7Ozs0LRih6qqKuXl5fXTXvWcMUYLFy7Um2++qXfffVdZWVndjjlx4oSOHDmijIwMSVJ2draSkpLCfgeNjY36+OOPbfc7aGlpUV1dnTIyMkLTw+fud2trq7Zu3Rra73iq7be//a3S0tL0/e9/v8t+8Xz8YnXMcnNzFQgEtHPnzlCfHTt2KBAI2KLmjnBz6NAhvfPOOxo2bFi3Y/bv36+2trbQcbV7jee6kNdkPNS3bt06ZWdn64Ybbui2r52OX3efC3HxPryoS5QR8sYbb5ikpCSzbt068/vf/96UlJSYIUOGmM8//7y/d61bP/3pT43H4zHvv/++aWxsDC1ff/21McaY5uZm87Of/cxs377d1NfXm/fee8/k5uaaK6+80gSDwdB2iouLzfDhw80777xjPvzwQ3PLLbeYG264wZw+fbq/SjPGGPOzn/3MvP/+++azzz4z1dXVZubMmSYlJSV0bH75y18aj8dj3nzzTbNv3z5z1113mYyMjLio7Vzt7e1m5MiRZunSpWHt8Xj8mpubTU1NjampqTGSzOrVq01NTU3oDqJYHbPp06eb66+/3vh8PuPz+cx1111nZs6c2e81trW1mVmzZpnhw4eb2trasPdlS0uLMcaYTz/91PziF78wu3btMvX19ebtt982Y8eONRMnTrRFjV3VF8vXpB3r6xAIBMyll15qXnjhhYjxdj9+3X0uGGP/9yEBJ4aef/55M2rUKDNo0CAzadKksNus7UxS1OW3v/2tMcaYr7/+2hQUFJjvfOc7JikpyYwcOdLce++9pqGhIWw733zzjVm4cKG54oorzODBg83MmTMj+vSHuXPnmoyMDJOUlGQyMzPNnXfeafbv3x9af+bMGfPkk0+a9PR043a7zc0332z27dsXtg271nau//qv/zKSzMGDB8Pa4/H4vffee1Ffk/fee68xJnbH7MSJE+buu+82KSkpJiUlxdx9993m5MmT/V5jfX19p+/L9957zxhjTENDg7n55pvNFVdcYQYNGmTGjBljFi1aZE6cOGGLGruqL5avSTvW1+HFF180gwcPNqdOnYoYb/fj193ngjH2fx+6/n8hAAAAjsE1OAAAwHEIOAAAwHEIOAAAwHEIOAAAwHEIOAAAwHEIOAAAwHEIOAAAwHEIOAAAwHEIOAAAwHEIOAAAwHEIOAAAwHEIOAAAwHH+H/L70m0RCfpRAAAAAElFTkSuQmCC"
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "execution_count": 149
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-23T06:53:21.216815Z",
     "start_time": "2025-07-23T06:53:17.455880Z"
    }
   },
   "cell_type": "code",
   "source": [
    "U2_1_rederived_sorted=np.sort(U2_1_rederived)\n",
    "zz = U2_1_rederived_sorted[n+1:]\n",
    "xx = np.arange(1,n)\n",
    "yy = 10*np.log(n / (n-xx)) / np.sqrt(2*n)\n",
    "plt.bar(range(len(yy)), yy, label='U1', color='blue')\n",
    "plt.show()\n",
    "plt.bar(range(len(zz)), zz, label='U1', color='blue')\n",
    "plt.show()\n",
    "\n"
   ],
   "id": "acd0061f3614049c",
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ],
      "image/png": "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"
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ],
      "image/png": "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bNhgduzYYW666aaIW+jOOOMMs3nzZvPaa6+Zr33tayf81sSjOXKXkDHM81DZunWrSU5ONkuXLjXvvvuueeqpp8xJJ51knnzyyWANc33sbrnlFnP66acHtzVv2LDBZGRkmLvvvjtYwzzHZt++faaxsdE0NjYaSeY3v/mNaWxsDN6uY6jm9brrrjMXXHCB8fv9xu/3m/PPP59tzcNt+fLlJicnx6SmpppJkyYFt+Ti6CRFPB5//PFgzcGDB829995rsrKyjNPpNFdeeaXZsWNHyPv873//M3fccYcZN26cGT16tLn++utNa2vrcT6b+NI3sDDPQ+cvf/mLyc/PN06n00yYMME8+uijIa8z18euq6vLzJ8/35x55pnG5XKZvLw8U15ebrq7u4M1zHNsXnjhhYj/v3zLLbcYY4ZuXvfs2WNuvvlmM2bMGDNmzBhz8803m08++eSYxu4wxpjY12cAAACGH99hAQAA1iOwAAAA6xFYAACA9QgsAADAegQWAABgPQILAACwHoEFAABYj8ACAACsR2ABAADWI7AAAADrEVgAAID1CCwAAMB6/w+khFswxP5e2AAAAABJRU5ErkJggg=="
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "execution_count": 170
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-21T00:56:09.701074Z",
     "start_time": "2025-07-21T00:56:09.695755Z"
    }
   },
   "cell_type": "code",
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.0025487170363496514\n"
     ]
    }
   ],
   "execution_count": 39,
   "source": [
    "print(np.sum( U2_1**4))\n",
    "#plt.bar(range(n*k), np.sort(U1_1), label='U1', color='blue')\n",
    "#U1_hist = np.histogram(U1_2)\n",
    "#plt.bar(A1_hist[1][1:], U1_hist[0])\n",
    "#U1_hist\n",
    "#plt.bar(range(n*k), U2_2, label='U1', color='red')\n",
    "#plt.bar(range(n*k), U2_3, label='U1', color='green')\n",
    "# print(np.dot(U1_1, U1_2))\n",
    "# print(np.linalg.norm(U1_1))\n",
    "# print(np.linalg.norm(U1_2))\n",
    "# print(np.linalg.norm(U1_1 - U1_2))\n",
    "# print(\"#######\")\n",
    "# print(np.dot(w2,U2_1) / np.linalg.norm(w2) / np.linalg.norm(U2_1))\n"
   ],
   "id": "3ee78bad946649b6"
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-21T00:56:45.885766Z",
     "start_time": "2025-07-21T00:56:45.879594Z"
    }
   },
   "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": "7a73388abbf6175a",
   "outputs": [],
   "execution_count": 40
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-21T14:42:15.021076Z",
     "start_time": "2025-07-21T14:42:15.002733Z"
    }
   },
   "cell_type": "code",
   "source": [
    "d = a+b\n",
    "partition1, perp1 = find_perp_vector(U1=U1_1, U2=U2_1, d=d, n=n)\n",
    "partition2, perp2 = find_perp_vector(U1=U1_2, U2=U2_2, d=d, n=n)\n",
    "partition3, perp3 = find_perp_vector(U1=U1_3, U2=U2_3, d=d, n=n)\n",
    "\n",
    "perp1 = perp1 / np.linalg.norm(perp1)\n",
    "perp2 = perp2 / np.linalg.norm(perp2)\n",
    "perp3 = perp3 / np.linalg.norm(perp3)"
   ],
   "id": "e9868e80e263abef",
   "outputs": [],
   "execution_count": 126
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-21T00:57:22.995410Z",
     "start_time": "2025-07-21T00:57:22.991132Z"
    }
   },
   "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": "3fb9c98c9b5e64d0",
   "outputs": [],
   "execution_count": 44
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-21T14:42:19.090528Z",
     "start_time": "2025-07-21T14:42:19.085935Z"
    }
   },
   "cell_type": "code",
   "source": [
    "gamma1 = score_partition(partition=partition1, correct_partition=correct_partition1, n=n)\n",
    "gamma2 = score_partition(partition=partition2, correct_partition=correct_partition2, n=n)\n",
    "gamma3 = score_partition(partition=partition3, correct_partition=correct_partition3, n=n)"
   ],
   "id": "7d5b2ea08377cebd",
   "outputs": [],
   "execution_count": 127
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-21T14:42:20.813229Z",
     "start_time": "2025-07-21T14:42:20.808946Z"
    }
   },
   "cell_type": "code",
   "source": [
    "print(gamma1)\n",
    "print(gamma2)\n",
    "print(gamma3)"
   ],
   "id": "c592192acf979d1a",
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.01200000000000001\n",
      "0.014000000000000012\n",
      "0.02200000000000002\n"
     ]
    }
   ],
   "execution_count": 128
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-21T01:06:46.896572Z",
     "start_time": "2025-07-21T01:06:46.889159Z"
    }
   },
   "cell_type": "code",
   "source": [
    "print(scipy.stats.skew(perp1))\n",
    "print(scipy.stats.kurtosis(perp1))\n",
    "print(np.sum(perp1))\n",
    "print(np.sum(perp1**2))\n",
    "print(np.sum(perp1**4))"
   ],
   "id": "e286ec2442a8db7f",
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-0.009246806828951733\n",
      "-0.45128308603486156\n",
      "1.1102230246251565e-15\n",
      "0.9999999999999999\n",
      "0.0025487169139651374\n"
     ]
    }
   ],
   "execution_count": 59
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-21T04:50:38.767811Z",
     "start_time": "2025-07-21T04:50:38.762355Z"
    }
   },
   "cell_type": "code",
   "source": [
    "perp1_ordered = np.sort(perp1)\n",
    "print(perp1_ordered[0]*np.sqrt(1000))\n",
    "print(perp1_ordered[249]*np.sqrt(1000))\n",
    "print(perp1_ordered[499]*np.sqrt(1000))\n",
    "print(perp1_ordered[749]*np.sqrt(1000))\n",
    "print(perp1_ordered[999]*np.sqrt(1000))"
   ],
   "id": "f2d032d94d9fcc8c",
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-3.0009312101815984\n",
      "-0.7328746439731518\n",
      "-0.006986670263469219\n",
      "0.7120842863813229\n",
      "3.286479574992917\n"
     ]
    }
   ],
   "execution_count": 74
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-21T01:22:51.344874Z",
     "start_time": "2025-07-21T01:22:51.335984Z"
    }
   },
   "cell_type": "code",
   "source": [
    "z_perp1 = scipy.stats.zscore(perp1)\n",
    "print(scipy.stats.skew(z_perp1))\n",
    "print(scipy.stats.kurtosis(z_perp1))\n",
    "print(np.sum(z_perp1))\n",
    "print(np.sum(z_perp1**2))\n",
    "print(np.sum(z_perp1**4))\n",
    "\n",
    "print(np.sum(z_perp1 >= 1))\n",
    "print(np.sum(z_perp1 <= -1))"
   ],
   "id": "93a382b12bef5b0e",
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-0.009246806828951733\n",
      "-0.4512830860348611\n",
      "1.7763568394002505e-14\n",
      "1000.0\n",
      "2548.7169139651382\n",
      "165\n",
      "171\n"
     ]
    }
   ],
   "execution_count": 68
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-21T01:06:16.065191Z",
     "start_time": "2025-07-21T01:06:16.060052Z"
    }
   },
   "cell_type": "code",
   "source": [
    "# angle between the two vectors\n",
    "cos_theta = np.dot(perp1, w2) / np.linalg.norm(perp1) / np.linalg.norm(w2)\n",
    "sin_theta = np.sqrt(1-cos_theta**2)\n",
    "print(cos_theta)\n",
    "print(sin_theta)\n"
   ],
   "id": "fe595b857bbb34a6",
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(0.7512138230195856+0j)\n",
      "(0.6600589307814104+0j)\n"
     ]
    }
   ],
   "execution_count": 57
  },
  {
   "metadata": {},
   "cell_type": "markdown",
   "source": "Simply Averaging A",
   "id": "a42a5e492fb1e1ef"
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-11T06:00:06.015647Z",
     "start_time": "2025-07-11T06:00:03.709331Z"
    }
   },
   "cell_type": "code",
   "source": [
    "A_a123 = (A1 + A2 + A3) / 3\n",
    "A_a123_reordered, _, correct_partition1, _ = reorder_matrix(A=A_a123, threshold=threshold, reordering=reordering, n=n)\n",
    "U1_a123, U2_a123 = get_eigenvectors_from_A(A=A_a123_reordered)\n",
    "partition_a123, perp_a123 = find_perp_vector(U1=U1_a123, U2=U2_a123, d=d, n=n)\n",
    "gamma_a123 = score_partition(partition=partition_a123, correct_partition=correct_partition1, n=n)\n"
   ],
   "id": "d1e98eec53071c32",
   "outputs": [],
   "execution_count": 276
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-11T06:00:22.834699Z",
     "start_time": "2025-07-11T06:00:22.829949Z"
    }
   },
   "cell_type": "code",
   "source": [
    "print(np.dot(w1,U1_a123) / np.linalg.norm(w1) / np.linalg.norm(U1_a123))\n",
    "print(np.dot(w2,U2_a123) / np.linalg.norm(w2) / np.linalg.norm(U2_a123))\n",
    "print(np.dot(w2,perp_a123) / np.linalg.norm(w2) / np.linalg.norm(perp_a123))"
   ],
   "id": "ea80ebe6d97cf8a9",
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(-0.9966063027302263+0j)\n",
      "(-0.9151615544993826+0j)\n",
      "(0.9151623054371072+0j)\n"
     ]
    }
   ],
   "execution_count": 278
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-11T06:00:11.207403Z",
     "start_time": "2025-07-11T06:00:11.201871Z"
    }
   },
   "cell_type": "code",
   "source": "print(gamma_a123)",
   "id": "89ccd147fdbc77c",
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.01200000000000001\n"
     ]
    }
   ],
   "execution_count": 277
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-11T06:04:10.279945Z",
     "start_time": "2025-07-11T06:04:10.273404Z"
    }
   },
   "cell_type": "code",
   "source": [
    "U1_b123 = (U1_1 + U1_2 + U1_3) / 3\n",
    "U2_b123 = (U2_1 - U2_2 + U2_3) / 3\n",
    "\n",
    "print(np.linalg.norm(U1_b123))\n",
    "print(np.linalg.norm(U2_b123))\n",
    "print(np.dot(U1_b123, U2_b123))\n",
    "print(np.dot(U1_1, U2_1))\n",
    "print(np.dot(U1_2, U2_2))\n",
    "print(np.dot(U2_1, U2_2))"
   ],
   "id": "2a1f0a7e854478eb",
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.9931229289691577\n",
      "0.8221224405175326\n",
      "0.0016872632833882279\n",
      "-2.3527187142935446e-17\n",
      "-2.1516330926153737e-16\n",
      "-0.5291061500966369\n"
     ]
    }
   ],
   "execution_count": 286
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-11T06:04:12.122763Z",
     "start_time": "2025-07-11T06:04:12.113689Z"
    }
   },
   "cell_type": "code",
   "source": [
    "partition_b123, perp_b123 = find_perp_vector(U1=U1_b123, U2=U2_b123, d=d, n=n)\n",
    "gamma_b123 = score_partition(partition=partition_b123, correct_partition=correct_partition1, n=n)\n"
   ],
   "id": "6f5a15ed3c4d056a",
   "outputs": [],
   "execution_count": 287
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-11T06:04:14.076793Z",
     "start_time": "2025-07-11T06:04:14.071898Z"
    }
   },
   "cell_type": "code",
   "source": "print(np.dot(w2,perp_b123) / np.linalg.norm(w2) / np.linalg.norm(perp_b123))\n",
   "id": "667652a5156322cf",
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(0.8855207067815549+0j)\n"
     ]
    }
   ],
   "execution_count": 288
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-11T06:04:15.995789Z",
     "start_time": "2025-07-11T06:04:15.991179Z"
    }
   },
   "cell_type": "code",
   "source": "print(gamma_b123)",
   "id": "8c06f1cb402352a5",
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.026000000000000023\n"
     ]
    }
   ],
   "execution_count": 289
  },
  {
   "metadata": {},
   "cell_type": "markdown",
   "source": "Average the perpendicular vector and use it as a voting system",
   "id": "381348ef18ad1bfb"
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-11T06:04:56.769085Z",
     "start_time": "2025-07-11T06:04:56.764268Z"
    }
   },
   "cell_type": "code",
   "source": [
    "perp_c123 = (perp1 - perp2 + perp3) / 3\n",
    "\n",
    "perp_c123_args = np.argsort(perp_c123)\n",
    "partition_c123_1 = perp_c123_args[0:n]\n",
    "partition_c123_2 = perp_c123_args[n:]\n",
    "partition_c123 = [partition_c123_1, partition_c123_2]\n",
    "\n",
    "gamma_c123 = score_partition(partition=partition_c123, correct_partition=correct_partition1, n=n)"
   ],
   "id": "f50e6feeaa42aa5d",
   "outputs": [],
   "execution_count": 290
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-11T06:05:13.442766Z",
     "start_time": "2025-07-11T06:05:13.426018Z"
    }
   },
   "cell_type": "code",
   "source": "print(np.dot(w2,perp_c123) / np.linalg.norm(w2) / np.linalg.norm(perp_c123))\n",
   "id": "a6718c4d74fbb536",
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(0.8855214109808781+0j)\n"
     ]
    }
   ],
   "execution_count": 291
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-11T06:05:15.976446Z",
     "start_time": "2025-07-11T06:05:15.971167Z"
    }
   },
   "cell_type": "code",
   "source": "print(gamma_c123)",
   "id": "42d3dfc777a0cfb",
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.026000000000000023\n"
     ]
    }
   ],
   "execution_count": 292
  },
  {
   "metadata": {},
   "cell_type": "markdown",
   "source": "Subtract the A by the mean, then do elementwise RMS of both matrices",
   "id": "bd7ce7e9ed41f01b"
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-11T06:10:36.258319Z",
     "start_time": "2025-07-11T06:10:36.238324Z"
    }
   },
   "cell_type": "code",
   "source": [
    "#A1_d = A1 - np.mean(A1)\n",
    "#A2_d = A2 - np.mean(A2)\n",
    "\n",
    "A1_d = A1 - A_a123\n",
    "A2_d = A2 - A_a123\n",
    "A3_d = A3 - A_a123\n",
    "#A_d12 = ((np.cbrt(A1_d) + np.cbrt(A2_d))/2)**3\n",
    "#A_d12 = np.cbrt((A1_d**3 + A2_d**3)/2)\n",
    "#A_d12 = np.sqrt((A1_d**2 + A2_d**2)/2)\n",
    "A_d123 = np.sqrt((A1_d**2 + A2_d**2 + A3_d**2)/3)"
   ],
   "id": "38e5617f0df20bc8",
   "outputs": [],
   "execution_count": 298
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-11T06:10:37.892696Z",
     "start_time": "2025-07-11T06:10:37.811701Z"
    }
   },
   "cell_type": "code",
   "source": [
    "diff_a = A_a123 - threshold\n",
    "diff_d = A_d123 - threshold\n",
    "print(np.linalg.norm(A1 - threshold))\n",
    "print(np.linalg.norm(A2 - threshold))\n",
    "print(np.linalg.norm(A3 - threshold))\n",
    "print(np.linalg.norm(diff_a))\n",
    "print(np.linalg.norm(diff_d))\n",
    "print(\"######\")\n",
    "print(np.mean(diff_a))\n",
    "print(np.mean(diff_d))\n",
    "print(np.var(diff_a))\n",
    "print(np.var(diff_d))\n",
    "print(\"######\")\n",
    "print(np.var(A1 - threshold))\n",
    "print(np.var(A2 - threshold))\n",
    "print(np.var(A3 - threshold))\n",
    "print(np.mean(A1 - threshold))\n",
    "print(np.mean(A2 - threshold))\n",
    "print(np.mean(A3 - threshold))"
   ],
   "id": "aed79ca2861ef7c1",
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "217.7670314809143\n",
      "218.34120087608227\n",
      "217.15487560727124\n",
      "125.84505464172166\n",
      "165.01184810436908\n",
      "######\n",
      "1.833333333332963e-05\n",
      "0.016991767854134303\n",
      "0.015836977441666678\n",
      "0.02694018984000971\n",
      "######\n",
      "0.04742247915899998\n",
      "0.047672784519000005\n",
      "0.04715615991100001\n",
      "2.899999999998572e-05\n",
      "0.00030899999999998577\n",
      "-0.00028300000000001414\n"
     ]
    }
   ],
   "execution_count": 299
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-11T06:11:13.710628Z",
     "start_time": "2025-07-11T06:11:12.942542Z"
    }
   },
   "cell_type": "code",
   "source": [
    "A_d123_reordered, _, correct_partition1, _ = reorder_matrix(A=A_d123, threshold=threshold, reordering=reordering, n=n)\n",
    "U1_d123, U2_d123 = get_eigenvectors_from_A(A=A_d123_reordered)\n",
    "partition_d123, perp_d123 = find_perp_vector(U1=U1_d123, U2=U2_d123, d=d, n=n)\n",
    "\n",
    "gamma_d123 = score_partition(partition=partition_d123, correct_partition=correct_partition1, n=n)\n"
   ],
   "id": "2a375c4d2d345d03",
   "outputs": [],
   "execution_count": 300
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-11T06:11:16.425435Z",
     "start_time": "2025-07-11T06:11:16.420647Z"
    }
   },
   "cell_type": "code",
   "source": "print(gamma_d123)",
   "id": "377280ca74ea0fa2",
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.010000000000000009\n"
     ]
    }
   ],
   "execution_count": 301
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-11T05:55:34.454676Z",
     "start_time": "2025-07-11T05:55:34.447663Z"
    }
   },
   "cell_type": "code",
   "source": [
    "print(np.linalg.norm(U1_d12))\n",
    "print(np.linalg.norm(U2_d12))\n",
    "print(np.linalg.norm(perp_d12))\n",
    "print(\"###\")\n",
    "print(np.dot(U1_d12, perp_d12) / np.linalg.norm(U1_d12) / np.linalg.norm(perp_d12))\n",
    "print(np.dot(U2_d12, perp_d12) / np.linalg.norm(U2_d12) / np.linalg.norm(perp_d12))\n",
    "print(\"###\")\n",
    "print(np.dot(w1,U1_d12) / np.linalg.norm(w1) / np.linalg.norm(U1_d12))\n",
    "print(np.dot(w2,U2_d12) / np.linalg.norm(w2) / np.linalg.norm(U2_d12))\n",
    "print(np.dot(U1_d12,U2_d12) / np.linalg.norm(U1_d12) / np.linalg.norm(U2_d12))\n",
    "print(np.dot(w2,perp_d12) / np.linalg.norm(w2) / np.linalg.norm(perp_d12))\n"
   ],
   "id": "e4e0599c92d0b37c",
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1.0\n",
      "1.0\n",
      "1.4142135623730951\n",
      "###\n",
      "-0.7071067811865475\n",
      "0.7071067811865475\n",
      "###\n",
      "(0.031622776601683986+0j)\n",
      "(-0.031622776601684166+0j)\n",
      "0.0\n",
      "(-3.1401849173675493e-16+0j)\n"
     ]
    }
   ],
   "execution_count": 264
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-11T05:55:40.554063Z",
     "start_time": "2025-07-11T05:55:38.017456Z"
    }
   },
   "cell_type": "code",
   "source": "plt.bar(range(n*k), perp_d12, label='perp_d12', color='blue')",
   "id": "9c2ec5c5c90ac4c5",
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<BarContainer object of 1000 artists>"
      ]
     },
     "execution_count": 265,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ],
      "image/png": "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1tbyO1chxDp3Dta587DWnYN17hyhWmdjjA4fPqykpCR169b2t2zOyh2cbt26qX///iF9j5iYGP7H0wlY587BOnce1rpzsM6dIxTrfLKdm6/xJWMAAGAdAg4AALAOAaeDud1u/fznP5fb7T7TQ7Ea69w5WOfOw1p3Dta5c3SFdT4rv2QMAADsxg4OAACwDgEHAABYh4ADAACsQ8ABAADWIeB0sIULFyolJUXR0dFKT0/X5s2bz/SQwkZhYaEuuugi9e7dW3FxcZo8ebJ2794dVGOM0fz585WUlKQePXpo3Lhxeu+994JqGhsbdffddys2Nla9evXSddddp3379nXmVMJKYWGhXC6X8vPzA22sc8fYv3+/brnlFvXr1089e/bUhRdeqMrKysB51rljHDt2TPfff79SUlLUo0cPDRo0SAsWLNCJEycCNax1+23atEnXXnutkpKS5HK59Ic//CHofEetaUNDgzwejxzHkeM48ng8OnTo0OlPwKDDrFy50nTv3t288MIL5v333zezZ882vXr1Mn/5y1/O9NDCwoQJE8yLL75odu3aZaqrq80111xjzj33XHPkyJFAzaOPPmp69+5tiouLzbvvvmtyc3NNYmKi8fv9gZoZM2aY733ve6a0tNTs2LHDXH755eaCCy4wx44dOxPT6tK2b99uBg4caM4//3wze/bsQDvrfPr++te/mgEDBpjbb7/dbNu2zezdu9esX7/efPTRR4Ea1rlj/Md//Ifp16+f+e///m+zd+9e88orr5jvfOc75sknnwzUsNbtV1JSYubNm2eKi4uNJLN69eqg8x21phMnTjSpqammrKzMlJWVmdTUVDNp0qTTHj8BpwONGTPGzJgxI6ht6NCh5t577z1DIwpv9fX1RpLZuHGjMcaYEydOmISEBPPoo48Gar788kvjOI55/vnnjTHGHDp0yHTv3t2sXLkyULN//37TrVs3s27dus6dQBd3+PBhM3jwYFNaWmouu+yyQMBhnTvG3LlzzSWXXNLqeda541xzzTXmn//5n4PafvSjH5lbbrnFGMNad4RvBpyOWtP333/fSDJbt24N1JSXlxtJ5k9/+tNpjZk/UXWQpqYmVVZWKicnJ6g9JydHZWVlZ2hU4c3n80mS+vbtK0nau3evvF5v0Bq73W5ddtllgTWurKzU0aNHg2qSkpKUmprKv8M33HXXXbrmmms0fvz4oHbWuWOsWbNGo0eP1o033qi4uDilpaXphRdeCJxnnTvOJZdcojfeeEMffvihJGnnzp3asmWLrr76akmsdSh01JqWl5fLcRxlZGQEajIzM+U4zmmv+1n5Y5uhcODAAR0/flzx8fFB7fHx8fJ6vWdoVOHLGKM5c+bokksuUWpqqiQF1rGlNf7LX/4SqImKilKfPn2a1fDv8H9WrlypHTt26O233252jnXuGP/7v/+rRYsWac6cObrvvvu0fft2zZo1S263W7feeivr3IHmzp0rn8+noUOHKiIiQsePH9fDDz+sm266SRL/TYdCR62p1+tVXFxcs/7j4uJOe90JOB3M5XIFvTbGNGvDyc2cOVPvvPOOtmzZ0uzct1lj/h3+T21trWbPnq3XX39d0dHRrdaxzqfnxIkTGj16tB555BFJUlpamt577z0tWrRIt956a6COdT59RUVFevnll/Xb3/5WI0aMUHV1tfLz85WUlKTbbrstUMdad7yOWNOW6jti3fkTVQeJjY1VREREs8RZX1/fLOGibXfffbfWrFmjt956S/379w+0JyQkSFKba5yQkKCmpiY1NDS0WnO2q6ysVH19vdLT0xUZGanIyEht3LhRTz/9tCIjIwPrxDqfnsTERA0fPjyobdiwYaqpqZHEf88d6d/+7d907733aurUqRo5cqQ8Ho9+8pOfqLCwUBJrHQodtaYJCQn69NNPm/X/2Wefnfa6E3A6SFRUlNLT01VaWhrUXlpaquzs7DM0qvBijNHMmTO1atUqvfnmm0pJSQk6n5KSooSEhKA1bmpq0saNGwNrnJ6eru7duwfV1NXVadeuXfw7/H9XXHGF3n33XVVXVweO0aNHa9q0aaqurtagQYNY5w5w8cUXN3vMwYcffqgBAwZI4r/njvT555+rW7fgj7OIiIjAbeKsdcfrqDXNysqSz+fT9u3bAzXbtm2Tz+c7/XU/ra8oI8jXt4kvWbLEvP/++yY/P9/06tXLfPzxx2d6aGHhxz/+sXEcx2zYsMHU1dUFjs8//zxQ8+ijjxrHccyqVavMu+++a2666aYWb0vs37+/Wb9+vdmxY4f5wQ9+cFbf6nkq/v4uKmNY546wfft2ExkZaR5++GGzZ88es3z5ctOzZ0/z8ssvB2pY545x2223me9973uB28RXrVplYmNjzc9+9rNADWvdfocPHzZVVVWmqqrKSDJPPPGEqaqqCjz6pKPWdOLEieb888835eXlpry83IwcOZLbxLui5557zgwYMMBERUWZUaNGBW5xxslJavF48cUXAzUnTpwwP//5z01CQoJxu93m0ksvNe+++25QP1988YWZOXOm6du3r+nRo4eZNGmSqamp6eTZhJdvBhzWuWP88Y9/NKmpqcbtdpuhQ4eaxYsXB51nnTuG3+83s2fPNueee66Jjo42gwYNMvPmzTONjY2BGta6/d56660W/z/5tttuM8Z03JoePHjQTJs2zfTu3dv07t3bTJs2zTQ0NJz2+F3GGHN6e0AAAABdC9/BAQAA1iHgAAAA6xBwAACAdQg4AADAOgQcAABgHQIOAACwDgEHAABYh4ADAACsQ8ABAADWIeAAAADrEHAAAIB1CDgAAMA6/w9smin/xvYKMwAAAABJRU5ErkJggg=="
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "execution_count": 265
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-11T05:55:51.880916Z",
     "start_time": "2025-07-11T05:55:51.869589Z"
    }
   },
   "cell_type": "code",
   "source": [
    "unique_values, counts = np.unique(A_d12_reordered.flatten(), return_counts=True)\n",
    "print(unique_values)\n",
    "print(counts)"
   ],
   "id": "7946ee75a4c2e76f",
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.]\n",
      "[1000000]\n"
     ]
    }
   ],
   "execution_count": 266
  }
 ],
 "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
}
