{
 "cells": [
  {
   "cell_type": "code",
   "id": "initial_id",
   "metadata": {
    "collapsed": true,
    "ExecuteTime": {
     "end_time": "2025-07-20T05:46:57.078729Z",
     "start_time": "2025-07-20T05:46:39.486524Z"
    }
   },
   "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",
    "import cvxpy as cp\n",
    "\n"
   ],
   "outputs": [],
   "execution_count": 2
  },
  {
   "metadata": {},
   "cell_type": "markdown",
   "source": "Optimization problem given n, k, and sin theta",
   "id": "1f2305809c78623d"
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-21T00:58:26.312405Z",
     "start_time": "2025-07-21T00:58:26.308870Z"
    }
   },
   "cell_type": "code",
   "source": [
    "n = 500\n",
    "k = (int)(0.114*500)"
   ],
   "id": "db00f0df67377388",
   "outputs": [],
   "execution_count": 75
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-21T04:53:08.163989Z",
     "start_time": "2025-07-21T04:53:08.019013Z"
    }
   },
   "cell_type": "code",
   "source": [
    "x = cp.Variable(2*n)\n",
    "sos = cp.sum_squares(x)\n",
    "constraints = [sos <= 1]\n",
    "\n",
    "for i in range(2*n-1):\n",
    "    constraints.append(x[i] >= x[i+1])\n",
    "\n",
    "constraints.append(x[249] * np.sqrt(2*n) <= 0.75)\n",
    "constraints.append(x[749] * np.sqrt(2*n) >= -0.75)\n",
    "\n",
    "coefficients = np.ones([1,2*n])\n",
    "coefficients[0,n-k:n] = -1\n",
    "coefficients[0,n+k:2*n] = -1\n",
    "objective = cp.Maximize(cp.vdot(coefficients, x))\n",
    "\n",
    "prob1 = cp.Problem(objective, constraints)\n",
    "\n"
   ],
   "id": "2492f92c8ad1cd0b",
   "outputs": [],
   "execution_count": 109
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-21T04:53:11.337768Z",
     "start_time": "2025-07-21T04:53:10.248146Z"
    }
   },
   "cell_type": "code",
   "source": "prob1.solve()",
   "id": "10715544a69a5db8",
   "outputs": [
    {
     "data": {
      "text/plain": [
       "np.float64(28.93639532260393)"
      ]
     },
     "execution_count": 110,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "execution_count": 110
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-21T04:53:13.551897Z",
     "start_time": "2025-07-21T04:53:13.545542Z"
    }
   },
   "cell_type": "code",
   "source": "sos.value",
   "id": "9a2c459da7a85c5d",
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array(0.99999993)"
      ]
     },
     "execution_count": 111,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "execution_count": 111
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-21T04:53:15.817840Z",
     "start_time": "2025-07-21T04:53:15.811457Z"
    }
   },
   "cell_type": "code",
   "source": "prob1.value / np.sqrt(2*n)",
   "id": "fe1a20d6eeff56dd",
   "outputs": [
    {
     "data": {
      "text/plain": [
       "np.float64(0.9150491649447119)"
      ]
     },
     "execution_count": 112,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "execution_count": 112
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-21T04:54:23.432071Z",
     "start_time": "2025-07-21T04:54:21.053848Z"
    }
   },
   "cell_type": "code",
   "source": "plt.bar(range(n*2), x.value, label='U1', color='blue')",
   "id": "ced6451779d90f1b",
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<BarContainer object of 1000 artists>"
      ]
     },
     "execution_count": 118,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ],
      "image/png": "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W1RQUKD58+erpKREEnsdDb21px6PR19++WXY+F999dVF7zsBp5fEx8crMzNTFRUVIe0VFRXKzc3to1nFFmOM5s6dq3fffVcffPCB0tPTQ95PT0+Xx+MJ2ePOzk5VVlYG9zgzM1MDBgwIqWlubtYnn3zCn8P/90d/9Efav3+/6urqgkdWVpYeeugh1dXVacSIEexzL/iDP/iDsMcc/OIXv9CwYcMk8e9zbzp27Jj69Qv9cda/f//gbeLsde/rrT3NycmR3+/Xrl27gjU7d+6U3++/+H2/qEuUEeLMbeIbN240n376qSkqKjJXXXWV+dWvftXXU4sJf/mXf2lcLpfZvn27aW5uDh7Hjh0L1rz88svG5XKZd9991+zfv988+OCDEW9LvP766837779vPv74Y/OHf/iHV/Stnt3xu3dRGcM+94Zdu3aZuLg489JLL5n//d//NW+99ZYZNGiQefPNN4M17HPvePTRR811110XvE383XffNcnJyebZZ58N1rDXPdfe3m5qa2tNbW2tkWRWrlxpamtrg48+6a09nTRpkrn11luN1+s1Xq/X3HLLLdwmfjlas2aNGTZsmImPjzdjx44N3uKM85MU8Xj99deDNadOnTIvvPCC8Xg8xul0mjvvvNPs378/ZJxvv/3WzJ0711x77bVm4MCBZtq0aaaxsfESrya2nB1w2Ofe8R//8R8mIyPDOJ1OM3LkSPPqq6+GvM8+945AIGCefvppc8MNN5iEhAQzYsQIs3jxYtPR0RGsYa977sMPP4z43+RHH33UGNN7e3rkyBHz0EMPmcTERJOYmGgeeugh09bWdtHzdxhjzMWdAwIAALi8cA0OAACwDgEHAABYh4ADAACsQ8ABAADWIeAAAADrEHAAAIB1CDgAAMA6BBwAAGAdAg4AALAOAQcAAFiHgAMAAKxDwAEAANb5fzCg5N0ihEdoAAAAAElFTkSuQmCC"
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "execution_count": 118
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-21T04:54:11.822339Z",
     "start_time": "2025-07-21T04:54:11.813499Z"
    }
   },
   "cell_type": "code",
   "source": [
    "x.value\n",
    "\n",
    "print(scipy.stats.skew(x.value))\n",
    "print(scipy.stats.kurtosis(x.value))\n",
    "print(np.sum(x.value))\n",
    "print(np.sum(x.value**2))\n",
    "print(np.sum(x.value**4))\n",
    "print(x.value[249] * np.sqrt(2*n))\n",
    "print(x.value[749] * np.sqrt(2*n))"
   ],
   "id": "da95540fdb92f5ad",
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-3.480818960634903e-05\n",
      "-1.6510725955490118\n",
      "-0.01587752983972912\n",
      "0.9999999334526898\n",
      "0.0013489281272807295\n",
      "0.7500000003099809\n",
      "-0.7500000002861743\n"
     ]
    }
   ],
   "execution_count": 117
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-21T04:53:23.439101Z",
     "start_time": "2025-07-21T04:53:23.417851Z"
    }
   },
   "cell_type": "code",
   "source": [
    "z_x = scipy.stats.zscore(x.value)\n",
    "print(scipy.stats.skew(z_x))\n",
    "print(scipy.stats.kurtosis(z_x))\n",
    "print(np.sum(z_x))\n",
    "print(np.sum(z_x**2))\n",
    "print(np.sum(z_x**4))\n",
    "\n",
    "print(np.sum(z_x >= 1))\n",
    "print(np.sum(z_x <= -1))\n",
    "\n",
    "z_x"
   ],
   "id": "c480bd51369012f5",
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-3.480818960679243e-05\n",
      "-1.6510725955490118\n",
      "1.1368683772161603e-13\n",
      "1000.0000000000002\n",
      "1348.927404450989\n",
      "249\n",
      "250\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "array([ 1.25467512e+00,  1.25441627e+00,  1.25428078e+00,  1.25418802e+00,\n",
       "        1.25411661e+00,  1.25405783e+00,  1.25400741e+00,  1.25396295e+00,\n",
       "        1.25392301e+00,  1.25388663e+00,  1.25385313e+00,  1.25382204e+00,\n",
       "        1.25379299e+00,  1.25376568e+00,  1.25373990e+00,  1.25371546e+00,\n",
       "        1.25369219e+00,  1.25366999e+00,  1.25364873e+00,  1.25362833e+00,\n",
       "        1.25360870e+00,  1.25358978e+00,  1.25357151e+00,  1.25355384e+00,\n",
       "        1.25353671e+00,  1.25352010e+00,  1.25350395e+00,  1.25348825e+00,\n",
       "        1.25347295e+00,  1.25345804e+00,  1.25344349e+00,  1.25342927e+00,\n",
       "        1.25341536e+00,  1.25340176e+00,  1.25338844e+00,  1.25337538e+00,\n",
       "        1.25336257e+00,  1.25335001e+00,  1.25333766e+00,  1.25332554e+00,\n",
       "        1.25331361e+00,  1.25330188e+00,  1.25329034e+00,  1.25327897e+00,\n",
       "        1.25326777e+00,  1.25325673e+00,  1.25324584e+00,  1.25323510e+00,\n",
       "        1.25322451e+00,  1.25321404e+00,  1.25320371e+00,  1.25319350e+00,\n",
       "        1.25318340e+00,  1.25317343e+00,  1.25316356e+00,  1.25315379e+00,\n",
       "        1.25314413e+00,  1.25313457e+00,  1.25312510e+00,  1.25311572e+00,\n",
       "        1.25310642e+00,  1.25309722e+00,  1.25308809e+00,  1.25307904e+00,\n",
       "        1.25307006e+00,  1.25306116e+00,  1.25305232e+00,  1.25304356e+00,\n",
       "        1.25303485e+00,  1.25302621e+00,  1.25301764e+00,  1.25300912e+00,\n",
       "        1.25300065e+00,  1.25299224e+00,  1.25298389e+00,  1.25297558e+00,\n",
       "        1.25296733e+00,  1.25295912e+00,  1.25295095e+00,  1.25294284e+00,\n",
       "        1.25293476e+00,  1.25292672e+00,  1.25291873e+00,  1.25291077e+00,\n",
       "        1.25290285e+00,  1.25289497e+00,  1.25288712e+00,  1.25287930e+00,\n",
       "        1.25287152e+00,  1.25286377e+00,  1.25285604e+00,  1.25284835e+00,\n",
       "        1.25284068e+00,  1.25283304e+00,  1.25282542e+00,  1.25281783e+00,\n",
       "        1.25281026e+00,  1.25280272e+00,  1.25279519e+00,  1.25278769e+00,\n",
       "        1.25278021e+00,  1.25277274e+00,  1.25276529e+00,  1.25275786e+00,\n",
       "        1.25275045e+00,  1.25274305e+00,  1.25273566e+00,  1.25272829e+00,\n",
       "        1.25272093e+00,  1.25271358e+00,  1.25270625e+00,  1.25269892e+00,\n",
       "        1.25269161e+00,  1.25268430e+00,  1.25267700e+00,  1.25266971e+00,\n",
       "        1.25266242e+00,  1.25265514e+00,  1.25264786e+00,  1.25264059e+00,\n",
       "        1.25263333e+00,  1.25262606e+00,  1.25261880e+00,  1.25261154e+00,\n",
       "        1.25260428e+00,  1.25259701e+00,  1.25258975e+00,  1.25258249e+00,\n",
       "        1.25257522e+00,  1.25256795e+00,  1.25256068e+00,  1.25255340e+00,\n",
       "        1.25254612e+00,  1.25253883e+00,  1.25253153e+00,  1.25252422e+00,\n",
       "        1.25251691e+00,  1.25250959e+00,  1.25250226e+00,  1.25249492e+00,\n",
       "        1.25248756e+00,  1.25248019e+00,  1.25247282e+00,  1.25246542e+00,\n",
       "        1.25245801e+00,  1.25245059e+00,  1.25244315e+00,  1.25243569e+00,\n",
       "        1.25242821e+00,  1.25242072e+00,  1.25241320e+00,  1.25240566e+00,\n",
       "        1.25239811e+00,  1.25239052e+00,  1.25238292e+00,  1.25237529e+00,\n",
       "        1.25236763e+00,  1.25235995e+00,  1.25235224e+00,  1.25234450e+00,\n",
       "        1.25233673e+00,  1.25232892e+00,  1.25232109e+00,  1.25231322e+00,\n",
       "        1.25230532e+00,  1.25229738e+00,  1.25228940e+00,  1.25228138e+00,\n",
       "        1.25227332e+00,  1.25226523e+00,  1.25225708e+00,  1.25224890e+00,\n",
       "        1.25224066e+00,  1.25223238e+00,  1.25222405e+00,  1.25221567e+00,\n",
       "        1.25220724e+00,  1.25219875e+00,  1.25219020e+00,  1.25218159e+00,\n",
       "        1.25217293e+00,  1.25216420e+00,  1.25215540e+00,  1.25214654e+00,\n",
       "        1.25213761e+00,  1.25212861e+00,  1.25211953e+00,  1.25211037e+00,\n",
       "        1.25210113e+00,  1.25209181e+00,  1.25208241e+00,  1.25207291e+00,\n",
       "        1.25206332e+00,  1.25205363e+00,  1.25204385e+00,  1.25203396e+00,\n",
       "        1.25202396e+00,  1.25201384e+00,  1.25200361e+00,  1.25199326e+00,\n",
       "        1.25198278e+00,  1.25197217e+00,  1.25196142e+00,  1.25195052e+00,\n",
       "        1.25193948e+00,  1.25192827e+00,  1.25191690e+00,  1.25190536e+00,\n",
       "        1.25189364e+00,  1.25188173e+00,  1.25186962e+00,  1.25185729e+00,\n",
       "        1.25184475e+00,  1.25183198e+00,  1.25181895e+00,  1.25180567e+00,\n",
       "        1.25179212e+00,  1.25177827e+00,  1.25176412e+00,  1.25174964e+00,\n",
       "        1.25173480e+00,  1.25171960e+00,  1.25170399e+00,  1.25168795e+00,\n",
       "        1.25167146e+00,  1.25165446e+00,  1.25163692e+00,  1.25161880e+00,\n",
       "        1.25160004e+00,  1.25158059e+00,  1.25156036e+00,  1.25153929e+00,\n",
       "        1.25151727e+00,  1.25149420e+00,  1.25146994e+00,  1.25144433e+00,\n",
       "        1.25141717e+00,  1.25138822e+00,  1.25135717e+00,  1.25132361e+00,\n",
       "        1.25128702e+00,  1.25124666e+00,  1.25120152e+00,  1.25115006e+00,\n",
       "        1.25108988e+00,  1.25101679e+00,  1.25092261e+00,  1.25078722e+00,\n",
       "        1.25053269e+00,  7.50502211e-01,  7.50502226e-01,  7.50502241e-01,\n",
       "        7.50502256e-01,  7.50502271e-01,  7.50502286e-01,  7.50502301e-01,\n",
       "        7.50502315e-01,  7.50502330e-01,  7.50502345e-01,  7.50502359e-01,\n",
       "        7.50502374e-01,  7.50502389e-01,  7.50502403e-01,  7.50502418e-01,\n",
       "        7.50502433e-01,  7.50502447e-01,  7.50502462e-01,  7.50502476e-01,\n",
       "        7.50502490e-01,  7.50502505e-01,  7.50502519e-01,  7.50502534e-01,\n",
       "        7.50502548e-01,  7.50502562e-01,  7.50502576e-01,  7.50502591e-01,\n",
       "        7.50502605e-01,  7.50502619e-01,  7.50502633e-01,  7.50502647e-01,\n",
       "        7.50502661e-01,  7.50502675e-01,  7.50502689e-01,  7.50502703e-01,\n",
       "        7.50502717e-01,  7.50502731e-01,  7.50502745e-01,  7.50502759e-01,\n",
       "        7.50502773e-01,  7.50502786e-01,  7.50502800e-01,  7.50502814e-01,\n",
       "        7.50502827e-01,  7.50502841e-01,  7.50502854e-01,  7.50502868e-01,\n",
       "        7.50502881e-01,  7.50502895e-01,  7.50502908e-01,  7.50502922e-01,\n",
       "        7.50502935e-01,  7.50502948e-01,  7.50502961e-01,  7.50502975e-01,\n",
       "        7.50502988e-01,  7.50503001e-01,  7.50503014e-01,  7.50503027e-01,\n",
       "        7.50503040e-01,  7.50503053e-01,  7.50503065e-01,  7.50503078e-01,\n",
       "        7.50503091e-01,  7.50503104e-01,  7.50503116e-01,  7.50503129e-01,\n",
       "        7.50503141e-01,  7.50503154e-01,  7.50503166e-01,  7.50503178e-01,\n",
       "        7.50503191e-01,  7.50503203e-01,  7.50503215e-01,  7.50503227e-01,\n",
       "        7.50503239e-01,  7.50503251e-01,  7.50503263e-01,  7.50503275e-01,\n",
       "        7.50503287e-01,  7.50503298e-01,  7.50503310e-01,  7.50503322e-01,\n",
       "        7.50503333e-01,  7.50503345e-01,  7.50503356e-01,  7.50503367e-01,\n",
       "        7.50503378e-01,  7.50503390e-01,  7.50503401e-01,  7.50503412e-01,\n",
       "        7.50503422e-01,  7.50503433e-01,  7.50503444e-01,  7.50503454e-01,\n",
       "        7.50503465e-01,  7.50503475e-01,  7.50503486e-01,  7.50503496e-01,\n",
       "        7.50503506e-01,  7.50503516e-01,  7.50503526e-01,  7.50503536e-01,\n",
       "        7.50503546e-01,  7.50503555e-01,  7.50503565e-01,  7.50503574e-01,\n",
       "        7.50503584e-01,  7.50503593e-01,  7.50503602e-01,  7.50503611e-01,\n",
       "        7.50503619e-01,  7.50503628e-01,  7.50503637e-01,  7.50503645e-01,\n",
       "        7.50503653e-01,  7.50503661e-01,  7.50503669e-01,  7.50503677e-01,\n",
       "        7.50503685e-01,  7.50503692e-01,  7.50503699e-01,  7.50503707e-01,\n",
       "        7.50503714e-01,  7.50503720e-01,  7.50503727e-01,  7.50503733e-01,\n",
       "        7.50503740e-01,  7.50503746e-01,  7.50503751e-01,  7.50503757e-01,\n",
       "        7.50503762e-01,  7.50503768e-01,  7.50503772e-01,  7.50503777e-01,\n",
       "        7.50503782e-01,  7.50503786e-01,  7.50503790e-01,  7.50503793e-01,\n",
       "        7.50503796e-01,  7.50503799e-01,  7.50503802e-01,  7.50503805e-01,\n",
       "        7.50503807e-01,  7.50503808e-01,  7.50503810e-01,  7.50503811e-01,\n",
       "        7.50503811e-01,  7.50503811e-01,  7.50503811e-01,  7.50503810e-01,\n",
       "        7.50503809e-01,  7.50503807e-01,  7.50503805e-01,  7.50503802e-01,\n",
       "        7.50503799e-01,  7.50503795e-01,  7.50503790e-01,  7.50503785e-01,\n",
       "        7.50503779e-01,  7.50503773e-01,  7.50503765e-01,  7.50503757e-01,\n",
       "        7.50503747e-01,  7.50503737e-01,  7.50503726e-01,  7.50503714e-01,\n",
       "        7.50503700e-01,  7.50503685e-01,  7.50503669e-01,  7.50503652e-01,\n",
       "        7.50503632e-01,  7.50503611e-01,  7.50503588e-01,  7.50503563e-01,\n",
       "        7.50503536e-01,  7.50503506e-01,  7.50503473e-01,  7.50503437e-01,\n",
       "        7.50503397e-01,  7.50503353e-01,  7.50503304e-01,  7.50503249e-01,\n",
       "        7.50503187e-01,  7.50503118e-01,  7.50503038e-01,  7.50502946e-01,\n",
       "        7.50502839e-01,  7.50502710e-01,  7.50502551e-01,  7.50502348e-01,\n",
       "        7.50502070e-01,  7.50501644e-01,  7.50500773e-01,  5.02641845e-04,\n",
       "        5.02304000e-04,  5.02144826e-04,  5.02045214e-04,  5.01975384e-04,\n",
       "        5.01923424e-04,  5.01883377e-04,  5.01851841e-04,  5.01826688e-04,\n",
       "        5.01806499e-04,  5.01790281e-04,  5.01777313e-04,  5.01767054e-04,\n",
       "        5.01759085e-04,  5.01753081e-04,  5.01748779e-04,  5.01745967e-04,\n",
       "        5.01744469e-04,  5.01744139e-04,  5.01744855e-04,  5.01746511e-04,\n",
       "        5.01749019e-04,  5.01752301e-04,  5.01756289e-04,  5.01760925e-04,\n",
       "        5.01766157e-04,  5.01771939e-04,  5.01778230e-04,  5.01784994e-04,\n",
       "        5.01792199e-04,  5.01799814e-04,  5.01807815e-04,  5.01816175e-04,\n",
       "        5.01824875e-04,  5.01833893e-04,  5.01843211e-04,  5.01852813e-04,\n",
       "        5.01862684e-04,  5.01872810e-04,  5.01883176e-04,  5.01893772e-04,\n",
       "        5.01904586e-04,  5.01915608e-04,  5.01926828e-04,  5.01938236e-04,\n",
       "        5.01949826e-04,  5.01961588e-04,  5.01973516e-04,  5.01985602e-04,\n",
       "        5.01997841e-04,  5.02010225e-04,  5.02022750e-04,  5.02035410e-04,\n",
       "        5.02048199e-04,  5.02061113e-04,  5.02074148e-04,  5.02087299e-04,\n",
       "        5.02100562e-04,  5.02113713e-04,  5.02126748e-04,  5.02139662e-04,\n",
       "        5.02152451e-04,  5.02165111e-04,  5.02177636e-04,  5.02190020e-04,\n",
       "        5.02202259e-04,  5.02214345e-04,  5.02226273e-04,  5.02238035e-04,\n",
       "        5.02249625e-04,  5.02261033e-04,  5.02272253e-04,  5.02283275e-04,\n",
       "        5.02294089e-04,  5.02304685e-04,  5.02315051e-04,  5.02325177e-04,\n",
       "        5.02335048e-04,  5.02344650e-04,  5.02353969e-04,  5.02362987e-04,\n",
       "        5.02371686e-04,  5.02380046e-04,  5.02388047e-04,  5.02395662e-04,\n",
       "        5.02402867e-04,  5.02409631e-04,  5.02415922e-04,  5.02421704e-04,\n",
       "        5.02426936e-04,  5.02431572e-04,  5.02435560e-04,  5.02438842e-04,\n",
       "        5.02441350e-04,  5.02443006e-04,  5.02443722e-04,  5.02443392e-04,\n",
       "        5.02441894e-04,  5.02439082e-04,  5.02434780e-04,  5.02428776e-04,\n",
       "        5.02420807e-04,  5.02410548e-04,  5.02397580e-04,  5.02381362e-04,\n",
       "        5.02361173e-04,  5.02336020e-04,  5.02304484e-04,  5.02264438e-04,\n",
       "        5.02212477e-04,  5.02142647e-04,  5.02043035e-04,  5.01883861e-04,\n",
       "        5.01546016e-04, -7.49496575e-01, -7.49497446e-01, -7.49497872e-01,\n",
       "       -7.49498150e-01, -7.49498353e-01, -7.49498511e-01, -7.49498640e-01,\n",
       "       -7.49498748e-01, -7.49498840e-01, -7.49498920e-01, -7.49498989e-01,\n",
       "       -7.49499051e-01, -7.49499105e-01, -7.49499155e-01, -7.49499199e-01,\n",
       "       -7.49499239e-01, -7.49499275e-01, -7.49499308e-01, -7.49499338e-01,\n",
       "       -7.49499365e-01, -7.49499390e-01, -7.49499413e-01, -7.49499434e-01,\n",
       "       -7.49499453e-01, -7.49499471e-01, -7.49499487e-01, -7.49499502e-01,\n",
       "       -7.49499515e-01, -7.49499528e-01, -7.49499539e-01, -7.49499549e-01,\n",
       "       -7.49499558e-01, -7.49499567e-01, -7.49499574e-01, -7.49499581e-01,\n",
       "       -7.49499587e-01, -7.49499592e-01, -7.49499597e-01, -7.49499601e-01,\n",
       "       -7.49499604e-01, -7.49499607e-01, -7.49499609e-01, -7.49499611e-01,\n",
       "       -7.49499612e-01, -7.49499613e-01, -7.49499613e-01, -7.49499613e-01,\n",
       "       -7.49499612e-01, -7.49499611e-01, -7.49499610e-01, -7.49499608e-01,\n",
       "       -7.49499606e-01, -7.49499604e-01, -7.49499601e-01, -7.49499598e-01,\n",
       "       -7.49499595e-01, -7.49499591e-01, -7.49499587e-01, -7.49499583e-01,\n",
       "       -7.49499579e-01, -7.49499574e-01, -7.49499569e-01, -7.49499564e-01,\n",
       "       -7.49499559e-01, -7.49499553e-01, -7.49499547e-01, -7.49499541e-01,\n",
       "       -7.49499535e-01, -7.49499529e-01, -7.49499522e-01, -7.49499515e-01,\n",
       "       -7.49499508e-01, -7.49499501e-01, -7.49499494e-01, -7.49499486e-01,\n",
       "       -7.49499479e-01, -7.49499471e-01, -7.49499463e-01, -7.49499455e-01,\n",
       "       -7.49499447e-01, -7.49499438e-01, -7.49499430e-01, -7.49499421e-01,\n",
       "       -7.49499412e-01, -7.49499403e-01, -7.49499394e-01, -7.49499385e-01,\n",
       "       -7.49499376e-01, -7.49499367e-01, -7.49499357e-01, -7.49499347e-01,\n",
       "       -7.49499338e-01, -7.49499328e-01, -7.49499318e-01, -7.49499308e-01,\n",
       "       -7.49499298e-01, -7.49499288e-01, -7.49499277e-01, -7.49499267e-01,\n",
       "       -7.49499256e-01, -7.49499246e-01, -7.49499235e-01, -7.49499224e-01,\n",
       "       -7.49499213e-01, -7.49499202e-01, -7.49499191e-01, -7.49499180e-01,\n",
       "       -7.49499169e-01, -7.49499158e-01, -7.49499146e-01, -7.49499135e-01,\n",
       "       -7.49499123e-01, -7.49499112e-01, -7.49499100e-01, -7.49499088e-01,\n",
       "       -7.49499077e-01, -7.49499065e-01, -7.49499053e-01, -7.49499041e-01,\n",
       "       -7.49499029e-01, -7.49499017e-01, -7.49499005e-01, -7.49498992e-01,\n",
       "       -7.49498980e-01, -7.49498968e-01, -7.49498955e-01, -7.49498943e-01,\n",
       "       -7.49498930e-01, -7.49498918e-01, -7.49498905e-01, -7.49498893e-01,\n",
       "       -7.49498880e-01, -7.49498867e-01, -7.49498854e-01, -7.49498841e-01,\n",
       "       -7.49498828e-01, -7.49498815e-01, -7.49498802e-01, -7.49498789e-01,\n",
       "       -7.49498776e-01, -7.49498763e-01, -7.49498750e-01, -7.49498737e-01,\n",
       "       -7.49498723e-01, -7.49498710e-01, -7.49498697e-01, -7.49498683e-01,\n",
       "       -7.49498670e-01, -7.49498656e-01, -7.49498643e-01, -7.49498629e-01,\n",
       "       -7.49498615e-01, -7.49498602e-01, -7.49498588e-01, -7.49498574e-01,\n",
       "       -7.49498561e-01, -7.49498547e-01, -7.49498533e-01, -7.49498519e-01,\n",
       "       -7.49498505e-01, -7.49498491e-01, -7.49498477e-01, -7.49498463e-01,\n",
       "       -7.49498449e-01, -7.49498435e-01, -7.49498421e-01, -7.49498407e-01,\n",
       "       -7.49498392e-01, -7.49498378e-01, -7.49498364e-01, -7.49498350e-01,\n",
       "       -7.49498335e-01, -7.49498321e-01, -7.49498307e-01, -7.49498292e-01,\n",
       "       -7.49498278e-01, -7.49498263e-01, -7.49498249e-01, -7.49498234e-01,\n",
       "       -7.49498220e-01, -7.49498205e-01, -7.49498191e-01, -7.49498176e-01,\n",
       "       -7.49498161e-01, -7.49498147e-01, -7.49498132e-01, -7.49498117e-01,\n",
       "       -7.49498102e-01, -7.49498088e-01, -7.49498073e-01, -7.49498058e-01,\n",
       "       -7.49498043e-01, -7.49498028e-01, -1.24952756e+00, -1.24978199e+00,\n",
       "       -1.24991731e+00, -1.25001145e+00, -1.25008449e+00, -1.25014464e+00,\n",
       "       -1.25019607e+00, -1.25024118e+00, -1.25028150e+00, -1.25031807e+00,\n",
       "       -1.25035160e+00, -1.25038263e+00, -1.25041156e+00, -1.25043869e+00,\n",
       "       -1.25046428e+00, -1.25048852e+00, -1.25051157e+00, -1.25053357e+00,\n",
       "       -1.25055462e+00, -1.25057483e+00, -1.25059427e+00, -1.25061301e+00,\n",
       "       -1.25063111e+00, -1.25064863e+00, -1.25066560e+00, -1.25068208e+00,\n",
       "       -1.25069810e+00, -1.25071369e+00, -1.25072888e+00, -1.25074370e+00,\n",
       "       -1.25075816e+00, -1.25077230e+00, -1.25078613e+00, -1.25079967e+00,\n",
       "       -1.25081293e+00, -1.25082593e+00, -1.25083869e+00, -1.25085122e+00,\n",
       "       -1.25086352e+00, -1.25087562e+00, -1.25088752e+00, -1.25089922e+00,\n",
       "       -1.25091075e+00, -1.25092210e+00, -1.25093329e+00, -1.25094432e+00,\n",
       "       -1.25095520e+00, -1.25096593e+00, -1.25097653e+00, -1.25098699e+00,\n",
       "       -1.25099732e+00, -1.25100754e+00, -1.25101763e+00, -1.25102762e+00,\n",
       "       -1.25103749e+00, -1.25104726e+00, -1.25105693e+00, -1.25106651e+00,\n",
       "       -1.25107599e+00, -1.25108538e+00, -1.25109468e+00, -1.25110390e+00,\n",
       "       -1.25111304e+00, -1.25112210e+00, -1.25113109e+00, -1.25114000e+00,\n",
       "       -1.25114885e+00, -1.25115762e+00, -1.25116633e+00, -1.25117498e+00,\n",
       "       -1.25118357e+00, -1.25119210e+00, -1.25120057e+00, -1.25120899e+00,\n",
       "       -1.25121735e+00, -1.25122566e+00, -1.25123393e+00, -1.25124214e+00,\n",
       "       -1.25125031e+00, -1.25125843e+00, -1.25126651e+00, -1.25127455e+00,\n",
       "       -1.25128255e+00, -1.25129050e+00, -1.25129843e+00, -1.25130631e+00,\n",
       "       -1.25131416e+00, -1.25132197e+00, -1.25132976e+00, -1.25133751e+00,\n",
       "       -1.25134523e+00, -1.25135292e+00, -1.25136058e+00, -1.25136822e+00,\n",
       "       -1.25137583e+00, -1.25138341e+00, -1.25139097e+00, -1.25139851e+00,\n",
       "       -1.25140602e+00, -1.25141352e+00, -1.25142099e+00, -1.25142844e+00,\n",
       "       -1.25143588e+00, -1.25144330e+00, -1.25145070e+00, -1.25145809e+00,\n",
       "       -1.25146546e+00, -1.25147281e+00, -1.25148015e+00, -1.25148748e+00,\n",
       "       -1.25149480e+00, -1.25150211e+00, -1.25150941e+00, -1.25151669e+00,\n",
       "       -1.25152397e+00, -1.25153124e+00, -1.25153851e+00, -1.25154576e+00,\n",
       "       -1.25155302e+00, -1.25156026e+00, -1.25156751e+00, -1.25157474e+00,\n",
       "       -1.25158198e+00, -1.25158921e+00, -1.25159645e+00, -1.25160368e+00,\n",
       "       -1.25161091e+00, -1.25161814e+00, -1.25162538e+00, -1.25163262e+00,\n",
       "       -1.25163986e+00, -1.25164710e+00, -1.25165435e+00, -1.25166160e+00,\n",
       "       -1.25166886e+00, -1.25167613e+00, -1.25168340e+00, -1.25169069e+00,\n",
       "       -1.25169798e+00, -1.25170528e+00, -1.25171259e+00, -1.25171991e+00,\n",
       "       -1.25172725e+00, -1.25173460e+00, -1.25174196e+00, -1.25174933e+00,\n",
       "       -1.25175673e+00, -1.25176413e+00, -1.25177156e+00, -1.25177900e+00,\n",
       "       -1.25178646e+00, -1.25179395e+00, -1.25180145e+00, -1.25180897e+00,\n",
       "       -1.25181652e+00, -1.25182409e+00, -1.25183168e+00, -1.25183930e+00,\n",
       "       -1.25184695e+00, -1.25185463e+00, -1.25186233e+00, -1.25187006e+00,\n",
       "       -1.25187783e+00, -1.25188562e+00, -1.25189345e+00, -1.25190132e+00,\n",
       "       -1.25190922e+00, -1.25191715e+00, -1.25192513e+00, -1.25193315e+00,\n",
       "       -1.25194120e+00, -1.25194930e+00, -1.25195745e+00, -1.25196564e+00,\n",
       "       -1.25197388e+00, -1.25198216e+00, -1.25199050e+00, -1.25199889e+00,\n",
       "       -1.25200734e+00, -1.25201584e+00, -1.25202440e+00, -1.25203302e+00,\n",
       "       -1.25204171e+00, -1.25205045e+00, -1.25205927e+00, -1.25206816e+00,\n",
       "       -1.25207712e+00, -1.25208615e+00, -1.25209526e+00, -1.25210445e+00,\n",
       "       -1.25211373e+00, -1.25212309e+00, -1.25213255e+00, -1.25214210e+00,\n",
       "       -1.25215174e+00, -1.25216149e+00, -1.25217134e+00, -1.25218130e+00,\n",
       "       -1.25219138e+00, -1.25220157e+00, -1.25221189e+00, -1.25222234e+00,\n",
       "       -1.25223292e+00, -1.25224364e+00, -1.25225451e+00, -1.25226553e+00,\n",
       "       -1.25227672e+00, -1.25228807e+00, -1.25229960e+00, -1.25231131e+00,\n",
       "       -1.25232322e+00, -1.25233533e+00, -1.25234766e+00, -1.25236021e+00,\n",
       "       -1.25237300e+00, -1.25238604e+00, -1.25239934e+00, -1.25241293e+00,\n",
       "       -1.25242682e+00, -1.25244102e+00, -1.25245556e+00, -1.25247045e+00,\n",
       "       -1.25248573e+00, -1.25250142e+00, -1.25251755e+00, -1.25253414e+00,\n",
       "       -1.25255125e+00, -1.25256890e+00, -1.25258716e+00, -1.25260606e+00,\n",
       "       -1.25262566e+00, -1.25264605e+00, -1.25266729e+00, -1.25268947e+00,\n",
       "       -1.25271271e+00, -1.25273714e+00, -1.25276290e+00, -1.25279018e+00,\n",
       "       -1.25281921e+00, -1.25285027e+00, -1.25288374e+00, -1.25292010e+00,\n",
       "       -1.25296001e+00, -1.25300444e+00, -1.25305483e+00, -1.25311357e+00,\n",
       "       -1.25318494e+00, -1.25327765e+00, -1.25341307e+00, -1.25367181e+00])"
      ]
     },
     "execution_count": 114,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "execution_count": 114
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-21T04:55:48.710902Z",
     "start_time": "2025-07-21T04:55:48.683146Z"
    }
   },
   "cell_type": "code",
   "source": [
    "total_sum = 0\n",
    "for i in range(2*n):\n",
    "    total_sum += x[i].value * coefficients[0,i]\n",
    "    \n",
    "cos_theta = total_sum / np.sqrt(2*n)\n",
    "sin_theta = np.sqrt(1-cos_theta**2)\n",
    "print(cos_theta)\n",
    "print(sin_theta)"
   ],
   "id": "ff3f078877087181",
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.9150491649447124\n",
      "0.40334231830293293\n"
     ]
    }
   ],
   "execution_count": 119
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-20T06:04:26.733350Z",
     "start_time": "2025-07-20T06:04:26.726653Z"
    }
   },
   "cell_type": "code",
   "source": "coefficients",
   "id": "140644522179d97",
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[ 1.,  1.,  1.,  1.,  1.,  1.,  1.,  1.,  1.,  1.,  1.,  1.,  1.,\n",
       "         1.,  1.,  1.,  1.,  1.,  1.,  1.,  1.,  1.,  1.,  1.,  1.,  1.,\n",
       "         1.,  1.,  1.,  1.,  1.,  1.,  1.,  1.,  1.,  1.,  1.,  1.,  1.,\n",
       "         1.,  1.,  1.,  1.,  1.,  1.,  1.,  1.,  1.,  1.,  1.,  1.,  1.,\n",
       "         1.,  1.,  1.,  1.,  1.,  1.,  1.,  1.,  1.,  1.,  1.,  1.,  1.,\n",
       "         1.,  1.,  1.,  1.,  1.,  1.,  1.,  1.,  1.,  1.,  1.,  1.,  1.,\n",
       "         1.,  1., -1., -1., -1., -1., -1., -1., -1., -1., -1., -1., -1.,\n",
       "        -1., -1., -1., -1., -1., -1., -1., -1., -1.,  1.,  1.,  1.,  1.,\n",
       "         1.,  1.,  1.,  1.,  1.,  1.,  1.,  1.,  1.,  1.,  1.,  1.,  1.,\n",
       "         1.,  1.,  1., -1., -1., -1., -1., -1., -1., -1., -1., -1., -1.,\n",
       "        -1., -1., -1., -1., -1., -1., -1., -1., -1., -1., -1., -1., -1.,\n",
       "        -1., -1., -1., -1., -1., -1., -1., -1., -1., -1., -1., -1., -1.,\n",
       "        -1., -1., -1., -1., -1., -1., -1., -1., -1., -1., -1., -1., -1.,\n",
       "        -1., -1., -1., -1., -1., -1., -1., -1., -1., -1., -1., -1., -1.,\n",
       "        -1., -1., -1., -1., -1., -1., -1., -1., -1., -1., -1., -1., -1.,\n",
       "        -1., -1., -1., -1., -1.]])"
      ]
     },
     "execution_count": 44,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "execution_count": 44
  }
 ],
 "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
}
