{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "from joblib import Parallel, delayed\n",
    "import matplotlib\n",
    "from utils.testing import SeqIndTester,Seq_C_2ST\n",
    "from random import shuffle"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "sns.set(style=\"whitegrid\",\n",
    "        font_scale=1.4,\n",
    "        rc={\n",
    "            \"lines.linewidth\": 2,\n",
    "#             \"axes.facecolor\": \".9\",\n",
    "            'figure.figsize': (8, 6)\n",
    "        })\n",
    "sns.set_palette('Set2')\n",
    "matplotlib.rcParams['text.usetex'] = True"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "First sims"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "im = plt.imread('KDEF_and_AKDEF/KDEF_cropped_gray_group/AN/AF01ANS.JPG')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Scale images to the [0, 1] range\n",
    "x_train = im.astype(\"float32\") / 255"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x14c866290>"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.imshow(im, cmap='gray')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "# create a training dataset\n",
    "import os\n",
    "\n",
    "cand_labels = ['AF', 'AN', 'DI', 'HA', 'NE', 'SA', 'SU']\n",
    "targ_dir = 'KDEF_and_AKDEF/KDEF_cropped_gray_group'\n",
    "list_images = list()\n",
    "list_labels = list()\n",
    "total_cnt = 0\n",
    "for cur_ind, cur_label in enumerate(cand_labels):\n",
    "    cur_dir = os.path.join(targ_dir, cur_label)\n",
    "    cur_cnt = 0\n",
    "    for fname in os.listdir(cur_dir):\n",
    "        if fname.endswith('.JPG'):\n",
    "            cur_cnt +=1\n",
    "            img_src = os.path.join(cur_dir, fname)\n",
    "            im = plt.imread(img_src).astype(\"float32\") / 255\n",
    "            list_images += [im.copy()]\n",
    "            list_labels += [cur_ind]\n",
    "    # total_cnt+=cur_cnt*(cur_cnt-1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "# create a training dataset\n",
    "import os\n",
    "\n",
    "pos_em = ['HA', 'NE', 'SU']\n",
    "neg_em = ['AF', 'AN', 'DI']\n",
    "targ_dir = 'KDEF_and_AKDEF/KDEF_cropped_gray_group'\n",
    "p_images = list()\n",
    "q_images = list()\n",
    "for cur_ind, cur_label in enumerate(pos_em):\n",
    "    cur_dir = os.path.join(targ_dir, cur_label)\n",
    "    cur_cnt = 0\n",
    "    for fname in os.listdir(cur_dir):\n",
    "        if fname.endswith('.JPG'):\n",
    "            cur_cnt += 1\n",
    "            img_src = os.path.join(cur_dir, fname)\n",
    "            im = plt.imread(img_src).astype(\"float32\") / 255\n",
    "            p_images += [im.copy()]\n",
    "\n",
    "for cur_ind, cur_label in enumerate(neg_em):\n",
    "    cur_dir = os.path.join(targ_dir, cur_label)\n",
    "    cur_cnt = 0\n",
    "    for fname in os.listdir(cur_dir):\n",
    "        if fname.endswith('.JPG'):\n",
    "            cur_cnt += 1\n",
    "            img_src = os.path.join(cur_dir, fname)\n",
    "            im = plt.imread(img_src).astype(\"float32\") / 255\n",
    "            q_images += [im.copy()]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(-0.5, 63.5, 63.5, -0.5)"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAeIAAAHiCAYAAAA06c+jAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/NK7nSAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAuUklEQVR4nO3dTW9eZ9W38dO3ManjOEltx0lTN29EJUCpKoTaCoEqoTCACWLAgAFfoDPEgA/AV2AOEsOOOkBqhegAEFABbUmjKk1DSNLWSR3Hcey4wZjgZ1TE/YjzWNezdq570fs5ftPVfe23c+9VS/ufNbG7u7vbJElSif+qPgBJkv5/ZiOWJKmQjViSpEI2YkmSCtmIJUkqZCOWJKmQjViSpEI2YkmSCtmIJUkq9IlR/8O//e1v3dra2lq39ve//x1/94c//GG39sorr8QH9m/84x//wPpf//rXbu2//uvB/79JdDy0z71793ZrCwsL3dq+ffu6tdXVVTweqm9sbOC2PZ/85CexTteAts3WHnroITwe8olPjPzY/DfRs5A93omJiW5tZmamW4vW+s7OTup4Dh482K1NTk7iPre2trq1zc3Nbo3W5crKSrdG74LW+J7RO5HuZfZ5j7Ydx3atxe+vzHZ0ntFzsri42K394Ac/6Naeeuqpbo3WbHRMQ94lH/EvYkmSCtmIJUkqZCOWJKmQjViSpEI2YkmSCtmIJUkqNHIO48MPP+zW6FP9c+fO4e9Sff/+/d0aRaaiT/Wzn6LTdvQ5PsUcon0eOXKkW6MoyPLycrdGcY7WOHZA0R1aB1HkJxvpyEYHKN7VWj5KROe5vb2N+6T7SdeHIkoHDhzo1qanp/F4pqamujW6BrOzs91aFIXJxpeoRu+R9fV1PB6qU43Ok94HUXSH1hetEfrd6Nmk60f7pJ5BsbHomab31xtvvNGtLS0tdWvR+4Du55Br+xH/IpYkqZCNWJKkQjZiSZIK2YglSSpkI5YkqZCNWJKkQiPHl+gz9bt373ZrUXyJPnGnz/zpE/cbN27gPulT9Wx0h85jbm4Oj4eiMjRp5PLly90afeJPx9oanyddd6pF8QCKSND1+0+L7pBo0g+tvfv376dqNFXm0KFDeDx0TyhSRusnivLRNaIJS7QdrZ8ovkTvEooIZo81uj7Z6CW9Y6LIVDZqRLVsHCja9uc//3m3RtOX6D3bGr+/jC9JkvQxZyOWJKmQjViSpEI2YkmSCtmIJUkqZCOWJKmQjViSpEIj54gp30YjCd999138Xcq0ZkdsRWMQKYdG21KNcnrR8Zw+fbpbo6zi6upqt0bZNsqHtsbnQnk6yqzSOMeoTnlXyrNma5HsKLpoBCCh+5nN20d5aFoHZFwZ0WxOlu4XZc2j383eT7oGQ64PrT26dlF2OXue0XuvJ8re0r9bQf9+wi9+8Ytu7YknnsB9Ur+J/o2EUfgXsSRJhWzEkiQVshFLklTIRixJUiEbsSRJhWzEkiQVGjm+RJ+M05isN954A3+XtqXoAH1OHkVT6HP9bAyC4gFHjx7F46F90hg2Og/6pD6KB9C28/Pz3RpFkB599FHc5+HDh1PHQ+eSHeMXoX1SbUh8ie51Ni4UHU92nyRae/QsRDGbzG9GES66fjTqcGtrq1ujd140KpPQtnQeUUwtO/KSjmfU8YD/r2iNvPrqq91a1KeeffbZ7CGNxL+IJUkqZCOWJKmQjViSpEI2YkmSCtmIJUkqZCOWJKnQyN+Q0yfuf/jDH7q1S5cu4e/Sp/EUmaLJHtEEE5KNBNF5LC0t4T4vXLjQrWWn0QyZPDQ3N9etLS4udms0Jenhhx/GfdIxZafukGgyTHYK1xC0brPRlCHxpXEYct2z6Dyja0Dri6aN0XtkcnIS90myMVISPUPZ2Bg90+O6J3QNbt261a29/PLLuM+nnnqqW6P306gxLf8iliSpkI1YkqRCNmJJkgrZiCVJKmQjliSpkI1YkqRCI8eXrly50q298MIL3Vr0aTx9bk5RBvqkfkhEgo6XPqunCUvr6+t4PBRJoH0uLCx0a3SOFLtorbWZmZlujT7Vp1hGFCnLTmqhGt3LaF0OiVdkZc+F7kl2MlNr45n4FEVhxnFtaW1Fx0PnQuudJn9NTEx0a9G7KzuNbci0I5p0R9eHYpD0ToyOle4nRaZoWtbbb7+N+3zttde6taeffrpbi6Z7fcS/iCVJKmQjliSpkI1YkqRCNmJJkgrZiCVJKmQjliSpkI1YkqRCI4fLXnzxxW7t2rVr3dqQ/CgZ1yi67KjD6enpbu327du4T7oGlEekbClt98gjj+Dx7NmzJ/W7NOqQrmtUpyzeqDm9/1uUH6XMYTb3HaH8ZDabO65MLx0rPSdRfjub8R8Xukb0nOzu7qb2t7W1hfVohGkPZYGj3C7dE1oj2Rw6HWtr/MxnR+d+8MEHuE8a9Xv69Olujf6th3/lX8SSJBWyEUuSVMhGLElSIRuxJEmFbMSSJBWyEUuSVGjk+NIvf/nLbi0bn4i2pc/qh4ypozGA9Ik7jfWamprq1tbW1vB4svuk86CY0fz8PB4PxQMookTRimj0YvaeZGNs0bqk607nSb8bxTKyowWz0a8oCkP7pGdzyIhS2md2RGl2VF9r+VGs9JxQnDGKlNEaoutDEckoQkq/S+uAjjUbQWqNjzfbFyiu2BqPn7x8+XK39vjjj+PvfsS/iCVJKmQjliSpkI1YkqRCNmJJkgrZiCVJKmQjliSp0MjxpdXV1W4tO4FjiCFTWrIRicnJyW7t5s2b3VoUp6IJHRRDotjKzMxMtxZFSGiqTMW0LLoGdG1pn9F5ZNc0xTmidUn1bGRqyJQb2pbiJ+OajBZFTDKidUD3OnsNaFIbxZ5a4+NdWVnp1uheR1E+kn3+aK1Hx0P17NqL3tHvvPNOtxbFU0fhX8SSJBWyEUuSVMhGLElSIRuxJEmFbMSSJBWyEUuSVGjk+BJ9ok2fokfxpeyEJfpMnX6zNf78nWIiFOuh6RxRbGVxcbFbo4hENr5EMazW+Bpk42hDYiK0LU1qyUatWovXUA/dryH7zEbu6Dejc8xGTLKTkCLZ60PbRZN+aFu617T26LpG06A2Nze7texErGgd0HnSuWQnV0VRooqJfdeuXevWHkRcz7+IJUkqZCOWJKmQjViSpEI2YkmSCtmIJUkqZCOWJKnQyBmN7MSL6LPw7D4pYhOh46VP9el4qEbTlVrjc6GoEX2qT7954MABPB6KU1FcIRujaS1/T6L4SWZ/rY0nShTtM7ttNpYxJFpI2w55H2QjQTRdiI6VIoCt5dc7rcshkTs6Xrp22fXc2vgm6PVEx5ONhg1B+3T6kiRJH3M2YkmSCtmIJUkqZCOWJKmQjViSpEI2YkmSCtmIJUkqNHKOODvSasiIKNp2SF6MMraUYVtfX0/95sGDB/F46Dxp9GI2K7x//348HsojRtv2ROuA9pldB5QtjY5nyMi07HbZvCZlRLPZ29byzxjdy+gaZMcZZjPP0b9HkB0Jms0fRxna6enpbo2ezSFZ/P/pdRntL3s841qXv/rVr7q1559/Pj6w5l/EkiSVshFLklTIRixJUiEbsSRJhWzEkiQVshFLklRo5PgSoc/Jo/F39Nl4Nq4QGUfk5dixY91aNGqNUCRhfn6+W6PYxbhGhdH1ie5XdgRgtjZkXdKx0r2OYhcU6cjGPegaROuS1lD22YziOSQbYxvXeyR7v7LjS1vLj0EkUXQn+xzRdtG4R5K9Z7T2omtA6+utt95KHc+/8i9iSZIK2YglSSpkI5YkqZCNWJKkQjZiSZIK2YglSSo08nfg9Hl3NkIS1bNTSqLP+LNxK4oOZKcSRfukc6Hrs7Gx0a2tra2ljyd7rEOiMrRtdrpXdDzZ381OZmotP7GH7jXdryjGRudCz1A01Sm7z5WVlW6NrgHVhsRo7t27161tb293azSNbWFhAfeZnfI2ZOIT1alG64C2G9IzaP3QvY72Sc/RkPX+z/0P/gVJkpRmI5YkqZCNWJKkQjZiSZIK2YglSSpkI5YkqdADiS/Rp/HjmuwxZIoLfW5OEYDZ2dlujaI70dSd7DQR+t3r1693a9G1o99dXl7u1u7fv9+tTU5O4j5pHdCUKXLmzJlu7cSJE7jt0aNHu7XspKhxRZuyU5KGxPzI+vp6txZF51ZXV7u1d955p1ujdXn37t1ujY61tXysju71kSNHurX3338fj+f48ePdGkWfqEbXvLVh6zbzm9H+sutyyDS2IdGnUfgXsSRJhWzEkiQVshFLklTIRixJUiEbsSRJhWzEkiQVeiDxpSGTNAh9pk7RgWiiSjZ+QjEauj7Rp/G07c2bN7s1mkYzMTHRrU1NTeHx0PWhWA9FQXZ2dnCfdG0pQkJrhNZBFFshFD8hQyY+0RqhGNKQyAZFgui60/sguu4Ub6JzoTVNkcTFxUU8Hlq3tE9azwcOHOjW6Jq31trrr7+eOh5aI9E6oPuZncpHsvGkyJDI65CI7ij8i1iSpEI2YkmSCtmIJUkqZCOWJKmQjViSpEI2YkmSCtmIJUkqNHKOmDJh2Vpr+QwWZc2GjF6krCflWcnm5ibWKatIoxdnZma6NToPGqXWGudk5+bmujW6J1F+lEZTUo1G3FGOeMioNdrnkNwurS/63XHlLul3s7Uoy7m7u9utbW9vd2s08pLWc/RMU/6WtqXzpLGD9Ly31trVq1e7tY2NjW6NxpBG14DWezZjPGQM4jhE+8ye56j8i1iSpEI2YkmSCtmIJUkqZCOWJKmQjViSpEI2YkmSCj2Q+NKQ7cYRX4r2STESiudQlIGiMvfv38fjofFlhw8f7tYeffTRbo3Og8bCRdvSZ/x0XWl8YmscUaJxjxS9oHsSjSTMjhbMjguNfjc7wm1IlIi2zUbKoud9enq6Wzt9+nS3trCw0K3RCLsoUkbrJBtpOXbsWLcWPZtUv379eup43n//fdxnNq5XEUPKHk90rOOOW/kXsSRJhWzEkiQVshFLklTIRixJUiEbsSRJhWzEkiQVGjm+VCH7KXoUX6I4A8UnKA6TnXzSGk+HOXnyZGq7bOyiNY6mZGM00XYUkchO+qE1QveyNV5D2TjMkIlPdP2yMaMoukN1uj50bbPrpzW+7mtra90aRX7oN1tr7dq1a6lt9+/f361RHC+6JxQtpG3pnly5cgX3eePGjW4tGyPNxmGrjDuK9fG6GpIk/S9jI5YkqZCNWJKkQjZiSZIK2YglSSpkI5YkqdADiS9Fn9yTik/cKXYwMzPTrWU/YZ+fn8c6TSaiGAQdD8WpoutKcYVsbIxiNNG2tL4o9jQETXWia0CxsSHHSrEfiqbQPukcW8tPkqK1d/v2bdwn/e7W1la3RteA4kJ79uzB46FrQLFEWge01mnqV2v5eBy9g2gaVGscb6Lnmq7BkPjpuCch/Tvjjlv5F7EkSYVsxJIkFbIRS5JUyEYsSVIhG7EkSYVsxJIkFbIRS5JUaOQAcDb7NmTsGW07JNdFOeJsrpnyvocPH8bjobwdjRmjvCblKm/evInHs76+3q3dunWrW7t//363Fo2bo2tLeU3KgdJIy6mpKTyezc3Nbo2u7cLCQrcWZUSz2cpsxjjKdtPao7GD169fTx1PVKccMa09+s0huVPaJ91reh88/PDDuE/63SgX3kPvn9Z49GJ2dOeQf3vifyP/IpYkqZCNWJKkQjZiSZIK2YglSSpkI5YkqZCNWJKkQg/kG3L6pD6KKxAa4RZFQQhFXijOQBEc+hw/+lSfYiTZKBFdu8uXL+Px0ChIihKRaAQgnSdFJCh6QWuEzrE1jjfROqBjpRhI9LtRxKQnO66wNY4hra6udmt0L6PYIcXGqEbP2MGDB7u1iYmJ9PEcOHAg9bsXL17s1qI1QnWqDRkdSL9LIybpvUZxz/9E4xqv+BH/IpYkqZCNWJKkQjZiSZIK2YglSSpkI5YkqZCNWJKkQiPHl7Kxnmj6Ev1udnJTFJGgWAvFRGiaz5DjoWjP7du3u7UbN250ax988EG3FkW/rl692q1R7ICuTzTxiY6JJhpRVGZnZye1v9Za293d7dYolkH3K9pndpJNdroQ7a+11u7cudOt0XWn44meBdonobjQhQsXurUoWvjZz362W6PzvHLlSrdG6yCKlNE9o/VOUasoSkTxJTqXcUd+/lM8iPP0L2JJkgrZiCVJKmQjliSpkI1YkqRCNmJJkgrZiCVJKvRApi9R5IeiTa1xBIBiIvTJeBSRoMk7dC7ZiTw0wSWyvb3drdG1oxhNFAv7xje+0a19+tOf7tZ+/OMfd2tLS0u4z+Xl5W7tySef7Nbonvz+97/v1ijq0Vprhw4dwnrP/fv3u7VsHK81Xu/ZyUMUU2stP2mLIi1bW1u4LZ3LmTNnujV6xuieRO+K8+fPd2vf+973ujWaSvTTn/60W1tbW8PjOXr0aLdG7wN6TqJJZBQfPHbsWLdGsTF6t+/duxePh2QjgBFal8aXJEn6mLMRS5JUyEYsSVIhG7EkSYVsxJIkFbIRS5JUaOT4En3mT3EF+ky9NZ78QZ+i08SiKJJAn/JTjaIgFF+KPm+/fv16t0ZTiyjqQJ/qf+ELX8Dj+drXvtat/eY3v+nWaFINRRla4wjFuXPnurXvf//73RpNwKGoR2utnTx5Eus9ND0oimVQRIKeE1pfNCXp8OHDeDwUCZqdne3W5ufnu7VLly7hPmnq1Te/+c1u7Uc/+lG3RmvrzTffxOP54he/mNr2mWee6dYef/zxbi26PnSvszGtKL5E73d6J1IUlN7fQ+JAdJ5DpgRS3fiSJEkfczZiSZIK2YglSSpkI5YkqZCNWJKkQjZiSZIK2YglSSo0co6YMo6Uj6QcY2ucNaNMGGW3orzmnj17ujXK4lEOjc4jyqjRyEL6XUL5PsoFtpa/12+99Va3Fo13W1xc7NYol0q/S+cZjfijbak2ZF3SvaZRdLTP1dXV1Hat8Rqi60dZfFpbrfE62NjY6NZojVCG/ciRI3g89P76zGc+062999573drc3Fy3Rte8Nb62ZGJiolujTHhr/N6j60PP5sWLF7u1ihxxtE/6Ny2if7diFP5FLElSIRuxJEmFbMSSJBWyEUuSVMhGLElSIRuxJEmFRo4vEfosnGIX0bYUE6FIUBSRoE/5aSQYHU/2s/nWOJKQHX+XHanXWmvnz5/v1k6dOtWtffnLX+7WXnvtNdwnRXtovOLrr7/erdG9jCIb2TGbUUSJ0JqmsY0UraB7vbKyMtqB/RsU8yOHDh3COp3nq6++2q0tLS11axThisZh0hhEehZoRCK9f44fP47HQyiWeeDAgW4tWrP03qPYGNWyEcDIg4gS/Tv0Po3e76PwL2JJkgrZiCVJKmQjliSpkI1YkqRCNmJJkgrZiCVJKjRyfIk+KacIQDTd5MMPP+zW6BN3muwRfcJOcSHaNhtRomkrQ1DEhiItt27dwt/985//3K29/fbb3RpNjqEIUmscD1heXu7WdnZ2urUhETeSncIVxcayk8iyz1B0DbLRQoo2UaSstdbu3bvXrdEzTxGckydPdmu7u7t4PPSsUCSP3on0/onel3S8dL/oug+J3NG5UESQnoUoUkbrNhsBjCbkUf8bErf6iH8RS5JUyEYsSVIhG7EkSYVsxJIkFbIRS5JUyEYsSVKhkTMcFJ+gKS6PPfYY/i5NIpmcnOzW6FP0IbEMOk/63SERgOyn8XQedH0oetIax2EoMkW1O3fu4D6zsQy6PnRPosjBI4880q1l4xNRrI62XV9fTx3PkOckO22M9knn0Rq/D2if9Lv0m9EUqaNHj2K9h6I7NJUoitHQPaP425Bnge4nvaNp/QyZvkTRJ4pt0nst2ifVaZ+j8i9iSZIK2YglSSpkI5YkqZCNWJKkQjZiSZIK2YglSSpkI5YkqdADyRGvrq52azTWrLVhebKeISPuKMdHx0P7jPKj2Vwc5WvpeGi76HgoK0x5Q8pOttba9vZ2t7a1tdWtZUdaRuP46BpEWc/M8bSWz11ubGx0a7QOojw5/fsA9CzQOMzo2aSxlnT9KEObvV/RtnSee/bs6daGPJtUp+Ohe0352tb4HUTPHx1r9t9AaI0z0dl3f/RsUt0xiJIkfczZiCVJKmQjliSpkI1YkqRCNmJJkgrZiCVJKjTyt970WThFWqKxZ4uLi6Mewn9Dn7BHEQD6HJ8+Rc+OuIs+jafoBX3Knx2fGMU5xhFNWVtbw33SMU1PT6e2m5ub69aOHDmSPh6Ke1BMJIplZKNG2WONxrdl1zT9Lq2f1vi5vnr1ardG14feB9GzQOMMKeKWjTNGkTL63ezxROsyG8+h88xGL1vjyFQ2fhqdIx2TYxAlSfqYsxFLklTIRixJUiEbsSRJhWzEkiQVshFLklRo5PgSxQooInHp0iX83SeeeKJbo8/qKQYRRaZowgtN+qFP3GkCThTZIBRtoutOUYYoIkGxA7on9Il/FBNZXl7u1rLRlKWlJdwnofOk46EoQ3TdCf0uXVuqDVkHdK+HTKNZWFjo1ugdlJ0AR/Gk1vj5y07LGhJ1pGuQjbhF+yT0nNB7NhvLbI3v2e3bt7u1IROU6PpFcdlR+BexJEmFbMSSJBWyEUuSVMhGLElSIRuxJEmFbMSSJBUaOb5EE5bo8+1osgfFfiYnJ7u1EydOdGvnzp3DfVKcgT5TH0eEpLV8TISuO9WiuALVs9NNomtA50nxL4ppZWNYrfHxZifrDImJZNcBRdyiyMaQaTXZ7bLTtOja0jWIRJOAMrLPe1TPxnOGxM12d3e7NXrGstHLCJ0Lvb+j6559J47Kv4glSSpkI5YkqZCNWJKkQjZiSZIK2YglSSpkI5YkqdDI3+aP69P48+fPd2tnz57t1ujT+OPHj+M+Kb6U/eSeprQMie6QcU3HyUaxhkx4oeuXjS9RNI6iDK0Ni2JlZSe80L2maxDJrqEhEa5s/CR7fYZEuLLb0XmM6/rQuyuK8lGdavSeped9fn4ejyd7DbJrNqoPiX/98/cH/4IkSUqzEUuSVMhGLElSIRuxJEmFbMSSJBWyEUuSVMhGLElSoZEDrNmscJTPunbtWrdGYxApN/ilL30J9/n22293a3QulMWj/FqUWaVzycqOK2wtnxskDz30ULpOOVA6nui6E7on2axidN2zxztkvGL2d7NZ2CiDTXXKRNM+h4wEHfJuG8dvjmMMabTusuudntsjR450a3v37sXj2dzc7NayayRC5/kg3t/+RSxJUiEbsSRJhWzEkiQVshFLklTIRixJUiEbsSRJhUaOL1FMhEZaRZEN+sT9t7/9bbf23HPPpY6ntdYeffTRbu3WrVvd2vb2dreWHZ/YWj4qQ4aM8ctGEsiQT/yHRC96hsREqEbXZ8g1oDWUjQtFz2Y2vkSGvA8o4jYkNpZFx5odvTgk3kWGRBK3tra6tZ2dnW4tG0mMzMzMdGvZ52RItCmKZo7Cv4glSSpkI5YkqZCNWJKkQjZiSZIK2YglSSpkI5YkqdDI35DT5930KfqQCTjnzp3r1r7+9a93a9Hn+PS5OU3+oN+9e/dutzYkJkKyEYAhERK6PkNiItn4yTim47TGMQiKkNDaGhJfovVF92RInCobP6GY35D3AcmuvegZGkccLRuNay0/CSn77mqN40v379/HbXvoukbPbTbGNq740oOYfuZfxJIkFbIRS5JUyEYsSVIhG7EkSYVsxJIkFbIRS5JUaOT8SzaiFMUKKCZCn6nfvHmzWzt+/Djuk+IeGxsb3RqdJ33iH0U26PN3un4UnxjyqX52qsyQWAbJRlOGTLmhuEc20jLkume3o0lkQ6Zw0XOb3S7alp6j7ESsIfGl7PrKvvNa42tAtSHT4SiiRNeAtpucnMR9Ejreikjng+BfxJIkFbIRS5JUyEYsSVIhG7EkSYVsxJIkFbIRS5JUyEYsSVKhkcNRlIuj7GSUoaU6/e6vf/3rbu3AgQO4T8rqUfYtO95tZ2cnfTzZDCRlVqPxbVSn2pAxiNlRYhUjErP3JLo+2eueHccXZVazIx3pPKNngZ6j7AjOIXnyLPpdOh76dwxay2eFNzc3u7UoR0y/S/9+AtVmZmZS27XG/4ZE9t9diAzJoo/Cv4glSSpkI5YkqZCNWJKkQjZiSZIK2YglSSpkI5YkqdDI311TlIE+qY9iIvRJ+d27d7u1t956q1uLPsc/depUt7a+vt6tnThxIrXdwYMH8XgoWkCf41Ocg2S3a42PZ8gn/tkYSTbCtbKygr+bjefcuHGjW1taWsJ9ZmMQtN7pGYriHLTtu+++260NiY3duXOnW6PjpTVN1yd6V9AYyezIRtqOrnlrHKGkc8mOkIzqNM7w3Llz3dr+/fu7NXqXttba2tpat5btU3SfW8vHd0flX8SSJBWyEUuSVMhGLElSIRuxJEmFbMSSJBWyEUuSVGjkvAR9ok2fdkfTlwhFHehTfYo2tdbaxYsXU/uk8zxz5ky3Fk3doXOJptX0DIkS0TXIXp/oGlCdpr9kfzO6BrRPqt2+fbtbo9hF9LsU96DIy5DYxeXLl7u1q1evdms0/Sya+JRF50lrNloH2clNVMvGzVrj6XD0rh0SX6LIFE1KoklSFB+M1mW2p1CMNLoGtE4exAQv/yKWJKmQjViSpEI2YkmSCtmIJUkqZCOWJKmQjViSpEIjx5eGRFNINipDos/bKT5A50Kf3D/xxBPdWjaCFImmlPQsLCyk95mNggyJiWTXAW0XRSSuXbvWrb3//vup7SYmJnCfdD9pchOtZ4qXUCyltdbefPPNbu3KlSvd2tGjR7u1Y8eO4T6za5PeT+OaCpZ979E9id4V2ago3evd3V3cJ9VpchytyyGxuuyUsiG9ZkgUchT+RSxJUiEbsSRJhWzEkiQVshFLklTIRixJUiEbsSRJhR5IfGnIdBP65D4bD4j2SZ/H0wQcmp5Dn+pPTk7i8dBEGjqX6Hd7onhXNu4xJMZGsrGDvXv3dms0Gaa11u7du9etLS8vd2s3btzo1qKIxF/+8pdujSIvdN1pu2j90KQfeoZofdHxtMbxJXoHZac6DZkKNo6pc3TNo+OhWvS7WRSLyj6bQyb2EXpHj2sK16j8i1iSpEI2YkmSCtmIJUkqZCOWJKmQjViSpEI2YkmSCtmIJUkqNHx+U2BcIxLpd6McWjYTTdlTGmF38OBBPB4afUb5P8pOzszMdGtDspPZ3He0z2xWOJtrjnKDhw8f7tZWV1e7tWwmvDXO5lIGktYl3a99+/bh8czOzmK9h/LJe/bswW1pVCTdT7p29LzTvxsQoW2pRus5yvvSuyL7ro22o+t39+7d1D7pN6NcLj1H2XdFlEOn0Z40EnRU/kUsSVIhG7EkSYVsxJIkFbIRS5JUyEYsSVIhG7EkSYVGji9loynjii8N2W4ccRgakTg/P58+HtonRVroNynaFO1zXOPA6HgpmkL3i6I7UZRoaWnpge8zWpc0IpCu7QcffIC/2xNFiSiCQ2uIYk/Rs7C4uNit0XXPxpeGrFm61xQzonUQRS/HMWo0ikzRMVF0LvseoXvZWv59Sb8bRUzPnj3brb300ku47Sj8i1iSpEI2YkmSCtmIJUkqZCOWJKmQjViSpEI2YkmSCo0cX8pGNiLjmPQTyX7+Tq5du9atnTp1CrelGEk2lkHnQdGK6Hezk08i2elL2XsZHStNYzl27Fhqn5HslBuaWETnEcVEsvGc6enp1PG0ll9f2Wchkl1DU1NT3Vr0/P1Pi+JLFGPLTl/KPtOt5SNntB3FFVtr7fOf/3y3RpP3RuVfxJIkFbIRS5JUyEYsSVIhG7EkSYVsxJIkFbIRS5JUaOT4UjaaEn1qPiRikjWOyAtNX6LP/6PfpSgIoYhENH1pHFGiSHaqUzZqFaHozv79+1P7jGJ+2XV59OjR1PFE12cc0cLofZC9nxSjGfKOGUeU7969e6nfbC0fFc3ey9b4/UW17LtiyHOyb98+3LYnipjSM//MM8+k9vmv/ItYkqRCNmJJkgrZiCVJKmQjliSpkI1YkqRCNmJJkgqNnO8Yx8SL1vIRk3HFVrL7zH7i31o8kaYnmp7TQ/GJ1jgCkI2CDFkHdP2yEZIoIkG/S9eAtovu84cffoj1zD5JtH7odzc2Nro1urbRNchG4LLrMrrm2TVE6317exv3mUXHShOWovcTRTMJ3RNae0Oezez7IFoHFI9bXFzEbUfhX8SSJBWyEUuSVMhGLElSIRuxJEmFbMSSJBWyEUuSVMhGLElSoZEDiJQJGzJmLJsbHDKOL5uJpvMkUQ5vbm6uW6P83549e7q1iYmJ1G+2xjm+cdyv1vLrK2vI8WTz5Nncd2ut7d2794HvM8r00nnS9RtynpTnpN/NjpCMZMcO0j2h5y96NrPrckiOmO5J9trSdjRyMNqWjpXW+5UrV3CfKysr3dqNGze6tbNnz+LvfsS/iCVJKmQjliSpkI1YkqRCNmJJkgrZiCVJKmQjliSp0MjxpXGNWsvGDoaMOsz+bjZiQ5++t9ba6dOnu7WdnZ3UPodESCgGQbUhMbbstrQdxTKiWApdv+y9Xl9fT++TRlNSjeIcy8vLeDw0+o3W5fT0dLcWrctxxCSHjEylNUTXIIoE9ezu7mKdzpPGK9J6j46V1sGQZz67XTa6Smvvvffew33+7Gc/69Yonvr888/j737Ev4glSSpkI5YkqZCNWJKkQjZiSZIK2YglSSpkI5YkqdDIGaDsp+jjihkNMa7P6nui6UsUH6CJIRSfmJyc7NampqbweEh28lC0DrKxsWxMJFpbdM9o2sq9e/e6tegaUMSEok80mYniS7R+WuPpXnQutL5mZ2dxnzR5h2JR9GzSsQ6J+WUnLNGzGaHzpH1StCl6hrLPGB0r3ecoWkjPbjRRrCd6t1+8eLFbG9Lj/rn/wb8gSZLSbMSSJBWyEUuSVMhGLElSIRuxJEmFbMSSJBUa/t1148/No8/Cs7EVEm2XnRhCUQe6BtHn+BRNWVpa6taiSS09UXwiOwGHojJRrCA7PYeu3ebmZrcWTVuhKUp0P7PXbgi6BkOiO3TP6Fzo+lDUqrXWFhYWujWaMnXw4MFu7dChQ90ara3W+Dyj+FdP9rmNZI91SFxoHJOQItkJcNk121o+ijUq/yKWJKmQjViSpEI2YkmSCtmIJUkqZCOWJKmQjViSpEI2YkmSCo2cI6ZM4cbGRvoAxpGtHPKb2cxc9jdb48zqyZMnU/scMmota1zXnXKDd+7c6dZodFk0mnJ1dTW1LWWpI9ks9TjWbLQt5UApuxzliCkTTVnhEydOdGuU88xmgVvjcY/0/N29eze9T7rXNAaR1mV2zOEQtJ6jjDFtS9eWfpee99Z47S0vL+O2o/AvYkmSCtmIJUkqZCOWJKmQjViSpEI2YkmSCtmIJUkqNHJ86bHHHuvW6PP3KM6RHVs1rsgGycZzohFbFF+ikWnZUWLR9cle2yEjAKNxdBkTExPdWhRXoEgCXQOK50TnmB2vmF3vQ0a/ETrP6BpQ/eGHH+7W6PqMK56TfRYIrdnWOG5F7wq6BtE6oDhatG1G9JvUUyi+RBHcaK1Tna7PqPyLWJKkQjZiSZIK2YglSSpkI5YkqZCNWJKkQjZiSZIKjfzdNU03uXXrVrcWfYqejWwMkf0cP3s8UXyCJs5QnIM+x6dJLNHn9vfu3evWshGlKLaSjedQhOvIkSPdWnRP6Hgp+kS/S/erNb4vFMvIrstoHVCd7gk9Q/v27cN9Hjt2rFs7dOhQt0brgO5JNA1qe3u7W6MJS3QN6Fije0kRJULHEz2b2fclrRFaz9GzmX0fUOxpbm4O90nHRL1xVP5FLElSIRuxJEmFbMSSJBWyEUuSVMhGLElSIRuxJEmFRo4vPfvss90axZeiT9EpCpKNJAyZpEH7zH6qH8VE6FN+ihbQNYhiImTPnj2p7cYxjaY1vu4U05qZmenWZmdncZ8USaDzpHsSTXyitZedaERrL5reRXW6BhQFWVxcxH0ePHiwW6O4EK33KDaWReuSjpXWSBRPyk76oesT/SatW3p3ZSNu0fHQ9aP3TLaftNbamTNnurXnnnsOtx2FfxFLklTIRixJUiEbsSRJhWzEkiQVshFLklTIRixJUqGRv4V/6qmnujWKJJw7dw5/98UXX+zW6JP78+fPd2tRVCYb98hOMIniVLTPO3fudGt03WnSyNTUFB4PTaSha0CTarKRqNb4flI0hSIk0bQVMo6YUWscoaD7mY3yDZm+lN0uitXRtnSvs8c6RHYSGd2vKFaXjaPRJDJ6bltrbf/+/d1a9p045DmhOl2D7DSx1lo7e/Zst/btb38btx2FfxFLklTIRixJUiEbsSRJhWzEkiQVshFLklTIRixJUiEbsSRJhUYO31FmlTKZND4qqv/xj3/s1mg015UrV3CflDXLjtEakoujfW5ubuK2GTs7O1inTB3VaCRhlO2mOh0v5ZPpeKLReHSeNKqPUD67tdY2Nja6NcqeRjnQnihPnh1rGa2vLMqF070egsYSZq9P9jcj9H6an5/v1ra2tvB3aZzohQsXurW1tbVujZ6/aDznkGvUE72ffve733Vr3/nOdwbv37+IJUkqZCOWJKmQjViSpEI2YkmSCtmIJUkqZCOWJKnQyPGl7Cfj0XZPPvlkt0Yxkc997nPd2k9+8hPc55/+9KdubRxjEKP4EsVaKJZBx0Pj1O7du4fHkx3pSJGEKF5C8QHaNhvdiSIStA7oeChiQ7XomKhG0aZxoYgS3cvofTAxMZHalu4JxYWi2Mo4RGuP0HWnOBq9D+j6tMbXiGKtND6R3hVRzI+iq/QsDBnPSWNIr1271q1F8d2P+BexJEmFbMSSJBWyEUuSVMhGLElSIRuxJEmFbMSSJBUaOb5EkZa7d+92azSZqTX+NJ62XVpa6tYWFhZwny+88EK39sorr+C2PdlJLNG2N2/e7NZoKgp9jh/Fl2jiE8UgKHYQTZHKRoIowkW1CN0TmlZD50HPSWv52BhFWsYV3clOWIqmXmUjXNl4ZXQNsuuS0HlQfKs1vp80iSwbO4x85Stf6dZOnTrVrR07dqxbi6abUZTo5Zdf7tY+9alPpff55ptvdmtR9GkU/kUsSVIhG7EkSYVsxJIkFbIRS5JUyEYsSVIhG7EkSYVGji8RmsBBkzJa44kYR44c6dY2Nja6tdOnT+M+v/Wtb3Vrly5d6tbW1ta6tSHRivX19W6NPtWnT+4pujM9PY3HQ/Ec+l2KL0VRj2wcJiuKidDkGDpWmv5C97k1jspQzCYbQ4rWJdWzcZgDBw7gPmlN07uCrkE2ZjQu2cleEXquab1H8SWK1VEk6Ktf/Wq3Ru+RKA5E95oiU9loXGt8LnQ/R+VfxJIkFbIRS5JUyEYsSVIhG7EkSYVsxJIkFbIRS5JUyEYsSVKhkQNQlPuiDFaUUaMMVjQ2LvObrfGYxO9+97vdGuVk6TdXVlbweF566aVu7datW90a5VIp2x1l5igLSxljuu5RZpXGu1GOkdYXrdkot0zHS+MnSfQsZPPJ2fGJ0T2h/O3U1FS3NiSvSWuIsrB0LnQetO4i2dGUdI50n1vjc6ExiHS/omchm22m9U558SHjOWmfdG2jnkH/nsOQMZIf8S9iSZIK2YglSSpkI5YkqZCNWJKkQjZiSZIK2YglSSo0cnyJPtWnGE000ooiJtk4DP1maxw1evrppx/48czNzeHx0Of6dP0uXLjQrQ2JlNH9pFGQFG2iaEVrHMEhs7Oz3Vo2ytAaR2UoekERNzrW1ngd0JqO1ntPFNmgyAvFaLIjElvj60f3JBsXGoLuFx0PRaaiSBk9R3SeQ0ZB0jrIoudvyPubxuPSOzF6/9B7OHqXjMK/iCVJKmQjliSpkI1YkqRCNmJJkgrZiCVJKmQjliSp0MTukPEjkiRpEP8iliSpkI1YkqRCNmJJkgrZiCVJKmQjliSpkI1YkqRCNmJJkgrZiCVJKmQjliSp0P8Bpvcj270IyIsAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.imshow(p_images[-2], cmap='gray')\n",
    "plt.axis('off')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(-0.5, 63.5, 63.5, -0.5)"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.imshow(q_images[100], cmap='gray')\n",
    "plt.axis('off')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "402"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(p_images)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "400"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(q_images)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [],
   "source": [
    "x_train = np.vstack([np.stack(p_images),np.stack(q_images)])\n",
    "y_train = np.hstack([np.ones(len(p_images)),-np.ones(len(q_images))])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [],
   "source": [
    "t_size = len(y_train)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [],
   "source": [
    "global_sims = 200\n",
    "rej_hist_dep = list()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [],
   "source": [
    "for cur_sim in range(global_sims):\n",
    "    rej_hist_dep += [[]]\n",
    "    # sample data\n",
    "    # cur_order = np.random.choice(ind_array, size=t_size, replace=True)\n",
    "    cur_order = np.arange(t_size)\n",
    "    shuffle(cur_order)\n",
    "    x_tr, y_tr = x_train[cur_order], y_train[cur_order]\n",
    "    # use some data to estimate hyperparam\n",
    "    tester = Seq_C_2ST()\n",
    "    tester.payoff_style = 'classification'\n",
    "    tester.pred_model = 'CNN'\n",
    "    tester.bet_scheme = 'ONS'\n",
    "    for cur_ind in range(t_size):\n",
    "        tester.process_pair(x_tr[cur_ind], y_tr[cur_ind])\n",
    "        if tester.null_rejected:\n",
    "            # account for the first pair\n",
    "            rej_hist_dep[cur_sim] += [True]\n",
    "            rej_hist_dep[cur_sim] += [True for _ in range(t_size-1-cur_ind)]\n",
    "            break\n",
    "            #add break and fill the rest with true\n",
    "        else:\n",
    "            rej_hist_dep[cur_sim] += [False]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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FP39/bDZbFnn3rkM2969e+F2u3PuNJdrMw+iYpj0Atru1ePaRAzvXo4vn1ZnEODxx1eWYMsEERFR5an4ZBhAQcug5arysvJLC8lsVGH7vXq88UFqg406vYAvthiwdYMeksRWCSIiokpTFckwUTWZDEnJr01T1WCjTgDAyjAREVGlqegJdETVZOx6FKGIjMlgqgJcp+dTjIiIqJKxMkxUAsGwjJMuP1QCsLIptamGoAJeejuApjoVtt2jL+MIiYiIKBeWrYhKQAxIaKpToalehetiqk1CkmS8cymCty9Fyjg6IiIiyoeVYaISWNqgxr72etzyxvB//jS+8kljnYB1yzQIhgHNwuzATERERLPEZJiohC5djyE2VRj+/N06NNersX0zM2EiIqJKxTYJohK6ciuW/HrDcm0ZR0JERESFYGWYqEiSLOPvf+uHSS/g2kQqGRYE4ONPo1izRA1B4LJqRERElYjJMFGR/CEZV2/HAAHwTu02p1YB712O4Fe3YvjqZwz43HpdmUdJREREubBNgqhIeq2Av3zQiI7PGnDNE0+GlzWqYTGpsNiignURe4aJiIgqFSvDREXSqgVsWKGFPyQlJ881mgR8fauxvAMjIiKiGbEyTFQik6G0necMfGoRERFVA1aGiYp0bSKGcFSGP5xKhk16TpgjIiKqBkyGiYr0xgdhnHdHsH556ukUjcn4yS99WNmsxiP3s12CiIioUjEZJiqSUS+goU4FrTpVDRYE4LpHYrsEERFRhWMyTFSkr7Qa8JVW4LejweSxVc0afMmmgZYLSRAREVU0JsNEJZI+ga65XoW1S/n0IiIiqnT8Gy5RESQplQBnribBCXRERETVgKUroiL87kIIF69G8dBGPfxpybDHL+Gja1Esa1TBpOdnTiIiokrFd2miIly6HsMtb3ynjcmglDz+zscR/MNZP67cipVraERERFQAVoaJirB7uwlj16NY0aTG+1eiAACdBljWqIJOLaDeyM+bRERElYzJMFERDFoBG1dqMToWgS8Yb5P4zF06fGOrqcwjIyIiokKwbEVUAq9dDCW/3rpBV8aREBER0WwwGSaaA0mW8TOXH+c+DiMYlvDWRxEAgF4LbLlLW+bRERERUaHYJkE0B6EI8PGnUXxyO4ZF9arkShI2qxa+gIR/ei2ApnoV/uIBtksQERFVMibDRHNg1AlYbFFh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",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "[line1] = plt.plot(1+np.arange(t_size), np.mean(rej_hist_dep,axis=0), linewidth=2, color='cornflowerblue', label = 'Seq-C-2ST')\n",
    "\n",
    "plt.plot(1+np.arange(t_size), np.mean(rej_hist_dep,axis=0)-2*np.std(rej_hist_dep,axis=0)/np.sqrt(200), linewidth=1.5,  linestyle='dotted', alpha=0.75,\n",
    "         color='cornflowerblue')\n",
    "plt.plot(1+np.arange(t_size), np.mean(rej_hist_dep,axis=0)+2*np.std(rej_hist_dep,axis=0)/np.sqrt(200), linewidth=1.5,  linestyle='dotted',alpha=0.75,\n",
    "         color='cornflowerblue')\n",
    "\n",
    "plt.xlabel('Sample size', fontsize=18)\n",
    "plt.ylabel('Rejection Rate', fontsize=18)\n",
    "# plt.axhline(y=0.05, label=r'$\\alpha=0.05$', linestyle='dotted', c='gray')\n",
    "plt.legend(bbox_to_anchor=(1, 0.95))\n",
    "plt.savefig('sims_res/img/kdef_res.pdf', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [],
   "source": [
    "with open('sims_res/kdef_cnn_dep_new.npy', 'wb') as f:\n",
    "    np.save(f, rej_hist_dep)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3.10.6 64-bit",
   "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.10.6"
  },
  "orig_nbformat": 4,
  "vscode": {
   "interpreter": {
    "hash": "aee8b7b246df8f9039afb4144a1f6fd8d2ca17a180786b69acc140d282b71a49"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
