{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "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",
    "import numpy as np\n",
    "from mindreadingautobots.entropy_and_bayesian import boolean\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Find a trick (Joker) function \n",
    "\n",
    "Recall that we start with uniformly random bitstrings $X$ (each length $n$ bitstrings), then we generate $Y=f(X)$ and create a pair $(X, Y)$. This pair $X,Y$ has a joint distribution. By applying bitflips to turn $X \\rightarrow Z$, we end up with a new joinst distr $p_{ZY}$ where $Z$ is a bitflipped version of $X$ and $Y=f(X)$.\n",
    "\n",
    "By trick function, we mean that for data with  we are looking for $g^*$ (optimal prediction for _noisy_ data) is more accuracte and less sensitive than $f$ (function used to generate noiseless data).\n",
    "\n",
    "We want an example of data and noise such that MLD (for the noisy data) evaluated on noiseless data is _worse_ than MLD (for noiseless data) evaluated on noiseless data.\n",
    "\n",
    "Suppose $f^*(z^{n-1}) = \\argmax_{x'} p_{X|Z^{n-1}}(x|z^{n-1})$ is our MLD for noisy data and $fN*(x^{n-1}) = \\argmax_{x'} p_{X|X^{n-1}}(x|x^{n-1})$ is our MLD for noiseless data. We build $f^*$ analytically, then compare it to $g^*$. \n",
    "\n",
    "Our example will be $k=3$ majority function (in which case $g^*$ is just majority)."
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Searching for weight-based 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}"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Searching for joker functions\n",
    "\n",
    "**constraints**:\n",
    "- we want both senstivities to be $\\gg 0$\n",
    "- we want function accuracies to be $\\gg 1/2$ (this is equivalent to $p$ not big)\n",
    "- we want functions that are more balanced (`imbal` closer to 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "counterexample= [0, 0, 0, 1, 1, 1]\n",
      "\t noisy g* acc= [np.float64(0.6463449999999998)]\n",
      "\t noisy g* sensitivity= 1.875\n",
      "\t noisy f acc= [np.float64(0.6463449999999998)]\n",
      "\t noisy f sensitivity= 1.875\n",
      "(np.float64(0.6463449999999998), 1.875) (np.float64(0.6463449999999998), 1.875)\n",
      "\n"
     ]
    }
   ],
   "source": [
    "n = 5 # total number of bits\n",
    "p = 0.3 # probability of each bit of X flipping, this DOESN'T flip Y ever.\n",
    "\n",
    "\n",
    "X_arr = np.array(list(itertools.product([0, 1], repeat=n)))\n",
    "# p_x = 1 / (2 ** n) # uniform distribution over x # chaos distribution and the thing with chaos distribution is its fair\n",
    "# WEIGHT-BASED FUNCTIONS\n",
    "signatures = itertools.product([0, 1], repeat=n+1)\n",
    "for signature in signatures:\n",
    "# signature = [1,0,0,1,1,0] # n+1 elements\n",
    "    print(\"counterexample=\", 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",
    "    # 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",
    "    # round up to get argmax \n",
    "    noisy_mle = np.round(noisy_lookup)  \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()\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Checking even vs odd majority functions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "counterexample= [0, 0, 0, 1, 1, 1]\n",
      "noisy val acc of noisy MLE\n",
      "\t noisy fN* acc= [np.float64(0.6463449999999998)]\n",
      "\t fN* sensitivity= 1.875\n",
      "noisy val acc of f\n",
      "\t noisy f acc= [np.float64(0.6463449999999998)]\n",
      "\t f sensitivity= 1.875\n",
      "noiseless val acc of gfN*\n",
      "\t noiseless fN* acc= 1.0\n",
      "(np.float64(0.6463449999999998), 1.875) (np.float64(0.6463449999999998), 1.875)\n",
      "\n",
      "counterexample= [0, 0, 1, 1, 1]\n",
      "noisy val acc of noisy MLE\n",
      "\t noisy fN* acc= [np.float64(0.7064624999999999)]\n",
      "\t fN* sensitivity= 0.5\n",
      "noisy val acc of f\n",
      "\t noisy f acc= [np.float64(0.6941124999999999)]\n",
      "\t f sensitivity= 1.5\n",
      "noiseless val acc of gfN*\n",
      "\t noiseless fN* acc= 0.75\n",
      "(np.float64(0.7064624999999999), 0.5) (np.float64(0.6941124999999999), 1.5)\n",
      "\n"
     ]
    }
   ],
   "source": [
    "n = 5 # total number of bits\n",
    "p = 0.3 # probability of each bit of X flipping, this DOESN'T flip Y ever.\n",
    "\n",
    "\n",
    "# p_x = 1 / (2 ** n) # uniform distribution over x # chaos distribution and the thing with chaos distribution is its fair\n",
    "# WEIGHT-BASED FUNCTIONS\n",
    "signatures = [[0, 0, 0, 1, 1, 1], [0, 0, 1, 1, 1]]\n",
    "# signatures = itertools.product([0, 1], repeat=n+1)\n",
    "for signature in signatures:\n",
    "    n = len(signature) - 1\n",
    "    X_arr = np.array(list(itertools.product([0, 1], repeat=n)))\n",
    "    print(\"counterexample=\", 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",
    "    # 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",
    "    # round up to get argmax \n",
    "    noisy_mle = np.round(noisy_lookup)  \n",
    "    out = np.multiply(noisy_mle, true_lookup) / 2 ** n # \"inner product\" of the functions\n",
    "    diff = out.sum()\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",
    "    print(\"noisy val acc of noisy MLE\")\n",
    "    print(\"\\t noisy fN* acc=\", fn_accs)\n",
    "    print(\"\\t fN* sensitivity=\", sensitivity_fnstar)\n",
    "    print(\"noisy val acc of f\")\n",
    "    print(\"\\t noisy f acc=\", f_accs)\n",
    "    print(\"\\t f sensitivity=\", sensitivity_f)\n",
    "    print(\"noiseless val acc of gfN*\")\n",
    "    print(\"\\t noiseless fN* acc=\", noiseless_fnstar_acc)\n",
    "\n",
    "\n",
    "    print((fn_accs[0], sensitivity_fnstar), (f_accs[0], sensitivity_f))\n",
    "    print()\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Different search: not weight based."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# this code looks at all possible boolean functions that are perfectly balanced\n",
    "\n",
    "def boolean_function_from_signature(f):\n",
    "    \"\"\"Given a length 2^n binary array, return the function with that boolean signature.\"\"\"\n",
    "    X_arr = list(itertools.product([0, 1], repeat=n))\n",
    "    X_arr = [tuple(x) for x in X_arr]\n",
    "    lookup = dict(zip(X_arr, f))\n",
    "    def func(x):\n",
    "        return lookup[tuple(x)]\n",
    "    return lookup, func\n",
    "\n",
    "n = 4\n",
    "# WARNING: n=4 might take 5 minutes\n",
    "assert n <= 4\n",
    "k = n\n",
    "# pvals = [0.01, 0.25, 0.49]\n",
    "pvals = [0.2]\n",
    "\n",
    "# a \"signature\" of a boolean function is a length 2**n bitstring S where f(x) = S[bin(x)]\n",
    "# we will check signatures for perfectly balanced functions\n",
    "sig_arr = np.array(list(itertools.product([0, 1], repeat=2**n)))\n",
    "sig_arr = sig_arr[sig_arr.sum(axis=1) == 2**(n-1)] # only balanced functions\n",
    "\n",
    "X_arr = np.array(list(itertools.product([0, 1], repeat=n)))\n",
    "p_x = 1 / (2 ** k) # uniform distribution over x\n",
    "for i, signature in enumerate(sig_arr):\n",
    "    # iterate over signatures\n",
    "    print(signature)\n",
    "    dct, func = boolean_function_from_signature(signature)\n",
    "    for p in pvals:        \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(product([0,1], repeat=k)):\n",
    "            func_value = func(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=k):\n",
    "                z = np.array(x) ^ np.array(e)\n",
    "                p_x_given_z = p ** sum(e) * (1-p)**(k - 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",
    "        # the function is balanced if the sums of the two rows of true_lookup are equal\n",
    "        # imbal = abs(true_lookup[0,:].sum() - true_lookup[1,:].sum())  / 2 ** n\n",
    "        # round up to get argmax \n",
    "        noisy_mle = np.round(noisy_lookup)  \n",
    "        out = np.multiply(noisy_mle, true_lookup) / 2 ** n # \"inner product\" of the functions\n",
    "        diff = out.sum()\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(k, p, func)\n",
    "        noisy_f_acc = boolean.compute_acc_noisytest(p_zy, func, n) # accuracy of f on noisy data\n",
    "        # noiseless_fnstar_acc = 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"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Random search over boolean functions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "!!!p=0\n",
      "boolean signature | imbal? | nacc(fN*) | taccfN* |naccfN*-naccf| S(f) | S(fN*) | S(f) - S(fN*)\n",
      "--------------------------------------------------------------------------\n",
      "  [0 0 0 0 0 0]   | 1.0000 |   1.0000  | 1.0000 | 0.0000    |0.0000|0.0000  |  0.0000 \n",
      "  [0 0 0 0 0 1]   | 0.9375 |   1.0000  | 1.0000 | 0.0000    |0.3125|0.3125  |  0.0000 \n",
      "  [0 0 0 0 1 0]   | 0.6875 |   1.0000  | 1.0000 | 0.0000    |1.5625|1.5625  |  0.0000 \n",
      "  [0 0 0 0 1 1]   | 0.6250 |   1.0000  | 1.0000 | 0.0000    |1.2500|1.2500  |  0.0000 \n",
      "  [0 0 0 1 0 0]   | 0.3750 |   1.0000  | 1.0000 | 0.0000    |3.1250|3.1250  |  0.0000 \n",
      "  [0 0 0 1 0 1]   | 0.3125 |   1.0000  | 1.0000 | 0.0000    |3.4375|3.4375  |  0.0000 \n",
      "  [0 0 0 1 1 0]   | 0.0625 |   1.0000  | 1.0000 | 0.0000    |2.1875|2.1875  |  0.0000 \n",
      "  [0 0 0 1 1 1]   | 0.0000 |   1.0000  | 1.0000 | 0.0000    |1.8750|1.8750  |  0.0000 \n",
      "  [0 0 1 0 0 0]   | 0.3750 |   1.0000  | 1.0000 | 0.0000    |3.1250|3.1250  |  0.0000 \n",
      "  [0 0 1 0 0 1]   | 0.3125 |   1.0000  | 1.0000 | 0.0000    |3.4375|3.4375  |  0.0000 \n",
      "  [0 0 1 0 1 0]   | 0.0625 |   1.0000  | 1.0000 | 0.0000    |4.6875|4.6875  |  0.0000 \n",
      "  [0 0 1 0 1 1]   | 0.0000 |   1.0000  | 1.0000 | 0.0000    |4.3750|4.3750  |  0.0000 \n",
      "  [0 0 1 1 0 0]   | 0.2500 |   1.0000  | 1.0000 | 0.0000    |2.5000|2.5000  |  0.0000 \n",
      "  [0 0 1 1 0 1]   | 0.3125 |   1.0000  | 1.0000 | 0.0000    |2.8125|2.8125  |  0.0000 \n",
      "  [0 0 1 1 1 0]   | 0.5625 |   1.0000  | 1.0000 | 0.0000    |1.5625|1.5625  |  0.0000 \n",
      "  [0 0 1 1 1 1]   | 0.6250 |   1.0000  | 1.0000 | 0.0000    |1.2500|1.2500  |  0.0000 \n",
      "  [0 1 0 0 0 0]   | 0.6875 |   1.0000  | 1.0000 | 0.0000    |1.5625|1.5625  |  0.0000 \n",
      "  [0 1 0 0 0 1]   | 0.6250 |   1.0000  | 1.0000 | 0.0000    |1.8750|1.8750  |  0.0000 \n",
      "  [0 1 0 0 1 0]   | 0.3750 |   1.0000  | 1.0000 | 0.0000    |3.1250|3.1250  |  0.0000 \n",
      "  [0 1 0 0 1 1]   | 0.3125 |   1.0000  | 1.0000 | 0.0000    |2.8125|2.8125  |  0.0000 \n",
      "  [0 1 0 1 0 0]   | 0.0625 |   1.0000  | 1.0000 | 0.0000    |4.6875|4.6875  |  0.0000 \n",
      "  [0 1 0 1 0 1]   | 0.0000 |   1.0000  | 1.0000 | 0.0000    |5.0000|5.0000  |  0.0000 \n",
      "  [0 1 0 1 1 0]   | 0.2500 |   1.0000  | 1.0000 | 0.0000    |3.7500|3.7500  |  0.0000 \n",
      "  [0 1 0 1 1 1]   | 0.3125 |   1.0000  | 1.0000 | 0.0000    |3.4375|3.4375  |  0.0000 \n",
      ">>[0 1 1 0 0 0]   | 0.0625 |   1.0000  | 1.0000 | 0.0000    |2.1875|2.1875  |  0.0000 \n",
      "  [0 1 1 0 0 1]   | 0.0000 |   1.0000  | 1.0000 | 0.0000    |2.5000|2.5000  |  0.0000 \n",
      ">>[0 1 1 0 1 0]   | 0.2500 |   1.0000  | 1.0000 | 0.0000    |3.7500|3.7500  |  0.0000 \n",
      "  [0 1 1 0 1 1]   | 0.3125 |   1.0000  | 1.0000 | 0.0000    |3.4375|3.4375  |  0.0000 \n",
      "  [0 1 1 1 0 0]   | 0.5625 |   1.0000  | 1.0000 | 0.0000    |1.5625|1.5625  |  0.0000 \n",
      "  [0 1 1 1 0 1]   | 0.6250 |   1.0000  | 1.0000 | 0.0000    |1.8750|1.8750  |  0.0000 \n",
      "  [0 1 1 1 1 0]   | 0.8750 |   1.0000  | 1.0000 | 0.0000    |0.6250|0.6250  |  0.0000 \n",
      "  [0 1 1 1 1 1]   | 0.9375 |   1.0000  | 1.0000 | 0.0000    |0.3125|0.3125  |  0.0000 \n",
      "  [1 0 0 0 0 0]   | 0.9375 |   1.0000  | 1.0000 | 0.0000    |0.3125|0.3125  |  0.0000 \n",
      "  [1 0 0 0 0 1]   | 0.8750 |   1.0000  | 1.0000 | 0.0000    |0.6250|0.6250  |  0.0000 \n",
      "  [1 0 0 0 1 0]   | 0.6250 |   1.0000  | 1.0000 | 0.0000    |1.8750|1.8750  |  0.0000 \n",
      "  [1 0 0 0 1 1]   | 0.5625 |   1.0000  | 1.0000 | 0.0000    |1.5625|1.5625  |  0.0000 \n",
      "  [1 0 0 1 0 0]   | 0.3125 |   1.0000  | 1.0000 | 0.0000    |3.4375|3.4375  |  0.0000 \n",
      "  [1 0 0 1 0 1]   | 0.2500 |   1.0000  | 1.0000 | 0.0000    |3.7500|3.7500  |  0.0000 \n",
      ">>[1 0 0 1 1 0]   | 0.0000 |   1.0000  | 1.0000 | 0.0000    |2.5000|2.5000  |  0.0000 \n",
      "  [1 0 0 1 1 1]   | 0.0625 |   1.0000  | 1.0000 | 0.0000    |2.1875|2.1875  |  0.0000 \n",
      "  [1 0 1 0 0 0]   | 0.3125 |   1.0000  | 1.0000 | 0.0000    |3.4375|3.4375  |  0.0000 \n",
      "  [1 0 1 0 0 1]   | 0.2500 |   1.0000  | 1.0000 | 0.0000    |3.7500|3.7500  |  0.0000 \n",
      "  [1 0 1 0 1 0]   | 0.0000 |   1.0000  | 1.0000 | 0.0000    |5.0000|5.0000  |  0.0000 \n",
      "  [1 0 1 0 1 1]   | 0.0625 |   1.0000  | 1.0000 | 0.0000    |4.6875|4.6875  |  0.0000 \n",
      "  [1 0 1 1 0 0]   | 0.3125 |   1.0000  | 1.0000 | 0.0000    |2.8125|2.8125  |  0.0000 \n",
      "  [1 0 1 1 0 1]   | 0.3750 |   1.0000  | 1.0000 | 0.0000    |3.1250|3.1250  |  0.0000 \n",
      "  [1 0 1 1 1 0]   | 0.6250 |   1.0000  | 1.0000 | 0.0000    |1.8750|1.8750  |  0.0000 \n",
      "  [1 0 1 1 1 1]   | 0.6875 |   1.0000  | 1.0000 | 0.0000    |1.5625|1.5625  |  0.0000 \n",
      "  [1 1 0 0 0 0]   | 0.6250 |   1.0000  | 1.0000 | 0.0000    |1.2500|1.2500  |  0.0000 \n",
      "  [1 1 0 0 0 1]   | 0.5625 |   1.0000  | 1.0000 | 0.0000    |1.5625|1.5625  |  0.0000 \n",
      "  [1 1 0 0 1 0]   | 0.3125 |   1.0000  | 1.0000 | 0.0000    |2.8125|2.8125  |  0.0000 \n",
      "  [1 1 0 0 1 1]   | 0.2500 |   1.0000  | 1.0000 | 0.0000    |2.5000|2.5000  |  0.0000 \n",
      "  [1 1 0 1 0 0]   | 0.0000 |   1.0000  | 1.0000 | 0.0000    |4.3750|4.3750  |  0.0000 \n",
      "  [1 1 0 1 0 1]   | 0.0625 |   1.0000  | 1.0000 | 0.0000    |4.6875|4.6875  |  0.0000 \n",
      "  [1 1 0 1 1 0]   | 0.3125 |   1.0000  | 1.0000 | 0.0000    |3.4375|3.4375  |  0.0000 \n",
      "  [1 1 0 1 1 1]   | 0.3750 |   1.0000  | 1.0000 | 0.0000    |3.1250|3.1250  |  0.0000 \n",
      "  [1 1 1 0 0 0]   | 0.0000 |   1.0000  | 1.0000 | 0.0000    |1.8750|1.8750  |  0.0000 \n",
      "  [1 1 1 0 0 1]   | 0.0625 |   1.0000  | 1.0000 | 0.0000    |2.1875|2.1875  |  0.0000 \n",
      "  [1 1 1 0 1 0]   | 0.3125 |   1.0000  | 1.0000 | 0.0000    |3.4375|3.4375  |  0.0000 \n",
      "  [1 1 1 0 1 1]   | 0.3750 |   1.0000  | 1.0000 | 0.0000    |3.1250|3.1250  |  0.0000 \n",
      "  [1 1 1 1 0 0]   | 0.6250 |   1.0000  | 1.0000 | 0.0000    |1.2500|1.2500  |  0.0000 \n",
      "  [1 1 1 1 0 1]   | 0.6875 |   1.0000  | 1.0000 | 0.0000    |1.5625|1.5625  |  0.0000 \n",
      "  [1 1 1 1 1 0]   | 0.9375 |   1.0000  | 1.0000 | 0.0000    |0.3125|0.3125  |  0.0000 \n",
      "  [1 1 1 1 1 1]   | 1.0000 |   1.0000  | 1.0000 | 0.0000    |0.0000|0.0000  |  0.0000 \n",
      "\n",
      "!!!p=0.1\n",
      "boolean signature | imbal? | nacc(fN*) | taccfN* |naccfN*-naccf| S(f) | S(fN*) | S(f) - S(fN*)\n",
      "--------------------------------------------------------------------------\n",
      "  [0 0 0 0 0 0]   | 1.0000 |   1.0000  | 1.0000 | 0.0000    |0.0000|0.0000  |  0.0000 \n",
      "  [0 0 0 0 0 1]   | 0.9375 |   0.9744  | 1.0000 | 0.0000    |0.3125|0.3125  |  0.0000 \n",
      "  [0 0 0 0 1 0]   | 0.6875 |   0.8811  | 1.0000 | 0.0000    |1.5625|1.5625  |  0.0000 \n",
      "  [0 0 0 0 1 1]   | 0.6250 |   0.8966  | 1.0000 | 0.0000    |1.2500|1.2500  |  0.0000 \n",
      "  [0 0 0 1 0 0]   | 0.3750 |   0.7716  | 1.0000 | 0.0000    |3.1250|3.1250  |  0.0000 \n",
      "  [0 0 0 1 0 1]   | 0.3125 |   0.7551  | 1.0000 | 0.0000    |3.4375|3.4375  |  0.0000 \n",
      "  [0 0 0 1 1 0]   | 0.0625 |   0.8198  | 1.0000 | 0.0000    |2.1875|2.1875  |  0.0000 \n",
      "  [0 0 0 1 1 1]   | 0.0000 |   0.8443  | 1.0000 | 0.0000    |1.8750|1.8750  |  0.0000 \n",
      "  [0 0 1 0 0 0]   | 0.3750 |   0.7716  | 1.0000 | 0.0000    |3.1250|3.1250  |  0.0000 \n",
      "  [0 0 1 0 0 1]   | 0.3125 |   0.7470  | 1.0000 | 0.0000    |3.4375|3.4375  |  0.0000 \n",
      "  [0 0 1 0 1 0]   | 0.0625 |   0.6803  | 1.0000 | 0.0000    |4.6875|4.6875  |  0.0000 \n",
      "  [0 0 1 0 1 1]   | 0.0000 |   0.6967  | 1.0000 | 0.0000    |4.3750|4.3750  |  0.0000 \n",
      "  [0 0 1 1 0 0]   | 0.2500 |   0.7953  | 1.0000 | 0.0000    |2.5000|2.5000  |  0.0000 \n",
      "  [0 0 1 1 0 1]   | 0.3125 |   0.7798  | 1.0000 | 0.0000    |2.8125|2.8125  |  0.0000 \n",
      "  [0 0 1 1 1 0]   | 0.5625 |   0.8710  | 1.0000 | 0.0000    |1.5625|1.5625  |  0.0000 \n",
      "  [0 0 1 1 1 1]   | 0.6250 |   0.8966  | 1.0000 | 0.0000    |1.2500|1.2500  |  0.0000 \n",
      "  [0 1 0 0 0 0]   | 0.6875 |   0.8811  | 1.0000 | 0.0000    |1.5625|1.5625  |  0.0000 \n",
      "  [0 1 0 0 0 1]   | 0.6250 |   0.8556  | 1.0000 | 0.0000    |1.8750|1.8750  |  0.0000 \n",
      "  [0 1 0 0 1 0]   | 0.3750 |   0.7643  | 1.0000 | 0.0000    |3.1250|3.1250  |  0.0000 \n",
      "  [0 1 0 0 1 1]   | 0.3125 |   0.7798  | 1.0000 | 0.0000    |2.8125|2.8125  |  0.0000 \n",
      "  [0 1 0 1 0 0]   | 0.0625 |   0.6803  | 1.0000 | 0.0000    |4.6875|4.6875  |  0.0000 \n",
      "  [0 1 0 1 0 1]   | 0.0000 |   0.6638  | 1.0000 | 0.0000    |5.0000|5.0000  |  0.0000 \n",
      "  [0 1 0 1 1 0]   | 0.2500 |   0.7305  | 1.0000 | 0.0000    |3.7500|3.7500  |  0.0000 \n",
      "  [0 1 0 1 1 1]   | 0.3125 |   0.7551  | 1.0000 | 0.0000    |3.4375|3.4375  |  0.0000 \n",
      ">>[0 1 1 0 0 0]   | 0.0625 |   0.8198  | 1.0000 | 0.0000    |2.1875|2.1875  |  0.0000 \n",
      "  [0 1 1 0 0 1]   | 0.0000 |   0.7952  | 1.0000 | 0.0000    |2.5000|2.5000  |  0.0000 \n",
      ">>[0 1 1 0 1 0]   | 0.2500 |   0.7305  | 1.0000 | 0.0000    |3.7500|3.7500  |  0.0000 \n",
      "  [0 1 1 0 1 1]   | 0.3125 |   0.7470  | 1.0000 | 0.0000    |3.4375|3.4375  |  0.0000 \n",
      "  [0 1 1 1 0 0]   | 0.5625 |   0.8710  | 1.0000 | 0.0000    |1.5625|1.5625  |  0.0000 \n",
      "  [0 1 1 1 0 1]   | 0.6250 |   0.8556  | 1.0000 | 0.0000    |1.8750|1.8750  |  0.0000 \n",
      "  [0 1 1 1 1 0]   | 0.8750 |   0.9488  | 1.0000 | 0.0000    |0.6250|0.6250  |  0.0000 \n",
      "  [0 1 1 1 1 1]   | 0.9375 |   0.9744  | 1.0000 | 0.0000    |0.3125|0.3125  |  0.0000 \n",
      "  [1 0 0 0 0 0]   | 0.9375 |   0.9744  | 1.0000 | 0.0000    |0.3125|0.3125  |  0.0000 \n",
      "  [1 0 0 0 0 1]   | 0.8750 |   0.9488  | 1.0000 | 0.0000    |0.6250|0.6250  |  0.0000 \n",
      "  [1 0 0 0 1 0]   | 0.6250 |   0.8556  | 1.0000 | 0.0000    |1.8750|1.8750  |  0.0000 \n",
      "  [1 0 0 0 1 1]   | 0.5625 |   0.8710  | 1.0000 | 0.0000    |1.5625|1.5625  |  0.0000 \n",
      "  [1 0 0 1 0 0]   | 0.3125 |   0.7470  | 1.0000 | 0.0000    |3.4375|3.4375  |  0.0000 \n",
      "  [1 0 0 1 0 1]   | 0.2500 |   0.7305  | 1.0000 | 0.0000    |3.7500|3.7500  |  0.0000 \n",
      ">>[1 0 0 1 1 0]   | 0.0000 |   0.7952  | 1.0000 | 0.0000    |2.5000|2.5000  |  0.0000 \n",
      "  [1 0 0 1 1 1]   | 0.0625 |   0.8198  | 1.0000 | 0.0000    |2.1875|2.1875  |  0.0000 \n",
      "  [1 0 1 0 0 0]   | 0.3125 |   0.7551  | 1.0000 | 0.0000    |3.4375|3.4375  |  0.0000 \n",
      "  [1 0 1 0 0 1]   | 0.2500 |   0.7305  | 1.0000 | 0.0000    |3.7500|3.7500  |  0.0000 \n",
      "  [1 0 1 0 1 0]   | 0.0000 |   0.6638  | 1.0000 | 0.0000    |5.0000|5.0000  |  0.0000 \n",
      "  [1 0 1 0 1 1]   | 0.0625 |   0.6803  | 1.0000 | 0.0000    |4.6875|4.6875  |  0.0000 \n",
      "  [1 0 1 1 0 0]   | 0.3125 |   0.7798  | 1.0000 | 0.0000    |2.8125|2.8125  |  0.0000 \n",
      "  [1 0 1 1 0 1]   | 0.3750 |   0.7643  | 1.0000 | 0.0000    |3.1250|3.1250  |  0.0000 \n",
      "  [1 0 1 1 1 0]   | 0.6250 |   0.8556  | 1.0000 | 0.0000    |1.8750|1.8750  |  0.0000 \n",
      "  [1 0 1 1 1 1]   | 0.6875 |   0.8811  | 1.0000 | 0.0000    |1.5625|1.5625  |  0.0000 \n",
      "  [1 1 0 0 0 0]   | 0.6250 |   0.8966  | 1.0000 | 0.0000    |1.2500|1.2500  |  0.0000 \n",
      "  [1 1 0 0 0 1]   | 0.5625 |   0.8710  | 1.0000 | 0.0000    |1.5625|1.5625  |  0.0000 \n",
      "  [1 1 0 0 1 0]   | 0.3125 |   0.7798  | 1.0000 | 0.0000    |2.8125|2.8125  |  0.0000 \n",
      "  [1 1 0 0 1 1]   | 0.2500 |   0.7953  | 1.0000 | 0.0000    |2.5000|2.5000  |  0.0000 \n",
      "  [1 1 0 1 0 0]   | 0.0000 |   0.6967  | 1.0000 | 0.0000    |4.3750|4.3750  |  0.0000 \n",
      "  [1 1 0 1 0 1]   | 0.0625 |   0.6803  | 1.0000 | 0.0000    |4.6875|4.6875  |  0.0000 \n",
      "  [1 1 0 1 1 0]   | 0.3125 |   0.7470  | 1.0000 | 0.0000    |3.4375|3.4375  |  0.0000 \n",
      "  [1 1 0 1 1 1]   | 0.3750 |   0.7716  | 1.0000 | 0.0000    |3.1250|3.1250  |  0.0000 \n",
      "  [1 1 1 0 0 0]   | 0.0000 |   0.8443  | 1.0000 | 0.0000    |1.8750|1.8750  |  0.0000 \n",
      "  [1 1 1 0 0 1]   | 0.0625 |   0.8198  | 1.0000 | 0.0000    |2.1875|2.1875  |  0.0000 \n",
      "  [1 1 1 0 1 0]   | 0.3125 |   0.7551  | 1.0000 | 0.0000    |3.4375|3.4375  |  0.0000 \n",
      "  [1 1 1 0 1 1]   | 0.3750 |   0.7716  | 1.0000 | 0.0000    |3.1250|3.1250  |  0.0000 \n",
      "  [1 1 1 1 0 0]   | 0.6250 |   0.8966  | 1.0000 | 0.0000    |1.2500|1.2500  |  0.0000 \n",
      "  [1 1 1 1 0 1]   | 0.6875 |   0.8811  | 1.0000 | 0.0000    |1.5625|1.5625  |  0.0000 \n",
      "  [1 1 1 1 1 0]   | 0.9375 |   0.9744  | 1.0000 | 0.0000    |0.3125|0.3125  |  0.0000 \n",
      "  [1 1 1 1 1 1]   | 1.0000 |   1.0000  | 1.0000 | 0.0000    |0.0000|0.0000  |  0.0000 \n",
      "\n",
      "!!!p=0.15\n",
      "boolean signature | imbal? | nacc(fN*) | taccfN* |naccfN*-naccf| S(f) | S(fN*) | S(f) - S(fN*)\n",
      "--------------------------------------------------------------------------\n",
      "  [0 0 0 0 0 0]   | 1.0000 |   1.0000  | 1.0000 | 0.0000    |0.0000|0.0000  |  0.0000 \n",
      "  [0 0 0 0 0 1]   | 0.9375 |   0.9687  | 0.9688 | 0.0035    |0.3125|0.0000  |  0.3125 \n",
      "  [0 0 0 0 1 0]   | 0.6875 |   0.8437  | 0.8438 | 0.0003    |1.5625|0.0000  |  1.5625 \n",
      "  [0 0 0 0 1 1]   | 0.6250 |   0.8576  | 1.0000 | 0.0000    |1.2500|1.2500  |  0.0000 \n",
      "  [0 0 0 1 0 0]   | 0.3750 |   0.7049  | 1.0000 | 0.0000    |3.1250|3.1250  |  0.0000 \n",
      "  [0 0 0 1 0 1]   | 0.3125 |   0.6874  | 1.0000 | 0.0000    |3.4375|3.4375  |  0.0000 \n",
      "  [0 0 0 1 1 0]   | 0.0625 |   0.7551  | 0.9688 | 0.0019    |2.1875|1.8750  |  0.3125 \n",
      "  [0 0 0 1 1 1]   | 0.0000 |   0.7847  | 1.0000 | 0.0000    |1.8750|1.8750  |  0.0000 \n",
      "  [0 0 1 0 0 0]   | 0.3750 |   0.7049  | 1.0000 | 0.0000    |3.1250|3.1250  |  0.0000 \n",
      "  [0 0 1 0 0 1]   | 0.3125 |   0.6752  | 0.9688 | 0.0020    |3.4375|3.1250  |  0.3125 \n",
      "  [0 0 1 0 1 0]   | 0.0625 |   0.6013  | 1.0000 | 0.0000    |4.6875|4.6875  |  0.0000 \n",
      "  [0 0 1 0 1 1]   | 0.0000 |   0.6185  | 1.0000 | 0.0000    |4.3750|4.3750  |  0.0000 \n",
      "  [0 0 1 1 0 0]   | 0.2500 |   0.7219  | 1.0000 | 0.0000    |2.5000|2.5000  |  0.0000 \n",
      "  [0 0 1 1 0 1]   | 0.3125 |   0.7074  | 1.0000 | 0.0000    |2.8125|2.8125  |  0.0000 \n",
      "  [0 0 1 1 1 0]   | 0.5625 |   0.8265  | 0.9688 | 0.0034    |1.5625|1.2500  |  0.3125 \n",
      "  [0 0 1 1 1 1]   | 0.6250 |   0.8576  | 1.0000 | 0.0000    |1.2500|1.2500  |  0.0000 \n",
      "  [0 1 0 0 0 0]   | 0.6875 |   0.8437  | 0.8438 | 0.0003    |1.5625|0.0000  |  1.5625 \n",
      "  [0 1 0 0 0 1]   | 0.6250 |   0.8125  | 0.8125 | 0.0036    |1.8750|0.0000  |  1.8750 \n",
      "  [0 1 0 0 1 0]   | 0.3750 |   0.6930  | 1.0000 | 0.0000    |3.1250|3.1250  |  0.0000 \n",
      "  [0 1 0 0 1 1]   | 0.3125 |   0.7074  | 1.0000 | 0.0000    |2.8125|2.8125  |  0.0000 \n",
      "  [0 1 0 1 0 0]   | 0.0625 |   0.6013  | 1.0000 | 0.0000    |4.6875|4.6875  |  0.0000 \n",
      "  [0 1 0 1 0 1]   | 0.0000 |   0.5840  | 1.0000 | 0.0000    |5.0000|5.0000  |  0.0000 \n",
      "  [0 1 0 1 1 0]   | 0.2500 |   0.6577  | 0.9688 | 0.0020    |3.7500|3.4375  |  0.3125 \n",
      "  [0 1 0 1 1 1]   | 0.3125 |   0.6874  | 1.0000 | 0.0000    |3.4375|3.4375  |  0.0000 \n",
      ">>[0 1 1 0 0 0]   | 0.0625 |   0.7551  | 0.9688 | 0.0019    |2.1875|1.8750  |  0.3125 \n",
      "  [0 1 1 0 0 1]   | 0.0000 |   0.7255  | 0.9375 | 0.0037    |2.5000|1.8750  |  0.6250 \n",
      ">>[0 1 1 0 1 0]   | 0.2500 |   0.6577  | 0.9688 | 0.0020    |3.7500|3.4375  |  0.3125 \n",
      "  [0 1 1 0 1 1]   | 0.3125 |   0.6752  | 0.9688 | 0.0020    |3.4375|3.1250  |  0.3125 \n",
      "  [0 1 1 1 0 0]   | 0.5625 |   0.8265  | 0.9688 | 0.0034    |1.5625|1.2500  |  0.3125 \n",
      "  [0 1 1 1 0 1]   | 0.6250 |   0.8125  | 0.8125 | 0.0036    |1.8750|0.0000  |  1.8750 \n",
      "  [0 1 1 1 1 0]   | 0.8750 |   0.9375  | 0.9375 | 0.0070    |0.6250|0.0000  |  0.6250 \n",
      "  [0 1 1 1 1 1]   | 0.9375 |   0.9687  | 0.9688 | 0.0035    |0.3125|0.0000  |  0.3125 \n",
      "  [1 0 0 0 0 0]   | 0.9375 |   0.9687  | 0.9688 | 0.0035    |0.3125|0.0000  |  0.3125 \n",
      "  [1 0 0 0 0 1]   | 0.8750 |   0.9375  | 0.9375 | 0.0070    |0.6250|0.0000  |  0.6250 \n",
      "  [1 0 0 0 1 0]   | 0.6250 |   0.8125  | 0.8125 | 0.0036    |1.8750|0.0000  |  1.8750 \n",
      "  [1 0 0 0 1 1]   | 0.5625 |   0.8265  | 0.9688 | 0.0034    |1.5625|1.2500  |  0.3125 \n",
      "  [1 0 0 1 0 0]   | 0.3125 |   0.6752  | 0.9688 | 0.0020    |3.4375|3.1250  |  0.3125 \n",
      "  [1 0 0 1 0 1]   | 0.2500 |   0.6577  | 0.9688 | 0.0020    |3.7500|3.4375  |  0.3125 \n",
      ">>[1 0 0 1 1 0]   | 0.0000 |   0.7255  | 0.9375 | 0.0037    |2.5000|1.8750  |  0.6250 \n",
      "  [1 0 0 1 1 1]   | 0.0625 |   0.7551  | 0.9688 | 0.0019    |2.1875|1.8750  |  0.3125 \n",
      "  [1 0 1 0 0 0]   | 0.3125 |   0.6874  | 1.0000 | 0.0000    |3.4375|3.4375  |  0.0000 \n",
      "  [1 0 1 0 0 1]   | 0.2500 |   0.6577  | 0.9688 | 0.0020    |3.7500|3.4375  |  0.3125 \n",
      "  [1 0 1 0 1 0]   | 0.0000 |   0.5840  | 1.0000 | 0.0000    |5.0000|5.0000  |  0.0000 \n",
      "  [1 0 1 0 1 1]   | 0.0625 |   0.6013  | 1.0000 | 0.0000    |4.6875|4.6875  |  0.0000 \n",
      "  [1 0 1 1 0 0]   | 0.3125 |   0.7074  | 1.0000 | 0.0000    |2.8125|2.8125  |  0.0000 \n",
      "  [1 0 1 1 0 1]   | 0.3750 |   0.6930  | 1.0000 | 0.0000    |3.1250|3.1250  |  0.0000 \n",
      "  [1 0 1 1 1 0]   | 0.6250 |   0.8125  | 0.8125 | 0.0036    |1.8750|0.0000  |  1.8750 \n",
      "  [1 0 1 1 1 1]   | 0.6875 |   0.8437  | 0.8438 | 0.0003    |1.5625|0.0000  |  1.5625 \n",
      "  [1 1 0 0 0 0]   | 0.6250 |   0.8576  | 1.0000 | 0.0000    |1.2500|1.2500  |  0.0000 \n",
      "  [1 1 0 0 0 1]   | 0.5625 |   0.8265  | 0.9688 | 0.0034    |1.5625|1.2500  |  0.3125 \n",
      "  [1 1 0 0 1 0]   | 0.3125 |   0.7074  | 1.0000 | 0.0000    |2.8125|2.8125  |  0.0000 \n",
      "  [1 1 0 0 1 1]   | 0.2500 |   0.7219  | 1.0000 | 0.0000    |2.5000|2.5000  |  0.0000 \n",
      "  [1 1 0 1 0 0]   | 0.0000 |   0.6185  | 1.0000 | 0.0000    |4.3750|4.3750  |  0.0000 \n",
      "  [1 1 0 1 0 1]   | 0.0625 |   0.6013  | 1.0000 | 0.0000    |4.6875|4.6875  |  0.0000 \n",
      "  [1 1 0 1 1 0]   | 0.3125 |   0.6752  | 0.9688 | 0.0020    |3.4375|3.1250  |  0.3125 \n",
      "  [1 1 0 1 1 1]   | 0.3750 |   0.7049  | 1.0000 | 0.0000    |3.1250|3.1250  |  0.0000 \n",
      "  [1 1 1 0 0 0]   | 0.0000 |   0.7847  | 1.0000 | 0.0000    |1.8750|1.8750  |  0.0000 \n",
      "  [1 1 1 0 0 1]   | 0.0625 |   0.7551  | 0.9688 | 0.0019    |2.1875|1.8750  |  0.3125 \n",
      "  [1 1 1 0 1 0]   | 0.3125 |   0.6874  | 1.0000 | 0.0000    |3.4375|3.4375  |  0.0000 \n",
      "  [1 1 1 0 1 1]   | 0.3750 |   0.7049  | 1.0000 | 0.0000    |3.1250|3.1250  |  0.0000 \n",
      "  [1 1 1 1 0 0]   | 0.6250 |   0.8576  | 1.0000 | 0.0000    |1.2500|1.2500  |  0.0000 \n",
      "  [1 1 1 1 0 1]   | 0.6875 |   0.8437  | 0.8438 | 0.0003    |1.5625|0.0000  |  1.5625 \n",
      "  [1 1 1 1 1 0]   | 0.9375 |   0.9687  | 0.9688 | 0.0035    |0.3125|0.0000  |  0.3125 \n",
      "  [1 1 1 1 1 1]   | 1.0000 |   1.0000  | 1.0000 | 0.0000    |0.0000|0.0000  |  0.0000 \n",
      "\n",
      "!!!p=0.2\n",
      "boolean signature | imbal? | nacc(fN*) | taccfN* |naccfN*-naccf| S(f) | S(fN*) | S(f) - S(fN*)\n",
      "--------------------------------------------------------------------------\n",
      "  [0 0 0 0 0 0]   | 1.0000 |   1.0000  | 1.0000 | 0.0000    |0.0000|0.0000  |  0.0000 \n",
      "  [0 0 0 0 0 1]   | 0.9375 |   0.9688  | 0.9688 | 0.0108    |0.3125|0.0000  |  0.3125 \n",
      "  [0 0 0 0 1 0]   | 0.6875 |   0.8438  | 0.8438 | 0.0282    |1.5625|0.0000  |  1.5625 \n",
      "  [0 0 0 0 1 1]   | 0.6250 |   0.8273  | 0.8438 | 0.0026    |1.2500|0.3125  |  0.9375 \n",
      "  [0 0 0 1 0 0]   | 0.3750 |   0.6875  | 0.6875 | 0.0285    |3.1250|0.0000  |  3.1250 \n",
      "  [0 0 0 1 0 1]   | 0.3125 |   0.6583  | 0.6875 | 0.0157    |3.4375|0.3125  |  3.1250 \n",
      "  [0 0 0 1 1 0]   | 0.0625 |   0.7057  | 0.9688 | 0.0071    |2.1875|1.8750  |  0.3125 \n",
      "  [0 0 0 1 1 1]   | 0.0000 |   0.7333  | 1.0000 | 0.0000    |1.8750|1.8750  |  0.0000 \n",
      "  [0 0 1 0 0 0]   | 0.3750 |   0.6875  | 0.6875 | 0.0285    |3.1250|0.0000  |  3.1250 \n",
      "  [0 0 1 0 0 1]   | 0.3125 |   0.6563  | 0.6562 | 0.0329    |3.4375|0.0000  |  3.4375 \n",
      "  [0 0 1 0 1 0]   | 0.0625 |   0.5545  | 1.0000 | 0.0000    |4.6875|4.6875  |  0.0000 \n",
      "  [0 0 1 0 1 1]   | 0.0000 |   0.5701  | 1.0000 | 0.0000    |4.3750|4.3750  |  0.0000 \n",
      "  [0 0 1 1 0 0]   | 0.2500 |   0.6640  | 1.0000 | 0.0000    |2.5000|2.5000  |  0.0000 \n",
      "  [0 0 1 1 0 1]   | 0.3125 |   0.6753  | 0.8438 | 0.0213    |2.8125|1.2500  |  1.5625 \n",
      "  [0 0 1 1 1 0]   | 0.5625 |   0.7961  | 0.8125 | 0.0126    |1.5625|0.3125  |  1.2500 \n",
      "  [0 0 1 1 1 1]   | 0.6250 |   0.8273  | 0.8438 | 0.0027    |1.2500|0.3125  |  0.9375 \n",
      "  [0 1 0 0 0 0]   | 0.6875 |   0.8438  | 0.8438 | 0.0283    |1.5625|0.0000  |  1.5625 \n",
      "  [0 1 0 0 0 1]   | 0.6250 |   0.8125  | 0.8125 | 0.0382    |1.8750|0.0000  |  1.8750 \n",
      "  [0 1 0 0 1 0]   | 0.3750 |   0.6875  | 0.6875 | 0.0435    |3.1250|0.0000  |  3.1250 \n",
      "  [0 1 0 0 1 1]   | 0.3125 |   0.6753  | 0.8438 | 0.0214    |2.8125|1.2500  |  1.5625 \n",
      "  [0 1 0 1 0 0]   | 0.0625 |   0.5545  | 1.0000 | 0.0000    |4.6875|4.6875  |  0.0000 \n",
      "  [0 1 0 1 0 1]   | 0.0000 |   0.5389  | 1.0000 | 0.0000    |5.0000|5.0000  |  0.0000 \n",
      "  [0 1 0 1 1 0]   | 0.2500 |   0.6271  | 0.6562 | 0.0200    |3.7500|0.3125  |  3.4375 \n",
      "  [0 1 0 1 1 1]   | 0.3125 |   0.6583  | 0.6875 | 0.0157    |3.4375|0.3125  |  3.1250 \n",
      ">>[0 1 1 0 0 0]   | 0.0625 |   0.7056  | 0.9688 | 0.0071    |2.1875|1.8750  |  0.3125 \n",
      "  [0 1 1 0 0 1]   | 0.0000 |   0.6780  | 0.9375 | 0.0143    |2.5000|1.8750  |  0.6250 \n",
      ">>[0 1 1 0 1 0]   | 0.2500 |   0.6271  | 0.6562 | 0.0200    |3.7500|0.3125  |  3.4375 \n",
      "  [0 1 1 0 1 1]   | 0.3125 |   0.6563  | 0.6562 | 0.0329    |3.4375|0.0000  |  3.4375 \n",
      "  [0 1 1 1 0 0]   | 0.5625 |   0.7961  | 0.8125 | 0.0126    |1.5625|0.3125  |  1.2500 \n",
      "  [0 1 1 1 0 1]   | 0.6250 |   0.8125  | 0.8125 | 0.0382    |1.8750|0.0000  |  1.8750 \n",
      "  [0 1 1 1 1 0]   | 0.8750 |   0.9375  | 0.9375 | 0.0215    |0.6250|0.0000  |  0.6250 \n",
      "  [0 1 1 1 1 1]   | 0.9375 |   0.9688  | 0.9688 | 0.0108    |0.3125|0.0000  |  0.3125 \n",
      "  [1 0 0 0 0 0]   | 0.9375 |   0.9688  | 0.9688 | 0.0108    |0.3125|0.0000  |  0.3125 \n",
      "  [1 0 0 0 0 1]   | 0.8750 |   0.9375  | 0.9375 | 0.0215    |0.6250|0.0000  |  0.6250 \n",
      "  [1 0 0 0 1 0]   | 0.6250 |   0.8125  | 0.8125 | 0.0382    |1.8750|0.0000  |  1.8750 \n",
      "  [1 0 0 0 1 1]   | 0.5625 |   0.7961  | 0.8125 | 0.0126    |1.5625|0.3125  |  1.2500 \n",
      "  [1 0 0 1 0 0]   | 0.3125 |   0.6563  | 0.6562 | 0.0329    |3.4375|0.0000  |  3.4375 \n",
      "  [1 0 0 1 0 1]   | 0.2500 |   0.6271  | 0.6562 | 0.0200    |3.7500|0.3125  |  3.4375 \n",
      ">>[1 0 0 1 1 0]   | 0.0000 |   0.6780  | 0.9375 | 0.0143    |2.5000|1.8750  |  0.6250 \n",
      "  [1 0 0 1 1 1]   | 0.0625 |   0.7056  | 0.9688 | 0.0071    |2.1875|1.8750  |  0.3125 \n",
      "  [1 0 1 0 0 0]   | 0.3125 |   0.6583  | 0.6875 | 0.0157    |3.4375|0.3125  |  3.1250 \n",
      "  [1 0 1 0 0 1]   | 0.2500 |   0.6271  | 0.6562 | 0.0200    |3.7500|0.3125  |  3.4375 \n",
      "  [1 0 1 0 1 0]   | 0.0000 |   0.5389  | 1.0000 | 0.0000    |5.0000|5.0000  |  0.0000 \n",
      "  [1 0 1 0 1 1]   | 0.0625 |   0.5545  | 1.0000 | 0.0000    |4.6875|4.6875  |  0.0000 \n",
      "  [1 0 1 1 0 0]   | 0.3125 |   0.6753  | 0.8438 | 0.0214    |2.8125|1.2500  |  1.5625 \n",
      "  [1 0 1 1 0 1]   | 0.3750 |   0.6875  | 0.6875 | 0.0435    |3.1250|0.0000  |  3.1250 \n",
      "  [1 0 1 1 1 0]   | 0.6250 |   0.8125  | 0.8125 | 0.0382    |1.8750|0.0000  |  1.8750 \n",
      "  [1 0 1 1 1 1]   | 0.6875 |   0.8438  | 0.8438 | 0.0283    |1.5625|0.0000  |  1.5625 \n",
      "  [1 1 0 0 0 0]   | 0.6250 |   0.8273  | 0.8438 | 0.0027    |1.2500|0.3125  |  0.9375 \n",
      "  [1 1 0 0 0 1]   | 0.5625 |   0.7961  | 0.8125 | 0.0126    |1.5625|0.3125  |  1.2500 \n",
      "  [1 1 0 0 1 0]   | 0.3125 |   0.6753  | 0.8438 | 0.0213    |2.8125|1.2500  |  1.5625 \n",
      "  [1 1 0 0 1 1]   | 0.2500 |   0.6640  | 1.0000 | 0.0000    |2.5000|2.5000  |  0.0000 \n",
      "  [1 1 0 1 0 0]   | 0.0000 |   0.5701  | 1.0000 | 0.0000    |4.3750|4.3750  |  0.0000 \n",
      "  [1 1 0 1 0 1]   | 0.0625 |   0.5545  | 1.0000 | 0.0000    |4.6875|4.6875  |  0.0000 \n",
      "  [1 1 0 1 1 0]   | 0.3125 |   0.6563  | 0.6562 | 0.0329    |3.4375|0.0000  |  3.4375 \n",
      "  [1 1 0 1 1 1]   | 0.3750 |   0.6875  | 0.6875 | 0.0285    |3.1250|0.0000  |  3.1250 \n",
      "  [1 1 1 0 0 0]   | 0.0000 |   0.7333  | 1.0000 | 0.0000    |1.8750|1.8750  |  0.0000 \n",
      "  [1 1 1 0 0 1]   | 0.0625 |   0.7057  | 0.9688 | 0.0071    |2.1875|1.8750  |  0.3125 \n",
      "  [1 1 1 0 1 0]   | 0.3125 |   0.6583  | 0.6875 | 0.0157    |3.4375|0.3125  |  3.1250 \n",
      "  [1 1 1 0 1 1]   | 0.3750 |   0.6875  | 0.6875 | 0.0285    |3.1250|0.0000  |  3.1250 \n",
      "  [1 1 1 1 0 0]   | 0.6250 |   0.8273  | 0.8438 | 0.0026    |1.2500|0.3125  |  0.9375 \n",
      "  [1 1 1 1 0 1]   | 0.6875 |   0.8438  | 0.8438 | 0.0282    |1.5625|0.0000  |  1.5625 \n",
      "  [1 1 1 1 1 0]   | 0.9375 |   0.9688  | 0.9688 | 0.0108    |0.3125|0.0000  |  0.3125 \n",
      "  [1 1 1 1 1 1]   | 1.0000 |   1.0000  | 1.0000 | 0.0000    |0.0000|0.0000  |  0.0000 \n",
      "\n",
      "!!!p=0.25\n",
      "boolean signature | imbal? | nacc(fN*) | taccfN* |naccfN*-naccf| S(f) | S(fN*) | S(f) - S(fN*)\n",
      "--------------------------------------------------------------------------\n",
      "  [0 0 0 0 0 0]   | 1.0000 |   1.0000  | 1.0000 | 0.0000    |0.0000|0.0000  |  0.0000 \n",
      "  [0 0 0 0 0 1]   | 0.9375 |   0.9688  | 0.9688 | 0.0164    |0.3125|0.0000  |  0.3125 \n",
      "  [0 0 0 0 1 0]   | 0.6875 |   0.8438  | 0.8438 | 0.0491    |1.5625|0.0000  |  1.5625 \n",
      "  [0 0 0 0 1 1]   | 0.6250 |   0.8208  | 0.8438 | 0.0244    |1.2500|0.3125  |  0.9375 \n",
      "  [0 0 0 1 0 0]   | 0.3750 |   0.6875  | 0.6875 | 0.0598    |3.1250|0.0000  |  3.1250 \n",
      "  [0 0 0 1 0 1]   | 0.3125 |   0.6563  | 0.6875 | 0.0433    |3.4375|0.3125  |  3.1250 \n",
      "  [0 0 0 1 1 0]   | 0.0625 |   0.6630  | 0.9688 | 0.0099    |2.1875|1.8750  |  0.3125 \n",
      "  [0 0 0 1 1 1]   | 0.0000 |   0.6877  | 1.0000 | 0.0000    |1.8750|1.8750  |  0.0000 \n",
      "  [0 0 1 0 0 0]   | 0.3750 |   0.6875  | 0.6875 | 0.0598    |3.1250|0.0000  |  3.1250 \n",
      "  [0 0 1 0 0 1]   | 0.3125 |   0.6562  | 0.6562 | 0.0652    |3.4375|0.0000  |  3.4375 \n",
      "  [0 0 1 0 1 0]   | 0.0625 |   0.5352  | 0.6875 | 0.0067    |4.6875|1.5625  |  3.1250 \n",
      "  [0 0 1 0 1 1]   | 0.0000 |   0.5437  | 0.3750 | 0.0024    |4.3750|1.8750  |  2.5000 \n",
      "  [0 0 1 1 0 0]   | 0.2500 |   0.6436  | 0.6875 | 0.0244    |2.5000|0.6250  |  1.8750 \n",
      "  [0 0 1 1 0 1]   | 0.3125 |   0.6655  | 0.6875 | 0.0500    |2.8125|0.3125  |  2.5000 \n",
      "  [0 0 1 1 1 0]   | 0.5625 |   0.7896  | 0.8125 | 0.0389    |1.5625|0.3125  |  1.2500 \n",
      "  [0 0 1 1 1 1]   | 0.6250 |   0.8208  | 0.8438 | 0.0244    |1.2500|0.3125  |  0.9375 \n",
      "  [0 1 0 0 0 0]   | 0.6875 |   0.8438  | 0.8438 | 0.0491    |1.5625|0.0000  |  1.5625 \n",
      "  [0 1 0 0 0 1]   | 0.6250 |   0.8125  | 0.8125 | 0.0637    |1.8750|0.0000  |  1.8750 \n",
      "  [0 1 0 0 1 0]   | 0.3750 |   0.6875  | 0.6875 | 0.0757    |3.1250|0.0000  |  3.1250 \n",
      "  [0 1 0 0 1 1]   | 0.3125 |   0.6655  | 0.6875 | 0.0500    |2.8125|0.3125  |  2.5000 \n",
      "  [0 1 0 1 0 0]   | 0.0625 |   0.5352  | 0.6875 | 0.0067    |4.6875|1.5625  |  3.1250 \n",
      "  [0 1 0 1 0 1]   | 0.0000 |   0.5156  | 1.0000 | 0.0000    |5.0000|5.0000  |  0.0000 \n",
      "  [0 1 0 1 1 0]   | 0.2500 |   0.6251  | 0.6562 | 0.0487    |3.7500|0.3125  |  3.4375 \n",
      "  [0 1 0 1 1 1]   | 0.3125 |   0.6563  | 0.6875 | 0.0433    |3.4375|0.3125  |  3.1250 \n",
      ">>[0 1 1 0 0 0]   | 0.0625 |   0.6630  | 0.9688 | 0.0099    |2.1875|1.8750  |  0.3125 \n",
      "  [0 1 1 0 0 1]   | 0.0000 |   0.6382  | 0.9375 | 0.0200    |2.5000|1.8750  |  0.6250 \n",
      ">>[0 1 1 0 1 0]   | 0.2500 |   0.6251  | 0.6562 | 0.0487    |3.7500|0.3125  |  3.4375 \n",
      "  [0 1 1 0 1 1]   | 0.3125 |   0.6562  | 0.6562 | 0.0652    |3.4375|0.0000  |  3.4375 \n",
      "  [0 1 1 1 0 0]   | 0.5625 |   0.7896  | 0.8125 | 0.0389    |1.5625|0.3125  |  1.2500 \n",
      "  [0 1 1 1 0 1]   | 0.6250 |   0.8125  | 0.8125 | 0.0637    |1.8750|0.0000  |  1.8750 \n",
      "  [0 1 1 1 1 0]   | 0.8750 |   0.9375  | 0.9375 | 0.0327    |0.6250|0.0000  |  0.6250 \n",
      "  [0 1 1 1 1 1]   | 0.9375 |   0.9688  | 0.9688 | 0.0164    |0.3125|0.0000  |  0.3125 \n",
      "  [1 0 0 0 0 0]   | 0.9375 |   0.9688  | 0.9688 | 0.0164    |0.3125|0.0000  |  0.3125 \n",
      "  [1 0 0 0 0 1]   | 0.8750 |   0.9375  | 0.9375 | 0.0327    |0.6250|0.0000  |  0.6250 \n",
      "  [1 0 0 0 1 0]   | 0.6250 |   0.8125  | 0.8125 | 0.0637    |1.8750|0.0000  |  1.8750 \n",
      "  [1 0 0 0 1 1]   | 0.5625 |   0.7896  | 0.8125 | 0.0389    |1.5625|0.3125  |  1.2500 \n",
      "  [1 0 0 1 0 0]   | 0.3125 |   0.6562  | 0.6562 | 0.0652    |3.4375|0.0000  |  3.4375 \n",
      "  [1 0 0 1 0 1]   | 0.2500 |   0.6251  | 0.6562 | 0.0487    |3.7500|0.3125  |  3.4375 \n",
      ">>[1 0 0 1 1 0]   | 0.0000 |   0.6382  | 0.9375 | 0.0200    |2.5000|1.8750  |  0.6250 \n",
      "  [1 0 0 1 1 1]   | 0.0625 |   0.6630  | 0.9688 | 0.0099    |2.1875|1.8750  |  0.3125 \n",
      "  [1 0 1 0 0 0]   | 0.3125 |   0.6563  | 0.6875 | 0.0433    |3.4375|0.3125  |  3.1250 \n",
      "  [1 0 1 0 0 1]   | 0.2500 |   0.6251  | 0.6562 | 0.0487    |3.7500|0.3125  |  3.4375 \n",
      "  [1 0 1 0 1 0]   | 0.0000 |   0.5156  | 1.0000 | 0.0000    |5.0000|5.0000  |  0.0000 \n",
      "  [1 0 1 0 1 1]   | 0.0625 |   0.5352  | 0.6875 | 0.0067    |4.6875|1.5625  |  3.1250 \n",
      "  [1 0 1 1 0 0]   | 0.3125 |   0.6655  | 0.6875 | 0.0500    |2.8125|0.3125  |  2.5000 \n",
      "  [1 0 1 1 0 1]   | 0.3750 |   0.6875  | 0.6875 | 0.0757    |3.1250|0.0000  |  3.1250 \n",
      "  [1 0 1 1 1 0]   | 0.6250 |   0.8125  | 0.8125 | 0.0637    |1.8750|0.0000  |  1.8750 \n",
      "  [1 0 1 1 1 1]   | 0.6875 |   0.8438  | 0.8438 | 0.0491    |1.5625|0.0000  |  1.5625 \n",
      "  [1 1 0 0 0 0]   | 0.6250 |   0.8208  | 0.8438 | 0.0244    |1.2500|0.3125  |  0.9375 \n",
      "  [1 1 0 0 0 1]   | 0.5625 |   0.7896  | 0.8125 | 0.0389    |1.5625|0.3125  |  1.2500 \n",
      "  [1 1 0 0 1 0]   | 0.3125 |   0.6655  | 0.6875 | 0.0500    |2.8125|0.3125  |  2.5000 \n",
      "  [1 1 0 0 1 1]   | 0.2500 |   0.6436  | 0.6875 | 0.0244    |2.5000|0.6250  |  1.8750 \n",
      "  [1 1 0 1 0 0]   | 0.0000 |   0.5437  | 0.3750 | 0.0024    |4.3750|1.8750  |  2.5000 \n",
      "  [1 1 0 1 0 1]   | 0.0625 |   0.5352  | 0.6875 | 0.0067    |4.6875|1.5625  |  3.1250 \n",
      "  [1 1 0 1 1 0]   | 0.3125 |   0.6562  | 0.6562 | 0.0652    |3.4375|0.0000  |  3.4375 \n",
      "  [1 1 0 1 1 1]   | 0.3750 |   0.6875  | 0.6875 | 0.0598    |3.1250|0.0000  |  3.1250 \n",
      "  [1 1 1 0 0 0]   | 0.0000 |   0.6877  | 1.0000 | 0.0000    |1.8750|1.8750  |  0.0000 \n",
      "  [1 1 1 0 0 1]   | 0.0625 |   0.6630  | 0.9688 | 0.0099    |2.1875|1.8750  |  0.3125 \n",
      "  [1 1 1 0 1 0]   | 0.3125 |   0.6563  | 0.6875 | 0.0433    |3.4375|0.3125  |  3.1250 \n",
      "  [1 1 1 0 1 1]   | 0.3750 |   0.6875  | 0.6875 | 0.0598    |3.1250|0.0000  |  3.1250 \n",
      "  [1 1 1 1 0 0]   | 0.6250 |   0.8208  | 0.8438 | 0.0244    |1.2500|0.3125  |  0.9375 \n",
      "  [1 1 1 1 0 1]   | 0.6875 |   0.8438  | 0.8438 | 0.0491    |1.5625|0.0000  |  1.5625 \n",
      "  [1 1 1 1 1 0]   | 0.9375 |   0.9688  | 0.9688 | 0.0164    |0.3125|0.0000  |  0.3125 \n",
      "  [1 1 1 1 1 1]   | 1.0000 |   1.0000  | 1.0000 | 0.0000    |0.0000|0.0000  |  0.0000 \n",
      "\n",
      "!!!p=0.3\n",
      "boolean signature | imbal? | nacc(fN*) | taccfN* |naccfN*-naccf| S(f) | S(fN*) | S(f) - S(fN*)\n",
      "--------------------------------------------------------------------------\n",
      "  [0 0 0 0 0 0]   | 1.0000 |   1.0000  | 1.0000 | 0.0000    |0.0000|0.0000  |  0.0000 \n",
      "  [0 0 0 0 0 1]   | 0.9375 |   0.9687  | 0.9688 | 0.0207    |0.3125|0.0000  |  0.3125 \n",
      "  [0 0 0 0 1 0]   | 0.6875 |   0.8437  | 0.8438 | 0.0651    |1.5625|0.0000  |  1.5625 \n",
      "  [0 0 0 0 1 1]   | 0.6250 |   0.8143  | 0.8438 | 0.0426    |1.2500|0.3125  |  0.9375 \n",
      "  [0 0 0 1 0 0]   | 0.3750 |   0.6875  | 0.6875 | 0.0811    |3.1250|0.0000  |  3.1250 \n",
      "  [0 0 0 1 0 1]   | 0.3125 |   0.6562  | 0.6562 | 0.0632    |3.4375|0.0000  |  3.4375 \n",
      "  [0 0 0 1 1 0]   | 0.0625 |   0.6253  | 0.9688 | 0.0106    |2.1875|1.8750  |  0.3125 \n",
      "  [0 0 0 1 1 1]   | 0.0000 |   0.6463  | 1.0000 | 0.0000    |1.8750|1.8750  |  0.0000 \n",
      "  [0 0 1 0 0 0]   | 0.3750 |   0.6875  | 0.6875 | 0.0811    |3.1250|0.0000  |  3.1250 \n",
      "  [0 0 1 0 0 1]   | 0.3125 |   0.6562  | 0.6562 | 0.0853    |3.4375|0.0000  |  3.4375 \n",
      "  [0 0 1 0 1 0]   | 0.0625 |   0.5312  | 0.5312 | 0.0163    |4.6875|0.0000  |  4.6875 \n",
      "  [0 0 1 0 1 1]   | 0.0000 |   0.5402  | 0.3750 | 0.0157    |4.3750|1.8750  |  2.5000 \n",
      "  [0 0 1 1 0 0]   | 0.2500 |   0.6324  | 0.6875 | 0.0471    |2.5000|0.6250  |  1.8750 \n",
      "  [0 0 1 1 0 1]   | 0.3125 |   0.6598  | 0.6875 | 0.0714    |2.8125|0.3125  |  2.5000 \n",
      "  [0 0 1 1 1 0]   | 0.5625 |   0.7832  | 0.8125 | 0.0597    |1.5625|0.3125  |  1.2500 \n",
      "  [0 0 1 1 1 1]   | 0.6250 |   0.8143  | 0.8438 | 0.0426    |1.2500|0.3125  |  0.9375 \n",
      "  [0 1 0 0 0 0]   | 0.6875 |   0.8437  | 0.8438 | 0.0651    |1.5625|0.0000  |  1.5625 \n",
      "  [0 1 0 0 0 1]   | 0.6250 |   0.8125  | 0.8125 | 0.0823    |1.8750|0.0000  |  1.8750 \n",
      "  [0 1 0 0 1 0]   | 0.3750 |   0.6875  | 0.6875 | 0.0957    |3.1250|0.0000  |  3.1250 \n",
      "  [0 1 0 0 1 1]   | 0.3125 |   0.6598  | 0.6875 | 0.0714    |2.8125|0.3125  |  2.5000 \n",
      "  [0 1 0 1 0 0]   | 0.0625 |   0.5312  | 0.5312 | 0.0163    |4.6875|0.0000  |  4.6875 \n",
      "  [0 1 0 1 0 1]   | 0.0000 |   0.5051  | 1.0000 | 0.0000    |5.0000|5.0000  |  0.0000 \n",
      "  [0 1 0 1 1 0]   | 0.2500 |   0.6250  | 0.6250 | 0.0671    |3.7500|0.0000  |  3.7500 \n",
      "  [0 1 0 1 1 1]   | 0.3125 |   0.6562  | 0.6562 | 0.0632    |3.4375|0.0000  |  3.4375 \n",
      ">>[0 1 1 0 0 0]   | 0.0625 |   0.6253  | 0.9688 | 0.0106    |2.1875|1.8750  |  0.3125 \n",
      "  [0 1 1 0 0 1]   | 0.0000 |   0.6042  | 0.9375 | 0.0214    |2.5000|1.8750  |  0.6250 \n",
      ">>[0 1 1 0 1 0]   | 0.2500 |   0.6250  | 0.6250 | 0.0671    |3.7500|0.0000  |  3.7500 \n",
      "  [0 1 1 0 1 1]   | 0.3125 |   0.6562  | 0.6562 | 0.0853    |3.4375|0.0000  |  3.4375 \n",
      "  [0 1 1 1 0 0]   | 0.5625 |   0.7832  | 0.8125 | 0.0597    |1.5625|0.3125  |  1.2500 \n",
      "  [0 1 1 1 0 1]   | 0.6250 |   0.8125  | 0.8125 | 0.0823    |1.8750|0.0000  |  1.8750 \n",
      "  [0 1 1 1 1 0]   | 0.8750 |   0.9375  | 0.9375 | 0.0412    |0.6250|0.0000  |  0.6250 \n",
      "  [0 1 1 1 1 1]   | 0.9375 |   0.9687  | 0.9688 | 0.0207    |0.3125|0.0000  |  0.3125 \n",
      "  [1 0 0 0 0 0]   | 0.9375 |   0.9687  | 0.9688 | 0.0207    |0.3125|0.0000  |  0.3125 \n",
      "  [1 0 0 0 0 1]   | 0.8750 |   0.9375  | 0.9375 | 0.0412    |0.6250|0.0000  |  0.6250 \n",
      "  [1 0 0 0 1 0]   | 0.6250 |   0.8125  | 0.8125 | 0.0823    |1.8750|0.0000  |  1.8750 \n",
      "  [1 0 0 0 1 1]   | 0.5625 |   0.7832  | 0.8125 | 0.0597    |1.5625|0.3125  |  1.2500 \n",
      "  [1 0 0 1 0 0]   | 0.3125 |   0.6562  | 0.6562 | 0.0853    |3.4375|0.0000  |  3.4375 \n",
      "  [1 0 0 1 0 1]   | 0.2500 |   0.6250  | 0.6250 | 0.0671    |3.7500|0.0000  |  3.7500 \n",
      ">>[1 0 0 1 1 0]   | 0.0000 |   0.6042  | 0.9375 | 0.0214    |2.5000|1.8750  |  0.6250 \n",
      "  [1 0 0 1 1 1]   | 0.0625 |   0.6253  | 0.9688 | 0.0106    |2.1875|1.8750  |  0.3125 \n",
      "  [1 0 1 0 0 0]   | 0.3125 |   0.6562  | 0.6562 | 0.0632    |3.4375|0.0000  |  3.4375 \n",
      "  [1 0 1 0 0 1]   | 0.2500 |   0.6250  | 0.6250 | 0.0671    |3.7500|0.0000  |  3.7500 \n",
      "  [1 0 1 0 1 0]   | 0.0000 |   0.5051  | 1.0000 | 0.0000    |5.0000|5.0000  |  0.0000 \n",
      "  [1 0 1 0 1 1]   | 0.0625 |   0.5312  | 0.5312 | 0.0163    |4.6875|0.0000  |  4.6875 \n",
      "  [1 0 1 1 0 0]   | 0.3125 |   0.6598  | 0.6875 | 0.0714    |2.8125|0.3125  |  2.5000 \n",
      "  [1 0 1 1 0 1]   | 0.3750 |   0.6875  | 0.6875 | 0.0957    |3.1250|0.0000  |  3.1250 \n",
      "  [1 0 1 1 1 0]   | 0.6250 |   0.8125  | 0.8125 | 0.0823    |1.8750|0.0000  |  1.8750 \n",
      "  [1 0 1 1 1 1]   | 0.6875 |   0.8437  | 0.8438 | 0.0651    |1.5625|0.0000  |  1.5625 \n",
      "  [1 1 0 0 0 0]   | 0.6250 |   0.8143  | 0.8438 | 0.0426    |1.2500|0.3125  |  0.9375 \n",
      "  [1 1 0 0 0 1]   | 0.5625 |   0.7832  | 0.8125 | 0.0597    |1.5625|0.3125  |  1.2500 \n",
      "  [1 1 0 0 1 0]   | 0.3125 |   0.6598  | 0.6875 | 0.0714    |2.8125|0.3125  |  2.5000 \n",
      "  [1 1 0 0 1 1]   | 0.2500 |   0.6324  | 0.6875 | 0.0471    |2.5000|0.6250  |  1.8750 \n",
      "  [1 1 0 1 0 0]   | 0.0000 |   0.5402  | 0.3750 | 0.0157    |4.3750|1.8750  |  2.5000 \n",
      "  [1 1 0 1 0 1]   | 0.0625 |   0.5312  | 0.5312 | 0.0163    |4.6875|0.0000  |  4.6875 \n",
      "  [1 1 0 1 1 0]   | 0.3125 |   0.6562  | 0.6562 | 0.0853    |3.4375|0.0000  |  3.4375 \n",
      "  [1 1 0 1 1 1]   | 0.3750 |   0.6875  | 0.6875 | 0.0811    |3.1250|0.0000  |  3.1250 \n",
      "  [1 1 1 0 0 0]   | 0.0000 |   0.6463  | 1.0000 | 0.0000    |1.8750|1.8750  |  0.0000 \n",
      "  [1 1 1 0 0 1]   | 0.0625 |   0.6253  | 0.9688 | 0.0106    |2.1875|1.8750  |  0.3125 \n",
      "  [1 1 1 0 1 0]   | 0.3125 |   0.6562  | 0.6562 | 0.0632    |3.4375|0.0000  |  3.4375 \n",
      "  [1 1 1 0 1 1]   | 0.3750 |   0.6875  | 0.6875 | 0.0811    |3.1250|0.0000  |  3.1250 \n",
      "  [1 1 1 1 0 0]   | 0.6250 |   0.8143  | 0.8438 | 0.0426    |1.2500|0.3125  |  0.9375 \n",
      "  [1 1 1 1 0 1]   | 0.6875 |   0.8437  | 0.8438 | 0.0651    |1.5625|0.0000  |  1.5625 \n",
      "  [1 1 1 1 1 0]   | 0.9375 |   0.9687  | 0.9688 | 0.0207    |0.3125|0.0000  |  0.3125 \n",
      "  [1 1 1 1 1 1]   | 1.0000 |   1.0000  | 1.0000 | 0.0000    |0.0000|0.0000  |  0.0000 \n"
     ]
    }
   ],
   "source": [
    "# n = 5\n",
    "n = 5\n",
    "k = n\n",
    "# p = 0.2\n",
    "pvals = [0, 0.1, 0.15, 0.2, 0.25, 0.3]\n",
    "\n",
    "X_arr = np.array(list(itertools.product([0, 1], repeat=n)))\n",
    "\n",
    "\n",
    "p_x = 1 / (2 ** k) # uniform distribution over x\n",
    "\n",
    "H = np.array(list(itertools.product([0, 1], repeat=n+1)))\n",
    "mine = [\n",
    "    [1,0,0,1,1,0],\n",
    "    [0,1,1,0,1,0],\n",
    "    [0,1,1,0,0,0]\n",
    "]\n",
    "# H = [[0, 1, 0, 0, 0]]\n",
    "\n",
    "for p in pvals:\n",
    "    print()\n",
    "    print(f\"!!!p={p}\")\n",
    "    print(\"boolean signature | imbal? | nacc(fN*) | taccfN* |naccfN*-naccf| S(f) | S(fN*) | S(f) - S(fN*)\")\n",
    "    print(\"--------------------------------------------------------------------------\")\n",
    "    for i, signature in enumerate(H):\n",
    "        sss = \"  \"\n",
    "        if list(signature) in mine:\n",
    "            sss = \">>\"\n",
    "        hash = dict(zip(range(n+1), signature))\n",
    "        func = lambda b: hash[sum(b)]\n",
    "        \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(product([0,1], repeat=k)):\n",
    "            func_value = func(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=k):\n",
    "                z = np.array(x) ^ np.array(e)\n",
    "                p_x_given_z = p ** sum(e) * (1-p)**(k - 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",
    "        # the function is balanced if the sums of the two rows of true_lookup are equal\n",
    "        imbal = abs(true_lookup[0,:].sum() - true_lookup[1,:].sum())  / 2 ** n\n",
    "        \n",
    "        # if not balanced:\n",
    "        #     continue\n",
    "        # round up to get argmax \n",
    "        noisy_mle = np.round(noisy_lookup)  \n",
    "        out = np.multiply(noisy_mle, true_lookup) / 2 ** n # \"inner product\" of the functions\n",
    "        noiseless_fnstar_acc = 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 = average_sensitivity(func, X_arr)\n",
    "        sensitivity_fnstar = average_sensitivity(fnstar, X_arr)\n",
    "        sensitivity_diff = sensitivity_f - sensitivity_fnstar\n",
    "        # accuracies on dataset\n",
    "        #  = compute_acc_test(fnstar, func, n) # accuracy of fN* on noiseless data\n",
    "\n",
    "        p_zy = generate_noisy_distr(k, p, func)\n",
    "        noisy_f_acc = compute_acc_noisytest(p_zy, func, n) # accuracy of f on noisy data\n",
    "        noisy_fnstar_acc = compute_acc_noisytest(p_zy, fnstar, n) # accuracy of fN* MLE on noisy data\n",
    "        nacc_diff = noisy_fnstar_acc - noisy_f_acc\n",
    "\n",
    "\n",
    "\n",
    "        print(f\"{sss}{signature}   | {imbal:0.4f} |   {noisy_fnstar_acc:1.4f}  | {noiseless_fnstar_acc:1.4f} | {nacc_diff:1.4f}    |{sensitivity_f:1.4f}|{sensitivity_fnstar:1.4f}  |  {sensitivity_diff:1.4f} \")\n",
    "        if sensitivity_fnstar == 0:\n",
    "            topr = sum(noisy_mle[0,:])\n",
    "            botr = sum(noisy_mle[1,:])\n",
    "            assert (np.allclose(topr, 0) or np.allclose(topr, 1 << n))\n",
    "            assert (np.allclose(botr, 0) or np.allclose(botr, 1 << n))\n",
    "\n",
    "    \n",
    "    \n"
   ]
  }
 ],
 "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
}
