{
 "cells": [
  {
   "cell_type": "code",
   "id": "initial_id",
   "metadata": {
    "collapsed": true,
    "ExecuteTime": {
     "end_time": "2025-09-25T01:55:54.102222Z",
     "start_time": "2025-09-25T01:55:49.386156Z"
    }
   },
   "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",
    "from scipy.stats import kurtosis\n",
    "from scipy.stats import norm\n",
    "\n"
   ],
   "outputs": [],
   "execution_count": 1
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-25T01:56:58.621081Z",
     "start_time": "2025-09-25T01:56:36.829454Z"
    }
   },
   "cell_type": "code",
   "source": [
    "n_values = range(500,1001,25)\n",
    "n_values = [500]\n",
    "\n",
    "np.random.seed(10)\n",
    "\n",
    "binomial_df = pd.DataFrame(columns=['k', 'sin_theta', 'i', 'n'])\n",
    "\n",
    "for n in n_values:\n",
    "    p = 0.06\n",
    "    q = 0.04\n",
    "    \n",
    "    repetitions = 50\n",
    "    \n",
    "    for i in range(repetitions):\n",
    "        \n",
    "        arr1 = np.random.binomial(n,p, size=n*2)\n",
    "        arr2 = np.random.binomial(n,q, size=n*2)\n",
    "        multiplier = np.random.randint(2, size = n*2)*2-1\n",
    "        my_array = (arr1 - arr2)*multiplier\n",
    "        \n",
    "        my_array = np.sort(my_array)[::-1]\n",
    "        my_array = my_array / np.linalg.norm(my_array)\n",
    "        k_values = range((int)(n/2))\n",
    "        \n",
    "        for k in k_values:\n",
    "            coefficients = np.ones([1,2*n])\n",
    "            coefficients[0,n-k:n] = -1\n",
    "            coefficients[0,n+k:2*n] = -1\n",
    "            cos_theta = coefficients.dot(my_array) / np.sqrt(2*n)\n",
    "            sin_theta = np.sqrt(1-cos_theta**2)\n",
    "            \n",
    "            binomial_df.loc[len(binomial_df)] = [k, sin_theta, i, n]\n"
   ],
   "id": "705825c6959db429",
   "outputs": [],
   "execution_count": 3
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-25T01:57:21.340151Z",
     "start_time": "2025-09-25T01:57:20.432200Z"
    }
   },
   "cell_type": "code",
   "source": "binomial_df.to_parquet('binomial_df_500.parquet')",
   "id": "2948acdc87e36bca",
   "outputs": [],
   "execution_count": 4
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-08-22T03:12:56.560745Z",
     "start_time": "2025-08-22T03:12:56.513431Z"
    }
   },
   "cell_type": "code",
   "source": "binomial_df.to_parquet('binomial_df.parquet')",
   "id": "c27afde16fa4d965",
   "outputs": [],
   "execution_count": 7
  },
  {
   "metadata": {},
   "cell_type": "markdown",
   "source": "Load Chernoff and Combine with Binomial",
   "id": "9ffcda230629504b"
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-25T01:58:32.846212Z",
     "start_time": "2025-09-25T01:58:32.815106Z"
    }
   },
   "cell_type": "code",
   "source": [
    "chernoff_df_500 = chernoff_df[chernoff_df['n']==500]\n",
    "chernoff_df_500\n"
   ],
   "id": "7eed764af9539ab8",
   "outputs": [
    {
     "data": {
      "text/plain": [
       "    Unnamed: 0      k  sin_theta      n\n",
       "0            0    0.0   0.224525  500.0\n",
       "1            1    5.0   0.244268  500.0\n",
       "2            2   10.0   0.262538  500.0\n",
       "3            3   15.0   0.279624  500.0\n",
       "4            4   20.0   0.295730  500.0\n",
       "5            5   25.0   0.311011  500.0\n",
       "6            6   30.0   0.325580  500.0\n",
       "7            7   35.0   0.339533  500.0\n",
       "8            8   40.0   0.352938  500.0\n",
       "9            9   45.0   0.365859  500.0\n",
       "10          10   50.0   0.378344  500.0\n",
       "11          11   55.0   0.390435  500.0\n",
       "12          12   60.0   0.402169  500.0\n",
       "13          13   65.0   0.413573  500.0\n",
       "14          14   70.0   0.424678  500.0\n",
       "15          15   75.0   0.435503  500.0\n",
       "16          16   80.0   0.446071  500.0\n",
       "17          17   85.0   0.456398  500.0\n",
       "18          18   90.0   0.466502  500.0\n",
       "19          19   95.0   0.476395  500.0\n",
       "20          20  100.0   0.486092  500.0\n",
       "21          21  105.0   0.495603  500.0\n",
       "22          22  110.0   0.504939  500.0\n",
       "23          23  115.0   0.514109  500.0\n",
       "24          24  120.0   0.523123  500.0\n",
       "25          25  125.0   0.531989  500.0\n",
       "26          26  130.0   0.540713  500.0\n",
       "27          27  135.0   0.549302  500.0\n",
       "28          28  140.0   0.557763  500.0\n",
       "29          29  145.0   0.566102  500.0\n",
       "30          30  150.0   0.574322  500.0\n",
       "31          31  155.0   0.582432  500.0\n",
       "32          32  160.0   0.590433  500.0\n",
       "33          33  165.0   0.598331  500.0\n",
       "34          34  170.0   0.606130  500.0\n",
       "35          35  175.0   0.613833  500.0\n",
       "36          36  180.0   0.621445  500.0\n",
       "37          37  185.0   0.628968  500.0\n",
       "38          38  190.0   0.636405  500.0\n",
       "39          39  195.0   0.643761  500.0\n",
       "40          40  200.0   0.651036  500.0\n",
       "41          41  205.0   0.658235  500.0\n",
       "42          42  210.0   0.665360  500.0\n",
       "43          43  215.0   0.672412  500.0\n",
       "44          44  220.0   0.679395  500.0\n",
       "45          45  225.0   0.686310  500.0\n",
       "46          46  230.0   0.693160  500.0\n",
       "47          47  235.0   0.699946  500.0\n",
       "48          48  240.0   0.706671  500.0\n",
       "49          49  245.0   0.713335  500.0"
      ],
      "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>n</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.224525</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>5.0</td>\n",
       "      <td>0.244268</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.262538</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>3</td>\n",
       "      <td>15.0</td>\n",
       "      <td>0.279624</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>4</td>\n",
       "      <td>20.0</td>\n",
       "      <td>0.295730</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>5</td>\n",
       "      <td>25.0</td>\n",
       "      <td>0.311011</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>6</td>\n",
       "      <td>30.0</td>\n",
       "      <td>0.325580</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>7</td>\n",
       "      <td>35.0</td>\n",
       "      <td>0.339533</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>8</td>\n",
       "      <td>40.0</td>\n",
       "      <td>0.352938</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>9</td>\n",
       "      <td>45.0</td>\n",
       "      <td>0.365859</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>10</td>\n",
       "      <td>50.0</td>\n",
       "      <td>0.378344</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>11</td>\n",
       "      <td>55.0</td>\n",
       "      <td>0.390435</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>12</td>\n",
       "      <td>60.0</td>\n",
       "      <td>0.402169</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>13</td>\n",
       "      <td>65.0</td>\n",
       "      <td>0.413573</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>14</td>\n",
       "      <td>70.0</td>\n",
       "      <td>0.424678</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>15</td>\n",
       "      <td>75.0</td>\n",
       "      <td>0.435503</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>16</td>\n",
       "      <td>80.0</td>\n",
       "      <td>0.446071</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>17</td>\n",
       "      <td>85.0</td>\n",
       "      <td>0.456398</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>18</td>\n",
       "      <td>90.0</td>\n",
       "      <td>0.466502</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>19</td>\n",
       "      <td>95.0</td>\n",
       "      <td>0.476395</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20</th>\n",
       "      <td>20</td>\n",
       "      <td>100.0</td>\n",
       "      <td>0.486092</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>21</th>\n",
       "      <td>21</td>\n",
       "      <td>105.0</td>\n",
       "      <td>0.495603</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>22</td>\n",
       "      <td>110.0</td>\n",
       "      <td>0.504939</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>23</td>\n",
       "      <td>115.0</td>\n",
       "      <td>0.514109</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>24</th>\n",
       "      <td>24</td>\n",
       "      <td>120.0</td>\n",
       "      <td>0.523123</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25</th>\n",
       "      <td>25</td>\n",
       "      <td>125.0</td>\n",
       "      <td>0.531989</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>26</th>\n",
       "      <td>26</td>\n",
       "      <td>130.0</td>\n",
       "      <td>0.540713</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>27</th>\n",
       "      <td>27</td>\n",
       "      <td>135.0</td>\n",
       "      <td>0.549302</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>28</th>\n",
       "      <td>28</td>\n",
       "      <td>140.0</td>\n",
       "      <td>0.557763</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>29</th>\n",
       "      <td>29</td>\n",
       "      <td>145.0</td>\n",
       "      <td>0.566102</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>30</th>\n",
       "      <td>30</td>\n",
       "      <td>150.0</td>\n",
       "      <td>0.574322</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>31</th>\n",
       "      <td>31</td>\n",
       "      <td>155.0</td>\n",
       "      <td>0.582432</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>32</th>\n",
       "      <td>32</td>\n",
       "      <td>160.0</td>\n",
       "      <td>0.590433</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>33</th>\n",
       "      <td>33</td>\n",
       "      <td>165.0</td>\n",
       "      <td>0.598331</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>34</th>\n",
       "      <td>34</td>\n",
       "      <td>170.0</td>\n",
       "      <td>0.606130</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>35</th>\n",
       "      <td>35</td>\n",
       "      <td>175.0</td>\n",
       "      <td>0.613833</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>36</th>\n",
       "      <td>36</td>\n",
       "      <td>180.0</td>\n",
       "      <td>0.621445</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>37</th>\n",
       "      <td>37</td>\n",
       "      <td>185.0</td>\n",
       "      <td>0.628968</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>38</th>\n",
       "      <td>38</td>\n",
       "      <td>190.0</td>\n",
       "      <td>0.636405</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>39</th>\n",
       "      <td>39</td>\n",
       "      <td>195.0</td>\n",
       "      <td>0.643761</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>40</th>\n",
       "      <td>40</td>\n",
       "      <td>200.0</td>\n",
       "      <td>0.651036</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>41</th>\n",
       "      <td>41</td>\n",
       "      <td>205.0</td>\n",
       "      <td>0.658235</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>42</th>\n",
       "      <td>42</td>\n",
       "      <td>210.0</td>\n",
       "      <td>0.665360</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>43</th>\n",
       "      <td>43</td>\n",
       "      <td>215.0</td>\n",
       "      <td>0.672412</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>44</th>\n",
       "      <td>44</td>\n",
       "      <td>220.0</td>\n",
       "      <td>0.679395</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>45</th>\n",
       "      <td>45</td>\n",
       "      <td>225.0</td>\n",
       "      <td>0.686310</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>46</th>\n",
       "      <td>46</td>\n",
       "      <td>230.0</td>\n",
       "      <td>0.693160</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>47</th>\n",
       "      <td>47</td>\n",
       "      <td>235.0</td>\n",
       "      <td>0.699946</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>48</th>\n",
       "      <td>48</td>\n",
       "      <td>240.0</td>\n",
       "      <td>0.706671</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>49</th>\n",
       "      <td>49</td>\n",
       "      <td>245.0</td>\n",
       "      <td>0.713335</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "execution_count": 7
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-25T01:57:51.198356Z",
     "start_time": "2025-09-25T01:57:51.188860Z"
    }
   },
   "cell_type": "code",
   "source": "chernoff_df = pd.read_csv('chernoff_df.csv')",
   "id": "f8e459118076622a",
   "outputs": [],
   "execution_count": 5
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-12T04:25:47.884790Z",
     "start_time": "2025-09-12T04:25:47.855699Z"
    }
   },
   "cell_type": "code",
   "source": [
    "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})\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": "d7533836437aaa89",
   "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": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "execution_count": 5
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-12T04:36:45.718382Z",
     "start_time": "2025-09-12T04:36:45.704174Z"
    }
   },
   "cell_type": "code",
   "source": "binomial_df",
   "id": "623ea21166d5d6a8",
   "outputs": [
    {
     "data": {
      "text/plain": [
       "        k              sin_theta  i    n\n",
       "0       0  [0.45676149095723917]  0  750\n",
       "1       1  [0.45676149095723917]  0  750\n",
       "2       2  [0.45676149095723917]  0  750\n",
       "3       3  [0.45676149095723917]  0  750\n",
       "4       4  [0.45676149095723917]  0  750\n",
       "...   ...                    ... ..  ...\n",
       "1870  370   [0.9233151045934119]  4  750\n",
       "1871  371   [0.9242664707019187]  4  750\n",
       "1872  372   [0.9252111642654588]  4  750\n",
       "1873  373   [0.9261492057024822]  4  750\n",
       "1874  374   [0.9270806152053115]  4  750\n",
       "\n",
       "[1875 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>k</th>\n",
       "      <th>sin_theta</th>\n",
       "      <th>i</th>\n",
       "      <th>n</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>[0.45676149095723917]</td>\n",
       "      <td>0</td>\n",
       "      <td>750</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>[0.45676149095723917]</td>\n",
       "      <td>0</td>\n",
       "      <td>750</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\n",
       "      <td>[0.45676149095723917]</td>\n",
       "      <td>0</td>\n",
       "      <td>750</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>3</td>\n",
       "      <td>[0.45676149095723917]</td>\n",
       "      <td>0</td>\n",
       "      <td>750</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>4</td>\n",
       "      <td>[0.45676149095723917]</td>\n",
       "      <td>0</td>\n",
       "      <td>750</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>1870</th>\n",
       "      <td>370</td>\n",
       "      <td>[0.9233151045934119]</td>\n",
       "      <td>4</td>\n",
       "      <td>750</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1871</th>\n",
       "      <td>371</td>\n",
       "      <td>[0.9242664707019187]</td>\n",
       "      <td>4</td>\n",
       "      <td>750</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1872</th>\n",
       "      <td>372</td>\n",
       "      <td>[0.9252111642654588]</td>\n",
       "      <td>4</td>\n",
       "      <td>750</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1873</th>\n",
       "      <td>373</td>\n",
       "      <td>[0.9261492057024822]</td>\n",
       "      <td>4</td>\n",
       "      <td>750</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1874</th>\n",
       "      <td>374</td>\n",
       "      <td>[0.9270806152053115]</td>\n",
       "      <td>4</td>\n",
       "      <td>750</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>1875 rows × 4 columns</p>\n",
       "</div>"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "execution_count": 24
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-25T02:06:43.828163Z",
     "start_time": "2025-09-25T02:06:42.382168Z"
    }
   },
   "cell_type": "code",
   "source": [
    "plt.scatter(chernoff_df_500['sin_theta'], chernoff_df_500['k'] / chernoff_df_500['n'], color='blue', s=5, label='Chernoff-optimized')\n",
    "#plt.scatter(chernoff_df['sin_theta_lemma'], chernoff_df['k'], color='red', s=5)\n",
    "for i in range(repetitions):\n",
    "    this_binomial_df = binomial_df[binomial_df['i'] == i]\n",
    "    if i == 0:\n",
    "        plt.scatter(this_binomial_df['sin_theta'], this_binomial_df['k'] / this_binomial_df['n'], color='lime', s=5, label=\"Binomial-simulated\")\n",
    "    else:\n",
    "        plt.scatter(this_binomial_df['sin_theta'], this_binomial_df['k'] / this_binomial_df['n'], color='lime', s=5,)\n",
    "\n",
    "#plt.scatter(spectral_df['sin_theta_real'], spectral_df['k_real'], color='orange', s=5)\n",
    "plt.plot(this_binomial_df['predicted_sin'], this_binomial_df['k'] / this_binomial_df['n'], color='green', linestyle='--', label=\"Binomial-predicted\")\n",
    "    #plt.plot(this_binomial_df['predicted_sin_using_log'], this_binomial_df['k'], color='red', linestyle='--')\n",
    "plt.legend()\n",
    "plt.xlabel(\"sin theta\")\n",
    "plt.ylabel(\"gamma\")\n",
    "plt.show()"
   ],
   "id": "354104a70530b23e",
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ],
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjcAAAGwCAYAAABVdURTAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjAsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvlHJYcgAAAAlwSFlzAAAPYQAAD2EBqD+naQAAZttJREFUeJzt3Xd8VFX6x/HPJCGFQIL0SAkBpIjUoEgHkWoB3VXWQrOs/FaXYgURJKigrgi6iosFUBaRXRUrKlFBgxSlZC0gogJBDFKEhAgJTHJ/f0xmyJCZZGZyp2TyffOaV2buvXPmzM2QPDn3ec6xGIZhICIiIhImIoLdAREREREzKbgRERGRsKLgRkRERMKKghsREREJKwpuREREJKwouBEREZGwouBGREREwkpUsDsQaEVFRfz666/UrFkTi8US7O6IiIiIBwzD4Pjx45x77rlERJQ9NlPlgptff/2VJk2aBLsbIiIi4oN9+/bRuHHjMo+pcsFNzZo1AdvJSUhICHJvRERExBO5ubk0adLE8Xu8LFUuuLFfikpISFBwIyIiUsl4klKihGIREREJKwpuREREJKwouBEREZGwUuVybjxVWFjI6dOng90NEdNER0eXWz4pIhIOFNycxTAMDhw4wLFjx4LdFRFTRUREkJKSQnR0dLC7IiLiVwpuzmIPbOrXr0/16tU10Z+EBfvkldnZ2TRt2lSfaxEJawpuSigsLHQENnXq1Al2d0RMVa9ePX799VesVivVqlULdndERPxGF+BLsOfYVK9ePcg9ETGf/XJUYWFhkHsiIuJfCm5c0JC9hCN9rkWkqgh6cLNgwQJSUlKIjY0lNTWVjIwMt8euXbsWi8VS6vb9998HsMciIiISyoIa3KxYsYJJkyYxbdo0tm3bRu/evRk6dChZWVllPm/nzp1kZ2c7buedd16AeiwiIiKhLqjBzZNPPsnNN9/MLbfcQtu2bZk/fz5NmjThueeeK/N59evXp2HDho5bZGRkgHpc+VksFt56661gd8OtAwcOMHDgQOLj46lVq5bbbYHUr18/Jk2aVKE2lixZ4ve+jx07lhEjRvj1NUREKoOgBTenTp1iy5YtDBo0yGn7oEGDWL9+fZnP7dy5M0lJSQwYMIA1a9aUeWxBQQG5ublOt3B24MAB/v73v9O8eXNiYmJo0qQJV1xxBZ988kmwu+aRefPmkZ2dTWZmJj/88IPbbf5gv+x59hxHb775Jg899FCF2h45cqRf+y4i4m955JFMMpZy/lWnOs1pzkxmYsUalL4GrRT88OHDFBYW0qBBA6ftDRo04MCBAy6fk5SUxPPPP09qaioFBQUsXbqUAQMGsHbtWvr06ePyOXPmzCEtLc30/oeiPXv20LNnT2rVqsXjjz9Ohw4dOH36NB999BG3336733KTTp06ZdrEcD/99BOpqalOlxpdbQuk2rVrV7iNuLg44uLiTOiNiEjg5ZFHLWpRSPnVlic5yW52k0YaEUQwgxkB6OFZjCDZv3+/ARjr16932v7www8brVu39ridyy+/3Ljiiivc7s/PzzdycnIct3379hmAkZOTU+rYkydPGtu3bzdOnjzp+RsJIUOHDjUaNWpk5OXlldp39OhRwzAMAzBeeOEFY8SIEUZcXJzRsmVL4+2333Y69rvvvjOGDh1qxMfHG/Xr1zduvPFG49ChQ479ffv2NW6//XZj8uTJRp06dYw+ffoYa9asMQDj448/NlJTU424uDije/fuxvfff+/U9oIFC4zmzZsb1apVM1q1amW88sorjn3JyckG4LiNGTPG5TZXCgsLjbS0NKNRo0ZGdHS00bFjR+ODDz5w7N+9e7cBGMuXLze6d+9uxMTEGOeff76xZs0ap/2uXqtv377GxIkTnfr50EMPGaNGjTLi4+ONpk2bGm+99ZZx8OBB48orrzTi4+ONCy64wPjqq68cz1m8eLGRmJjo9r3ab3a//PKLce211xq1atUyateubVx55ZXG7t27HfutVqsxefJkIzEx0ahdu7Zxzz33GKNHjzaGDx/u8vwYRuX/fItI8DQzmhn48G+gMdC0PuTk5Lj9/X22oF2Wqlu3LpGRkaVGaQ4ePFhqNKcsF198Mbt27XK7PyYmhoSEBKdbIFitMGsWDBpk+2r188jc77//zocffsjtt99OfHx8qf0l8z3S0tK49tpr+frrrxk2bBg33HADv//+OwDZ2dn07duXTp06sXnzZj788EN+++03rr32Wqf2Xn75ZaKiovjiiy9YuHChY/u0adOYO3cumzdvJioqiptuusmxb+XKlUycOJG77rqLb7/9lttuu41x48Y5Li1+9dVXDBkyhGuvvZbs7Gyeeuopl9tceeqpp5g7dy5PPPEEX3/9NYMHD+bKK68s9dm45557uOuuu9i2bRs9evTgyiuv5MiRIzRp0oQ33ngDOJOw7u61wHaprGfPnmzbto3LLruMUaNGMXr0aG688Ua2bt1Ky5YtGT16NIZhuHz+V1995UiI/+WXX7j44ovp3bs3ACdOnKB///7UqFGDzz//nHXr1lGjRg2GDBnCqVOnAJg7dy6LFi3ipZdeYt26dfz++++sXLnSbX9FRHyVRx572OP+gI+Br1zv6kUvf3SpfKaFVD646KKLjP/7v/9z2ta2bVtjypQpHrfxpz/9yejfv7/Hx5cV+Zn5l21ammFYLIYBtq9paRVuskybNm0yAOPNN98s8zjAeOCBBxyP8/LyDIvF4hjlmD59ujFo0CCn59hHu3bu3GkYhm0ko1OnTk7HlBy5sXv//fcNwHE+e/ToYdx6661Oz7vmmmuMYcOGOR4PHz681OiMq21nO/fcc41HHnnEaduFF15o/O1vfzMM48zIzKOPPurYf/r0aaNx48bGY4895vQe7KNcdq5Gbm688UbH4+zsbAMwpk+f7ti2YcMGAzCys7MNwyg9clPShAkTjOTkZOPgwYOGYRjGSy+9ZLRu3dooKipyHFNQUGDExcUZH330kWEYhpGUlOTyvWjkRkTMdNw4bkQake7HZjIxmFl82++8r5/RzzhtnDatL5Vi5Abgzjvv5MUXX2TRokXs2LGDyZMnk5WVxfjx4wGYOnUqo0ePdhw/f/583nrrLXbt2sV3333H1KlTeeONN7jjjjuC9RbcWrcO7H+0G4btsT8ZxS/myURtHTp0cNyPj4+nZs2aHDx4EIAtW7awZs0aatSo4bi1adMGsOW+2HXt2rXctpOSkgAcbe/YsYOePXs6Hd+zZ0927NhRbp/tli1b5tS3jIwMcnNz+fXXXz1qu3v37o77UVFRdO3a1avXtyv5Pu0jje3bty+1zf7e3Xn++ed56aWXePvtt6lXrx5g+x78+OOP1KxZ0/E+a9euTX5+Pj/99BM5OTlkZ2e7fC8igRboUWoJnHLzbPYD7xbf7w2ce2ZXc5qTTjpRQUrtDeraUiNHjuTIkSPMmjWL7OxsLrjgAlatWkVycjJgu0RScs6bU6dOcffdd7N//37i4uJo164d77//PsOGDQvWW3CrVy/4+GNbYGOx2B7703nnnYfFYmHHjh3llgOfva6QxWKhqKgIsC2weMUVV/DYY4+Vep49WAFcXvo6u217oGVvu+Q2O8MwvJo598orr6Rbt26Ox40aNXIsm+Fr277M3OvqfZb33s+2du1a/v73v7N8+XI6duzo2F5UVERqairLli0r9Rx7ACQSKmbPhpkzbT/rPv7Ytm1GEPJHxXztae8+sDkOvAYUAq2B/s67xzAmaIENhMDCmX/729/429/+5nLfkiVLnB7fe++93HvvvQHoVcXdf7/t67p1tsDG/thfateuzeDBg3n22WeZMGFCqeDj2LFjHs2z0qVLF9544w2aNWtGVJS5H4+2bduybt06p9G49evX07ZtW4/bqFmzJjVr1nTaFhcXx7nnnsu6deucqubWr1/PRRdd5HTsxo0bHcdYrVa2bNniGPkL5NpLP/74I3/605+4//77ufrqq532denShRUrVlC/fn23OWJJSUku30uXLl383neRkgI9Si3+Z8XKLGa5z7OxAiuAPKAecBVQ4m/EfvTjfvz8S68cQV9+IVxFRdn+elm92vbV5DjBpQULFlBYWMhFF13EG2+8wa5du9ixYwdPP/200yWMstx+++38/vvvXHfddXz55Zf8/PPPrF69mptuuqnCv/TvuecelixZwr/+9S927drFk08+yZtvvsndd99doXbtbT/22GOsWLGCnTt3MmXKFDIzM5k4caLTcc8++ywrV67k+++/5/bbb+fo0aOOpOfk5GQsFgvvvfcehw4dIi8vr8L9cuXkyZNcccUVdOrUib/+9a8cOHDAcQO44YYbqFu3LsOHDycjI4Pdu3fz2WefMXHiRH755RcAJk6cyKOPPup4L3/7299Kzc8jEgi9etlGpyEwo9TiX/nk05KWPISbub0M4D1sl6Rigb8AMWd296NfUC9H2QV95EbMk5KSwtatW3nkkUe46667yM7Opl69eqSmppY767PdueeeyxdffMF9993H4MGDKSgoIDk5mSFDhhARUbFYeMSIETz11FP84x//YMKECaSkpLB48WL69etXoXYBJkyYQG5uLnfddRcHDx7k/PPP55133ik1N86jjz7KY489xrZt22jRogVvv/02devWBWyXuNLS0pgyZQrjxo1j9OjRpUYPzfDbb7/x/fff8/3333Puuec67TMMg+rVq/P5559z3333cfXVV3P8+HEaNWrEgAEDHCM59u/v2LFjiYiI4KabbuKqq64iJyfH9P6KlCXQo9TiP/nk05CG5FDOz5F62IZGrgFKTAMWS2xIBDYAFsNwU6sapnJzc0lMTCQnJ6fUkH9+fj67d+92LOQp4WPPnj2kpKSwbds2OnXqFOzuBIU+3yJSlku4hDWUPeu/Qw6Q6LypP/35lE9N75ddWb+/z6bLUiIiIlVcPvlkkOH+gMNAQYnHZwU2tajFKlb5o2s+UXAjIiIeU+l3+LFfjnK7DtRxYCmwCFxdsapFLbLJJpbQGREO/oUxkQBo1qyZ29mCRcRzKv0OL+Xm2ZzGVvKdC1QDzlpGMIqokAtsQCM3IiLiBZV+h5dhDHMf2BjAW8CvQBxwffHXEnrTO+QCG1BwIyIiXlDpd/goN89mDbAdW6QwEqfKKAi9PJuSdFlKREQ8ptLv8JBHHnWp6z7P5n/giHuuAJKdd4dink1JCm5ERMRj9glKpfIqd80oK/BZ8f2eQCfn3aGaZ1OSghsREZEqpMw1o8AWGYwFvgIuKb07VPNsSlLOTRWxZ88eLBYLmZmZwe4KM2fO9HoiPYvFwltvveXT6wXyvVeknxXly3kVKYvKvsNPHnnu14wqWVCaAAzAac0oCO08m5IU3ISJsWPHYrFYHLc6deowZMgQvv76awCaNGniWHk92O6++24++eSTgL1eKL33sykgkVBmL/tOT7d9nT072D2SirBfjnLJCvwb+Nb985vRLOQvR9kpuAkjQ4YMITs7m+zsbD755BOioqK4/PLLAYiMjKRhw4amr/Ttixo1alCnTp2AvV4ovXeRykRl3+HF7eUoe8n3z8D7wMnShzSnObvYVSkCG1BwE1ZiYmJo2LAhDRs2pFOnTtx3333s27ePQ4cOlbo0s3btWiwWC5988gldu3alevXq9OjRg507dzq1+dxzz9GiRQuio6Np3bo1S5cuddpvsVhYuHAhl19+OdWrV6dt27Zs2LCBH3/8kX79+hEfH0/37t356aefHM85e7Tiq6++YuDAgdStW5fExET69u3L1q1bvXrvR48e5YYbbqBevXrExcVx3nnnsXjxYqD0ZSn7e//oo4/o3LkzcXFxXHLJJRw8eJAPPviAtm3bkpCQwHXXXceJEyccr9GsWTPmz5/v9LqdOnVi5syZbvt133330apVK6pXr07z5s2ZPn06p0+fBmDJkiWkpaXxv//9zzHiZl+oMycnh7/+9a/Ur1+fhIQELrnkEv73v/85tf3oo4/SoEEDatasyc0330x+fr5X50ykPCr7Dg9WrExnuvvLUR8D32GLCK6l1Fw2AGMYExILYnpKwU2YysvLY9myZbRs2bLMUZJp06Yxd+5cNm/eTFRUFDfddJNj38qVK5k4cSJ33XUX3377Lbfddhvjxo1jzRrnhdUeeughRo8eTWZmJm3atOH666/ntttuY+rUqWzevBmAO+64w20fjh8/zpgxY8jIyGDjxo2cd955DBs2jOPHj3v8fqdPn8727dv54IMP2LFjB88995xjtW93Zs6cyTPPPMP69evZt28f1157LfPnz+fVV1/l/fffJz09nX/+858e98GVmjVrsmTJErZv385TTz3FCy+8wLx58wAYOXIkd911F+3atXOMuI0cORLDMLjssss4cOAAq1atYsuWLXTp0oUBAwbw+++/A/Cf//yHBx98kEceeYTNmzeTlJTEggULKtRXkbPdf7/tctTAgbavKvuufPLJpyUteZiHXR/wJbC++P5wIKX0If3ox/1Usm++UcXk5OQYgJGTk1Nq38mTJ43t27cbJ0+erPDrnDZOG2lGmjHQGGikGWnGaeN0hdssy5gxY4zIyEgjPj7eiI+PNwAjKSnJ2LJli2EYhrF7924DMLZt22YYhmGsWbPGAIyPP/7Y0cb7779vAI7336NHD+PWW291ep1rrrnGGDZsmOMxYDzwwAOOxxs2bDAA46WXXnJsW758uREbG+t4/OCDDxodO3Z0+16sVqtRs2ZN491333V6nZUrV7p9zhVXXGGMGzfO5T5P3vucOXMMwPjpp58c22677TZj8ODBjsfJycnGvHnznNru2LGj8eCDD3rcz8cff9xITU11PHZ1Lj755BMjISHByM/Pd9reokULY+HChYZhGEb37t2N8ePHO+3v1q1bmefVzM+3iIS+k8ZJI9FINHD3bwcGaRjMxOBz18c0N5r7/feXp8r6/X02jdz4yWxmM5OZpJPOTGYyG/9n4vXv35/MzEwyMzPZtGkTgwYNYujQoezdu9ftczp06OC4n5SUBMDBgwcB2LFjBz179nQ6vmfPnuzYscNtGw0aNACgffv2Ttvy8/PJzc112YeDBw8yfvx4WrVqRWJiIomJieTl5ZGVleXy+KFDh1KjRg1q1KhBu3btAPi///s/XnvtNTp16sS9997L+vXrXT63rH7bLx2V3GY/F756/fXX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"
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "execution_count": 20
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-25T02:00:22.970367Z",
     "start_time": "2025-09-25T02:00:22.826808Z"
    }
   },
   "cell_type": "code",
   "source": [
    "binomial_df['sin_theta'] = binomial_df['sin_theta'].astype(float)\n",
    "binomial_df['cos_theta'] = np.sqrt(1-binomial_df['sin_theta']**2)\n",
    "predicted_x_n_minus_k = -norm.ppf((binomial_df['n'] - binomial_df['k'])/(binomial_df['n']*2+1))\n",
    "transformed_x = norm.pdf(predicted_x_n_minus_k)\n",
    "binomial_df['predicted_x_n_minus_k'] = predicted_x_n_minus_k\n",
    "binomial_df['x'] = transformed_x\n",
    "ols_result = sm.ols(formula='cos_theta ~ x', data=binomial_df).fit()\n",
    "ols_result.summary()"
   ],
   "id": "461f3cd6ce24e1c1",
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<class 'statsmodels.iolib.summary.Summary'>\n",
       "\"\"\"\n",
       "                            OLS Regression Results                            \n",
       "==============================================================================\n",
       "Dep. Variable:              cos_theta   R-squared:                       0.998\n",
       "Model:                            OLS   Adj. R-squared:                  0.998\n",
       "Method:                 Least Squares   F-statistic:                 5.277e+06\n",
       "Date:                Wed, 24 Sep 2025   Prob (F-statistic):               0.00\n",
       "Time:                        22:00:22   Log-Likelihood:                 45325.\n",
       "No. Observations:               12500   AIC:                        -9.065e+04\n",
       "Df Residuals:                   12498   BIC:                        -9.063e+04\n",
       "Df Model:                           1                                         \n",
       "Covariance Type:            nonrobust                                         \n",
       "==============================================================================\n",
       "                 coef    std err          t      P>|t|      [0.025      0.975]\n",
       "------------------------------------------------------------------------------\n",
       "Intercept     -1.3459      0.001  -1503.429      0.000      -1.348      -1.344\n",
       "x              5.5116      0.002   2297.194      0.000       5.507       5.516\n",
       "==============================================================================\n",
       "Omnibus:                      254.455   Durbin-Watson:                   0.010\n",
       "Prob(Omnibus):                  0.000   Jarque-Bera (JB):              273.577\n",
       "Skew:                           0.339   Prob(JB):                     3.92e-60\n",
       "Kurtosis:                       3.256   Cond. No.                         47.4\n",
       "==============================================================================\n",
       "\n",
       "Notes:\n",
       "[1] Standard Errors assume that the covariance matrix of the errors is correctly specified.\n",
       "\"\"\""
      ],
      "text/html": [
       "<table class=\"simpletable\">\n",
       "<caption>OLS Regression Results</caption>\n",
       "<tr>\n",
       "  <th>Dep. Variable:</th>        <td>cos_theta</td>    <th>  R-squared:         </th>  <td>   0.998</td> \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Model:</th>                   <td>OLS</td>       <th>  Adj. R-squared:    </th>  <td>   0.998</td> \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Method:</th>             <td>Least Squares</td>  <th>  F-statistic:       </th>  <td>5.277e+06</td>\n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Date:</th>             <td>Wed, 24 Sep 2025</td> <th>  Prob (F-statistic):</th>   <td>  0.00</td>  \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Time:</th>                 <td>22:00:22</td>     <th>  Log-Likelihood:    </th>  <td>  45325.</td> \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>No. Observations:</th>      <td> 12500</td>      <th>  AIC:               </th> <td>-9.065e+04</td>\n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Df Residuals:</th>          <td> 12498</td>      <th>  BIC:               </th> <td>-9.063e+04</td>\n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Df Model:</th>              <td>     1</td>      <th>                     </th>      <td> </td>    \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Covariance Type:</th>      <td>nonrobust</td>    <th>                     </th>      <td> </td>    \n",
       "</tr>\n",
       "</table>\n",
       "<table class=\"simpletable\">\n",
       "<tr>\n",
       "      <td></td>         <th>coef</th>     <th>std err</th>      <th>t</th>      <th>P>|t|</th>  <th>[0.025</th>    <th>0.975]</th>  \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Intercept</th> <td>   -1.3459</td> <td>    0.001</td> <td>-1503.429</td> <td> 0.000</td> <td>   -1.348</td> <td>   -1.344</td>\n",
       "</tr>\n",
       "<tr>\n",
       "  <th>x</th>         <td>    5.5116</td> <td>    0.002</td> <td> 2297.194</td> <td> 0.000</td> <td>    5.507</td> <td>    5.516</td>\n",
       "</tr>\n",
       "</table>\n",
       "<table class=\"simpletable\">\n",
       "<tr>\n",
       "  <th>Omnibus:</th>       <td>254.455</td> <th>  Durbin-Watson:     </th> <td>   0.010</td>\n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Prob(Omnibus):</th> <td> 0.000</td>  <th>  Jarque-Bera (JB):  </th> <td> 273.577</td>\n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Skew:</th>          <td> 0.339</td>  <th>  Prob(JB):          </th> <td>3.92e-60</td>\n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Kurtosis:</th>      <td> 3.256</td>  <th>  Cond. No.          </th> <td>    47.4</td>\n",
       "</tr>\n",
       "</table><br/><br/>Notes:<br/>[1] Standard Errors assume that the covariance matrix of the errors is correctly specified."
      ],
      "text/latex": "\\begin{center}\n\\begin{tabular}{lclc}\n\\toprule\n\\textbf{Dep. Variable:}    &    cos\\_theta    & \\textbf{  R-squared:         } &     0.998   \\\\\n\\textbf{Model:}            &       OLS        & \\textbf{  Adj. R-squared:    } &     0.998   \\\\\n\\textbf{Method:}           &  Least Squares   & \\textbf{  F-statistic:       } & 5.277e+06   \\\\\n\\textbf{Date:}             & Wed, 24 Sep 2025 & \\textbf{  Prob (F-statistic):} &     0.00    \\\\\n\\textbf{Time:}             &     22:00:22     & \\textbf{  Log-Likelihood:    } &    45325.   \\\\\n\\textbf{No. Observations:} &       12500      & \\textbf{  AIC:               } & -9.065e+04  \\\\\n\\textbf{Df Residuals:}     &       12498      & \\textbf{  BIC:               } & -9.063e+04  \\\\\n\\textbf{Df Model:}         &           1      & \\textbf{                     } &             \\\\\n\\textbf{Covariance Type:}  &    nonrobust     & \\textbf{                     } &             \\\\\n\\bottomrule\n\\end{tabular}\n\\begin{tabular}{lcccccc}\n                   & \\textbf{coef} & \\textbf{std err} & \\textbf{t} & \\textbf{P$> |$t$|$} & \\textbf{[0.025} & \\textbf{0.975]}  \\\\\n\\midrule\n\\textbf{Intercept} &      -1.3459  &        0.001     & -1503.429  &         0.000        &       -1.348    &       -1.344     \\\\\n\\textbf{x}         &       5.5116  &        0.002     &  2297.194  &         0.000        &        5.507    &        5.516     \\\\\n\\bottomrule\n\\end{tabular}\n\\begin{tabular}{lclc}\n\\textbf{Omnibus:}       & 254.455 & \\textbf{  Durbin-Watson:     } &    0.010  \\\\\n\\textbf{Prob(Omnibus):} &   0.000 & \\textbf{  Jarque-Bera (JB):  } &  273.577  \\\\\n\\textbf{Skew:}          &   0.339 & \\textbf{  Prob(JB):          } & 3.92e-60  \\\\\n\\textbf{Kurtosis:}      &   3.256 & \\textbf{  Cond. No.          } &     47.4  \\\\\n\\bottomrule\n\\end{tabular}\n%\\caption{OLS Regression Results}\n\\end{center}\n\nNotes: \\newline\n [1] Standard Errors assume that the covariance matrix of the errors is correctly specified."
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "execution_count": 9
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-25T02:00:33.463844Z",
     "start_time": "2025-09-25T02:00:33.455998Z"
    }
   },
   "cell_type": "code",
   "source": [
    "transformed_predicted_cos = ols_result.params['x'] * binomial_df['x'] + ols_result.params['Intercept']\n",
    "transformed_predicted_sin = np.sqrt(1 - transformed_predicted_cos**2)\n",
    "binomial_df['predicted_sin'] = transformed_predicted_sin\n"
   ],
   "id": "6d1831b130891f2b",
   "outputs": [],
   "execution_count": 10
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-12T05:19:10.260584Z",
     "start_time": "2025-09-12T05:19:10.222961Z"
    }
   },
   "cell_type": "code",
   "source": [
    "log_term = 1 / np.sqrt(np.log(1 * binomial_df['n']/ np.maximum(binomial_df['k'],1) ))\n",
    "binomial_df['log_term'] = log_term\n",
    "ols_result2 = sm.ols(formula='sin_theta ~ log_term - 1', data=binomial_df).fit()\n",
    "ols_result2.summary()\n"
   ],
   "id": "2b33db520d56b40a",
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<class 'statsmodels.iolib.summary.Summary'>\n",
       "\"\"\"\n",
       "                                 OLS Regression Results                                \n",
       "=======================================================================================\n",
       "Dep. Variable:              sin_theta   R-squared (uncentered):                   0.999\n",
       "Model:                            OLS   Adj. R-squared (uncentered):              0.999\n",
       "Method:                 Least Squares   F-statistic:                          1.352e+06\n",
       "Date:                Fri, 12 Sep 2025   Prob (F-statistic):                        0.00\n",
       "Time:                        01:19:10   Log-Likelihood:                          4188.1\n",
       "No. Observations:                1875   AIC:                                     -8374.\n",
       "Df Residuals:                    1874   BIC:                                     -8369.\n",
       "Df Model:                           1                                                  \n",
       "Covariance Type:            nonrobust                                                  \n",
       "==============================================================================\n",
       "                 coef    std err          t      P>|t|      [0.025      0.975]\n",
       "------------------------------------------------------------------------------\n",
       "log_term       0.8010      0.001   1162.738      0.000       0.800       0.802\n",
       "==============================================================================\n",
       "Omnibus:                     1165.357   Durbin-Watson:                   0.118\n",
       "Prob(Omnibus):                  0.000   Jarque-Bera (JB):            11937.804\n",
       "Skew:                           2.832   Prob(JB):                         0.00\n",
       "Kurtosis:                      13.987   Cond. No.                         1.00\n",
       "==============================================================================\n",
       "\n",
       "Notes:\n",
       "[1] R² is computed without centering (uncentered) since the model does not contain a constant.\n",
       "[2] Standard Errors assume that the covariance matrix of the errors is correctly specified.\n",
       "\"\"\""
      ],
      "text/html": [
       "<table class=\"simpletable\">\n",
       "<caption>OLS Regression Results</caption>\n",
       "<tr>\n",
       "  <th>Dep. Variable:</th>        <td>sin_theta</td>    <th>  R-squared (uncentered):</th>      <td>   0.999</td> \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Model:</th>                   <td>OLS</td>       <th>  Adj. R-squared (uncentered):</th> <td>   0.999</td> \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Method:</th>             <td>Least Squares</td>  <th>  F-statistic:       </th>          <td>1.352e+06</td>\n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Date:</th>             <td>Fri, 12 Sep 2025</td> <th>  Prob (F-statistic):</th>           <td>  0.00</td>  \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Time:</th>                 <td>01:19:10</td>     <th>  Log-Likelihood:    </th>          <td>  4188.1</td> \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>No. Observations:</th>      <td>  1875</td>      <th>  AIC:               </th>          <td>  -8374.</td> \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Df Residuals:</th>          <td>  1874</td>      <th>  BIC:               </th>          <td>  -8369.</td> \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Df Model:</th>              <td>     1</td>      <th>                     </th>              <td> </td>    \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Covariance Type:</th>      <td>nonrobust</td>    <th>                     </th>              <td> </td>    \n",
       "</tr>\n",
       "</table>\n",
       "<table class=\"simpletable\">\n",
       "<tr>\n",
       "      <td></td>        <th>coef</th>     <th>std err</th>      <th>t</th>      <th>P>|t|</th>  <th>[0.025</th>    <th>0.975]</th>  \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>log_term</th> <td>    0.8010</td> <td>    0.001</td> <td> 1162.738</td> <td> 0.000</td> <td>    0.800</td> <td>    0.802</td>\n",
       "</tr>\n",
       "</table>\n",
       "<table class=\"simpletable\">\n",
       "<tr>\n",
       "  <th>Omnibus:</th>       <td>1165.357</td> <th>  Durbin-Watson:     </th> <td>   0.118</td> \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Prob(Omnibus):</th>  <td> 0.000</td>  <th>  Jarque-Bera (JB):  </th> <td>11937.804</td>\n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Skew:</th>           <td> 2.832</td>  <th>  Prob(JB):          </th> <td>    0.00</td> \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Kurtosis:</th>       <td>13.987</td>  <th>  Cond. No.          </th> <td>    1.00</td> \n",
       "</tr>\n",
       "</table><br/><br/>Notes:<br/>[1] R² is computed without centering (uncentered) since the model does not contain a constant.<br/>[2] Standard Errors assume that the covariance matrix of the errors is correctly specified."
      ],
      "text/latex": "\\begin{center}\n\\begin{tabular}{lclc}\n\\toprule\n\\textbf{Dep. Variable:}    &    sin\\_theta    & \\textbf{  R-squared (uncentered):}      &     0.999   \\\\\n\\textbf{Model:}            &       OLS        & \\textbf{  Adj. R-squared (uncentered):} &     0.999   \\\\\n\\textbf{Method:}           &  Least Squares   & \\textbf{  F-statistic:       }          & 1.352e+06   \\\\\n\\textbf{Date:}             & Fri, 12 Sep 2025 & \\textbf{  Prob (F-statistic):}          &     0.00    \\\\\n\\textbf{Time:}             &     01:19:10     & \\textbf{  Log-Likelihood:    }          &    4188.1   \\\\\n\\textbf{No. Observations:} &        1875      & \\textbf{  AIC:               }          &    -8374.   \\\\\n\\textbf{Df Residuals:}     &        1874      & \\textbf{  BIC:               }          &    -8369.   \\\\\n\\textbf{Df Model:}         &           1      & \\textbf{                     }          &             \\\\\n\\textbf{Covariance Type:}  &    nonrobust     & \\textbf{                     }          &             \\\\\n\\bottomrule\n\\end{tabular}\n\\begin{tabular}{lcccccc}\n                   & \\textbf{coef} & \\textbf{std err} & \\textbf{t} & \\textbf{P$> |$t$|$} & \\textbf{[0.025} & \\textbf{0.975]}  \\\\\n\\midrule\n\\textbf{log\\_term} &       0.8010  &        0.001     &  1162.738  &         0.000        &        0.800    &        0.802     \\\\\n\\bottomrule\n\\end{tabular}\n\\begin{tabular}{lclc}\n\\textbf{Omnibus:}       & 1165.357 & \\textbf{  Durbin-Watson:     } &     0.118  \\\\\n\\textbf{Prob(Omnibus):} &   0.000  & \\textbf{  Jarque-Bera (JB):  } & 11937.804  \\\\\n\\textbf{Skew:}          &   2.832  & \\textbf{  Prob(JB):          } &      0.00  \\\\\n\\textbf{Kurtosis:}      &  13.987  & \\textbf{  Cond. No.          } &      1.00  \\\\\n\\bottomrule\n\\end{tabular}\n%\\caption{OLS Regression Results}\n\\end{center}\n\nNotes: \\newline\n [1] R² is computed without centering (uncentered) since the model does not contain a constant. \\newline\n [2] Standard Errors assume that the covariance matrix of the errors is correctly specified."
     },
     "execution_count": 81,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "execution_count": 81
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-12T05:19:19.378683Z",
     "start_time": "2025-09-12T05:19:19.355008Z"
    }
   },
   "cell_type": "code",
   "source": [
    "binomial_df['predicted_sin_using_log'] = ols_result2.params['log_term'] * binomial_df['log_term'] \n",
    "binomial_df"
   ],
   "id": "5c6b2b04d9a9389c",
   "outputs": [
    {
     "data": {
      "text/plain": [
       "        k  sin_theta  i    n  cos_theta         x  predicted_cos  \\\n",
       "0       0   0.456761  0  750   0.889589  0.398942       0.957953   \n",
       "1       1   0.456761  0  750   0.889589  0.398941       0.956626   \n",
       "2       2   0.456761  0  750   0.889589  0.398939       0.955298   \n",
       "3       3   0.456761  0  750   0.889589  0.398935       0.953970   \n",
       "4       4   0.456761  0  750   0.889589  0.398931       0.952641   \n",
       "...   ...        ... ..  ...        ...       ...            ...   \n",
       "1870  370   0.923315  4  750   0.384043  0.319895       0.440821   \n",
       "1871  371   0.924266  4  750   0.381748  0.319452       0.439364   \n",
       "1872  372   0.925211  4  750   0.379453  0.319007       0.437908   \n",
       "1873  373   0.926149  4  750   0.377157  0.318561       0.436451   \n",
       "1874  374   0.927081  4  750   0.374862  0.318113       0.434994   \n",
       "\n",
       "      predicted_sin  predicted_x_n_minus_k  log_term  predicted_sin_using_log  \n",
       "0          0.491507               0.000835  0.388659                 0.311312  \n",
       "1          0.491519               0.002505  0.388659                 0.311312  \n",
       "2          0.491544               0.004175  0.410757                 0.329012  \n",
       "3          0.491582               0.005845  0.425572                 0.340879  \n",
       "4          0.491633               0.007515  0.437112                 0.350122  \n",
       "...             ...                    ...       ...                      ...  \n",
       "1870       0.930962               0.664564  1.189659                 0.952904  \n",
       "1871       0.932069               0.666649  1.191937                 0.954729  \n",
       "1872       0.933171               0.668735  1.194223                 0.956560  \n",
       "1873       0.934265               0.670825  1.196516                 0.958396  \n",
       "1874       0.935353               0.672918  1.198816                 0.960238  \n",
       "\n",
       "[1875 rows x 11 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>k</th>\n",
       "      <th>sin_theta</th>\n",
       "      <th>i</th>\n",
       "      <th>n</th>\n",
       "      <th>cos_theta</th>\n",
       "      <th>x</th>\n",
       "      <th>predicted_cos</th>\n",
       "      <th>predicted_sin</th>\n",
       "      <th>predicted_x_n_minus_k</th>\n",
       "      <th>log_term</th>\n",
       "      <th>predicted_sin_using_log</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>0.456761</td>\n",
       "      <td>0</td>\n",
       "      <td>750</td>\n",
       "      <td>0.889589</td>\n",
       "      <td>0.398942</td>\n",
       "      <td>0.957953</td>\n",
       "      <td>0.491507</td>\n",
       "      <td>0.000835</td>\n",
       "      <td>0.388659</td>\n",
       "      <td>0.311312</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>0.456761</td>\n",
       "      <td>0</td>\n",
       "      <td>750</td>\n",
       "      <td>0.889589</td>\n",
       "      <td>0.398941</td>\n",
       "      <td>0.956626</td>\n",
       "      <td>0.491519</td>\n",
       "      <td>0.002505</td>\n",
       "      <td>0.388659</td>\n",
       "      <td>0.311312</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\n",
       "      <td>0.456761</td>\n",
       "      <td>0</td>\n",
       "      <td>750</td>\n",
       "      <td>0.889589</td>\n",
       "      <td>0.398939</td>\n",
       "      <td>0.955298</td>\n",
       "      <td>0.491544</td>\n",
       "      <td>0.004175</td>\n",
       "      <td>0.410757</td>\n",
       "      <td>0.329012</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>3</td>\n",
       "      <td>0.456761</td>\n",
       "      <td>0</td>\n",
       "      <td>750</td>\n",
       "      <td>0.889589</td>\n",
       "      <td>0.398935</td>\n",
       "      <td>0.953970</td>\n",
       "      <td>0.491582</td>\n",
       "      <td>0.005845</td>\n",
       "      <td>0.425572</td>\n",
       "      <td>0.340879</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>4</td>\n",
       "      <td>0.456761</td>\n",
       "      <td>0</td>\n",
       "      <td>750</td>\n",
       "      <td>0.889589</td>\n",
       "      <td>0.398931</td>\n",
       "      <td>0.952641</td>\n",
       "      <td>0.491633</td>\n",
       "      <td>0.007515</td>\n",
       "      <td>0.437112</td>\n",
       "      <td>0.350122</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1870</th>\n",
       "      <td>370</td>\n",
       "      <td>0.923315</td>\n",
       "      <td>4</td>\n",
       "      <td>750</td>\n",
       "      <td>0.384043</td>\n",
       "      <td>0.319895</td>\n",
       "      <td>0.440821</td>\n",
       "      <td>0.930962</td>\n",
       "      <td>0.664564</td>\n",
       "      <td>1.189659</td>\n",
       "      <td>0.952904</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1871</th>\n",
       "      <td>371</td>\n",
       "      <td>0.924266</td>\n",
       "      <td>4</td>\n",
       "      <td>750</td>\n",
       "      <td>0.381748</td>\n",
       "      <td>0.319452</td>\n",
       "      <td>0.439364</td>\n",
       "      <td>0.932069</td>\n",
       "      <td>0.666649</td>\n",
       "      <td>1.191937</td>\n",
       "      <td>0.954729</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1872</th>\n",
       "      <td>372</td>\n",
       "      <td>0.925211</td>\n",
       "      <td>4</td>\n",
       "      <td>750</td>\n",
       "      <td>0.379453</td>\n",
       "      <td>0.319007</td>\n",
       "      <td>0.437908</td>\n",
       "      <td>0.933171</td>\n",
       "      <td>0.668735</td>\n",
       "      <td>1.194223</td>\n",
       "      <td>0.956560</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1873</th>\n",
       "      <td>373</td>\n",
       "      <td>0.926149</td>\n",
       "      <td>4</td>\n",
       "      <td>750</td>\n",
       "      <td>0.377157</td>\n",
       "      <td>0.318561</td>\n",
       "      <td>0.436451</td>\n",
       "      <td>0.934265</td>\n",
       "      <td>0.670825</td>\n",
       "      <td>1.196516</td>\n",
       "      <td>0.958396</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1874</th>\n",
       "      <td>374</td>\n",
       "      <td>0.927081</td>\n",
       "      <td>4</td>\n",
       "      <td>750</td>\n",
       "      <td>0.374862</td>\n",
       "      <td>0.318113</td>\n",
       "      <td>0.434994</td>\n",
       "      <td>0.935353</td>\n",
       "      <td>0.672918</td>\n",
       "      <td>1.198816</td>\n",
       "      <td>0.960238</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>1875 rows × 11 columns</p>\n",
       "</div>"
      ]
     },
     "execution_count": 82,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "execution_count": 82
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-12T05:32:35.559257Z",
     "start_time": "2025-09-12T05:32:35.299742Z"
    }
   },
   "cell_type": "code",
   "source": [
    "\n",
    "for i in range(repetitions):\n",
    "    this_binomial_df = binomial_df[binomial_df['i'] == i]\n",
    "    plt.scatter(this_binomial_df['sin_theta'], this_binomial_df['k'], color='green', s=5)\n",
    "    plt.plot(this_binomial_df['predicted_sin'], this_binomial_df['k'], color='blue', linestyle='--')\n",
    "    #plt.plot(this_binomial_df['predicted_sin_using_log'], this_binomial_df['k'], color='red', linestyle='--')\n",
    "\n"
   ],
   "id": "fdd88a0b6abb141",
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ],
      "image/png": "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p8vH+eabb0hISPB08wKaO+e+V69eHDlyhKKiIsey3bt3ExQURFJSUr22N1DU5TuflZXFjz/+yMiRI+uziQHJnfN+6tQpgoKcfzIq/w/e0C3dXFKX73tISAhJSUkEBwezZMkSBg8efM6/j4Djpc65UoPKIWhvvvmm8f333xvp6elG06ZNHSMUnnrqKWPYsGGO7WfNmmUsXbrU2L17t7F9+3bjqaeeMgDjo48+8tZH8Ftmz31hYaGRlJRk3HnnncaOHTuMrKwso3379saDDz7orY/gl8ye90r33Xef0a1bt4ZubsAwe97feustw2q1GvPmzTP27t1rrF+/3ujatatx7bXXeusj+CWz533Xrl3G4sWLjd27dxtfffWVMXToUCM2NtbIzs720idoOAooPujVV181UlJSjNDQUOPqq682srKyHOuGDx9upKamOl6/8MILRrt27Yzw8HCjefPmxnXXXWd89tlnXmh1YDBz7g3DMHbu3Gn079/fiIiIMJKSkoyxY8cap06dauBW+z+z5/3EiRNGRESE8frrrzdwSwOL2fM+Z84c47LLLjMiIiKMhIQE49577zUOHz7cwK32f2bO+/fff29ceeWVRkREhBEVFWXccsstxg8//OCFVjc8i2GoNiciIiK+JcAvYImIiIg/UkARERERn6OAIiIiIj5HAUVERER8jgKKiIiI+BwFFBEREfE5CigiIiLicxRQRERExOcooIiIiIjPUUARERERn6OAIiIiIj5HAUVERER8zv8HzJYavLcz5qUAAAAASUVORK5CYII="
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "execution_count": 84
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-12T04:36:53.512658Z",
     "start_time": "2025-09-12T04:36:53.506915Z"
    }
   },
   "cell_type": "code",
   "source": "print(kurtosis( my_array, bias=False, fisher=True ))",
   "id": "d6bec333b40228f1",
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-1.186362662759519\n"
     ]
    }
   ],
   "execution_count": 26
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-12T05:32:56.024367Z",
     "start_time": "2025-09-12T05:32:55.760485Z"
    }
   },
   "cell_type": "code",
   "source": [
    "\n",
    "for i in range(repetitions):\n",
    "    this_binomial_df = binomial_df[binomial_df['i'] == i]\n",
    "    plt.scatter(this_binomial_df['sin_theta'], this_binomial_df['k'], color='green', s=5)\n",
    "    plt.plot(this_binomial_df['predicted_sin'], this_binomial_df['k'], color='blue', linestyle='--')\n",
    "    plt.plot(this_binomial_df['predicted_sin_using_log'], this_binomial_df['k'], color='red', linestyle='--')\n"
   ],
   "id": "a25c17c1fdeb77c",
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ],
      "image/png": "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jx71Um29x93r8vrrr3PhhRcSEhJCu3btmD9/vpdq6uOMembhwoVGYGCg8be//c3YunWr8dhjjxmNGjUy9u7dW2r5H3/80fjwww+NzZs3G7t37zYWLFhghIaGGm+//baXa+457l6TYseOHTPOPfdcIykpybjkkku8U1kvcve6pKamGoCxbds2Iz093fGy2+1errnnVOW7csMNNxhdunQxUlJSjN27dxvfffed8Z///MeLtfY8d6/LsWPHXL4j+/fvNyIjI43Jkyd7t+Ie5O41Wb16teHn52e89tprxq5du4zVq1cb7du3NwYNGuTlmnuWu9fljTfeMMLCwoyFCxcaO3fuND766COjcePGxpIlS7xcc99T7wLKlVdeaTz44IMu2y644AJj3LhxlT7HTTfdZNxxxx01XbVaU9VrMmTIEOPpp582Jk+eXC8DirvXpTigZGZmeqF2tcPda7J8+XLDZrMZR48e9Ub1ak11/11ZvHixYbFYjD179niierXC3WsyY8YM49xzz3XZNnv2bKNFixYeq2NtcPe6dO3a1Rg7dqzLtscee8zo3r27x+pYV9SrWzz5+fls2LCBpKQkl+1JSUmsXbu2Uuf46aefWLt2LYmJiZ6ootdV9Zq899577Ny5k8mTJ3u6irWiOt+Vyy67jNjYWHr37k1qaqonq+lVVbkmS5YsoXPnzkyfPp1zzjmHtm3bMnbsWHJzc71RZa+oiX9X3n33Xfr06UNCQoInquh1Vbkm3bp148CBAyxbtgzDMPjjjz/4+OOPuf76671RZa+oynXJy8sjODjYZVtISAjff/89BQUFHqtrXVCvAsqRI0coLCwkOjraZXt0dDQZGRnlHtuiRQusViudO3dm5MiR3HvvvZ6sqtdU5Zrs2LGDcePG8cEHHxAQUCefJ1mhqlyX2NhY3nnnHT755BM+/fRT2rVrR+/evVm1apU3quxxVbkmu3btYs2aNWzevJnFixfz6quv8vHHHzNy5EhvVNkrqvPvCkB6ejrLly+vN/+mQNWuSbdu3fjggw8YMmQIQUFBxMTEEBERwV//+ldvVNkrqnJd+vXrx9///nc2bNiAYRj88MMPzJ07l4KCAo4cOeKNavusevnrY7FYXNYNwyix7WyrV6/mxIkTrFu3jnHjxnH++edz++23e7KaXlXZa1JYWMjQoUN55plnaNu2rbeqV2vc+a60a9eOdu3aOda7du3K/v37efnll+nRo4dH6+lN7lyToqIiLBYLH3zwgeMJpTNnzuSWW27h9ddfJyQkxOP19Zaq/LsCMG/ePCIiIhg0aJCHalZ73LkmW7du5dFHH+Uvf/kL/fr1Iz09nSeeeIIHH3yQd9991xvV9Rp3rsukSZPIyMjgqquuwjAMoqOjGT58ONOnT8ff398b1fVZ9aoFJSoqCn9//xJJ9dChQyUS7dlat25Nx44due+++3j88ceZMmWKB2vqPe5ek+PHj/PDDz/wyCOPEBAQQEBAAM8++yz//e9/CQgI4JtvvvFW1T2qOt+VM1111VXs2LGjpqtXK6pyTWJjYznnnHNcHp9+4YUXYhgGBw4c8Gh9vaU63xXDMJg7dy533nknQUFBnqymV1XlmkybNo3u3bvzxBNPcPHFF9OvXz/eeOMN5s6dS3p6ujeq7XFVuS4hISHMnTuXnJwc9uzZw759+2jVqhVhYWFERUV5o9o+q14FlKCgIDp16kRKSorL9pSUFLp161bp8xiGQV5eXk1Xr1a4e03Cw8PZtGkTGzdudLwefPBB2rVrx8aNG+nSpYu3qu5RNfVd+emnn4iNja3p6tWKqlyT7t27c/DgQU6cOOHYtn37dvz8/GjRooVH6+st1fmupKWl8dtvvzFixAhPVtHrqnJNcnJy8PNz/ckpbiEw6skj4arzXQkMDKRFixb4+/uzcOFCBgwYUOJ6NTi10TPXk4qHeL377rvG1q1bjeTkZKNRo0aO3vPjxo0z7rzzTkf5OXPmGEuWLDG2b99ubN++3Zg7d64RHh5uTJw4sbY+Qo1z95qcrb6O4nH3usyaNctYvHixsX37dmPz5s3GuHHjDMD45JNPausj1Dh3r8nx48eNFi1aGLfccouxZcsWIy0tzWjTpo1x77331tZH8Iiq/h264447jC5duni7ul7h7jV57733jICAAOONN94wdu7caaxZs8bo3LmzceWVV9bWR/AId6/Ltm3bjAULFhjbt283vvvuO2PIkCFGZGSksXv37lr6BL6j3gUUwzCM119/3UhISDCCgoKMyy+/3EhLS3PsGzZsmJGYmOhYnz17ttG+fXsjNDTUCA8PNy677DLjjTfeMAoLC2uh5p7jzjU5W30NKIbh3nV56aWXjPPOO88IDg42mjRpYlx99dXG0qVLa6HWnuXud+WXX34x+vTpY4SEhBgtWrQwRo8ebeTk5Hi51p7n7nU5duyYERISYrzzzjterqn3uHtNZs+ebVx00UVGSEiIERsba/z5z382Dhw44OVae54712Xr1q3GpZdeaoSEhBjh4eHGjTfeaPz666+1UGvfYzGMetK2JiIiIvVGA7/BJSIiIr5IAUVERER8jgKKiIiI+BwFFBEREfE5CigiIiLicxRQRERExOcooIiIiIjPUUARERERn6OAIiIiIj5HAUVERER8jgKKiIiI+BwFFBEREfE5/x/rvEgQx+A1VQAAAABJRU5ErkJggg=="
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "execution_count": 85
  }
 ],
 "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
}
