{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The autoreload extension is already loaded. To reload it, use:\n",
      "  %reload_ext autoreload\n"
     ]
    }
   ],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Matplotlib is building the font cache; this may take a moment.\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "from itertools import product\n",
    "import itertools\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "from mindreadingautobots.entropy_and_bayesian import boolean\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Seaching for counterexamples to $f_N^* = f$ for parity and majority."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "def weight_by_lambda_S(fhat, lambda_func):\n",
    "    \"\"\"\n",
    "    Weight each Fourier coefficient by the size of its corresponding subset.\n",
    "    \n",
    "    Args:\n",
    "        fhat: A length 2^n array of Fourier coefficients\n",
    "        lambda_func: given |S|, returns the weighting function\n",
    "        \n",
    "    Returns:\n",
    "        A length 2^n array with each coefficient multiplied by |S|\n",
    "    \"\"\"\n",
    "    n = int(np.log2(len(fhat)))\n",
    "    assert len(fhat) == 2**n, \"Input array must have length 2^n\"\n",
    "    # Initialize output array\n",
    "    weighted = np.zeros_like(fhat)\n",
    "    \n",
    "    # For each subset S of [n]\n",
    "    for S in range(2**n):\n",
    "        # Convert S to binary representation\n",
    "        S_bin = format(S, f'0{n}b')\n",
    "        S_size = sum(1 for bit in S_bin if bit == '1')\n",
    "        \n",
    "        # Multiply coefficient by |S|\n",
    "        weighted[S] = fhat[S] * lambda_func(S_size)\n",
    "        \n",
    "    return weighted\n",
    "\n",
    "\n",
    "def guide(n):\n",
    "    out = []\n",
    "    for x in range(2**n):\n",
    "        x_bin = format(x, f'0{n}b')\n",
    "        out.append(x_bin)\n",
    "    return out\n",
    "\n",
    "\n",
    "def bool_list(n):\n",
    "    return list(itertools.product([0,1], repeat=n))\n",
    "\n",
    "def bool_list_pm(n):\n",
    "    return list(itertools.product([-1, 1], repeat=n))\n",
    "\n",
    "def guess_ghat(fhat, rho):\n",
    "    \"\"\"This doesn't give a valid boolean function necessarily.\"\"\"\n",
    "    n = int(np.log2(len(fhat)))\n",
    "    ghat = np.zeros(2**n)\n",
    "    denom = 0\n",
    "    for S in range(2**n):\n",
    "        s_sum = sum([int(c) for c in format(S, f'0{n}b')])\n",
    "        ghat[S] = rho ** (s_sum) * fhat[S]\n",
    "        denom += rho ** (2*s_sum) * fhat[S] ** 2\n",
    "    ghat = ghat / np.sqrt(denom)\n",
    "    return ghat\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "vec: [1 2 3 4]\n",
      "['0000', '0001', '0010', '0011', '0100', '0101', '0110', '0111', '1000', '1001', '1010', '1011', '1100', '1101', '1110', '1111']\n",
      "f: [-1, -1, -1, 1, -1, 1, 1, 1, -1, 1, -1, 1, -1, 1, 1, 1]\n",
      "Inf_0[f]: 0.125 Inf_0[g]: 0.0\n",
      "|fhat(S)|= 0.125 |ghat(S)|= 0.0\n",
      "Inf_1[f]: 0.375 Inf_1[g]: 0.25\n",
      "|fhat(S)|= 0.375 |ghat(S)|= 0.25\n",
      "Inf_2[f]: 0.375 Inf_2[g]: 0.25\n",
      "|fhat(S)|= 0.375 |ghat(S)|= 0.25\n",
      "Inf_3[f]: 0.625 Inf_3[g]: 0.75\n",
      "|fhat(S)|= 0.625 |ghat(S)|= 0.75\n",
      "       counterexample found\n",
      "--------------------------------\n",
      "  I[f]= 1.5\n",
      "  I[g]= 1.25\n",
      "fhat: [ 0.125  0.625  0.375 -0.125  0.375 -0.125  0.125 -0.375  0.125  0.125\n",
      " -0.125 -0.125 -0.125 -0.125  0.125  0.125]\n",
      "T_rho_f_hat: [ 0.125       0.15625     0.09375    -0.0078125   0.09375    -0.0078125\n",
      "  0.0078125  -0.00585938  0.03125     0.0078125  -0.0078125  -0.00195312\n",
      " -0.0078125  -0.00195312  0.00195312  0.00048828]\n",
      "T_rho(f): [-0.25732422  0.05029297 -0.06689453  0.24267578 -0.06689453  0.24267578\n",
      "  0.17236328  0.43310547 -0.18408203  0.17236328 -0.02294922  0.31591797\n",
      " -0.02294922  0.31591797  0.19873047  0.47705078]\n",
      "ghat: [ 0.25  0.75  0.25 -0.25  0.25 -0.25  0.25 -0.25  0.    0.    0.    0.\n",
      "  0.    0.    0.    0.  ]\n",
      "f: [-1, -1, -1, 1, -1, 1, 1, 1, -1, 1, -1, 1, -1, 1, 1, 1]\n",
      "g [-1.  1. -1.  1. -1.  1.  1.  1. -1.  1. -1.  1. -1.  1.  1.  1.]\n"
     ]
    }
   ],
   "source": [
    "# f = (1,-1, 1, -1, -1, -1, 1, -1) + (1,-1, -1, -1, -1, -1, 1, -1) \n",
    "# f = tuple([int(sum(x)/np.sqrt(n)) for x in xvals])\n",
    "# f = (1,-1, -1, -1, -1, -1, 1, -1)\n",
    "f = []\n",
    "n = 4\n",
    "\n",
    "\n",
    "# counterexample to inf_i[f] \\geq inf_i[g]\n",
    "# generate a list of length=3 random vectors\n",
    "random_vectors = [np.random.randn(n) for _ in range(10)]\n",
    "# 1, 2.1, 2.2, -2\n",
    "random_vectors = [np.array([1, 2, 3, 4])]\n",
    "for vec in random_vectors:\n",
    "    print(\"vec:\", vec)\n",
    "    f = []\n",
    "    def ltf(x):\n",
    "        return int(np.sign(1 + np.dot(vec, x)))\n",
    "\n",
    "    for x in bool_list_pm(n):\n",
    "        f.append(ltf(x))\n",
    "\n",
    "    np.testing.assert_array_equal(abs(np.array(f)), np.ones(2**n))\n",
    "\n",
    "\n",
    "    print(guide(n))\n",
    "\n",
    "    print(\"f:\", f)\n",
    "    rho = .25\n",
    "    fhat = boolean.boolean_fourier_transform(f)\n",
    "\n",
    "    # defining g in terms of f, as sign(trho(f))\n",
    "    trhof_hat = boolean.noise_operator_on(fhat, rho, input_fourier=True, return_fourier=True)\n",
    "    trho_f = boolean.inverse_boolean_fourier_transform(trhof_hat)\n",
    "    g = np.sign(trho_f)\n",
    "    ghash = dict(zip(bool_list_pm(n), g))\n",
    "    def g_of_x(x):\n",
    "        return int(ghash[tuple(x)])\n",
    "\n",
    "    ghat = boolean.boolean_fourier_transform(g)\n",
    "    for i in range(n):\n",
    "        inf_i_f = boolean.inf_i(f, i)\n",
    "        inf_i_g = boolean.inf_i(g, i)\n",
    "        print(f\"Inf_{i}[f]:\", boolean.inf_i(f, i), f\"Inf_{i}[g]:\", boolean.inf_i(g, i))\n",
    "        abs_fhatS = abs(fhat[2**(n-i-1)])\n",
    "        abs_ghatS = abs(ghat[2**(n-i-1)])\n",
    "        print(\"|fhat(S)|=\", abs_fhatS, \"|ghat(S)|=\", abs_ghatS)\n",
    "        assert(abs_fhatS == inf_i_f)\n",
    "        assert(abs_ghatS == inf_i_g)\n",
    "        if inf_i_g > inf_i_f:\n",
    "            print(\"       counterexample found\")\n",
    "\n",
    "    print(\"--------------------------------\")\n",
    "    print(\"  I[f]=\", boolean.total_inf(f))\n",
    "    print(\"  I[g]=\", boolean.total_inf(g))\n",
    "\n",
    "    print(\"fhat:\", fhat)\n",
    "    print(\"T_rho_f_hat:\", trhof_hat)\n",
    "    print(\"T_rho(f):\", trho_f)\n",
    "    print(\"ghat:\", ghat)\n",
    "\n",
    "    print(\"f:\", f)\n",
    "    print(\"g\",g)\n",
    "\n",
    "# for i in range(n):\n",
    "#     print(\"i=\", i)\n",
    "#     print(\"            f(x)   f(x_i)   g(x)   g(x_i)\")\n",
    "#     for x in bool_list_pm(n):\n",
    "#         x_i = list(x)\n",
    "#         x_i[i] = - x_i[i]\n",
    "#         print(\"x=\", x, \"x_i=\", x_i, )\n",
    "#         print(\"f(x)=\", ltf(x), \"f(x_i)=\", ltf(x_i))\n",
    "#         print(\"g(x)=\", g_of_x(x), \"g(x_i)=\", g_of_x(x_i))\n",
    "#         # print(\"sens(f, x)=\", boolean.s_v1(ltf, x))\n",
    "#         # print(\"sens(g, x)=\", boolean.s_v1(g_of_x, x))\n",
    "\n",
    "#         # print(x_i, ltf(x),\"    \", ltf(x_i), \"    \", g_of_x(x), \"    \", g_of_x(x_i))\n",
    "#         print()\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([-1, -1, -1,  1,  1,  1, -1])"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "weights"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(-1, -1, -1, -1, -1, -1) -1 -1\n",
      "(-1, -1, -1, -1, -1, 1) -1 0\n",
      "(-1, -1, -1, -1, 1, -1) 1 0\n",
      "(-1, -1, -1, -1, 1, 1) -1 1\n",
      "(-1, -1, -1, 1, -1, -1) 1 0\n",
      "(-1, -1, -1, 1, -1, 1) -1 1\n",
      "(-1, -1, -1, 1, 1, -1) 1 1\n",
      "(-1, -1, -1, 1, 1, 1) 1 1\n",
      "(-1, -1, 1, -1, -1, -1) 1 -1\n",
      "(-1, -1, 1, -1, -1, 1) -1 -1\n",
      "(-1, -1, 1, -1, 1, -1) 1 -1\n",
      "(-1, -1, 1, -1, 1, 1) 1 0\n",
      "(-1, -1, 1, 1, -1, -1) 1 -1\n",
      "(-1, -1, 1, 1, -1, 1) 1 0\n",
      "(-1, -1, 1, 1, 1, -1) 1 0\n",
      "(-1, -1, 1, 1, 1, 1) 1 1\n",
      "(-1, 1, -1, -1, -1, -1) -1 -1\n",
      "(-1, 1, -1, -1, -1, 1) -1 -1\n",
      "(-1, 1, -1, -1, 1, -1) -1 -1\n",
      "(-1, 1, -1, -1, 1, 1) -1 0\n",
      "(-1, 1, -1, 1, -1, -1) -1 -1\n",
      "(-1, 1, -1, 1, -1, 1) -1 0\n",
      "(-1, 1, -1, 1, 1, -1) 1 0\n",
      "(-1, 1, -1, 1, 1, 1) -1 1\n",
      "(-1, 1, 1, -1, -1, -1) -1 -1\n",
      "(-1, 1, 1, -1, -1, 1) -1 -1\n",
      "(-1, 1, 1, -1, 1, -1) 1 -1\n",
      "(-1, 1, 1, -1, 1, 1) -1 -1\n",
      "(-1, 1, 1, 1, -1, -1) 1 -1\n",
      "(-1, 1, 1, 1, -1, 1) -1 -1\n",
      "(-1, 1, 1, 1, 1, -1) 1 -1\n",
      "(-1, 1, 1, 1, 1, 1) 1 0\n",
      "(1, -1, -1, -1, -1, -1) -1 -1\n",
      "(1, -1, -1, -1, -1, 1) -1 0\n",
      "(1, -1, -1, -1, 1, -1) -1 0\n",
      "(1, -1, -1, -1, 1, 1) -1 1\n",
      "(1, -1, -1, 1, -1, -1) -1 0\n",
      "(1, -1, -1, 1, -1, 1) -1 1\n",
      "(1, -1, -1, 1, 1, -1) 1 1\n",
      "(1, -1, -1, 1, 1, 1) -1 1\n",
      "(1, -1, 1, -1, -1, -1) -1 -1\n",
      "(1, -1, 1, -1, -1, 1) -1 -1\n",
      "(1, -1, 1, -1, 1, -1) 1 -1\n",
      "(1, -1, 1, -1, 1, 1) -1 0\n",
      "(1, -1, 1, 1, -1, -1) 1 -1\n",
      "(1, -1, 1, 1, -1, 1) -1 0\n",
      "(1, -1, 1, 1, 1, -1) 1 0\n",
      "(1, -1, 1, 1, 1, 1) 1 1\n",
      "(1, 1, -1, -1, -1, -1) -1 -1\n",
      "(1, 1, -1, -1, -1, 1) -1 -1\n",
      "(1, 1, -1, -1, 1, -1) -1 -1\n",
      "(1, 1, -1, -1, 1, 1) -1 0\n",
      "(1, 1, -1, 1, -1, -1) -1 -1\n",
      "(1, 1, -1, 1, -1, 1) -1 0\n",
      "(1, 1, -1, 1, 1, -1) -1 0\n",
      "(1, 1, -1, 1, 1, 1) -1 1\n",
      "(1, 1, 1, -1, -1, -1) -1 -1\n",
      "(1, 1, 1, -1, -1, 1) -1 -1\n",
      "(1, 1, 1, -1, 1, -1) -1 -1\n",
      "(1, 1, 1, -1, 1, 1) -1 -1\n",
      "(1, 1, 1, 1, -1, -1) -1 -1\n",
      "(1, 1, 1, 1, -1, 1) -1 -1\n",
      "(1, 1, 1, 1, 1, -1) 1 -1\n",
      "(1, 1, 1, 1, 1, 1) -1 0\n"
     ]
    }
   ],
   "source": [
    "for x in bool_list_pm(6):\n",
    "    print(x, np.sign(weights[0] + np.dot(weights[1:], x)), ltf(x))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "weights= [ 1.25808639 -0.66197075 -7.14924899 -2.11928252  6.55575182  3.80343931]\n",
      "Inf_0[f]: 0.0 Inf_0[g]: 0.0\n",
      "fhat(i)= 0.0 ghat(i)= 0.0 sign(w[i])= 1.0\n",
      "Inf_1[f]: 0.125 Inf_1[g]: 0.0\n",
      "fhat(i)= -0.125 ghat(i)= 0.0 sign(w[i])= -1.0\n",
      "Inf_2[f]: 0.625 Inf_2[g]: 0.0\n",
      "fhat(i)= -0.625 ghat(i)= 0.0 sign(w[i])= -1.0\n",
      "Inf_3[f]: 0.375 Inf_3[g]: 0.0\n",
      "fhat(i)= -0.375 ghat(i)= 0.0 sign(w[i])= -1.0\n",
      "Inf_4[f]: 0.375 Inf_4[g]: 0.0\n",
      "fhat(i)= 0.375 ghat(i)= 0.0 sign(w[i])= 1.0\n",
      "fhat_dot_w= 7.8041648391987675 ghat_dot_w= 0.0\n",
      "ghat[0]= 1.0 fhat[0]= 0.125\n",
      "\n",
      "weights= [-1.83026328 -0.46287507 -3.26323803  5.52582999  1.59170405  0.0332962 ]\n",
      "Inf_0[f]: 0.0 Inf_0[g]: 0.0\n",
      "fhat(i)= 0.0 ghat(i)= 0.0 sign(w[i])= -1.0\n",
      "Inf_1[f]: 0.0 Inf_1[g]: 0.0\n",
      "fhat(i)= 0.0 ghat(i)= 0.0 sign(w[i])= -1.0\n",
      "Inf_2[f]: 0.25 Inf_2[g]: 0.0\n",
      "fhat(i)= -0.25 ghat(i)= 0.0 sign(w[i])= -1.0\n",
      "Inf_3[f]: 0.75 Inf_3[g]: 0.0\n",
      "fhat(i)= 0.75 ghat(i)= 0.0 sign(w[i])= 1.0\n",
      "Inf_4[f]: 0.25 Inf_4[g]: 0.0\n",
      "fhat(i)= 0.25 ghat(i)= 0.0 sign(w[i])= 1.0\n",
      "fhat_dot_w= 5.358108015857096 ghat_dot_w= 0.0\n",
      "ghat[0]= -1.0 fhat[0]= -0.25\n",
      "\n",
      "weights= [ 3.92414815 -1.16477953 -2.73978719 -3.64569171 -5.7569147   3.35134002]\n",
      "Inf_0[f]: 0.0 Inf_0[g]: 0.0\n",
      "fhat(i)= 0.0 ghat(i)= 0.0 sign(w[i])= 1.0\n",
      "Inf_1[f]: 0.125 Inf_1[g]: 0.0\n",
      "fhat(i)= -0.125 ghat(i)= 0.0 sign(w[i])= -1.0\n",
      "Inf_2[f]: 0.125 Inf_2[g]: 0.0\n",
      "fhat(i)= -0.125 ghat(i)= 0.0 sign(w[i])= -1.0\n",
      "Inf_3[f]: 0.375 Inf_3[g]: 0.0\n",
      "fhat(i)= -0.375 ghat(i)= 0.0 sign(w[i])= -1.0\n",
      "Inf_4[f]: 0.625 Inf_4[g]: 0.0\n",
      "fhat(i)= -0.625 ghat(i)= 0.0 sign(w[i])= -1.0\n",
      "fhat_dot_w= 5.453276918402018 ghat_dot_w= 0.0\n",
      "ghat[0]= 1.0 fhat[0]= 0.375\n",
      "\n",
      "weights= [ 0.45623994  0.32132848  6.76652058 -2.16131411 -0.45326614  2.43786695]\n",
      "Inf_0[f]: 0.0 Inf_0[g]: 0.0\n",
      "fhat(i)= 0.0 ghat(i)= 0.0 sign(w[i])= 1.0\n",
      "Inf_1[f]: 0.0 Inf_1[g]: 0.0\n",
      "fhat(i)= 0.0 ghat(i)= 0.0 sign(w[i])= 1.0\n",
      "Inf_2[f]: 1.0 Inf_2[g]: 1.0\n",
      "fhat(i)= 1.0 ghat(i)= 1.0 sign(w[i])= 1.0\n",
      "Inf_3[f]: 0.0 Inf_3[g]: 0.0\n",
      "fhat(i)= 0.0 ghat(i)= 0.0 sign(w[i])= -1.0\n",
      "Inf_4[f]: 0.0 Inf_4[g]: 0.0\n",
      "fhat(i)= 0.0 ghat(i)= 0.0 sign(w[i])= -1.0\n",
      "fhat_dot_w= 6.766520580963953 ghat_dot_w= 6.766520580963953\n",
      "ghat[0]= 0.0 fhat[0]= 0.0\n",
      "\n",
      "weights= [-1.25904683 -7.02455406 -6.76609445 -6.11471003 -0.48517374 -4.4112728 ]\n",
      "Inf_0[f]: 0.0 Inf_0[g]: 0.0\n",
      "fhat(i)= 0.0 ghat(i)= 0.0 sign(w[i])= -1.0\n",
      "Inf_1[f]: 0.5 Inf_1[g]: 0.5\n",
      "fhat(i)= -0.5 ghat(i)= -0.5 sign(w[i])= -1.0\n",
      "Inf_2[f]: 0.5 Inf_2[g]: 0.5\n",
      "fhat(i)= -0.5 ghat(i)= -0.5 sign(w[i])= -1.0\n",
      "Inf_3[f]: 0.5 Inf_3[g]: 0.5\n",
      "fhat(i)= -0.5 ghat(i)= -0.5 sign(w[i])= -1.0\n",
      "Inf_4[f]: 0.0 Inf_4[g]: 0.0\n",
      "fhat(i)= 0.0 ghat(i)= 0.0 sign(w[i])= -1.0\n",
      "fhat_dot_w= 9.952679272157116 ghat_dot_w= 9.952679272157116\n",
      "ghat[0]= 0.0 fhat[0]= 0.0\n",
      "\n",
      "weights= [-3.97715733  2.81057112 -2.36465222  0.2519792  -5.4789742   1.16828845]\n",
      "Inf_0[f]: 0.0 Inf_0[g]: 0.0\n",
      "fhat(i)= 0.0 ghat(i)= 0.0 sign(w[i])= -1.0\n",
      "Inf_1[f]: 0.25 Inf_1[g]: 0.0\n",
      "fhat(i)= 0.25 ghat(i)= 0.0 sign(w[i])= 1.0\n",
      "Inf_2[f]: 0.25 Inf_2[g]: 0.0\n",
      "fhat(i)= -0.25 ghat(i)= 0.0 sign(w[i])= -1.0\n",
      "Inf_3[f]: 0.0 Inf_3[g]: 0.0\n",
      "fhat(i)= 0.0 ghat(i)= 0.0 sign(w[i])= 1.0\n",
      "Inf_4[f]: 0.75 Inf_4[g]: 0.0\n",
      "fhat(i)= -0.75 ghat(i)= 0.0 sign(w[i])= -1.0\n",
      "fhat_dot_w= 5.403036486058394 ghat_dot_w= 0.0\n",
      "ghat[0]= -1.0 fhat[0]= -0.25\n",
      "\n",
      "weights= [ 2.36783712 -0.56514645  2.91097987  1.6895033  -0.93238801  3.47508931]\n",
      "Inf_0[f]: 0.0 Inf_0[g]: 0.0\n",
      "fhat(i)= 0.0 ghat(i)= 0.0 sign(w[i])= 1.0\n",
      "Inf_1[f]: 0.125 Inf_1[g]: 0.0\n",
      "fhat(i)= -0.125 ghat(i)= 0.0 sign(w[i])= -1.0\n",
      "Inf_2[f]: 0.625 Inf_2[g]: 0.0\n",
      "fhat(i)= 0.625 ghat(i)= 0.0 sign(w[i])= 1.0\n",
      "Inf_3[f]: 0.375 Inf_3[g]: 0.0\n",
      "fhat(i)= 0.375 ghat(i)= 0.0 sign(w[i])= 1.0\n",
      "Inf_4[f]: 0.125 Inf_4[g]: 0.0\n",
      "fhat(i)= -0.125 ghat(i)= 0.0 sign(w[i])= -1.0\n",
      "fhat_dot_w= 2.6401179639138266 ghat_dot_w= 0.0\n",
      "ghat[0]= 1.0 fhat[0]= 0.375\n",
      "\n",
      "weights= [ 0.05800775  1.75124703 -1.29472886 -2.53330315  2.10857205  0.74840025]\n",
      "Inf_0[f]: 0.0 Inf_0[g]: 0.0\n",
      "fhat(i)= 0.0 ghat(i)= 0.0 sign(w[i])= 1.0\n",
      "Inf_1[f]: 0.375 Inf_1[g]: 0.0\n",
      "fhat(i)= 0.375 ghat(i)= 0.0 sign(w[i])= 1.0\n",
      "Inf_2[f]: 0.125 Inf_2[g]: 0.0\n",
      "fhat(i)= -0.125 ghat(i)= 0.0 sign(w[i])= -1.0\n",
      "Inf_3[f]: 0.625 Inf_3[g]: 0.0\n",
      "fhat(i)= -0.625 ghat(i)= 0.0 sign(w[i])= -1.0\n",
      "Inf_4[f]: 0.375 Inf_4[g]: 0.0\n",
      "fhat(i)= 0.375 ghat(i)= 0.0 sign(w[i])= 1.0\n",
      "fhat_dot_w= 3.1925877328945322 ghat_dot_w= 0.0\n",
      "ghat[0]= 1.0 fhat[0]= 0.125\n",
      "\n",
      "weights= [-5.20157941  2.77989705  2.77972239 -1.45262027 -5.10326094 -6.85025262]\n",
      "Inf_0[f]: 0.0 Inf_0[g]: 0.0\n",
      "fhat(i)= 0.0 ghat(i)= 0.0 sign(w[i])= -1.0\n",
      "Inf_1[f]: 0.25 Inf_1[g]: 0.0\n",
      "fhat(i)= 0.25 ghat(i)= 0.0 sign(w[i])= 1.0\n",
      "Inf_2[f]: 0.25 Inf_2[g]: 0.0\n",
      "fhat(i)= 0.25 ghat(i)= 0.0 sign(w[i])= 1.0\n",
      "Inf_3[f]: 0.25 Inf_3[g]: 0.0\n",
      "fhat(i)= -0.25 ghat(i)= 0.0 sign(w[i])= -1.0\n",
      "Inf_4[f]: 0.5 Inf_4[g]: 0.0\n",
      "fhat(i)= -0.5 ghat(i)= 0.0 sign(w[i])= -1.0\n",
      "fhat_dot_w= 4.3046903950047435 ghat_dot_w= 0.0\n",
      "ghat[0]= -1.0 fhat[0]= -0.5\n",
      "\n",
      "weights= [-3.50665432  4.39507731 -0.86633537 -1.480287    1.97742922 -0.87049183]\n",
      "Inf_0[f]: 0.0 Inf_0[g]: 0.0\n",
      "fhat(i)= 0.0 ghat(i)= 0.0 sign(w[i])= -1.0\n",
      "Inf_1[f]: 0.625 Inf_1[g]: 0.0\n",
      "fhat(i)= 0.625 ghat(i)= 0.0 sign(w[i])= 1.0\n",
      "Inf_2[f]: 0.125 Inf_2[g]: 0.0\n",
      "fhat(i)= -0.125 ghat(i)= 0.0 sign(w[i])= -1.0\n",
      "Inf_3[f]: 0.125 Inf_3[g]: 0.0\n",
      "fhat(i)= -0.125 ghat(i)= 0.0 sign(w[i])= -1.0\n",
      "Inf_4[f]: 0.375 Inf_4[g]: 0.0\n",
      "fhat(i)= 0.375 ghat(i)= 0.0 sign(w[i])= 1.0\n",
      "fhat_dot_w= 3.781787074355183 ghat_dot_w= 0.0\n",
      "ghat[0]= -1.0 fhat[0]= -0.375\n",
      "\n"
     ]
    }
   ],
   "source": [
    "# f = (1,-1, 1, -1, -1, -1, 1, -1) + (1,-1, -1, -1, -1, -1, 1, -1) \n",
    "# f = tuple([int(sum(x)/np.sqrt(n)) for x in xvals])\n",
    "# f = (1,-1, -1, -1, -1, -1, 1, -1)\n",
    "n = 5\n",
    "rho = .01\n",
    "\n",
    "# counterexample to inf_i[f] \\geq inf_i[g]\n",
    "# int(np.sign(1 + x[0] + 2.1*x[1] - 2.2*x[2] -4*x[3]))\n",
    "\n",
    "ntrials = 10\n",
    "for _ in range(ntrials):\n",
    "    f = []\n",
    "    var = 3\n",
    "    weights = np.random.randn(n + 1) * var\n",
    "    def ltf(x):\n",
    "        ss = weights[0]\n",
    "        for i in range(1, n):   \n",
    "            ss += weights[i] * x[i]\n",
    "        return int(np.sign(ss))\n",
    "    # weights = np.random.choice([-1, 1], size=n)\n",
    "    # def ltf(x):\n",
    "    #     return int(np.sign(np.dot(weights, x)))\n",
    "\n",
    "    print(\"weights=\", weights)\n",
    "    # define a \"random\" LTF\n",
    "\n",
    "    for x in bool_list_pm(n):\n",
    "        f_x = ltf(x)\n",
    "        assert f_x != 0 # enforce assumption!\n",
    "        f.append(ltf(x))\n",
    "\n",
    "\n",
    "    # n = int(np.log2(len(f)))\n",
    "    fhat = boolean.boolean_fourier_transform(f)\n",
    "\n",
    "    # defining g in terms of f, as sign(trho(f))\n",
    "    trhof_hat = boolean.noise_operator_on(fhat, rho, input_fourier=True, return_fourier=True)\n",
    "    trho_f = boolean.inverse_boolean_fourier_transform(trhof_hat)\n",
    "    g = np.sign(trho_f)\n",
    "    ghash = dict(zip(bool_list_pm(n), g))\n",
    "    def g_of_x(x):\n",
    "        return int(ghash[tuple(x)])\n",
    "    ghat = boolean.boolean_fourier_transform(g)\n",
    "    # print(weights)\n",
    "    fhat_dot_w = 0\n",
    "    ghat_dot_w = 0\n",
    "    for i in range(n):\n",
    "        inf_i_f = boolean.inf_i(f, i)\n",
    "        inf_i_g = boolean.inf_i(g, i)\n",
    "        fhati = fhat[2**(n-i-1)]\n",
    "        ghati = ghat[2**(n-i-1)]\n",
    "        abs_fhati = abs(fhati)\n",
    "        abs_ghati = abs(ghati)\n",
    "        sgn_wi = np.sign(weights[i])\n",
    "        print(f\"Inf_{i}[f]:\", boolean.inf_i(f, i), f\"Inf_{i}[g]:\", boolean.inf_i(g, i))\n",
    "        print(\"fhat(i)=\", fhati, \"ghat(i)=\", ghati, \"sign(w[i])=\", sgn_wi)\n",
    "        assert(sgn_wi * fhati == inf_i_f)\n",
    "        assert(sgn_wi * ghati == inf_i_g)\n",
    "        if abs(ghati)> 0 and abs(fhati) > 0:\n",
    "            assert(np.sign(ghati) == np.sign(fhati))\n",
    "        fhat_dot_w += weights[i] * fhati\n",
    "        ghat_dot_w += weights[i] * ghati\n",
    "    print(\"fhat_dot_w=\", fhat_dot_w, \"ghat_dot_w=\", ghat_dot_w)\n",
    "    print(\"ghat[0]=\", ghat[0], \"fhat[0]=\", fhat[0])\n",
    "    print()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "# print(\"fhat:\", fhat[S_by_weight])\n",
    "# print(\"ghat:\", ghat[S_by_weight])\n",
    "# print(\"ghat_guess:\", ghat_maybe[S_by_weight])\n",
    "# fhat_sq = np.multiply(fhat, fhat)\n",
    "# ghat_sq = np.multiply(ghat, ghat)\n",
    "# fhat_ghat = np.multiply(fhat, ghat)\n",
    "\n",
    "\n",
    "# sz_S = lambda x: x\n",
    "# rho_to_S = lambda x: rho ** x\n",
    "# print()\n",
    "# int('000')\n",
    "\n",
    "\n",
    "# fig, ax = plt.subplots(figsize=(8, 5))\n",
    "# ax.plot(fhat[S_by_weight], label=r\"$ \\hat{f}(S)$\", color='b', ls=':')\n",
    "# # ax.plot(-fhat_sq[S_by_weight],  color='b')\n",
    "# ax.plot(ghat[S_by_weight], label=r\"$ \\hat{g}(S)$\", color='r', ls='-.')\n",
    "# # ax.plot(-ghat_sq[S_by_weight],  color='r')\n",
    "# # ax.plot(ghat_maybe[S_by_weight], label=r\"$ \\hat{g}(S)$ guess\", color='purple', ls='--')\n",
    "# ax.legend() \n",
    "# ax.set_xticks(np.arange(2**n))\n",
    "# ax.set_xticklabels(np.array(guide(n))[S_by_weight], rotation=45)\n",
    "\n",
    "# fig, ax = plt.subplots(figsize=(8, 5))\n",
    "# ax.plot(fhat_sq[S_by_weight], label=r\"$ \\hat{f}(S)^2$\", color='b', ls=':')\n",
    "# # ax.plot(-fhat_sq[S_by_weight],  color='b')\n",
    "# ax.plot(ghat_sq[S_by_weight], label=r\"$ \\hat{g}(S)^2$\", color='r', ls='-.')\n",
    "# # ax.plot(-ghat_sq[S_by_weight],  color='r')\n",
    "# ax.plot(fhat_ghat[S_by_weight], label=r\"$ \\hat{f}(S)\\hat{g}(S)$\", color='purple', ls='--')\n",
    "# ax.legend()\n",
    "# ax.set_xticks(np.arange(2**n))\n",
    "# ax.set_xticklabels(np.array(guide(n))[S_by_weight], rotation=45)\n",
    "# fig, ax = plt.subplots(figsize=(8, 5))\n",
    "# ax.plot(weight_by_lambda_S(fhat_sq, sz_S)[S_by_weight], label=r\"$ |S|\\hat{f}(S)^2$\", color='b', ls=':')\n",
    "# ax.plot(weight_by_lambda_S(ghat_sq, sz_S)[S_by_weight], label=r\"$ |S|\\hat{g}(S)^2$\", color='r', ls='-.')\n",
    "# ax.plot(-weight_by_lambda_S(ghat_sq, sz_S)[S_by_weight],  color='r')\n",
    "# ax.plot(weight_by_lambda_S(fhat_ghat, sz_S)[S_by_weight], label=r\"$ |S|\\hat{f}(S)\\hat{g}(S)$\", color='purple', ls='--')\n",
    "# ax.legend()\n",
    "# ax.set_xticks(np.arange(2**n))\n",
    "# ax.set_xticklabels(np.array(guide(n))[S_by_weight], rotation=45)\n",
    "# print(\"I[f]=\", sum(weight_by_lambda_S(fhat_sq, sz_S)))\n",
    "# print(\"I[g]=\", sum(weight_by_lambda_S(ghat_sq, sz_S)))\n",
    "# print(\"sum (fhat(S)ghat(S)|S|)=\", sum(weight_by_lambda_S(fhat_ghat, sz_S)))\n",
    "# print(\"abs(Ifg)=\", sum(abs(weight_by_lambda_S(fhat_ghat, sz_S))))\n",
    "\n",
    "# plt.plot(weight_by_lambda_S(fhat_sq, rho_to_S), label=\"\")\n",
    "# plt.plot(weight_by_lambda_S(fhat_ghat, rho_to_S), label=\"\")\n",
    "\n",
    "print()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "np.float64(0.5099019513592785)"
      ]
     },
     "execution_count": 49,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.sqrt(.26)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "fhat norm: 1.004987562112089\n",
      "hhat norm: 0.8717797887081347\n",
      "f: [-1.  1. -1.  1.  1.  1.  1.  1.]\n",
      "h: [-1. -1. -1.  1. -1.  1.  1.  1.]\n",
      "i: 0\n",
      "Inf_i[f]: 0.5\n",
      "Inf_i[h]: 0.5\n",
      "Inf_i[g]: 0.5\n",
      "\n",
      "i: 1\n",
      "Inf_i[f]: 0.0\n",
      "Inf_i[h]: 0.5\n",
      "Inf_i[g]: 0.5\n",
      "\n",
      "i: 2\n",
      "Inf_i[f]: 0.5\n",
      "Inf_i[h]: 0.5\n",
      "Inf_i[g]: 0.5\n",
      "\n"
     ]
    }
   ],
   "source": [
    "fhat = (0.1, 0.5, 0.5, 0, 0.5, -0.5, 0, 0)\n",
    "hhat = (0.1, 0.5, 0.5, 0, 0.5, 0, 0, 0)\n",
    "# hhat =  boolean.noise_operator_on(fhat, 1, input_fourier=True, return_fourier=True)\n",
    "print(\"fhat norm:\", np.linalg.norm(fhat))\n",
    "print(\"hhat norm:\", np.linalg.norm(hhat))\n",
    "\n",
    "f = np.sign(boolean.inverse_boolean_fourier_transform(fhat))\n",
    "h = np.sign(boolean.inverse_boolean_fourier_transform(hhat))\n",
    "g = np.sign(h)\n",
    "print(\"f:\", f)\n",
    "print(\"h:\", h)\n",
    "\n",
    "for i in range(3):\n",
    "    print(f\"i: {i}\")\n",
    "    print(f\"Inf_i[f]: {boolean.inf_i(f, i)}\")\n",
    "    print(f\"Inf_i[h]: {boolean.inf_i(h, i)}\")\n",
    "    print(f\"Inf_i[g]: {boolean.inf_i(g, i)}\")\n",
    "    print()\n",
    "\n",
    "# print(\"fhat:\", fhat)\n",
    "# print(\"hhat:\", hhat)\n",
    "# trhof_hat = boolean.noise_operator_on(fhat, rho, input_fourier=True, return_fourier=True)\n",
    "# trho_f = boolean.inverse_boolean_fourier_transform(trhof_hat)\n",
    "\n",
    "# print(\"T_rho_f_hat:\", trhof_hat)\n",
    "# print(\"T_rho(f):\", trho_f)\n",
    "\n",
    "# g_maybe = np.sign(trho_f)\n",
    "# print(\"=g?\",g_maybe)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[1. 1. 1. 1. 1. 1. 1. 1.]\n",
      "[-1.  1. -1.  1. -1.  1. -1.  1.]\n",
      "[-1. -1.  1.  1. -1. -1.  1.  1.]\n",
      "[ 1. -1. -1.  1.  1. -1. -1.  1.]\n",
      "[-1. -1. -1. -1.  1.  1.  1.  1.]\n",
      "[ 1. -1.  1. -1. -1.  1. -1.  1.]\n",
      "[ 1.  1. -1. -1. -1. -1.  1.  1.]\n",
      "[-1.  1.  1. -1.  1. -1. -1.  1.]\n"
     ]
    }
   ],
   "source": [
    "for s, s_bin in enumerate(itertools.product([0, 1], repeat=3)):\n",
    "    print(boolean.chi(s_bin, 3))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def convert_np_tuple(np_tuple):\n",
    "    return tuple(int(x) for x in np_tuple)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "def majority_signature(n):\n",
    "    assert n % 2 == 1\n",
    "    halflength = n // 2\n",
    "\n",
    "    return [0] * (halflength +1) + [1] * (halflength +1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[0, 0, 0, 0, 1, 1, 1, 1]"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "majority_signature(7)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "signature= [0, 0, 1, 1]\n",
      "noisy lookup table\n",
      "[[1. 1. 1. 0. 1. 0. 0. 0.]\n",
      " [0. 0. 0. 1. 0. 1. 1. 1.]]\n",
      "true lookup table\n",
      "[[1. 1. 1. 0. 1. 0. 0. 0.]\n",
      " [0. 0. 0. 1. 0. 1. 1. 1.]]\n",
      "\n",
      "signature= [0, 0, 0, 1, 1, 1]\n",
      "noisy lookup table\n",
      "[[1. 1. 1. 1. 1. 1. 1. 0. 1. 1. 1. 0. 1. 0. 0. 0. 1. 1. 1. 0. 1. 0. 0. 0.\n",
      "  1. 0. 0. 0. 0. 0. 0. 0.]\n",
      " [0. 0. 0. 0. 0. 0. 0. 1. 0. 0. 0. 1. 0. 1. 1. 1. 0. 0. 0. 1. 0. 1. 1. 1.\n",
      "  0. 1. 1. 1. 1. 1. 1. 1.]]\n",
      "true lookup table\n",
      "[[1. 1. 1. 1. 1. 1. 1. 0. 1. 1. 1. 0. 1. 0. 0. 0. 1. 1. 1. 0. 1. 0. 0. 0.\n",
      "  1. 0. 0. 0. 0. 0. 0. 0.]\n",
      " [0. 0. 0. 0. 0. 0. 0. 1. 0. 0. 0. 1. 0. 1. 1. 1. 0. 0. 0. 1. 0. 1. 1. 1.\n",
      "  0. 1. 1. 1. 1. 1. 1. 1.]]\n",
      "\n",
      "signature= [0, 0, 0, 0, 1, 1, 1, 1]\n",
      "noisy lookup table\n",
      "[[1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 0. 1. 1. 1. 1. 1. 1. 1. 0.\n",
      "  1. 1. 1. 0. 1. 0. 0. 0. 1. 1. 1. 1. 1. 1. 1. 0. 1. 1. 1. 0. 1. 0. 0. 0.\n",
      "  1. 1. 1. 0. 1. 0. 0. 0. 1. 0. 0. 0. 0. 0. 0. 0. 1. 1. 1. 1. 1. 1. 1. 0.\n",
      "  1. 1. 1. 0. 1. 0. 0. 0. 1. 1. 1. 0. 1. 0. 0. 0. 1. 0. 0. 0. 0. 0. 0. 0.\n",
      "  1. 1. 1. 0. 1. 0. 0. 0. 1. 0. 0. 0. 0. 0. 0. 0. 1. 0. 0. 0. 0. 0. 0. 0.\n",
      "  0. 0. 0. 0. 0. 0. 0. 0.]\n",
      " [0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 1. 0. 0. 0. 0. 0. 0. 0. 1.\n",
      "  0. 0. 0. 1. 0. 1. 1. 1. 0. 0. 0. 0. 0. 0. 0. 1. 0. 0. 0. 1. 0. 1. 1. 1.\n",
      "  0. 0. 0. 1. 0. 1. 1. 1. 0. 1. 1. 1. 1. 1. 1. 1. 0. 0. 0. 0. 0. 0. 0. 1.\n",
      "  0. 0. 0. 1. 0. 1. 1. 1. 0. 0. 0. 1. 0. 1. 1. 1. 0. 1. 1. 1. 1. 1. 1. 1.\n",
      "  0. 0. 0. 1. 0. 1. 1. 1. 0. 1. 1. 1. 1. 1. 1. 1. 0. 1. 1. 1. 1. 1. 1. 1.\n",
      "  1. 1. 1. 1. 1. 1. 1. 1.]]\n",
      "true lookup table\n",
      "[[1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 0. 1. 1. 1. 1. 1. 1. 1. 0.\n",
      "  1. 1. 1. 0. 1. 0. 0. 0. 1. 1. 1. 1. 1. 1. 1. 0. 1. 1. 1. 0. 1. 0. 0. 0.\n",
      "  1. 1. 1. 0. 1. 0. 0. 0. 1. 0. 0. 0. 0. 0. 0. 0. 1. 1. 1. 1. 1. 1. 1. 0.\n",
      "  1. 1. 1. 0. 1. 0. 0. 0. 1. 1. 1. 0. 1. 0. 0. 0. 1. 0. 0. 0. 0. 0. 0. 0.\n",
      "  1. 1. 1. 0. 1. 0. 0. 0. 1. 0. 0. 0. 0. 0. 0. 0. 1. 0. 0. 0. 0. 0. 0. 0.\n",
      "  0. 0. 0. 0. 0. 0. 0. 0.]\n",
      " [0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 1. 0. 0. 0. 0. 0. 0. 0. 1.\n",
      "  0. 0. 0. 1. 0. 1. 1. 1. 0. 0. 0. 0. 0. 0. 0. 1. 0. 0. 0. 1. 0. 1. 1. 1.\n",
      "  0. 0. 0. 1. 0. 1. 1. 1. 0. 1. 1. 1. 1. 1. 1. 1. 0. 0. 0. 0. 0. 0. 0. 1.\n",
      "  0. 0. 0. 1. 0. 1. 1. 1. 0. 0. 0. 1. 0. 1. 1. 1. 0. 1. 1. 1. 1. 1. 1. 1.\n",
      "  0. 0. 0. 1. 0. 1. 1. 1. 0. 1. 1. 1. 1. 1. 1. 1. 0. 1. 1. 1. 1. 1. 1. 1.\n",
      "  1. 1. 1. 1. 1. 1. 1. 1.]]\n",
      "\n",
      "signature= [0, 0, 0, 0, 0, 1, 1, 1, 1, 1]\n",
      "noisy lookup table\n",
      "[[1. 1. 1. ... 0. 0. 0.]\n",
      " [0. 0. 0. ... 1. 1. 1.]]\n",
      "true lookup table\n",
      "[[1. 1. 1. ... 0. 0. 0.]\n",
      " [0. 0. 0. ... 1. 1. 1.]]\n",
      "\n"
     ]
    }
   ],
   "source": [
    "# n = 3 # total number of bits\n",
    "p = 0.49# probability of each bit of X flipping, this DOESN'T flip Y ever.\n",
    "# signature = [0, 1, 0, 1]\n",
    "\n",
    "\n",
    "# signatures = [itertools.product([0, 1], repeat=n+1)]\n",
    "# signatures = [signature]\n",
    "signatures = [majority_signature(n) for n in [3, 5, 7, 9]]\n",
    "for signature in signatures:\n",
    "    n = len(signature) - 1\n",
    "    X_arr = np.array(list(itertools.product([0, 1], repeat=n)))\n",
    "    \n",
    "    print(\"signature=\", signature)\n",
    "    hash = dict(zip(range(n+1), signature))\n",
    "    func = lambda b: hash[sum(b)]\n",
    "\n",
    "    f_accs = []\n",
    "    fn_accs = []\n",
    "    # noisy_lookup[row,col] is the JOINT probability Pr(f(z)=row| x=col)\n",
    "    noisy_lookup = np.zeros((2, 2**n))\n",
    "    true_lookup = np.zeros((2, 2**n))\n",
    "    # simulate a noisy dataset essentially\n",
    "    for i, x in enumerate(X_arr):\n",
    "        func_value = func(x) # compute y=f(x)\n",
    "        # true lookup is an array with 2 rows; there is a p_x at [row, column] if \n",
    "        # f[column] = row]. so, true_lookup[i, j] = pr(f(x) = i| x=j)\n",
    "        true_lookup[func(x), i] = 1\n",
    "        # iterate over all of the z values that contribute to \n",
    "        for e in product([0, 1], repeat=n):\n",
    "            z = np.array(x) ^ np.array(e)\n",
    "            p_x_given_z = p ** sum(e) * (1-p)**(n - sum(e))\n",
    "            # increment noisy_lookup at the binary index of z\n",
    "            # noisy_lookup[i, j] = pr(f(z) = i,  x=j) \n",
    "            noisy_lookup[func_value, int(''.join(map(str, z)), 2)] += p_x_given_z \n",
    "\n",
    "    # # round up to get argmax \n",
    "    noisy_mle = np.round(noisy_lookup)  \n",
    "    print(\"noisy lookup table\")\n",
    "    print(noisy_mle)\n",
    "    print(\"true lookup table\")\n",
    "    print(true_lookup)\n",
    "    assert(np.all(noisy_mle == true_lookup))\n",
    "\n",
    "    # print(noisy_mle)\n",
    "    print()\n",
    "\n",
    "    # # the function is balanced if the sums of the two rows of true_lookup are equal\n",
    "    # # GOAL: f should not be too imbalanced <=> `imbal` should be close to 0\n",
    "    # imbal = abs(true_lookup[0,:].sum() - true_lookup[1,:].sum())  / 2 ** n\n",
    "\n",
    "    # # if not balanced:\n",
    "    # #     continue\n",
    "    # out = np.multiply(noisy_mle, true_lookup) / 2 ** n # \"inner product\" of the functions\n",
    "    # diff = out.sum()\n",
    "\n",
    "\n",
    "    # fnstar_dct = {}\n",
    "    # for i, x in enumerate(X_arr):\n",
    "    #     fnstar_dct[tuple(x)] = np.argmax(noisy_lookup[:, i])\n",
    "    # def fnstar(x):\n",
    "    #     return fnstar_dct[tuple(x)]\n",
    "\n",
    "    # sensitivity_f = boolean.average_sensitivity(func, X_arr)\n",
    "    # sensitivity_fnstar = boolean.average_sensitivity(fnstar, X_arr)\n",
    "    # sensitivity_diff = sensitivity_f - sensitivity_fnstar\n",
    "    # # accuracies on dataset\n",
    "    # p_zy = boolean.generate_noisy_distr(n, p, func)\n",
    "    # noisy_f_acc = boolean.compute_acc_noisytest(p_zy, func, n) # accuracy of f on noisy data\n",
    "    # noiseless_fnstar_acc = boolean.compute_acc_test(fnstar, func, n) # accuracy of fN* on noiseless data\n",
    "    # noisy_fnstar_acc = boolean.compute_acc_noisytest(p_zy, fnstar, n) # accuracy of fN* MLE on noisy data\n",
    "\n",
    "    # acc_diff = noisy_fnstar_acc - noisy_f_acc\n",
    "    # f_accs.append(noisy_f_acc)\n",
    "    # fn_accs.append(noisy_fnstar_acc)\n",
    "\n",
    "    # print(\"\\t noisy fN* acc=\", fn_accs)\n",
    "    # print(\"\\t noisy fN* sensitivity=\", sensitivity_fnstar)\n",
    "\n",
    "    # print(\"\\t noisy f acc=\", f_accs)\n",
    "    # print(\"\\t noisy f sensitivity=\", sensitivity_f)\n",
    "\n",
    "    # print((fn_accs[0], sensitivity_fnstar), (f_accs[0], sensitivity_f))\n",
    "    # print()b\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Looking for $\\text{Pr}_{X|Z=z}(f(X) = f(z))$\n",
    "\n",
    "This is to test our theory work on the majority function being optimal for noisy prediction. We compute (numerically) noisy majority performance, and compare it to an analytical formula."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "\n",
    "# signatures = [itertools.product([0, 1], repeat=n+1)]\n",
    "# signatures = [signature]\n",
    "pvals = np.linspace(0.01, 0.5, 30)\n",
    "signatures = [majority_signature(n) for n in [7]]\n",
    "all_given_z = np.zeros((len(pvals), 2 ** 7))\n",
    "for kk, p in enumerate(pvals):\n",
    "    for signature in signatures:\n",
    "        n = len(signature) - 1\n",
    "        X_arr = np.array(list(itertools.product([0, 1], repeat=n)))\n",
    "        hash = dict(zip(range(n+1), signature))\n",
    "        func = lambda b: hash[sum(b)]\n",
    "\n",
    "        f_accs = []\n",
    "        fn_accs = []\n",
    "        # noisy_lookup[row,col] is the JOINT probability Pr(f(z)=row| x=col)\n",
    "        noisy_lookup = np.zeros((2, 2**n))\n",
    "        true_lookup = np.zeros((2, 2**n))\n",
    "\n",
    "        given_z = np.zeros(2**n)\n",
    "        # simulate a noisy dataset essentially\n",
    "        for i, x in enumerate(X_arr):\n",
    "            func_value = func(x) # compute y=f(x)\n",
    "            # true lookup is an array with 2 rows; there is a p_x at [row, column] if \n",
    "            # f[column] = row]. so, true_lookup[i, j] = pr(f(x) = i| x=j)\n",
    "            true_lookup[func_value, i] = 1\n",
    "            # iterate over all of the z values that contribute to \n",
    "            for e in product([0, 1], repeat=n):\n",
    "                z = np.array(x) ^ np.array(e)\n",
    "                p_x_given_z = p ** sum(e) * (1-p)**(n - sum(e))\n",
    "                # increment noisy_lookup at the binary index of z\n",
    "                # noisy_lookup[i, j] = pr(f(z) = i,  x=j) \n",
    "                z_idx = int(''.join(map(str, z)), 2)\n",
    "                noisy_lookup[func_value, z_idx] += p_x_given_z \n",
    "\n",
    "                f_z = func(z)\n",
    "                if f_z == func_value:\n",
    "                    given_z[z_idx] += p_x_given_z\n",
    "        all_given_z[kk] = given_z\n",
    "\n",
    "\n",
    "        # # # round up to get argmax \n",
    "        # noisy_mle = np.round(noisy_lookup)  \n",
    "        # print(\"noisy lookup table\")\n",
    "        # print(noisy_mle)\n",
    "        # print(\"true lookup table\")\n",
    "        # print(true_lookup)\n",
    "        # assert(np.all(noisy_mle == true_lookup))\n",
    "\n",
    "        # # print(noisy_mle)\n",
    "        # print()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "metadata": {},
   "outputs": [],
   "source": [
    "from math import comb\n",
    "def maj_ana(n, wt_z, p):\n",
    "    \"\"\"Compute Pr_{X|Z=z}(maj(X)=maj(z)) given wt(z).\"\"\"\n",
    "    out = 0\n",
    "    for w1 in range(0, wt_z + 1):\n",
    "        pr1 = comb(wt_z, w1)\n",
    "        for w0 in range(0, n//2 -wt_z + w1 + 1):\n",
    "            pr2 = comb(n - wt_z, w0)\n",
    "            err_wt = w0 + w1\n",
    "            err_prob = p**(err_wt) * (1-p) **(n - err_wt)\n",
    "            out += pr1 * pr2 * err_prob\n",
    "    return out"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for i in range(2 ** 7):\n",
    "    plt.plot(pvals, all_given_z[:,i])\n",
    "\n",
    "for w in [0, 1, 2, 3]:\n",
    "    y = [maj_ana(7, w, p) for p in pvals]\n",
    "    plt.plot(pvals, y, ls=':', c='k')\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "This is some work checking theory for PARITY, i.e. showing that even bitflips are marginally more likely than odd ones."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "metadata": {},
   "outputs": [],
   "source": [
    "def err_prob(n, wt_error, p):\n",
    "    return p ** wt_error * (1-p)**(n - wt_error)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAi4AAAGdCAYAAAA1/PiZAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjAsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvlHJYcgAAAAlwSFlzAAAPYQAAD2EBqD+naQAAKcJJREFUeJzt3QmYVNWZxvG3FxZRaFmUHQmiYqMsSsOgMYJiiBrcxsFsiOiQjGmdJGSSYEwkRqNGjZJozzCDQVySSIwGExdEUWNiUJAlok1UFBRFQCTpZm2ku+b57rHoptm6qqvuqXvr/3uek3uruug6XDtdL989S0EikUgIAAAgAgp9dwAAAKCpCC4AACAyCC4AACAyCC4AACAyCC4AACAyCC4AACAyCC4AACAyCC4AACAyihUzdXV1WrNmjdq2bauCggLf3QEAAE1g6+Fu2rRJ3bp1U2FhYf4EFwstPXv29N0NAACQhtWrV6tHjx75E1ys0pL8i7dr1853dwAAQBNUV1cHhYfk53jeBJfk7SELLQQXAACi5UDDPBicCwAAIoPgAgAAIoPgAgAAIoPgAgAAIoPgAgAAIoPgAgAAIoPgAgAAIiMng8ujjz6qY445RkcddZTuuusu390BAAA5IucWoNu5c6cmTZqkZ599ViUlJTrxxBN1/vnnq2PHjr67BgAAPMu5isuCBQvUv39/de/eXYcccojOPPNMzZ0713e3AABAHIPL888/rzFjxgS7O9qyvbNnz97jNRUVFerdu7dat26tYcOGBWGl4SaJFlqS7Pz999/PdDcBAEAEZTy4bNmyRQMHDgzCyd7MmjUruBU0ZcoULV68OHjt6NGjtX79+kx3BQAAxEzGg4vd2rn++uuDcSl7c9ttt2nixImaMGGCSktLNW3aNLVp00YzZswIvm6VmoYVFju35/alpqYm2FGyYcuGJUukz39eWrEiK98eAADk2hiXHTt2aNGiRRo1alR9BwoLg8fz588PHg8dOlSvvvpqEFg2b96sJ554IqjI7MuNN94YDOJNNtsSOxu+9S3pscek/v2la66Rtm3LytsAAIBcCS4bNmxQbW2tOnfuvNvz9njt2rXBeXFxsX72s59p5MiRGjRokL797W/vd0bRVVddpaqqql1t9erVWen7//2fdMYZFr6k666TSkulP/4xK28FAACiMh3anHPOOUFrilatWgUt244+WnrySemhh1z1ZdUq66e7fXT77VLfvlnvAgAAeS/UikunTp1UVFSkdevW7fa8Pe7SpYtyXUGBdOGF0vLl0ne/a9UhWyzP3T6aPFnatMl3DwEAiLdQg0vLli2DBeXmzZu367m6urrg8fDhwxUVhxwi/fSn0iuvSJ/9rLt9ZI+POUa67z77O/nuIQAA8ZTx4GIDapcuXRo0s3LlyuD83XffDR7bVOjp06frnnvu0fLly3X55ZcHU6htllHUHHusNGeO9Mgj0pFHSh98IF18sXTSSdJf/+q7dwAAxE9BIpFIZPIbPvfcc8HA2sbGjx+vmTNnBud33nmnbrnllmBArg3A/cUvfhEsRJcJNh3aZhfZQN127dopLDU1bqzL9dfbWjbuubFjXSWmd+/QugEAQCQ19fM748HFF1vwzprNWnrjjTdCDy5JNjnqhz+UfvlLya6sjRv+xjds9pN06KGhdwcAgEjIu+Diu+LS2N/+ZrfFpGeecY87dJB+8APp6193YQYAAKT++Z1zmyzGxcCB0tNPu7VebM2XjRtdkOnXT/rVrxjACwBAOgguWZ4+beu8WPXlrrtsOwO3/stXviINHuymUser3gUAQHYRXEJg671cdpn05pvST34iWQXMplKPGSOdfLINaPbdQwAAooHgEqI2baTvf196+223gN1BB0m2RZNNwrLtBD7ZrgkAAOwDwcUD23rJpknbTtM2WLdFCzcextZ/+dznpBdf9N1DAAByE8HFIxvzUlEhvf66u5VUVOT2Q7JFhM88kwoMAACxDS62hktpaanKysoUNZ/6lBu8+8Yb0qWXugBjK/JaBea00yTbIYFBvAAAsI5LTnrrLemGG6R775V27nTP2cLCV18tnX22VBibuAkAgMM6LhFm+x7ZyrsWYK64QmrdWnrpJemcc6QBAyTbOcE2dgQAIN8QXHJYr17SHXfYRpVuFlLbttJrr0m2H2WfPtItt0hVVb57CQBAeAguEdCli5uFtHq1O3btKr3/vgszPXtK3/ymm2INAEDcEVwipKTEhRWrwNitpGOPlTZtkn7+c6lvX+n886U//YmBvACA+CK4RJBt0mizj1591c0+srVfLKzMni2NGOH2SZo2Tdq82XdPAQDILIJLhNnsotGjpSeekCorpf/4D7c677Jl0uWXu3VirrxSWr7cd08BAMgMgktM2G2j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vf4Ze77h683o0aP3+Xqkf63h5zpv3bpVH3/8sTp06JDFnkZfc6+1/eNx3rx5ev311/WZz3wmy73Nv+v84x//WIcffrguu+yykHqan9d58+bNOuKII4LNF88999zgFn825X1w2bBhg2pra9W5c+fdnrfHa9eu3eufsedTeT3Sv9bwc52/973vBTu0Ng7oyMy1rqqq0iGHHKKWLVvq7LPP1h133KEzzjgjhB7nz3X+y1/+ol/+8pfB+C1k7zofc8wxmjFjhh555BHdf//9qqur00knnaT33ntP2RK73aEBNM9NN90UDGZ87rnnsj/ILk+1bdtWS5cuDf6lahWXSZMmqU+fPhoxYoTvrsXCpk2bNG7cuCC0dOrUyXd3Ym348OFBS7LQcuyxx+p///d/dd1112XlPfM+uNgPdVFRkdatW7fb8/a4S5cue/0z9nwqr0f61xrhXudbb701CC5PP/20BgwYkOWe5u+1tvJ73759g3ObVbR8+XLdeOONBJcMXee33npLq1at0pgxY3Y9Z5UAU1xcHNyaO/LII0Poef79jm7RooUGDx6sFStWZKmX3CoKSrUnnnhi8K+ehj/g9rhhimzInm/4evPUU0/t8/VI/1ojvOt88803B/9CmjNnTjBdF+H9TNufqampyVIv8+8621IVy5YtC6payXbOOedo5MiRwbmNxUB2fp7tVpNd+65duyprQh0KnMPTv1q1apWYOXNmMEXxq1/9ajD9Kzmla9y4cYnJkyfvNh26uLg4ceuttwZTR6dMmcJ06Cxd65qammCKrrWuXbsGU6Pt/M033/T4t4jfdb7pppuCKZC/+93vdpvWuGnTJo9/i3he6xtuuCExd+7cxFtvvRW83n6P2O+T6dOne/xbxO86N8asouxc52uvvTbx5JNPBj/PixYtSnzhC19ItG7dOphKnS0El0/ccccdiV69egW/vG062Isvvrjra6eeemrwQ9/Qb3/728TRRx8dvL5///6Jxx57zEOv43+tbQ0Gy9eNm70OmbvONtV8b9fZQjkye62vvvrqRN++fYNf7u3bt08MHz48+LBA5n9PN0Rwyc51/uY3v7nrtZ07d06cddZZicWLFyeyqcD+J3v1HAAAgMzJ+zEuAAAgOgguAAAgMgguAAAgMgguAAAgMgguAAAgMgguAAAgMgguAAAgMgguAAAgMgguAAAgMgguAAAgMgguAAAgMgguAABAUfH/rsLnIu/tB4oAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "flip_probs = []\n",
    "noflip_probs = []   \n",
    "pvals = np.linspace(0.001, 0.4999, 100)\n",
    "n = 8\n",
    "for p in pvals:\n",
    "    p_noflip = 0\n",
    "    for k in range(0, n+1, 2): # even flip ratees\n",
    "        p_noflip += (1-p)**(n-k) * p**k * comb(n, k)\n",
    "    assert np.isclose(p_noflip, 0.5 + 0.5 * (1-2*p)**n)\n",
    "    p_flip = 0\n",
    "    for k in range(1, n+1, 2): # odd flip rates\n",
    "        p_flip += (1-p)**(n-k) * p**k * comb(n, k)\n",
    "    flip_probs.append(p_flip)\n",
    "    noflip_probs.append(p_noflip)\n",
    "plt.plot(pvals, noflip_probs, c='blue')\n",
    "plt.plot(pvals, flip_probs, c='red')\n",
    "plt.semilogy()\n",
    "plt.show()\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from math import comb\n",
    "flip_probs = []\n",
    "noflip_probs = []   \n",
    "pvals = np.linspace(0.001, 0.4999, 100)\n",
    "n = 3\n",
    "p_noflip_0_arr = []\n",
    "p_noflip_2_arr = []\n",
    "p_flip_1_arr = []\n",
    "p_flip_3_arr = []\n",
    "for p in pvals:\n",
    "    p_noflip_0 = (1-p)**(n) # probability of no flip\n",
    "    p_noflip_2 = 3 * (1-p)**(n-2) * p**2 # probability of 2 flips\n",
    "    p_flip_1 = 3 * (1-p)**(n-1) * p # probability of 1 flip\n",
    "    p_flip_3 = p**3 # probability of 3 flips\n",
    "    \n",
    "    p_noflip_0_arr.append(p_noflip_0)\n",
    "    p_noflip_2_arr.append(p_noflip_2 + p_noflip_0)\n",
    "    p_flip_1_arr.append(p_flip_1)\n",
    "    p_flip_3_arr.append(p_flip_3 + p_flip_1)\n",
    "\n",
    "\n",
    "plt.plot(pvals, p_noflip_0_arr, c='blue', label='no flips at all')\n",
    "plt.plot(pvals, p_noflip_2_arr, c='green', label='even flips')\n",
    "plt.plot(pvals, p_flip_1_arr, c='red', label='exactly 1 flip')\n",
    "plt.plot(pvals, p_flip_3_arr, c='orange', label='odd flips')\n",
    "\n",
    "# plt.semilogy()\n",
    "plt.legend()\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Searching for counterexamples\n",
    "\n",
    "Instead of defining boolean functions as $f:\\{0,1\\}^n \\rightarrow \\{0,1\\}$, we define $f$ such that \n",
    "$$\n",
    "f(x) = g(\\text{wt}(x))\n",
    "$$\n",
    "what this does is, there are only $2^{n+1}$ possible functions $g$, instead of $2^{2^n}$ possible functions $f$. For example, if $n=3$, then a possible $g$ is \n",
    "\\begin{equation}\n",
    "     \\text{wt}(x) \\rightarrow \\begin{cases}\n",
    "        0 \\rightarrow 0 \\\\\n",
    "        1 \\rightarrow 1 \\\\\n",
    "        2 \\rightarrow 0 \\\\\n",
    "        3 \\rightarrow 1\n",
    "    \\end{cases}\n",
    "\\end{equation}"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": ".venv",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.1"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
