{
 "cells": [
  {
   "cell_type": "code",
   "id": "initial_id",
   "metadata": {
    "collapsed": true,
    "ExecuteTime": {
     "end_time": "2025-09-24T23:55:54.941284Z",
     "start_time": "2025-09-24T23:55:38.370564Z"
    }
   },
   "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",
    "\n"
   ],
   "outputs": [],
   "execution_count": 1
  },
  {
   "metadata": {},
   "cell_type": "markdown",
   "source": "Given these, we can calculate t_star and C now",
   "id": "ff66d265d1618151"
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-08-22T04:59:43.911378Z",
     "start_time": "2025-08-22T04:14:30.165996Z"
    }
   },
   "cell_type": "code",
   "source": [
    "n_values = range(500,1001,50)\n",
    "\n",
    "chernoff_df = pd.DataFrame(columns=['k', 'sin_theta', 'n'])\n",
    "\n",
    "for n in n_values:\n",
    "\n",
    "    a = 0.06 * n\n",
    "    b = 0.04 * n\n",
    "    \n",
    "    pa = a/n\n",
    "    pb = b/n\n",
    "    qa = 1-pa\n",
    "    qb = 1-pb\n",
    "    t_star = 0.5 * math.log(pa * qb / qa / pb) \n",
    "    exp_t_star = math.exp(t_star)\n",
    "    MGF_pos = (qa+pa*exp_t_star)**n * (qb+pb/exp_t_star)**n\n",
    "    MGF_neg = (qa+pa/exp_t_star)**n * (qb+pb*exp_t_star)**n\n",
    "    C = (MGF_pos + MGF_neg)/2\n",
    "\n",
    "    k_values = range(0,(int)(n/2),5)\n",
    "    \n",
    "    chernoff_numbers = np.zeros(n)\n",
    "        \n",
    "    do_solve = True\n",
    "    \n",
    "    for i in range(n):\n",
    "        chernoff_numbers[i] = math.log(C) + math.log(2*n+1) - math.log(i+1)\n",
    "    \n",
    "    for k in k_values:\n",
    "        print(k, n)\n",
    "        x = cp.Variable(n)\n",
    "        sos = cp.sum_squares(x)\n",
    "        constraints = [sos <= 0.5]\n",
    "    \n",
    "        for i in range(n-1):\n",
    "            constraints.append(x[i] >= x[i+1])\n",
    "    \n",
    "        for i in range(n-1):\n",
    "            constraints.append(x[i+1] / chernoff_numbers[i+1] <= x[i] / chernoff_numbers[i])\n",
    "            constraints.append(x[i] >= 0)\n",
    "        \n",
    "        constraints.append(x[n-1] >= 0)\n",
    "    \n",
    "        coefficients = np.ones([1,n])\n",
    "        coefficients[0,n-k:n] = -1\n",
    "        objective = cp.Maximize(cp.vdot(coefficients, x))\n",
    "    \n",
    "        prob1 = cp.Problem(objective, constraints)\n",
    "        if do_solve:\n",
    "            prob1.solve()\n",
    "            cos_theta = prob1.value * 2 / np.sqrt(2 * n)\n",
    "            sin_theta = np.sqrt(1 - cos_theta ** 2)\n",
    "            chernoff_df.loc[len(chernoff_df)] = [k, sin_theta, n]"
   ],
   "id": "db00f0df67377388",
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 500\n",
      "5 500\n",
      "10 500\n",
      "15 500\n",
      "20 500\n",
      "25 500\n",
      "30 500\n",
      "35 500\n",
      "40 500\n",
      "45 500\n",
      "50 500\n",
      "55 500\n",
      "60 500\n",
      "65 500\n",
      "70 500\n",
      "75 500\n",
      "80 500\n",
      "85 500\n",
      "90 500\n",
      "95 500\n",
      "100 500\n",
      "105 500\n",
      "110 500\n",
      "115 500\n",
      "120 500\n",
      "125 500\n",
      "130 500\n",
      "135 500\n",
      "140 500\n",
      "145 500\n",
      "150 500\n",
      "155 500\n",
      "160 500\n",
      "165 500\n",
      "170 500\n",
      "175 500\n",
      "180 500\n",
      "185 500\n",
      "190 500\n",
      "195 500\n",
      "200 500\n",
      "205 500\n",
      "210 500\n",
      "215 500\n",
      "220 500\n",
      "225 500\n",
      "230 500\n",
      "235 500\n",
      "240 500\n",
      "245 500\n",
      "0 550\n",
      "5 550\n",
      "10 550\n",
      "15 550\n",
      "20 550\n",
      "25 550\n",
      "30 550\n",
      "35 550\n",
      "40 550\n",
      "45 550\n",
      "50 550\n",
      "55 550\n",
      "60 550\n",
      "65 550\n",
      "70 550\n",
      "75 550\n",
      "80 550\n",
      "85 550\n",
      "90 550\n",
      "95 550\n",
      "100 550\n",
      "105 550\n",
      "110 550\n",
      "115 550\n",
      "120 550\n",
      "125 550\n",
      "130 550\n",
      "135 550\n",
      "140 550\n",
      "145 550\n",
      "150 550\n",
      "155 550\n",
      "160 550\n",
      "165 550\n",
      "170 550\n",
      "175 550\n",
      "180 550\n",
      "185 550\n",
      "190 550\n",
      "195 550\n",
      "200 550\n",
      "205 550\n",
      "210 550\n",
      "215 550\n",
      "220 550\n",
      "225 550\n",
      "230 550\n",
      "235 550\n",
      "240 550\n",
      "245 550\n",
      "250 550\n",
      "255 550\n",
      "260 550\n",
      "265 550\n",
      "270 550\n",
      "0 600\n",
      "5 600\n",
      "10 600\n",
      "15 600\n",
      "20 600\n",
      "25 600\n",
      "30 600\n",
      "35 600\n",
      "40 600\n",
      "45 600\n",
      "50 600\n",
      "55 600\n",
      "60 600\n",
      "65 600\n",
      "70 600\n",
      "75 600\n",
      "80 600\n",
      "85 600\n",
      "90 600\n",
      "95 600\n",
      "100 600\n",
      "105 600\n",
      "110 600\n",
      "115 600\n",
      "120 600\n",
      "125 600\n",
      "130 600\n",
      "135 600\n",
      "140 600\n",
      "145 600\n",
      "150 600\n",
      "155 600\n",
      "160 600\n",
      "165 600\n",
      "170 600\n",
      "175 600\n",
      "180 600\n",
      "185 600\n",
      "190 600\n",
      "195 600\n",
      "200 600\n",
      "205 600\n",
      "210 600\n",
      "215 600\n",
      "220 600\n",
      "225 600\n",
      "230 600\n",
      "235 600\n",
      "240 600\n",
      "245 600\n",
      "250 600\n",
      "255 600\n",
      "260 600\n",
      "265 600\n",
      "270 600\n",
      "275 600\n",
      "280 600\n",
      "285 600\n",
      "290 600\n",
      "295 600\n",
      "0 650\n",
      "5 650\n",
      "10 650\n",
      "15 650\n",
      "20 650\n",
      "25 650\n",
      "30 650\n",
      "35 650\n",
      "40 650\n",
      "45 650\n",
      "50 650\n",
      "55 650\n",
      "60 650\n",
      "65 650\n",
      "70 650\n",
      "75 650\n",
      "80 650\n",
      "85 650\n",
      "90 650\n",
      "95 650\n",
      "100 650\n",
      "105 650\n",
      "110 650\n",
      "115 650\n",
      "120 650\n",
      "125 650\n",
      "130 650\n",
      "135 650\n",
      "140 650\n",
      "145 650\n",
      "150 650\n",
      "155 650\n",
      "160 650\n",
      "165 650\n",
      "170 650\n",
      "175 650\n",
      "180 650\n",
      "185 650\n",
      "190 650\n",
      "195 650\n",
      "200 650\n",
      "205 650\n",
      "210 650\n",
      "215 650\n",
      "220 650\n",
      "225 650\n",
      "230 650\n",
      "235 650\n",
      "240 650\n",
      "245 650\n",
      "250 650\n",
      "255 650\n",
      "260 650\n",
      "265 650\n",
      "270 650\n",
      "275 650\n",
      "280 650\n",
      "285 650\n",
      "290 650\n",
      "295 650\n",
      "300 650\n",
      "305 650\n",
      "310 650\n",
      "315 650\n",
      "320 650\n",
      "0 700\n",
      "5 700\n",
      "10 700\n",
      "15 700\n",
      "20 700\n",
      "25 700\n",
      "30 700\n",
      "35 700\n",
      "40 700\n",
      "45 700\n",
      "50 700\n",
      "55 700\n",
      "60 700\n",
      "65 700\n",
      "70 700\n",
      "75 700\n",
      "80 700\n",
      "85 700\n",
      "90 700\n",
      "95 700\n",
      "100 700\n",
      "105 700\n",
      "110 700\n",
      "115 700\n",
      "120 700\n",
      "125 700\n",
      "130 700\n",
      "135 700\n",
      "140 700\n",
      "145 700\n",
      "150 700\n",
      "155 700\n",
      "160 700\n",
      "165 700\n",
      "170 700\n",
      "175 700\n",
      "180 700\n",
      "185 700\n",
      "190 700\n",
      "195 700\n",
      "200 700\n",
      "205 700\n",
      "210 700\n",
      "215 700\n",
      "220 700\n",
      "225 700\n",
      "230 700\n",
      "235 700\n",
      "240 700\n",
      "245 700\n",
      "250 700\n",
      "255 700\n",
      "260 700\n",
      "265 700\n",
      "270 700\n",
      "275 700\n",
      "280 700\n",
      "285 700\n",
      "290 700\n",
      "295 700\n",
      "300 700\n",
      "305 700\n",
      "310 700\n",
      "315 700\n",
      "320 700\n",
      "325 700\n",
      "330 700\n",
      "335 700\n",
      "340 700\n",
      "345 700\n",
      "0 750\n",
      "5 750\n",
      "10 750\n",
      "15 750\n",
      "20 750\n",
      "25 750\n",
      "30 750\n",
      "35 750\n",
      "40 750\n",
      "45 750\n",
      "50 750\n",
      "55 750\n",
      "60 750\n",
      "65 750\n",
      "70 750\n",
      "75 750\n",
      "80 750\n",
      "85 750\n",
      "90 750\n",
      "95 750\n",
      "100 750\n",
      "105 750\n",
      "110 750\n",
      "115 750\n",
      "120 750\n",
      "125 750\n",
      "130 750\n",
      "135 750\n",
      "140 750\n",
      "145 750\n",
      "150 750\n",
      "155 750\n",
      "160 750\n",
      "165 750\n",
      "170 750\n",
      "175 750\n",
      "180 750\n",
      "185 750\n",
      "190 750\n",
      "195 750\n",
      "200 750\n",
      "205 750\n",
      "210 750\n",
      "215 750\n",
      "220 750\n",
      "225 750\n",
      "230 750\n",
      "235 750\n",
      "240 750\n",
      "245 750\n",
      "250 750\n",
      "255 750\n",
      "260 750\n",
      "265 750\n",
      "270 750\n",
      "275 750\n",
      "280 750\n",
      "285 750\n",
      "290 750\n",
      "295 750\n",
      "300 750\n",
      "305 750\n",
      "310 750\n",
      "315 750\n",
      "320 750\n",
      "325 750\n",
      "330 750\n",
      "335 750\n",
      "340 750\n",
      "345 750\n",
      "350 750\n",
      "355 750\n",
      "360 750\n",
      "365 750\n",
      "370 750\n",
      "0 800\n",
      "5 800\n",
      "10 800\n",
      "15 800\n",
      "20 800\n",
      "25 800\n",
      "30 800\n",
      "35 800\n",
      "40 800\n",
      "45 800\n",
      "50 800\n",
      "55 800\n",
      "60 800\n",
      "65 800\n",
      "70 800\n",
      "75 800\n",
      "80 800\n",
      "85 800\n",
      "90 800\n",
      "95 800\n",
      "100 800\n",
      "105 800\n",
      "110 800\n",
      "115 800\n",
      "120 800\n",
      "125 800\n",
      "130 800\n",
      "135 800\n",
      "140 800\n",
      "145 800\n",
      "150 800\n",
      "155 800\n",
      "160 800\n",
      "165 800\n",
      "170 800\n",
      "175 800\n",
      "180 800\n",
      "185 800\n",
      "190 800\n",
      "195 800\n",
      "200 800\n",
      "205 800\n",
      "210 800\n",
      "215 800\n",
      "220 800\n",
      "225 800\n",
      "230 800\n",
      "235 800\n",
      "240 800\n",
      "245 800\n",
      "250 800\n",
      "255 800\n",
      "260 800\n",
      "265 800\n",
      "270 800\n",
      "275 800\n",
      "280 800\n",
      "285 800\n",
      "290 800\n",
      "295 800\n",
      "300 800\n",
      "305 800\n",
      "310 800\n",
      "315 800\n",
      "320 800\n",
      "325 800\n",
      "330 800\n",
      "335 800\n",
      "340 800\n",
      "345 800\n",
      "350 800\n",
      "355 800\n",
      "360 800\n",
      "365 800\n",
      "370 800\n",
      "375 800\n",
      "380 800\n",
      "385 800\n",
      "390 800\n",
      "395 800\n",
      "0 850\n",
      "5 850\n",
      "10 850\n",
      "15 850\n",
      "20 850\n",
      "25 850\n",
      "30 850\n",
      "35 850\n",
      "40 850\n",
      "45 850\n",
      "50 850\n",
      "55 850\n",
      "60 850\n",
      "65 850\n",
      "70 850\n",
      "75 850\n",
      "80 850\n",
      "85 850\n",
      "90 850\n",
      "95 850\n",
      "100 850\n",
      "105 850\n",
      "110 850\n",
      "115 850\n",
      "120 850\n",
      "125 850\n",
      "130 850\n",
      "135 850\n",
      "140 850\n",
      "145 850\n",
      "150 850\n",
      "155 850\n",
      "160 850\n",
      "165 850\n",
      "170 850\n",
      "175 850\n",
      "180 850\n",
      "185 850\n",
      "190 850\n",
      "195 850\n",
      "200 850\n",
      "205 850\n",
      "210 850\n",
      "215 850\n",
      "220 850\n",
      "225 850\n",
      "230 850\n",
      "235 850\n",
      "240 850\n",
      "245 850\n",
      "250 850\n",
      "255 850\n",
      "260 850\n",
      "265 850\n",
      "270 850\n",
      "275 850\n",
      "280 850\n",
      "285 850\n",
      "290 850\n",
      "295 850\n",
      "300 850\n",
      "305 850\n",
      "310 850\n",
      "315 850\n",
      "320 850\n",
      "325 850\n",
      "330 850\n",
      "335 850\n",
      "340 850\n",
      "345 850\n",
      "350 850\n",
      "355 850\n",
      "360 850\n",
      "365 850\n",
      "370 850\n",
      "375 850\n",
      "380 850\n",
      "385 850\n",
      "390 850\n",
      "395 850\n",
      "400 850\n",
      "405 850\n",
      "410 850\n",
      "415 850\n",
      "420 850\n",
      "0 900\n",
      "5 900\n",
      "10 900\n",
      "15 900\n",
      "20 900\n",
      "25 900\n",
      "30 900\n",
      "35 900\n",
      "40 900\n",
      "45 900\n",
      "50 900\n",
      "55 900\n",
      "60 900\n",
      "65 900\n",
      "70 900\n",
      "75 900\n",
      "80 900\n",
      "85 900\n",
      "90 900\n",
      "95 900\n",
      "100 900\n",
      "105 900\n",
      "110 900\n",
      "115 900\n",
      "120 900\n",
      "125 900\n",
      "130 900\n",
      "135 900\n",
      "140 900\n",
      "145 900\n",
      "150 900\n",
      "155 900\n",
      "160 900\n",
      "165 900\n",
      "170 900\n",
      "175 900\n",
      "180 900\n",
      "185 900\n",
      "190 900\n",
      "195 900\n",
      "200 900\n",
      "205 900\n",
      "210 900\n",
      "215 900\n",
      "220 900\n",
      "225 900\n",
      "230 900\n",
      "235 900\n",
      "240 900\n",
      "245 900\n",
      "250 900\n",
      "255 900\n",
      "260 900\n",
      "265 900\n",
      "270 900\n",
      "275 900\n",
      "280 900\n",
      "285 900\n",
      "290 900\n",
      "295 900\n",
      "300 900\n",
      "305 900\n",
      "310 900\n",
      "315 900\n",
      "320 900\n",
      "325 900\n",
      "330 900\n",
      "335 900\n",
      "340 900\n",
      "345 900\n",
      "350 900\n",
      "355 900\n",
      "360 900\n",
      "365 900\n",
      "370 900\n",
      "375 900\n",
      "380 900\n",
      "385 900\n",
      "390 900\n",
      "395 900\n",
      "400 900\n",
      "405 900\n",
      "410 900\n",
      "415 900\n",
      "420 900\n",
      "425 900\n",
      "430 900\n",
      "435 900\n",
      "440 900\n",
      "445 900\n",
      "0 950\n",
      "5 950\n",
      "10 950\n",
      "15 950\n",
      "20 950\n",
      "25 950\n",
      "30 950\n",
      "35 950\n",
      "40 950\n",
      "45 950\n",
      "50 950\n",
      "55 950\n",
      "60 950\n",
      "65 950\n",
      "70 950\n",
      "75 950\n",
      "80 950\n",
      "85 950\n",
      "90 950\n",
      "95 950\n",
      "100 950\n",
      "105 950\n",
      "110 950\n",
      "115 950\n",
      "120 950\n",
      "125 950\n",
      "130 950\n",
      "135 950\n",
      "140 950\n",
      "145 950\n",
      "150 950\n",
      "155 950\n",
      "160 950\n",
      "165 950\n",
      "170 950\n",
      "175 950\n",
      "180 950\n",
      "185 950\n",
      "190 950\n",
      "195 950\n",
      "200 950\n",
      "205 950\n",
      "210 950\n",
      "215 950\n",
      "220 950\n",
      "225 950\n",
      "230 950\n",
      "235 950\n",
      "240 950\n",
      "245 950\n",
      "250 950\n",
      "255 950\n",
      "260 950\n",
      "265 950\n",
      "270 950\n",
      "275 950\n",
      "280 950\n",
      "285 950\n",
      "290 950\n",
      "295 950\n",
      "300 950\n",
      "305 950\n",
      "310 950\n",
      "315 950\n",
      "320 950\n",
      "325 950\n",
      "330 950\n",
      "335 950\n",
      "340 950\n",
      "345 950\n",
      "350 950\n",
      "355 950\n",
      "360 950\n",
      "365 950\n",
      "370 950\n",
      "375 950\n",
      "380 950\n",
      "385 950\n",
      "390 950\n",
      "395 950\n",
      "400 950\n",
      "405 950\n",
      "410 950\n",
      "415 950\n",
      "420 950\n",
      "425 950\n",
      "430 950\n",
      "435 950\n",
      "440 950\n",
      "445 950\n",
      "450 950\n",
      "455 950\n",
      "460 950\n",
      "465 950\n",
      "470 950\n",
      "0 1000\n",
      "5 1000\n",
      "10 1000\n",
      "15 1000\n",
      "20 1000\n",
      "25 1000\n",
      "30 1000\n",
      "35 1000\n",
      "40 1000\n",
      "45 1000\n",
      "50 1000\n",
      "55 1000\n",
      "60 1000\n",
      "65 1000\n",
      "70 1000\n",
      "75 1000\n",
      "80 1000\n",
      "85 1000\n",
      "90 1000\n",
      "95 1000\n",
      "100 1000\n",
      "105 1000\n",
      "110 1000\n",
      "115 1000\n",
      "120 1000\n",
      "125 1000\n",
      "130 1000\n",
      "135 1000\n",
      "140 1000\n",
      "145 1000\n",
      "150 1000\n",
      "155 1000\n",
      "160 1000\n",
      "165 1000\n",
      "170 1000\n",
      "175 1000\n",
      "180 1000\n",
      "185 1000\n",
      "190 1000\n",
      "195 1000\n",
      "200 1000\n",
      "205 1000\n",
      "210 1000\n",
      "215 1000\n",
      "220 1000\n",
      "225 1000\n",
      "230 1000\n",
      "235 1000\n",
      "240 1000\n",
      "245 1000\n",
      "250 1000\n",
      "255 1000\n",
      "260 1000\n",
      "265 1000\n",
      "270 1000\n",
      "275 1000\n",
      "280 1000\n",
      "285 1000\n",
      "290 1000\n",
      "295 1000\n",
      "300 1000\n",
      "305 1000\n",
      "310 1000\n",
      "315 1000\n",
      "320 1000\n",
      "325 1000\n",
      "330 1000\n",
      "335 1000\n",
      "340 1000\n",
      "345 1000\n",
      "350 1000\n",
      "355 1000\n",
      "360 1000\n",
      "365 1000\n",
      "370 1000\n",
      "375 1000\n",
      "380 1000\n",
      "385 1000\n",
      "390 1000\n",
      "395 1000\n",
      "400 1000\n",
      "405 1000\n",
      "410 1000\n",
      "415 1000\n",
      "420 1000\n",
      "425 1000\n",
      "430 1000\n",
      "435 1000\n",
      "440 1000\n",
      "445 1000\n",
      "450 1000\n",
      "455 1000\n",
      "460 1000\n",
      "465 1000\n",
      "470 1000\n",
      "475 1000\n",
      "480 1000\n",
      "485 1000\n",
      "490 1000\n",
      "495 1000\n"
     ]
    }
   ],
   "execution_count": 3
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-08-15T03:01:04.565527Z",
     "start_time": "2025-08-15T03:01:04.549702Z"
    }
   },
   "cell_type": "code",
   "source": [
    "# pa = a/n\n",
    "# pb = b/n\n",
    "# qa = 1-pa\n",
    "# qb = 1-pb\n",
    "# t_star = 0.5 * math.log(pa * qb / qa / pb) \n",
    "# exp_t_star = math.exp(t_star)\n",
    "# MGF_pos = (qa+pa*exp_t_star)**n * (qb+pb/exp_t_star)**n\n",
    "# MGF_neg = (qa+pa/exp_t_star)**n * (qb+pb*exp_t_star)**n\n",
    "# C = (MGF_pos + MGF_neg)/2\n",
    "# \n",
    "# print(t_star)\n",
    "# print(C)"
   ],
   "id": "93d85e8dbd9c1491",
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.21325925865299836\n",
      "12.748078618985526\n"
     ]
    }
   ],
   "execution_count": 3
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-08-15T03:01:04.816453Z",
     "start_time": "2025-08-15T03:01:04.805575Z"
    }
   },
   "cell_type": "code",
   "source": [
    "# k_values = [3]\n",
    "# \n",
    "# chernoff_numbers = np.zeros(n)\n",
    "# for i in range(n):\n",
    "#     chernoff_numbers[i] = math.log(C) + math.log(2*n+1) - math.log(i+1)\n",
    "# \n",
    "# for k in k_values:\n",
    "#     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",
    "#     for i in range(n):\n",
    "#         chernoff_ratio = chernoff_numbers[i]/chernoff_numbers[0]\n",
    "#         #print(chernoff_ratio)\n",
    "#         constraints.append(x[i] <= chernoff_ratio * x[0])\n",
    "#         constraints.append(x[2*n-1-i] >= -chernoff_ratio * x[2*n-1])\n",
    "#         \n",
    "#         constraints.append(x[i] + x[2*n-1-i] == 0)\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": 4
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-08-15T03:15:58.041204Z",
     "start_time": "2025-08-15T03:01:05.148569Z"
    }
   },
   "cell_type": "code",
   "source": [
    "# k_values = range((int)(n/2))\n",
    "# \n",
    "# chernoff_numbers = np.zeros(n)\n",
    "# \n",
    "# chernoff_df = pd.DataFrame(columns=['k', 'sin_theta'])\n",
    "# \n",
    "# do_solve = True\n",
    "# \n",
    "# for i in range(n):\n",
    "#     chernoff_numbers[i] = math.log(C) + math.log(2*n+1) - math.log(i+1)\n",
    "# \n",
    "# for k in k_values:\n",
    "#     print(k)\n",
    "#     x = cp.Variable(n)\n",
    "#     sos = cp.sum_squares(x)\n",
    "#     constraints = [sos <= 0.5]\n",
    "# \n",
    "#     for i in range(n-1):\n",
    "#         constraints.append(x[i] >= x[i+1])\n",
    "# \n",
    "#     for i in range(n-1):\n",
    "#         constraints.append(x[i+1] / chernoff_numbers[i+1] <= x[i] / chernoff_numbers[i])\n",
    "#         constraints.append(x[i] >= 0)\n",
    "#     \n",
    "#     constraints.append(x[n-1] >= 0)\n",
    "# \n",
    "#     coefficients = np.ones([1,n])\n",
    "#     coefficients[0,n-k:n] = -1\n",
    "#     objective = cp.Maximize(cp.vdot(coefficients, x))\n",
    "# \n",
    "#     prob1 = cp.Problem(objective, constraints)\n",
    "#     if do_solve:\n",
    "#         prob1.solve()\n",
    "#         cos_theta = prob1.value * 2 / np.sqrt(2 * n)\n",
    "#         sin_theta = np.sqrt(1 - cos_theta ** 2)\n",
    "#         chernoff_df.loc[len(chernoff_df)] = [k, sin_theta]\n"
   ],
   "id": "f37477d264be41ce",
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "1\n",
      "2\n",
      "3\n",
      "4\n",
      "5\n",
      "6\n",
      "7\n",
      "8\n",
      "9\n",
      "10\n",
      "11\n",
      "12\n",
      "13\n",
      "14\n",
      "15\n",
      "16\n",
      "17\n",
      "18\n",
      "19\n",
      "20\n",
      "21\n",
      "22\n",
      "23\n",
      "24\n",
      "25\n",
      "26\n",
      "27\n",
      "28\n",
      "29\n",
      "30\n",
      "31\n",
      "32\n",
      "33\n",
      "34\n",
      "35\n",
      "36\n",
      "37\n",
      "38\n",
      "39\n",
      "40\n",
      "41\n",
      "42\n",
      "43\n",
      "44\n",
      "45\n",
      "46\n",
      "47\n",
      "48\n",
      "49\n",
      "50\n",
      "51\n",
      "52\n",
      "53\n",
      "54\n",
      "55\n",
      "56\n",
      "57\n",
      "58\n",
      "59\n",
      "60\n",
      "61\n",
      "62\n",
      "63\n",
      "64\n",
      "65\n",
      "66\n",
      "67\n",
      "68\n",
      "69\n",
      "70\n",
      "71\n",
      "72\n",
      "73\n",
      "74\n",
      "75\n",
      "76\n",
      "77\n",
      "78\n",
      "79\n",
      "80\n",
      "81\n",
      "82\n",
      "83\n",
      "84\n",
      "85\n",
      "86\n",
      "87\n",
      "88\n",
      "89\n",
      "90\n",
      "91\n",
      "92\n",
      "93\n",
      "94\n",
      "95\n",
      "96\n",
      "97\n",
      "98\n",
      "99\n",
      "100\n",
      "101\n",
      "102\n",
      "103\n",
      "104\n",
      "105\n",
      "106\n",
      "107\n",
      "108\n",
      "109\n",
      "110\n",
      "111\n",
      "112\n",
      "113\n",
      "114\n",
      "115\n",
      "116\n",
      "117\n",
      "118\n",
      "119\n",
      "120\n",
      "121\n",
      "122\n",
      "123\n",
      "124\n",
      "125\n",
      "126\n",
      "127\n",
      "128\n",
      "129\n",
      "130\n",
      "131\n",
      "132\n",
      "133\n",
      "134\n",
      "135\n",
      "136\n",
      "137\n",
      "138\n",
      "139\n",
      "140\n",
      "141\n",
      "142\n",
      "143\n",
      "144\n",
      "145\n",
      "146\n",
      "147\n",
      "148\n",
      "149\n",
      "150\n",
      "151\n",
      "152\n",
      "153\n",
      "154\n",
      "155\n",
      "156\n",
      "157\n",
      "158\n",
      "159\n",
      "160\n",
      "161\n",
      "162\n",
      "163\n",
      "164\n",
      "165\n",
      "166\n",
      "167\n",
      "168\n",
      "169\n",
      "170\n",
      "171\n",
      "172\n",
      "173\n",
      "174\n",
      "175\n",
      "176\n",
      "177\n",
      "178\n",
      "179\n",
      "180\n",
      "181\n",
      "182\n",
      "183\n",
      "184\n",
      "185\n",
      "186\n",
      "187\n",
      "188\n",
      "189\n",
      "190\n",
      "191\n",
      "192\n",
      "193\n",
      "194\n",
      "195\n",
      "196\n",
      "197\n",
      "198\n",
      "199\n",
      "200\n",
      "201\n",
      "202\n",
      "203\n",
      "204\n",
      "205\n",
      "206\n",
      "207\n",
      "208\n",
      "209\n",
      "210\n",
      "211\n",
      "212\n",
      "213\n",
      "214\n",
      "215\n",
      "216\n",
      "217\n",
      "218\n",
      "219\n",
      "220\n",
      "221\n",
      "222\n",
      "223\n",
      "224\n",
      "225\n",
      "226\n",
      "227\n",
      "228\n",
      "229\n",
      "230\n",
      "231\n",
      "232\n",
      "233\n",
      "234\n",
      "235\n",
      "236\n",
      "237\n",
      "238\n",
      "239\n",
      "240\n",
      "241\n",
      "242\n",
      "243\n",
      "244\n",
      "245\n",
      "246\n",
      "247\n",
      "248\n",
      "249\n"
     ]
    }
   ],
   "execution_count": 5
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-08-15T04:36:10.002778Z",
     "start_time": "2025-08-15T04:36:09.394720Z"
    }
   },
   "cell_type": "code",
   "source": "prob1.solve()",
   "id": "10715544a69a5db8",
   "outputs": [
    {
     "data": {
      "text/plain": [
       "np.float64(10.9952163913482)"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "execution_count": 15
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-08-15T04:36:15.829686Z",
     "start_time": "2025-08-15T04:36:15.817622Z"
    }
   },
   "cell_type": "code",
   "source": "sos.value",
   "id": "9a2c459da7a85c5d",
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array(0.49999999)"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "execution_count": 16
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-08-15T04:36:18.052857Z",
     "start_time": "2025-08-15T04:36:18.035649Z"
    }
   },
   "cell_type": "code",
   "source": [
    "cos_theta = prob1.value * 2 / np.sqrt(2*n)\n",
    "print(cos_theta)\n",
    "sin_theta = np.sqrt(1-cos_theta**2)\n",
    "print(sin_theta)\n",
    "print(sin_theta**2)"
   ],
   "id": "fe1a20d6eeff56dd",
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.6953985432615519\n",
      "0.7186242871137264\n",
      "0.5164208660297115\n"
     ]
    }
   ],
   "execution_count": 17
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-08-15T04:36:28.229948Z",
     "start_time": "2025-08-15T04:36:21.317992Z"
    }
   },
   "cell_type": "code",
   "source": "plt.bar(range(n), x.value, label='U1', color='blue')",
   "id": "ced6451779d90f1b",
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<BarContainer object of 500 artists>"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ],
      "image/png": "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dHSY+vp609bWZiSZF198Mez1p556yqxatcq0tbWZI0eOmMrKSrN27VozOjoaqnG73eaKK64wXq/XvPbaa+aLX/yiueGGG8zk5OQin4291q1bZ773ve+ZN954w/T29pqNGzeaT3ziE+a9994L1TDXF669vd38+Mc/NkePHjVHjx41dXV1JikpybzxxhvGGOZ4Ibz66qvmqquuMtdff73Ztm1baJy5vnA7d+40v/u7v2sGBwdD29DQUOh12+aYwDKDG2+80bjd7rCxa665xjz00ENL1FF8OzewnD592mRmZpqnnnoqNPbhhx+atLQ009TUZIwx5uTJkyYpKcns27cvVHP8+HGzYsUK85Of/GTReo83Q0NDRpLp6uoyxjDXC2n16tVm7969zPECOHXqlPmd3/kd4/V6zS233BIKLMz1/Ni5c6e54YYbor5m4xxzSWga4+Pj6unpUXl5edh4eXm5Dh48uERdLS99fX0KBoNhc5ySkqJbbrklNMc9PT2amJgIq8nKylJBQQE/hxmMjIxIki677DJJzPVCmJqa0r59+/T++++rpKSEOV4ADzzwgDZu3KjbbrstbJy5nj9vv/22srKylJubq7vuukvvvPOOJDvneE6/rfliMDw8rKmpqYhfwJiRkRHxixoxN2fnMdocHzt2LFSTnJys1atXR9Twc4jOGKOamhrddNNNKigokMRcz6cjR46opKREH374oT72sY/pxRdf1LXXXhv6B5o5nh/79u3Ta6+9pl/84hcRr/H3eX4UFxfr+eef16c+9Sn913/9l/7yL/9SpaWlevPNN62cYwLLeTgcjrA/G2MixnBh5jLH/Bym9+CDD+r111+P+ru4mOsL9+lPf1q9vb06efKk2tradM8996irqyv0OnN84QYGBrRt2zZ1dnbK6XROW8dcX5j169eH/vu6665TSUmJrr76av3d3/2dPv/5z0uya465JDSN9PR0JSQkRKTEoaGhiMSJuTl7N/pMc5yZmanx8XH97//+77Q1+K1vfOMbam9v18svv6wrr7wyNM5cz5/k5GR98pOfVFFRkTwej2644Qb97d/+LXM8j3p6ejQ0NCSXy6XExEQlJiaqq6tLu3fvVmJiYmiumOv5tXLlSl133XV6++23rfz7TGCZRnJyslwul7xeb9i41+tVaWnpEnW1vOTm5iozMzNsjsfHx9XV1RWaY5fLpaSkpLCawcFBvfHGG/wcPsIYowcffFD79+/Xv/7rvyo3NzfsdeZ64RhjNDY2xhzPoy996Us6cuSIent7Q1tRUZH+9E//VL29vcrLy2OuF8DY2JgCgYDWrl1r59/neb+Ndxk5+7Xm5uZm88tf/tJUVVWZlStXmnfffXepW4sbp06dMn6/3/j9fiPJ/M3f/I3x+/2hr4Y/9dRTJi0tzezfv98cOXLEfOUrX4n6tbkrr7zSvPTSS+a1114zv/d7v8dXE89x//33m7S0NHPgwIGwryh+8MEHoRrm+sLV1taaV155xfT19ZnXX3/d1NXVmRUrVpjOzk5jDHO8kD76LSFjmOv58M1vftMcOHDAvPPOO+bf//3fze23325WrVoV+oyzbY4JLOexZ88ek5OTY5KTk01hYWHoa6KYnZdfftlIitjuueceY8yZr87t3LnTZGZmmpSUFHPzzTebI0eOhB3j//7v/8yDDz5oLrvsMnPJJZeY22+/3fT39y/B2dgr2hxLMt/73vdCNcz1hfuzP/uz0L8Hl19+ufnSl74UCivGMMcL6dzAwlxfuLPPVUlKSjJZWVnmD//wD82bb74Zet22OXYYY8z8r9sAAADMH+5hAQAA1iOwAAAA6xFYAACA9QgsAADAegQWAABgPQILAACwHoEFAABYj8ACAACsR2ABAADWI7AAAADrEVgAAID1CCwAAMB6/w+7PsuiFVNXEAAAAABJRU5ErkJggg=="
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "execution_count": 18
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-25T02:03:37.662450Z",
     "start_time": "2025-09-25T02:03:37.419251Z"
    }
   },
   "cell_type": "code",
   "source": [
    "chernoff_df = pd.read_csv(\"chernoff_df.csv\")\n",
    "chernoff_df['n'].value_counts()\n",
    "chernoff_df_500 = chernoff_df[chernoff_df['n']==500]\n",
    "chernoff_df_500['sin_theta_lemma'] = np.sqrt((chernoff_df_500['k'] / chernoff_df_500['n']))\n",
    "\n",
    "n = 500\n",
    "\n",
    "a = 0.06 * n\n",
    "b = 0.04 * n\n",
    "\n",
    "pa = a/n\n",
    "pb = b/n\n",
    "qa = 1-pa\n",
    "qb = 1-pb\n",
    "t_star = 0.5 * math.log(pa * qb / qa / pb) \n",
    "exp_t_star = math.exp(t_star)\n",
    "MGF_pos = (qa+pa*exp_t_star)**n * (qb+pb/exp_t_star)**n\n",
    "MGF_neg = (qa+pa/exp_t_star)**n * (qb+pb*exp_t_star)**n\n",
    "C = (MGF_pos + MGF_neg)/2\n",
    "\n",
    "k_array = chernoff_df_500['k']\n",
    "gamma_array = chernoff_df_500['k'] / 500\n",
    "realized_sin = chernoff_df_500['sin_theta']\n",
    "predicted_cos = (1 - gamma_array) * (math.log(C) + 1 + np.log(2 + 1/n) - np.log(1 - gamma_array)) * math.sqrt(2*500) / t_star\n",
    "realized_cos = np.sqrt(1 - realized_sin**2)\n",
    "ols_data = pd.concat([realized_cos, predicted_cos], axis=1)\n",
    "ols_result = sm.ols(formula='realized_cos ~ predicted_cos', data=ols_data).fit()\n",
    "transformed_predicted_cos = ols_result.params['predicted_cos'] * predicted_cos + ols_result.params['Intercept']\n",
    "transformed_predicted_sin = np.sqrt(1 - transformed_predicted_cos**2)\n",
    "\n",
    "plt.scatter(chernoff_df_500['sin_theta'], chernoff_df_500['k']/n, color='mediumblue', s=5, label='Chernoff-optimizer')\n",
    "plt.scatter(chernoff_df_500['sin_theta_lemma'], chernoff_df_500['k']/n, color='red', s=5, label='Quadratic Lemma')\n",
    "plt.plot(transformed_predicted_sin, chernoff_df_500['k']/n, color='blue', linestyle='--', label='Chernoff-predicted')\n",
    "plt.legend()\n",
    "plt.xlabel(\"sin theta\")\n",
    "plt.ylabel(\"gamma\")\n",
    "plt.show()"
   ],
   "id": "ca328d6f82c4e64b",
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/qv/_v67fpcs0l33vlkg8tg1t8940000gn/T/ipykernel_44096/1967154373.py:4: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  chernoff_df_500['sin_theta_lemma'] = np.sqrt((chernoff_df_500['k'] / chernoff_df_500['n']))\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ],
      "image/png": "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jAxDdLSViIg9REdbychw7o2gjx49ytdff82YMWOoUqVKntcv/GCNiopi4MCB/Prrr9x4443ccccdHD16FLANBfbq1Yv27duzZcsWvv76a/7++28GDhyYo7133nkHT09PNm7cyIIFC+zbp02bxuzZs9myZQuenp7cc8899teWL1/O+PHjefDBB/ntt98YOXIkd999N2vWrAHg559/5oYbbmDgwIFYrVbmzp2b77b8zJ07l9mzZ/P888/z66+/0qdPH2655ZY8lXQPP/wwDz74IHFxcXTt2pVbbrmFI0eOEBISwtKlSwHb8h4FnQtsQ2XdunUjLi6Om266iaFDhzJs2DDuvPNOtm7dStOmTRk2bBgXuwH4zz//jNVqxWq18tdff3H11Vfb11Q7deoU11xzDf7+/nz//fds2LABf39/brjhBtLT0+1tfPvtt8THxxMTE8MXX3xx0VhFRByie3fI/k+YxQLdu2MMTJxo29SnD1xzjV+uXfxdE6upYFJSUgxgUlJS8rx2+vRps2PHDnP69OkSnycq6pCxWGINxBqLJdZERR0qcZsF+fHHHw1gli1bVuB+gHnsscfsz1NTU43FYjFfffWVMcaY6dOnm4iIiBzHHDhwwABm165dxhhjevXqZdq3b59jnzVr1hjArF692r7tyy+/NID9/ezatau57777chx3++23mxtvvNH+vF+/fuauu+7KsU9+23KrV6+eeeqpp3Jsu/LKK83o0aONMcbs27fPAObpp5+2v3727FlTv35988wzz+S4hn/++SdHO7169TLjx4+3Pw8NDTV33nmn/bnVajWAmT59un3bDz/8YABjtVqNMca8/fbbJjAwMN/Yx40bZ0JDQ01SUpIxxpi33nrLtGjRwmRlZdn3SUtLM76+vuabb74xxhhz1113maCgIJOWlnbR98SRv88iIubsWWOioowJD7d9PXvWfPqpMWCMr68xCQnGnD2bZaKiDpnw8N0mKuqQOXs269LtFlJBn9+5uXzOjbvasCG1VLvmzLmTFebGbe3atbN/X6VKFQICAkhKSgIgNjaWNWvW4O+fN9veu3evffijU6dOl2w7u0Q/KSmJBg0aEB8fz/33359j/27duhXYQ5Lb+++/z8iRI+3Pv/rqK6644goOHTpEt27d8rT9yy+/5NjWpUsX+/eenp506tSJ+Pj4Qp8/24XXmX1fprZt2+bZlpSURN26dS/azuuvv85bb73Fxo0b7QvAxsbG8vvvvxMQEJBj3zNnzrB3717787Zt22qejYiUHk9P+xybbFlZUKcOjBoFtvvjWlwyxyY3JTdO0r27P6tXn8CY0umaa9asGRaLhfj4ePr371/gvrkrfywWC1lZWYBt7srNN9/MM888k+e4C+8nlN/QV+62sxOt7LYv3JbNFHBH6vzccsstdO7c2f78sssusy+bUdy2i3Mn3/yu81LXntvatWt54IEH+PDDD7niiivs27OysggLC+P999/Pc0x2AgQX/xmIiJSW22+3DUd5lrFsQnNunGTq1LpERgYTHh5AZGQwU6de/H/vjlCjRg369OnDq6++ysmTJ/O8fuzYsUK107FjR7Zv307Dhg1p2rRpjkdJP0xbtWrFhnMT0LJt2rSJVq1aFbqNgICAHDH5+vpStWpV6tWrV6i2L5xYnZGRQWxsLC1btgRKdy2m33//nX/9619MnTqVAQMG5HitY8eO7Nmzhzp16uT5GTizFF5EJIeMDIiOhogI29eMjHx2McyZY6V//9KZX1pYZSzXch+enqXfNTdv3jy6du3KVVddRXR0NO3atSMjI4OYmBjmz59fqOGXMWPG8MYbbzB48GAefvhhatWqxe+//85HH33EG2+8gYeHR7Hje/jhhxk4cCAdO3bkuuuu47///S/Lli1jdXZJYQk8/PDDzJgxgyZNmtC+fXvefvtttm3blqf349VXX6VZs2a0atWKF198kX/++cc+6Tk0NBSLxcIXX3zBjTfeiK+vb77DcyV1+vRpbr75Ztq3b8/999+fYwmSunXrcscdd/Dcc8/Rr18/ewVYQkICy5Yt4+GHH6Z+/foOj0lEJI8CSr8jI6FlS9i1K5GoKNeXfuem5MaNNGrUiK1bt/LUU0/x4IMPYrVaqV27NmFhYcyfP79QbdSrV4+NGzfy6KOP0qdPH9LS0ggNDeWGG26gUqWSdfT179+fuXPn8txzzzFu3DgaNWrE22+/Te/evUvULsC4ceM4fvw4Dz74IElJSVx++eWsWLEiz71xnn76aZ555hni4uJo0qQJn3/+ObVq1QJsQ1xRUVFMnjyZu+++m2HDhuW515Ij/P333+zcuZOdO3dSr169HK8ZY/Dz8+P777/n0UcfZcCAAZw4cYLLLruM6667TmujiUjpuUjp9y+/wBNP2ObbdO58tkyUfudmMeYitapu6vjx4wQGBpKSkpLng+LMmTPs27ePRo0a4ePj46IIxRn2799Po0aNiIuLo3379q4Op1To91lESiQ6+nzPjcUCkZGY6Y9z7bWwdi0MHAitW1vtN+2z7RLstJ6bgj6/c1PPjYiIiOQ1dart6wXLLSxfbktsfHzg2Wfhssvqntvl/HILZYGSGxEREckrV+n3mTPw0EO27x96CGzLQJaN0u/clNxIhdCwYcOL3i1YREQubc4c2LcP6tWDRx91dTQFUym4iIhIRXeJsu9jx+Cpp2z/QaxePZEXXig7Zd/5Uc+NiIhIRVdA2TdAtWpw221HWbTIsH37ISIjs3cpe0NSoORGRERELlL2faGDB48CJy7YpWyUfedHw1IiIiIVXT4rfoPtXjZWa/Yu/mVjxe9CUM+NiIhIRZdP2TfAe+/Bf/4DTz6Jvcy7rJV950fJjYiISEWXz4rfJ07YqqJOnYL0dNcsK1RcGpYSh4mMjHTq3X979+7NhAkTnNa+iEiFUYhFMZ980pCYCL6+6Zw8Wbaro3JTcuNGDhw4wIgRI6hXrx5eXl6EhoYyfvx4jhw54urQimTt2rVYLJY8K5kvW7aMJ554otjtKjkSETknuzoqJsb2debMHC/v3QuzZ9u+P336AE8+aWXmzMQ8zZRVSm7cxB9//EGnTp3YvXs3H374Ib///juvvfYa3377LV26dOHo0aOuDpH09PQSHV+jRg0CAgIcFI2ISAV2ieqoiRMhM9MCpAApZb46KjclN25izJgxeHl5sWrVKnr16kWDBg3o27cvq1ev5uDBg0ybNs2+r8Vi4bPPPstxfLVq1XKsgP3oo4/SvHlz/Pz8aNy4MdOnT+fs2bM5jnn66acJCgoiICCAESNGcObMmRyvDx8+nP79+zNr1izq1atH8+bNAXjvvffo1KkTAQEB1K1blyFDhpCUlATYFri85pprAKhevToWi4Xhw4cDeXte0tLSeOSRRwgJCcHb25tmzZrx1ltvFfs93LRpEz179sTX15eQkBDGjRvHyZMn7a83bNiQJ598kmHDhuHv709oaCiff/45hw8fpl+/fvj7+9O2bVu2bNliP2bRokVUq1aNL774ghYtWuDn58dtt93GyZMneeedd2jYsCHVq1fngQceIDMz035cQe+RiEiJXaQ6CmDlSvjvf6FSJQP8dcEuZbc6KjclN85SiPFMRzl69CjffPMNo0ePxtfXN8drdevW5Y477mDJkiVFWn4gICCARYsWsWPHDubOncsbb7zBiy++aH/9448/ZsaMGTz11FNs2bKF4OBg5s2bl6edb7/9lvj4eGJiYvjiiy8AWw/OE088wS+//MJnn33Gvn377AlMSEgIS5cuBWDXrl1YrVbmzp2bb4zDhg3jo48+4qWXXiI+Pp7XXnsNf//i/fH973//o0+fPgwYMIBff/2VJUuWsGHDBsaOHZtjvxdffJFu3boRFxfHTTfdxNChQxk2bBh33nknW7dupWnTpgwbNizHe33q1CleeuklPvroI77++mvWrl3LgAEDWLlyJStXrmTx4sW8/vrrfPrpp/ZjCnqPRERKbOpU23BUeLjta3a1FPD771C5MkyYAFFRNQgPDyAyMrhMV0flYSqYlJQUA5iUlJQ8r50+fdrs2LHDnD59uuQniooyxmIxBmxfo6JK3uZFbN682QBm+fLl+b7+wgsvGMD8/fffxhiT776BgYHm7bffvug5nn32WRMWFmZ/3qVLFzNq1Kgc+3Tu3NlcccUV9ud33XWXCQoKMmlpaQXG/9NPPxnAnDhxwhhjzJo1awxg/vnnnxz79erVy4wfP94YY8yuXbsMYGJiYgps+2LH5zZ06FBz//3359i2fv16U6lSJfvvQ2hoqLnzzjvtr1utVgOY6dOn27f98MMPBjBWq9UYY8zbb79tAPP777/b9xk5cqTx8/OzX68xxvTp08eMHDnyorHnfo8Kw6G/zyJSoezebUw+H5MuVdDnd27quXGWQtztsbSYc3F4eXkV+phPP/2U7t27U7duXfz9/Zk+fToJCQn21+Pj4+nSpUuOY3I/B2jbtm2e88bFxdGvXz9CQ0MJCAigd+/eADnav5Rt27bh4eFBr169Cn1MQWJjY1m0aBH+/v72R58+fcjKymLfvn32/dq1a2f/PigoCLBdY+5tFw4h+fn50aRJkxz7NGzYMEcvU1BQUI5jHPEeiYgUV7NmULWqq6MoPiU3zlLAeKajNW3aFIvFwo4dO/J9fefOndSuXZtq1aqdC8eSZ4jqwvk0mzdv5t///jd9+/bliy++IC4ujmnTphVrQnCVKlVyPD958iQRERH4+/vz3nvv8fPPP7N8+XKgaBOOcw+/lVRWVhYjR45k27Zt9scvv/zCnj17ciQmlStXtn9vOffzzW9bVlZWvsdk75PftuxjHPUeiYgAhZ4m8cQThpEjk4mI2EN0dPkq/c5NN/Fzlovc7dEZatasSXh4OPPmzWPixIk5PvgTExN5//33GTNmjH1b7dq1sWbfTxvYs2cPp06dsj/fuHEjoaGhOSYh//nnnznO2apVKzZv3sywYcPs2zZv3nzJWHfu3ElycjJPP/00ISEhADkm4ML5HqYLJ9jm1rZtW7Kysli3bh3XX3/9Jc97KR07dmT79u00bdq0xG2VVGHeIxGRQrvEophg+6h6/HELUBOwsnr1iXO7lY+b9uWmnhtnyb7b46pVtq+ezs0jX3nlFdLS0ujTpw/ff/89Bw4c4OuvvyY8PJzmzZvz+AW/yNdeey2vvPIKW7duZcuWLYwaNSpHT0LTpk1JSEjgo48+Yu/evbz00kv2noNs48ePZ+HChSxcuJDdu3czY8YMtm/ffsk4GzRogJeXFy+//DJ//PEHK1asyHPvmtDQUCwWC1988QWHDx8mNTVv+WHDhg256667uOeee+wTbteuXcvHH39c4PkPHz6co3dm27ZtJCYm8uijj/LDDz8wZswYtm3bxp49e1ixYgUPPPDAJa/J0QrzHomIFNolpklkZMD5//8mA2fLXel3bkpu3ESzZs34+eefady4MQMHDiQ0NJS+ffvSvHlzNm7cmGN+x+zZswkJCaFnz54MGTKEhx56CD8/P/vr/fr1Y+LEiYwdO5b27duzadMmpk+fnuN8gwYN4vHHH+fRRx8lLCyMP//8k//85z+XjLN27dosWrSITz75hMsvv5ynn36a559/Psc+l112GVFRUUyePJmgoKA8FUvZ5s+fz2233cbo0aNp2bIl9913X47S7fx88MEHdOjQIcfjtddeo127dqxbt449e/bQo0cPOnTowPTp0wkOLv3/tRTmPRIRKbRLTJOYPx9+/RV8fbOAQxfsVn5Kv3OzmNyTL9zc8ePHCQwMJCUlhaq5ZkudOXOGffv20ahRI3x8fFwUoePMmDGDF154gVWrVuU72Vfcm7v9PotIMWVk2IamLpwmcW404e+/oUULSEmBV14xHDmSmGNhTE9Pi4uDP6+gz+/cNOfGjUVFRdGwYUN+/PFHOnfuTKVK6qgTEalw8lkUM9vkybbEpmNHGDXKgodH+Zxjk5uSGzd39913uzoEEREpg7Zuhewb07/6Knh4uDQch1JyIyIi4i4KGILKuZthxYpEWrWqRPXqVejUqQpQdoagSkrJjYiIiLsoRNm3bbdEoqOtGGObPDxzZnC5LfvOjyZhiIiIuItC3B3/2DFYt+5krt3Kb9l3fpTciIiIuItC3B1/4kSIjW0I+F+wW/kt+86PhqVERETcxSXujr9xY/YkYk/uvbcGf/5psZd9uxMlNyIiIu6igLLvjAwYPdr2/b33whtv1AJqlV5spUjDUhWMxWLhs88+c3UYF5WYmEh4eDhVqlSxL/SZ3zZXu/B93L9/PxaLhW3btpV6HMOHD6d///6lfl4RKX9eecV2J+IaNWDWLFdH41xKbtxMYmIiDzzwAI0bN8bb25uQkBBuvvlmvv32W1eHVigvvvgiVquVbdu2sXv37otuK0tCQkKwWq20adOmUPsrIRERhyjkat8ABw4YJk/OAqBbt2NUq+beixNoWMqN7N+/n27dulGtWjWeffZZ2rVrx9mzZ/nmm28YM2YMO3fudMp509PT7St5l9TevXsJCwujWbNmBW5zhLNnz+ZYMLS4PDw8qFvXvcarRaQcKGTZN8BNN50hLc0XOMl///uH25V+56aeGzcyevRoLBYLP/30E7fddhvNmzendevWTJo0ic2bN9v3S05O5tZbb8XPz49mzZqxYsWKHO3s2LGDG2+8EX9/f4KCghg6dCjJycn213v37s3YsWOZNGkStWrVIjw8nLVr12KxWPj222/p1KkTfn5+dO3alV27duVoe/78+TRp0gQvLy9atGjB4sWL7a81bNiQpUuX8u6772KxWBg+fHi+2/LTsGFDnnjiCYYMGYK/vz/16tXj5ZdfzrGPxWLhtddeo1+/flSpUoUnn3wSgP/+97+EhYXh4+ND48aNiYqKIuOC/wHt2bOHnj174uPjw+WXX05MTEyOdvMbltq+fTs33XQTVatWJSAggB49erB3714iIyN55513+Pzzz7FYLFgsFtauXQvAwYMHGTRoENWrV6dmzZr069eP/fv329vMzMxk0qRJVKtWjZo1a/LII49QwZaGE5ELFaLsG+DsWfj77wzAAAnnDnWv0u88TAWTkpJiAJOSkpLntdOnT5sdO3aY06dP53ktNfXij9y7F7TvqVOF27eojhw5YiwWi5k5c2aB+wGmfv365oMPPjB79uwx48aNM/7+/ubIkSPGGGMOHTpkatWqZaZMmWLi4+PN1q1bTXh4uLnmmmvsbfTq1cv4+/ubhx9+2OzcudPEx8ebNWvWGMB07tzZrF271mzfvt306NHDdO3a1X7csmXLTOXKlc2rr75qdu3aZWbPnm08PDzMd999Z4wxJikpydxwww1m4MCBxmq1mmPHjuW7LT+hoaEmICDAzJo1y+zatcu89NJLxsPDw6xatSrHtdepU8e89dZbZu/evWb//v3m66+/NlWrVjWLFi0ye/fuNatWrTINGzY0kZGRxhhjMjMzTZs2bUzv3r1NXFycWbdunenQoYMBzPLly40xxuzbt88AJi4uzhhjzF9//WVq1KhhBgwYYH7++Weza9cus3DhQrNz505z4sQJM3DgQHPDDTcYq9VqrFarSUtLMydPnjTNmjUz99xzj/n111/Njh07zJAhQ0yLFi1MWlqaMcaYZ555xgQGBppPP/3U7Nixw4wYMcIEBASYfv365fueFPT7LCJuICrKGIvFGLB9jYoqYNdDBrYbiDUWS6yJijpUioE6RkGf37kpublAQR8GtrQ4/8eNN+bc18/v4vv26pVz31q18t+vqH788UcDmGXLlhW4H2Aee+wx+/PU1FRjsVjMV199ZYwxZvr06SYiIiLHMQcOHDCA2bVrlzHGlty0b98+xz7Zyc3q1avt27788ksD2N/Prl27mvvuuy/Hcbfffru58YI3sF+/fuauu+7KsU9+23ILDQ01N9xwQ45tgwYNMn379s1x7RMmTMixT48ePfIkhIsXLzbBwcHGGGO++eYb4+HhYQ4cOGB//auvviowuZkyZYpp1KiRSU9PzzfWu+66K09C8tZbb5kWLVqYrKws+7a0tDTj6+trvvnmG2OMMcHBwebpp5+2v3727FlTv359JTciFdXZs7aEJjzc9vXs2QJ2zTJRUYdMePhuExV1yJw9m3XRfcuqoiQ3mnPjJsy5rkmL5dJrg7Rr187+fZUqVQgICCApKQmA2NhY1qxZg79/3hs67d27l+bNmwPQqVOnS7YdHGwbz01KSqJBgwbEx8dz//3359i/W7duzJ0795IxZ3v//fcZOXKk/flXX31Fjx49AOjSpUuOfbt06cKcOXNybMsdd2xsLD///DNPPfWUfVtmZiZnzpzh1KlTxMfH06BBA+rXr5+j3YJs27aNHj16FGk+T2xsLL//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vfY1a9YYwOzatctYrVb7IyMjo5QjL7ni/NxvueUW07lzZxMTE2P27dtnfvzxR7Nx48ZSjNoxinrtx44dy/HzPnDggKlRo4aZMWNG6Qaei5KbIrjqqqvMqFGjcmxr2bKlmTx5cr77P/LII6Zly5Y5to0cOdJcffXVTovRWYp67Rfq1atXuU5uSnLt2S6//HITFRXl6NCczhHXfuutt5o777zT0aGViuJe/6BBg8xjjz1mZsyYUW6Tm6Jee3Zy888//5RCdM5V1Gv/6quvTGBgoDly5EhphOdUJf2bX758ubFYLGb//v3OCK/QNCxVSOnp6cTGxhIREZFje0REBJs2bcr3mB9++CHP/n369GHLli2cPXvWabE6WnGu3V044tqzsrI4ceIENWrUcEaITuOIa4+Li2PTpk306tXLGSE6VXGv/+2332bv3r3MmDHD2SE6TUl+9h06dCA4OJjrrruONWvWODNMpyjOta9YsYJOnTrx7LPPctlll9G8eXMeeughTp8+XRohO4wj/ubfeustrr/+ekJDQ50RYqFVuIUziys5OZnMzEyCgoJybA8KCiIxMTHfYxITE/PdPyMjg+TkZIKDg50WryMV59rdhSOuffbs2Zw8eZKBAwc6I0SnKcm1169fn8OHD5ORkUFkZCT33nuvM0N1iuJc/549e5g8eTLr16/H07P8/vNanGsPDg7m9ddfJywsjLS0NBYvXsx1113H2rVr6dmzZ2mE7RDFufY//viDDRs24OPjw/Lly0lOTmb06NEcPXq0XM27Kem/d1arla+++ooPPvjAWSEWWvn963MRi8WS47kxJs+2S+2f3/byoKjX7k6Ke+0ffvghkZGRfP7559SpU8dZ4TlVca59/fr1pKamsnnzZiZPnkzTpk0ZPHiwM8N0msJef2ZmJkOGDCEqKormzZuXVnhOVZSffYsWLWjRooX9eZcuXThw4ADPP/98uUpushXl2rOysrBYLLz//vv2VatfeOEFbrvtNl599VV8fX2dHq8jFfffu0WLFlGtWjX69+/vpMgKT8lNIdWqVQsPD4882WtSUlKeLDdb3bp1893f09OTmjVrOi1WRyvOtbuLklz7kiVLGDFiBJ988gnXX3+9M8N0ipJce6NGjQBo27Ytf//9N5GRkeUuuSnq9Z84cYItW7YQFxfH2LFjAduHnjEGT09PVq1axbXXXlsqsZeUo/7mr776at577z1Hh+dUxbn24OBgLrvsMntiA9CqVSuMMfz11180a9bMqTE7Skl+7sYYFi5cyNChQ/Hy8nJmmIWiOTeF5OXlRVhYGDExMTm2x8TE0LVr13yP6dKlS579V61aRadOnahcubLTYnW04ly7uyjutX/44YcMHz6cDz74gJtuusnZYTqFo37uxhjS0tIcHZ7TFfX6q1atyv/+9z+2bdtmf4waNYoWLVqwbds2OnfuXFqhl5ijfvZxcXHlZvg9W3GuvVu3bhw6dIjU1FT7tt27d1OpUiXq16/v1HgdqSQ/93Xr1vH7778zYsQIZ4ZYeC6ZxlxOZZfIvfXWW2bHjh1mwoQJpkqVKvZZ4ZMnTzZDhw61759dCj5x4kSzY8cO89Zbb5X7UvDCXrsxxsTFxZm4uDgTFhZmhgwZYuLi4sz27dtdEX6JFPXaP/jgA+Pp6WleffXVHCWSx44dc9UlFFtRr/2VV14xK1asMLt37za7d+82CxcuNFWrVjXTpk1z1SWUSHF+7y9UnqulinrtL774olm+fLnZvXu3+e2338zkyZMNYJYuXeqqSyi2ol77iRMnTP369c1tt91mtm/fbtatW2eaNWtm7r33XlddQrEV93f+zjvvNJ07dy7tcC9KyU0RvfrqqyY0NNR4eXmZjh07mnXr1tlfu+uuu0yvXr1y7L927VrToUMH4+XlZRo2bGjmz59fyhE7TlGvHcjzCA0NLd2gHaQo196rV698r/2uu+4q/cAdoCjX/tJLL5nWrVsbPz8/U7VqVdOhQwczb948k5mZ6YLIHaOov/cXKs/JjTFFu/ZnnnnGNGnSxPj4+Jjq1aub7t27my+//NIFUTtGUX/u8fHx5vrrrze+vr6mfv36ZtKkSebUqVOlHLVjFPXajx07Znx9fc3rr79eypFenMWYczNcRURERNyA5tyIiIiIW1FyIyIiIm5FyY2IiIi4FSU3IiIi4laU3IiIiIhbUXIjIiIibkXJjYiIiLgVJTciIiLiVpTciIhLDB8+3CmrB+/fvx+LxcK2bdsc3raIlA9KbkTEJebOncuiRYtK1IazEiSAhg0bMmfOHKe0LSLO5enqAESkYgoMDHR1CCLiptRzIyJO8+mnn9K2bVt8fX2pWbMm119/PSdPngTy9rr07t2bcePG8cgjj1CjRg3q1q1LZGTkRduOjIzknXfe4fPPP8disWCxWFi7dq399T/++INrrrkGPz8/rrjiCn744Yccx2/atImePXvi6+tLSEgI48aNs8fWu3dv/vzzTyZOnGhvG+DIkSMMHjyY+vXr4+fnR9u2bfnwww8d82aJiMMouRERp7BarQwePJh77rmH+Ph41q5dy4ABAyhord533nmHKlWq8OOPP/Lss88SHR1NTExMvvs+9NBDDBw4kBtuuAGr1YrVaqVr167216dNm8ZDDz3Etm3baN68OYMHDyYjIwOA//3vf/Tp04cBAwbw66+/smTJEjZs2MDYsWMBWLZsGfXr1yc6OtreNsCZM2cICwvjiy++4LfffuP+++9n6NCh/Pjjj45620TEAbQquIg4xdatWwkLC2P//v2EhobmeX348OEcO3aMzz77DLD1lmRmZrJ+/Xr7PldddRXXXnstTz/9dL7nyN0G2CYUN2rUiDfffJMRI0YAsGPHDlq3bk18fDwtW7Zk2LBh+Pr6smDBAvtxGzZsoFevXpw8eRIfHx8aNmzIhAkTmDBhQoHXedNNN9GqVSuef/75Qr4zIuJs6rkREae44ooruO6662jbti233347b7zxBv/880+Bx7Rr1y7H8+DgYJKSkop1/gvbCg4OBrC3FRsby6JFi/D397c/+vTpQ1ZWFvv27btom5mZmTz11FO0a9eOmjVr4u/vz6pVq0hISChWjCLiHEpuRMQpPDw8iImJ4auvvuLyyy/n5ZdfpkWLFgUmD5UrV87x3GKxkJWVVazzX9hW9pyZ7LaysrIYOXIk27Ztsz9++eUX9uzZQ5MmTS7a5uzZs3nxxRd55JFH+O6779i2bRt9+vQhPT29WDGKiHOoWkpEnMZisdCtWze6devG448/TmhoKMuXL2fSpEkOad/Ly4vMzMwiH9exY0e2b99O06ZNi9T2+vXr6devH3feeSdgS5L27NlDq1atihyDiDiPem5ExCl+/PFHZs6cyZYtW0hISGDZsmUcPnzYoYlAw4YN+fXXX9m1axfJycmcPXu2UMc9+uij/PDDD4wZM4Zt27axZ88eVqxYwQMPPJCj7e+//56DBw+SnJwMQNOmTYmJiWHTpk3Ex8czcuRIEhMTHXY9IuIYSm5ExCmqVq3K999/z4033kjz5s157LHHmD17Nn379nXYOe677z5atGhBp06dqF27Nhs3bizUce3atWPdunXs2bOHHj160KFDB6ZPn26fmwMQHR3N/v37adKkCbVr1wZg+vTpdOzYkT59+tC7d2/q1q3rtJsIikjxqVpKRERE3Ip6bkRERMStKLkRERERt6LkRkRERNyKkhsRERFxK0puRERExK0ouRERERG3ouRGRERE3IqSGxEREXErSm5ERETErSi5EREREbei5EZERETcyv8D0vRKr5TUwDEAAAAASUVORK5CYII="
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "execution_count": 16
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-08-15T04:36:29.850746Z",
     "start_time": "2025-08-15T04:36:29.799022Z"
    }
   },
   "cell_type": "code",
   "source": "chernoff_df['sin_theta_lemma'] = np.sqrt((chernoff_df['k'] / n))",
   "id": "ae756de94010add3",
   "outputs": [
    {
     "data": {
      "text/plain": [
       "         k  sin_theta  sin_theta_lemma\n",
       "0      0.0   0.224525         0.000000\n",
       "1      1.0   0.228608         0.044721\n",
       "2      2.0   0.232622         0.063246\n",
       "3      3.0   0.236567         0.077460\n",
       "4      4.0   0.240448         0.089443\n",
       "..     ...        ...              ...\n",
       "245  245.0   0.713335         0.700000\n",
       "246  246.0   0.714661         0.701427\n",
       "247  247.0   0.715984         0.702851\n",
       "248  248.0   0.717305         0.704273\n",
       "249  249.0   0.718624         0.705691\n",
       "\n",
       "[250 rows x 3 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>sin_theta_lemma</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.224525</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1.0</td>\n",
       "      <td>0.228608</td>\n",
       "      <td>0.044721</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2.0</td>\n",
       "      <td>0.232622</td>\n",
       "      <td>0.063246</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>3.0</td>\n",
       "      <td>0.236567</td>\n",
       "      <td>0.077460</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>4.0</td>\n",
       "      <td>0.240448</td>\n",
       "      <td>0.089443</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>245</th>\n",
       "      <td>245.0</td>\n",
       "      <td>0.713335</td>\n",
       "      <td>0.700000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>246</th>\n",
       "      <td>246.0</td>\n",
       "      <td>0.714661</td>\n",
       "      <td>0.701427</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>247</th>\n",
       "      <td>247.0</td>\n",
       "      <td>0.715984</td>\n",
       "      <td>0.702851</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>248</th>\n",
       "      <td>248.0</td>\n",
       "      <td>0.717305</td>\n",
       "      <td>0.704273</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>249</th>\n",
       "      <td>249.0</td>\n",
       "      <td>0.718624</td>\n",
       "      <td>0.705691</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>250 rows × 3 columns</p>\n",
       "</div>"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "execution_count": 19
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-08-22T12:42:03.666477Z",
     "start_time": "2025-08-22T12:42:03.238696Z"
    }
   },
   "cell_type": "code",
   "source": "chernoff_df.to_csv('chernoff_df.csv')",
   "id": "5541d973d751a0cc",
   "outputs": [],
   "execution_count": 4
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-08-22T12:42:21.064141Z",
     "start_time": "2025-08-22T12:42:20.863303Z"
    }
   },
   "cell_type": "code",
   "source": "chernoff_df",
   "id": "6d6ed59153e13bb1",
   "outputs": [
    {
     "data": {
      "text/plain": [
       "         k  sin_theta       n\n",
       "0      0.0   0.224525   500.0\n",
       "1      5.0   0.244268   500.0\n",
       "2     10.0   0.262538   500.0\n",
       "3     15.0   0.279624   500.0\n",
       "4     20.0   0.295730   500.0\n",
       "..     ...        ...     ...\n",
       "820  475.0   0.694647  1000.0\n",
       "821  480.0   0.698171  1000.0\n",
       "822  485.0   0.701678  1000.0\n",
       "823  490.0   0.705167  1000.0\n",
       "824  495.0   0.708639  1000.0\n",
       "\n",
       "[825 rows x 3 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>n</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\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>5.0</td>\n",
       "      <td>0.244268</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\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>15.0</td>\n",
       "      <td>0.279624</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>20.0</td>\n",
       "      <td>0.295730</td>\n",
       "      <td>500.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>820</th>\n",
       "      <td>475.0</td>\n",
       "      <td>0.694647</td>\n",
       "      <td>1000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>821</th>\n",
       "      <td>480.0</td>\n",
       "      <td>0.698171</td>\n",
       "      <td>1000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>822</th>\n",
       "      <td>485.0</td>\n",
       "      <td>0.701678</td>\n",
       "      <td>1000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>823</th>\n",
       "      <td>490.0</td>\n",
       "      <td>0.705167</td>\n",
       "      <td>1000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>824</th>\n",
       "      <td>495.0</td>\n",
       "      <td>0.708639</td>\n",
       "      <td>1000.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>825 rows × 3 columns</p>\n",
       "</div>"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "execution_count": 5
  },
  {
   "metadata": {},
   "cell_type": "markdown",
   "source": "Do OLS",
   "id": "8dc56a0625d50d3f"
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-08-15T04:36:37.569771Z",
     "start_time": "2025-08-15T04:36:37.501694Z"
    }
   },
   "cell_type": "code",
   "source": [
    "k_array = chernoff_df['k']\n",
    "gamma_array = chernoff_df['k'] / n\n",
    "realized_sin = chernoff_df['sin_theta']\n",
    "predicted_cos = (1 - gamma_array) * (math.log(C) + 1 + np.log(2 + 1/n) - np.log(1 - gamma_array)) * math.sqrt(2*n) / t_star\n",
    "realized_cos = np.sqrt(1 - realized_sin**2)\n",
    "ols_data = pd.concat([realized_cos, predicted_cos], axis=1)\n",
    "ols_result = sm.ols(formula='realized_cos ~ predicted_cos', data=ols_data).fit()\n",
    "transformed_predicted_cos = ols_result.params['predicted_cos'] * predicted_cos + ols_result.params['Intercept']\n",
    "transformed_predicted_sin = np.sqrt(1 - transformed_predicted_cos**2)"
   ],
   "id": "c7f3b4a1762d6b01",
   "outputs": [],
   "execution_count": 21
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-08-15T04:36:40.443230Z",
     "start_time": "2025-08-15T04:36:40.102494Z"
    }
   },
   "cell_type": "code",
   "source": [
    "plt.scatter(chernoff_df['sin_theta'], chernoff_df['k'], color='blue', s=5)\n",
    "plt.scatter(chernoff_df['sin_theta_lemma'], chernoff_df['k'], color='red', s=5)\n",
    "plt.plot(transformed_predicted_sin, chernoff_df['k'], color='green', linestyle='--')\n",
    "plt.show()"
   ],
   "id": "da4726ca2c72d8d4",
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ],
      "image/png": "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EcG4ceP811EfcGfsb7/9NpdccgknnXQS8fHxnHfeeXz44Yd+7K13uTP2NWvWcP7559O6dWtiY2M544wzmDp1qh97613uftbtPv30U6KiojjnnHN820EfcWfcK1euxGKx1Hp8//33fuyx97j7mpeVlfHQQw/RoUMHYmJi6NSpE7NmzfJTb73LnbGPHDnS5et+9tln+7HHDTDCzMKFC43o6GjjpZdeMrZs2WKMHTvWaNmypfHjjz+6bL9z506jRYsWxtixY40tW7YYL730khEdHW3897//9XPPm8bdce/atcu45557jLlz5xrnnHOOMXbsWP922IvcHfvYsWONJ554wvjf//5nbNu2zZgwYYIRHR1tfPnll37uedO5O/Yvv/zSWLBggbFp0yZj165dxvz5840WLVoYL7zwgp973nTujt3uyJEjRlpampGRkWF0797dP531InfHnZeXZwDG1q1bjf379zseVqvVzz1vOk9e8yFDhhi9e/c2cnNzjV27dhlffPGF8emnn/qx197h7tiPHDni9Hrv2bPHSExMNCZOnOjfjtcj7AKUc88917jzzjudtp1xxhnGAw884LL9/fffb5xxxhlO2+644w6jT58+PuujL7g77ur69esX1AFKU8Zud9ZZZxlZWVne7prPeWPsV199tXHzzTd7u2s+5+nYb7jhBuPhhx82Jk6cGJQBirvjtgcohw8f9kPvfMvdsX/wwQdGQkKCcejQIX90z6ea+llfvHixYbFYjN27d/uiex4JqyWe8vJyNmzYQEZGhtP2jIwM1q5d6/KYzz77rFb7Sy+9lPXr11NRUeGzvnqTJ+MOFd4Ye1VVFcXFxSQmJvqiiz7jjbFv3LiRtWvX0q9fP1900Wc8Hfvs2bP54YcfmDhxoq+76BNNec179OhBSkoKAwYMIC8vz5fd9AlPxr506VJ69erFk08+ycknn8zpp5/OfffdR2lpqT+67DXe+Ky/8sorDBw4kA4dOviiix4JypsFeurgwYNUVlaSlJTktD0pKYn8/HyXx+Tn57tsb7VaOXjwICkpKT7rr7d4Mu5Q4Y2xP/XUUxw9epRhw4b5oos+05Sxt2vXjgMHDmC1WsnMzOS2227zZVe9zpOxb9++nQceeIDVq1cTFRWcX42ejDslJYUXX3yRnj17UlZWxvz58xkwYAArV67koosu8ke3vcKTse/cuZM1a9bQvHlzFi9ezMGDB7nrrrv49ddfgyoPpanfc/v37+eDDz5gwYIFvuqiR4LzU9hEFovF6WfDMGpta6i9q+1m5+64Q4mnY3/99dfJzMxkyZIltG3b1lfd8ylPxr569WpKSkr4/PPPeeCBBzjttNO48cYbfdlNn2js2CsrKxk+fDhZWVmcfvrp/uqez7jzmnfp0oUuXbo4fj7vvPPYs2cP//73v4MqQLFzZ+xVVVVYLBZee+01xx12n376aa677jqee+45YmNjfd5fb/L0e27OnDmceOKJDB061Ec980xYBSht2rQhMjKyVkRZUFBQK/K0S05Odtk+KiqK1q1b+6yv3uTJuENFU8a+aNEiRo0axZtvvsnAgQN92U2faMrYO3bsCEC3bt345ZdfyMzMDKoAxd2xFxcXs379ejZu3Mjo0aMB2y8vwzCIiooiJyeHiy++2C99bwpvfdb79OnDq6++6u3u+ZQnY09JSeHkk092BCcAZ555JoZhsHfvXjp37uzTPntLU153wzCYNWsWt9xyC82aNfNlN90WVjkozZo1o2fPnuTm5jptz83NpW/fvi6POe+882q1z8nJoVevXkRHR/usr97kybhDhadjf/311xk5ciQLFizgiiuu8HU3fcJbr7thGJSVlXm7ez7l7tjj4+P59ttv+eqrrxyPO++8ky5duvDVV1/Ru3dvf3W9Sbz1mm/cuDEolq+r82Ts559/Pvv27aOkpMSxbdu2bURERNCuXTuf9tebmvK6r1q1ih07djBq1ChfdtEzAUnNDSD7pVivvPKKsWXLFmPcuHFGy5YtHZnLDzzwgHHLLbc42tsvM/7HP/5hbNmyxXjllVeC+jLjxo7bMAxj48aNxsaNG42ePXsaw4cPNzZu3Ghs3rw5EN1vEnfHvmDBAiMqKsp47rnnnC7DO3LkSKCG4DF3xz59+nRj6dKlxrZt24xt27YZs2bNMuLj442HHnooUEPwmCfv+eqC9Soed8c9depUY/Hixca2bduMTZs2GQ888IABGG+99VaghuAxd8deXFxstGvXzrjuuuuMzZs3G6tWrTI6d+5s3HbbbYEagsc8fb/ffPPNRu/evf3d3UYJuwDFMAzjueeeMzp06GA0a9bM+OMf/2isWrXKsW/EiBFGv379nNqvXLnS6NGjh9GsWTPj1FNPNWbOnOnnHnuHu+MGaj06dOjg3057iTtj79evn8uxjxgxwv8d9wJ3xv7ss88aZ599ttGiRQsjPj7e6NGjhzFjxgyjsrIyAD1vOnff89UFa4BiGO6N+4knnjA6depkNG/e3GjVqpVxwQUXGO+//34Aeu0d7r7m3333nTFw4EAjNjbWaNeunTF+/Hjj2LFjfu61d7g79iNHjhixsbHGiy++6OeeNo7FMH7L+BQRERExibDKQREREZHgoABFRERETEcBioiIiJiOAhQRERExHQUoIiIiYjoKUERERMR0FKCIiIiI6ShAEREREdNRgCIiIiKmowBFRERETEcBioiIiJiOAhQRERExnf8PqDy2n12VToAAAAAASUVORK5CYII="
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "execution_count": 22
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-08-15T03:16:00.881960Z",
     "start_time": "2025-08-15T03:16:00.872122Z"
    }
   },
   "cell_type": "code",
   "source": "transformed_predicted_sin",
   "id": "9f7b9137c96523b1",
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0      0.209258\n",
       "1      0.213974\n",
       "2      0.218587\n",
       "3      0.223102\n",
       "4      0.227526\n",
       "         ...   \n",
       "245    0.709548\n",
       "246    0.710771\n",
       "247    0.711991\n",
       "248    0.713208\n",
       "249    0.714422\n",
       "Name: k, Length: 250, dtype: float64"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "execution_count": 14
  }
 ],
 "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
}
