{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "9332611f",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Import all utility functions\n",
    "from utility import *\n",
    "from matplotlib.ticker import LogLocator"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "34d716b6",
   "metadata": {},
   "source": [
    "## Real Data: Dynamics of at and qt and Delta"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "52a58a16",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>b</th>\n",
       "      <th>30.83</th>\n",
       "      <th>0</th>\n",
       "      <th>u</th>\n",
       "      <th>g</th>\n",
       "      <th>w</th>\n",
       "      <th>v</th>\n",
       "      <th>1.25</th>\n",
       "      <th>t</th>\n",
       "      <th>t.1</th>\n",
       "      <th>01</th>\n",
       "      <th>f</th>\n",
       "      <th>g.1</th>\n",
       "      <th>00202</th>\n",
       "      <th>0.1</th>\n",
       "      <th>+</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>a</td>\n",
       "      <td>58.67</td>\n",
       "      <td>4.460</td>\n",
       "      <td>u</td>\n",
       "      <td>g</td>\n",
       "      <td>q</td>\n",
       "      <td>h</td>\n",
       "      <td>3.04</td>\n",
       "      <td>t</td>\n",
       "      <td>t</td>\n",
       "      <td>6</td>\n",
       "      <td>f</td>\n",
       "      <td>g</td>\n",
       "      <td>00043</td>\n",
       "      <td>560</td>\n",
       "      <td>+</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>a</td>\n",
       "      <td>24.50</td>\n",
       "      <td>0.500</td>\n",
       "      <td>u</td>\n",
       "      <td>g</td>\n",
       "      <td>q</td>\n",
       "      <td>h</td>\n",
       "      <td>1.50</td>\n",
       "      <td>t</td>\n",
       "      <td>f</td>\n",
       "      <td>0</td>\n",
       "      <td>f</td>\n",
       "      <td>g</td>\n",
       "      <td>00280</td>\n",
       "      <td>824</td>\n",
       "      <td>+</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>b</td>\n",
       "      <td>27.83</td>\n",
       "      <td>1.540</td>\n",
       "      <td>u</td>\n",
       "      <td>g</td>\n",
       "      <td>w</td>\n",
       "      <td>v</td>\n",
       "      <td>3.75</td>\n",
       "      <td>t</td>\n",
       "      <td>t</td>\n",
       "      <td>5</td>\n",
       "      <td>t</td>\n",
       "      <td>g</td>\n",
       "      <td>00100</td>\n",
       "      <td>3</td>\n",
       "      <td>+</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>b</td>\n",
       "      <td>20.17</td>\n",
       "      <td>5.625</td>\n",
       "      <td>u</td>\n",
       "      <td>g</td>\n",
       "      <td>w</td>\n",
       "      <td>v</td>\n",
       "      <td>1.71</td>\n",
       "      <td>t</td>\n",
       "      <td>f</td>\n",
       "      <td>0</td>\n",
       "      <td>f</td>\n",
       "      <td>s</td>\n",
       "      <td>00120</td>\n",
       "      <td>0</td>\n",
       "      <td>+</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>b</td>\n",
       "      <td>32.08</td>\n",
       "      <td>4.000</td>\n",
       "      <td>u</td>\n",
       "      <td>g</td>\n",
       "      <td>m</td>\n",
       "      <td>v</td>\n",
       "      <td>2.50</td>\n",
       "      <td>t</td>\n",
       "      <td>f</td>\n",
       "      <td>0</td>\n",
       "      <td>t</td>\n",
       "      <td>g</td>\n",
       "      <td>00360</td>\n",
       "      <td>0</td>\n",
       "      <td>+</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>684</th>\n",
       "      <td>b</td>\n",
       "      <td>21.08</td>\n",
       "      <td>10.085</td>\n",
       "      <td>y</td>\n",
       "      <td>p</td>\n",
       "      <td>e</td>\n",
       "      <td>h</td>\n",
       "      <td>1.25</td>\n",
       "      <td>f</td>\n",
       "      <td>f</td>\n",
       "      <td>0</td>\n",
       "      <td>f</td>\n",
       "      <td>g</td>\n",
       "      <td>00260</td>\n",
       "      <td>0</td>\n",
       "      <td>-</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>685</th>\n",
       "      <td>a</td>\n",
       "      <td>22.67</td>\n",
       "      <td>0.750</td>\n",
       "      <td>u</td>\n",
       "      <td>g</td>\n",
       "      <td>c</td>\n",
       "      <td>v</td>\n",
       "      <td>2.00</td>\n",
       "      <td>f</td>\n",
       "      <td>t</td>\n",
       "      <td>2</td>\n",
       "      <td>t</td>\n",
       "      <td>g</td>\n",
       "      <td>00200</td>\n",
       "      <td>394</td>\n",
       "      <td>-</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>686</th>\n",
       "      <td>a</td>\n",
       "      <td>25.25</td>\n",
       "      <td>13.500</td>\n",
       "      <td>y</td>\n",
       "      <td>p</td>\n",
       "      <td>ff</td>\n",
       "      <td>ff</td>\n",
       "      <td>2.00</td>\n",
       "      <td>f</td>\n",
       "      <td>t</td>\n",
       "      <td>1</td>\n",
       "      <td>t</td>\n",
       "      <td>g</td>\n",
       "      <td>00200</td>\n",
       "      <td>1</td>\n",
       "      <td>-</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>687</th>\n",
       "      <td>b</td>\n",
       "      <td>17.92</td>\n",
       "      <td>0.205</td>\n",
       "      <td>u</td>\n",
       "      <td>g</td>\n",
       "      <td>aa</td>\n",
       "      <td>v</td>\n",
       "      <td>0.04</td>\n",
       "      <td>f</td>\n",
       "      <td>f</td>\n",
       "      <td>0</td>\n",
       "      <td>f</td>\n",
       "      <td>g</td>\n",
       "      <td>00280</td>\n",
       "      <td>750</td>\n",
       "      <td>-</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>688</th>\n",
       "      <td>b</td>\n",
       "      <td>35.00</td>\n",
       "      <td>3.375</td>\n",
       "      <td>u</td>\n",
       "      <td>g</td>\n",
       "      <td>c</td>\n",
       "      <td>h</td>\n",
       "      <td>8.29</td>\n",
       "      <td>f</td>\n",
       "      <td>f</td>\n",
       "      <td>0</td>\n",
       "      <td>t</td>\n",
       "      <td>g</td>\n",
       "      <td>00000</td>\n",
       "      <td>0</td>\n",
       "      <td>-</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>689 rows × 16 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "     b  30.83       0  u  g   w   v  1.25  t t.1  01  f g.1  00202  0.1  +\n",
       "0    a  58.67   4.460  u  g   q   h  3.04  t   t   6  f   g  00043  560  +\n",
       "1    a  24.50   0.500  u  g   q   h  1.50  t   f   0  f   g  00280  824  +\n",
       "2    b  27.83   1.540  u  g   w   v  3.75  t   t   5  t   g  00100    3  +\n",
       "3    b  20.17   5.625  u  g   w   v  1.71  t   f   0  f   s  00120    0  +\n",
       "4    b  32.08   4.000  u  g   m   v  2.50  t   f   0  t   g  00360    0  +\n",
       "..  ..    ...     ... .. ..  ..  ..   ... ..  ..  .. ..  ..    ...  ... ..\n",
       "684  b  21.08  10.085  y  p   e   h  1.25  f   f   0  f   g  00260    0  -\n",
       "685  a  22.67   0.750  u  g   c   v  2.00  f   t   2  t   g  00200  394  -\n",
       "686  a  25.25  13.500  y  p  ff  ff  2.00  f   t   1  t   g  00200    1  -\n",
       "687  b  17.92   0.205  u  g  aa   v  0.04  f   f   0  f   g  00280  750  -\n",
       "688  b  35.00   3.375  u  g   c   h  8.29  f   f   0  t   g  00000    0  -\n",
       "\n",
       "[689 rows x 16 columns]"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df = pd.read_csv(\"https://archive.ics.uci.edu/ml/machine-learning-databases/credit-screening/crx.data\")\n",
    "df"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "411e3d44",
   "metadata": {},
   "source": [
    "### Read Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "6eaa841b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "   b     x1    x2  y\n",
      "0  a  58.67  3.04  1\n",
      "1  a  24.50  1.50  1\n",
      "2  b  27.83  3.75  1\n",
      "3  b  20.17  1.71  1\n",
      "4  b  32.08  2.50  1\n",
      "0.47342995169082125 0.4432314410480349\n"
     ]
    }
   ],
   "source": [
    "df = pd.read_csv(\"https://archive.ics.uci.edu/ml/machine-learning-databases/credit-screening/crx.data\")\n",
    "df = df[['b','30.83','1.25','+']]\n",
    "df.columns = ['b','x1','x2','y']\n",
    "# preprocessing\n",
    "indexDrop = df[df['x1'] == '?'].index\n",
    "df.drop(indexDrop , inplace=True)\n",
    "df['x1'] = df['x1'].astype(float)\n",
    "df = df.replace(['+','-'],[1,-1])\n",
    "print(df.head())\n",
    "\n",
    "# normalize\n",
    "from sklearn.preprocessing import MinMaxScaler\n",
    "scaler = MinMaxScaler()\n",
    "scaler.fit(df['x1'].to_numpy().reshape(-1, 1))\n",
    "x1_new = scaler.transform(df['x1'].to_numpy().reshape(-1, 1)).reshape(-1)\n",
    "scaler.fit(df['x2'].to_numpy().reshape(-1, 1))\n",
    "x2_new = scaler.transform(df['x2'].to_numpy().reshape(-1, 1)).reshape(-1)\n",
    "df['x1'] = x1_new\n",
    "df['x2'] = x2_new\n",
    "df_a_n = df[(df['y'] == -1) & (df['b'] == 'a')]\n",
    "df_a_p = df[(df['y'] == 1) & (df['b'] == 'a')] \n",
    "df_b_n = df[(df['y'] == -1) & (df['b'] == 'b')]\n",
    "df_b_p = df[(df['y'] == 1) & (df['b'] == 'b')] \n",
    "\n",
    "alpha_a = len(df_a_p)/(len(df_a_p) + len(df_a_n))\n",
    "alpha_b = len(df_b_p)/(len(df_b_p) + len(df_b_n))\n",
    "print(alpha_a, alpha_b)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "94c6aeba",
   "metadata": {},
   "source": [
    "### Fit Beta Distribution"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "fa5b4389",
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_beta(x_range, a, b, mu=0, sigma=1, cdf=False, **kwargs):\n",
    "    '''\n",
    "    Plots the f distribution function for a given x range, a and b\n",
    "    If mu and sigma are not provided, standard beta is plotted\n",
    "    If cdf=True cumulative distribution is plotted\n",
    "    Passes any keyword arguments to matplotlib plot function\n",
    "    '''\n",
    "    x = x_range\n",
    "    if cdf:\n",
    "        y = beta.cdf(x, a, b, mu, sigma)\n",
    "    else:\n",
    "        y = beta.pdf(x, a, b, mu, sigma)\n",
    "    plt.plot(x, y, **kwargs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "7f18efc0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'a': {'p': (1.3706542514718514, 3.228400204907064, -0.001, 1.01), 'n': (1.498600121771358, 4.9391977367467055, -0.001, 1.01)}, 'b': {'p': (1.7273051679440754, 3.8445726915413543, -0.001, 1.01), 'n': (1.5914880665346363, 4.668080970432399, -0.001, 1.01)}} {'a': {'p': (0.6495516045489568, 6.603065071001021, -0.001, 1.01), 'n': (0.5115789917284371, 11.817068374890113, -0.001, 1.01)}, 'b': {'p': (0.5901224407140657, 3.429640130799842, -0.001, 1.01), 'n': (0.542739036698248, 10.99300719338469, -0.001, 1.01)}}\n"
     ]
    }
   ],
   "source": [
    "# save the beta distribution parameters\n",
    "params_1 = {'a':{'p':[],'n':[]},'b':{'p':[],'n':[]}}\n",
    "params_2 = {'a':{'p':[],'n':[]},'b':{'p':[],'n':[]}}\n",
    "\n",
    "# fit parameters\n",
    "params_1['a'] ['n'] = beta.fit(df_a_n['x1'],floc = -0.001, fscale = 1.01)\n",
    "params_1['a'] ['p'] = beta.fit(df_a_p['x1'],floc = -0.001, fscale = 1.01)\n",
    "params_1['b'] ['n'] = beta.fit(df_b_n['x1'],floc = -0.001, fscale = 1.01)\n",
    "params_1['b'] ['p'] = beta.fit(df_b_p['x1'],floc = -0.001, fscale = 1.01)\n",
    "params_2['a'] ['n'] = beta.fit(df_a_n['x2'],floc = -0.001, fscale = 1.01)\n",
    "params_2['a'] ['p'] = beta.fit(df_a_p['x2'],floc = -0.001, fscale = 1.01)\n",
    "params_2['b'] ['n'] = beta.fit(df_b_n['x2'],floc = -0.001, fscale = 1.01)\n",
    "params_2['b'] ['p'] = beta.fit(df_b_p['x2'],floc = -0.001, fscale = 1.01)\n",
    "\n",
    "print(params_1, params_2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "38279256",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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6IuIiAS+MHXdF/ELKvRFjsFms/H5558DsGXLFmw2G8uXL3c+/9tvv3HKKacQHh7ORRddRFpaGjab7aRnUm3evDkTJ048qfcINOq6L76iPBepGZTr1SPcphZ98R3luYvOqINQampwf56vpKSksHv3burWrevcdvfdd9OtWze+++474uLiiImJYffu3SQmJvow0sCkFv2qUZ57h/Jc/I1y3TuU694TruX1qkx57h01Pc/Voi9SSaGhoTRs2JCwMFchunHjRk4//XSaNGlCrVq1iIiICKq1cKuTc3k9FfriQ8pzkZpBue49EZqMT/xETc9zFfpS7crr2tKtWzdSj1xetNlsvPXWW4wcOZKYmBjatGnDl19+6bb/t99+S9u2bYmOjua0005j8uTJbt1uUlNT6datm9trJk6cSPPmzZ2PFy1axFlnnUXdunVJTExkyJAhLF26tMK4S3f/cdzPysri+uuvx2azMXny5HK7/8ybN4/BgwcTHR1NSkoKt99+O7m5uc7nMzIyOP/884mOjqZFixZ8+OGHlf5vGQysI/+qRT+4KM+V51IzKNeV62WF2TRGP9gozwMzz1Xoi1967LHHuOyyy1ixYgUjRozg6quvZt++fQBs376diy++mBEjRrB8+XL+/ve/8+CDD1b5Mw4ePMiYMWOYM2cOCxYsoE2bNowYMYKDBw8e97WOrkAJCQlMnDiR3bt3c/nllx+138qVKxk+fDgXX3wxK1asYNq0acydO5exY8c697n22mvZsmULP//8M9OnT+eVV14hIyOjyj9PoCoOjQIgmnxAhX5NojyvOXkuNZtyvWblepjG6NdIynP/y3OdUYtfuvbaa7nyyisBePLJJ3nxxRf5/fffOfvss3n11Vdp2bIlzz33HDabjXbt2rFy5UqeeuqpKn3G6aef7vb49ddfJykpidmzZ3Peeecd87WOrkA2m43ExEQaNmxY7n7/+9//uOqqq7jzzjsBaNOmDS+88AJDhgzh1VdfZdu2bXz33XcsWLCAvn37AvD222/ToUOHKv0sgawoPBrsh1Xo10DK85qT51KzKddrVq5H2FzN+Cr0aw7luf/luc6oxS916dLFeT82Npb4+HjnlbI1a9bQr18/t7E0/fv3r/JnZGRk8Mgjj/Dzzz+zZ88e7HY7eXl5bNu27eR/gCOWLFnChg0b3Lr0WJZFSUkJmzdvZt26dYSFhdGrVy/n8+3bt6dWrVoei8HfFYXHwOH9xJAHqNCvSZTntTwWg4g/U67X8lgMgSBchX6NpDyv5bEYPEVn1FLtQkJCsCzLbVtRmUFc4eHhbo9tNhslJSUAR732RD/j2muvZe/evUycOJFmzZoRGRlJ//79KSwsrPTPcjwlJSXcdNNN3H777Uc917RpU9auXQsQlBOAVFZxWDSACv0gozw3lOcS7JTrhnLdJQLX70Zj9IOD8twItDzXGbVUu3r16rF7927n45ycHDZv3lzp13fs2NG5PqbDggULjvqM9PR0LMtyJmLpNTQB5syZwyuvvMKIESMAM34oMzOzCj/J8fXo0YNVq1bRunXrcp/v0KEDxcXFLF68mD59+gCwdu3ak17LM5AUhccAxyn0U1PLXwumou3ic8pzF+W5BDPluoty3QgvVejb7cfYUQKG8twlkPJck/FJtTv99NN5//33mTNnDn/++SdjxowhNDS00q+/+eab2bhxI3fffTdr165lypQpTJ482W2foUOHsnfvXiZMmMDGjRt5+eWX+e6779z2ad26Ne+//z5r1qxh4cKFXH311URHR3viR3R64IEHmD9/PrfeeivLly9n/fr1fPnll9x2220AtGvXjrPPPpt//OMfLFy4kCVLlvD3v//d43H4s6Jw87NGUEQYRRRZlf9bEP+lPFeeS82gXFeulxWuFv2gozwPzDxXoS/Vbty4cQwePJjzzjuPESNGcNFFF9GqVatKv75p06Z8+umnfPXVV3Tt2pXXXnuNJ5980m2fDh068Morr/Dyyy/TtWtXfv/9d+699163fd555x32799P9+7dueaaa7j99tupX7++R35Ghy5dujB79mzWr1/PqaeeSvfu3Xn44YdJTk527jNp0iRSUlIYMmQIF198MTfeeKPH4/BnjhZ9MDPvq+t+cFCeK8+lZlCuK9fLCkNj9ION8jxA89yqotmzZ1vnnXeelZycbAHWjBkz3J4vKSmxHn30USs5OdmKioqyhgwZYv3555+Vfv/s7GwLsLKzs6saWo2Sn59vrV692srPz/d1KH7hl19+sQBr//79vg6lWhzr9++JHPJ2npeOc1HrEZYFlgVWA3ZbSeEHrUcftaxfhjxqPfqoZT36qHXk/8pR0fYgolx3qWl5blnezfXqzHMd049Nee6upuV6MB3Ts8Ga0/sux2HdatHCch7Lncf0Gky57lLT8tyyKv79e+tYWeUW/dzcXLp27cpLL71U7vMTJkzg2Wef5aWXXmLRokU0bNiQs846q1LrG4qIf6jOPC/doh9DHgUl4cfYW0Q8RcdzkZqhunM9TF33RfxClfvInnPOOZxzzjnlPmdZFhMnTuShhx7i4osvBuDdd9+lQYMGTJkyhZtuuunkohWRalGdee4Yow+m0D9sD6cSk7OKyEnS8VykZqjuXA8rKSI01EzEp0JfxHc8OkZ/8+bNpKenM2zYMOe2yMhIhgwZwrx588p9TUFBATk5OW43kaoaOnQolmX55RqWweZE8hwqzvXiMi36JYRwZDUWETfK8+rj6TwXqQrlevXxRq6H2IuIiDD3PbjqmQQZ5bn3ebTQT09PB6BBgwZu2xs0aOB8rqzx48eTmJjovKWkpHgyJBHxsBPJc6g414vC3Fv0QScGIr7m6TwXEf/kjVwPLSnCsaS6WvRFfMcrs+471j50sEqth1jWuHHjyM7Odt62b9/ujZBExMOqkudQca6X7boPOjEQ8ReeynMR8W+ezPWQErXoi/gDj65j1bBhQ8BcHSy9BEFGRsZRVwodIiMjiYyM9GQYIuJFJ5LnUHGul52MD1Toi/iap/NcRPyTN3I91O7eom9ZcIxrBiLiJR5t0W/RogUNGzZk1qxZzm2FhYXMnj2bAQMGePKjRMRHPJ3nxeV03VehL+JbOp6L1AzeyPXSLfqWZSblE5HqV+UW/UOHDrFhwwbn482bN7N8+XJq165N06ZNufPOO3nyySdp06YNbdq04cknnyQmJoarrrrKo4GLiPdUZ56rRV/EN3Q8F6kZqjvXS7fog+m+H+bRPsQiUhlVTrvFixdz2mmnOR/ffffdAIwZM4bJkydz//33k5+fzy233ML+/fvp27cvP/zwA/Hx8Z6L+kSkprr/KyIVqs48Lz1GP5p8s02FvojXBezxXESqpLpzPaSkiIgo12Md00V8o8pd9x1LIZS9TZ48GTCTeaSmprJ7924OHz7M7Nmz6dy5s6fjFjmu1NRUunXr5nx87bXXctFFFzkfW5bFjTfeSO3atbHZbCxfvpyhQ4dy5513ntTnTp48OeCXCqnOPFeLvpwM5fmJ0/FcAoly/cRVd66X16IvUhnKc89SR5pgVN29FgKkl8Tzzz+PZVnOxzNnzmTy5MmkpaXRsmVL6taty2effUZ46aOTeJ3G6J8g5Xm5lOcSdJTr5VKu+6+QEvdCX8f0SlCel0t5fnJU6EuNkZiY6PZ448aNJCcnu002U7t27eoOq8ZTi754kvJcpGZQrvuvULtrMj5Qi76cOOX5yfHorPsilZWbm8vo0aOJi4sjOTmZZ555xq3rjc1m4/PPP3d7Ta1atZzdzAAeeOAB2rZtS0xMDC1btuThhx+m6BgVYunuP9deey233XYb27Ztw2az0bx5c4Cjuv8UFhZy//3307hxY2JjY+nbty9paWlu7zt58mSaNm1KTEwMI0eOJCsr6wT/q9RMpcfoq9APLspzkZpBuS6lqUU/OCnPA48KffGJ++67j19++YUZM2bwww8/kJaWxpIlS6r0HvHx8UyePJnVq1fz/PPP8+abb/Lcc89V6rXPP/88jz/+OE2aNGH37t0sWrSo3P2uu+46fvvtNz766CNWrFjBqFGjOPvss1m/fj0ACxcu5Prrr+eWW25h+fLlnHbaafz3v/+t0s9R0xWXKvRjyQV0UhAslOciNYNyXUpTi35wUp4HHnXdl2p36NAh3n77bd577z3OOussAN59912aNGlSpff597//7bzfvHlz7rnnHqZNm8b9999/3NcmJiYSHx9PaGgoDRs2LHefjRs3MnXqVHbs2EGjRo0AuPfee5k5cyaTJk3iySef5Pnnn2f48OE8+OCDALRt25Z58+Yxc+bMKv0sNVlBuGtW33gOAir0g4HyXKRmUK5LWaH2ArXoBxnleWBSoS/VbuPGjRQWFtK/f3/nttq1a9OuXbsqvc/06dOZOHEiGzZs4NChQxQXF5OQkOCxOJcuXYplWbRt29Zte0FBAXXq1AFgzZo1jBw50u35/v37B+WXhbcURsY57yeQY7YVAhEVvEACgvJcpGZQrktZYcUFbi36KvQDn/I8MKnQl2pXevbMithstqP2Kz2GZ8GCBVxxxRU89thjDB8+nMTERD766COeeeYZj8VZUlJCaGgoS5YsITQ01O25uDhTnFbmZ5FjKw6LxsKGDcu9RV+FfkBTnovUDMp1KSus+LCW1wsyyvPApEJfql3r1q0JDw9nwYIFNG3aFID9+/ezbt06hgwZAkC9evXYvXu38zXr168nLy/P+fi3336jWbNmPPTQQ85tW7du9Wic3bt3x263k5GRwamnnlruPh07dmTB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ubY5bgkJ7uciUVHm3+ho1y0qKrB6FRQUkHPkd+TpPLdZfvbNsWnTJlq1auXrMEQC3saNG2npx+sSK9dFPMOfc115LuIZ/pznoFwX8QRP57nftejXPrJ21bZt20j04+XQcnJySElJYfv27SQkJBz/BT6iOD0nEGIEyM7OpmnTps5c8lfKdc8JhBhBcXpaIOS68tyzFKfnBEKMEBh5Dsp1TwqEGEFxepK38tzvCv2QI10tEhMT/faXUVpCQoLi9KBAiDMQYgRXLvkr5brnBUKMoDg9zZ9zXXnuHYrTcwIhRvDvPAflujcEQoygOD3J03nu398aIiIiIiIiIlIlKvRFREREREREgojfFfqRkZE8+uijREZG+jqUY1KcnhUIcQZCjKA4PS0Q4gyEGEFxelogxBkIMYLi9LRAiDMQYgTF6WmBEGcgxAiK05O8FaPfzbovIiIiIiIiIifO71r0RUREREREROTEqdAXERERERERCSIq9EVERERERESCiAp9ERERERERkSDik0L/lVdeoUWLFkRFRdGzZ0/mzJlzzP1nz55Nz549iYqKomXLlrz22mt+F+dnn33GWWedRb169UhISKB///58//33fhdnab/99hthYWF069bNuwEeUdU4CwoKeOihh2jWrBmRkZG0atWKd955x69i/PDDD+natSsxMTEkJydz3XXXkZWV5dUYf/31V84//3waNWqEzWbj888/P+5rAiGHfBWn8tyzAiHPTyTO6s515blv41SuH5vy3HOU676LUXl+fMp1z/BZnlvV7KOPPrLCw8OtN99801q9erV1xx13WLGxsdbWrVvL3X/Tpk1WTEyMdccdd1irV6+23nzzTSs8PNyaPn26X8V5xx13WE899ZT1+++/W+vWrbPGjRtnhYeHW0uXLvWrOB0OHDhgtWzZ0ho2bJjVtWtXr8Z4onFecMEFVt++fa1Zs2ZZmzdvthYuXGj99ttvfhPjnDlzrJCQEOv555+3Nm3aZM2ZM8fq1KmTddFFF3ktRsuyrG+//dZ66KGHrE8//dQCrBkzZhxz/0DJIV/EqTz3fZzVnecnEqcvcl157ts4leuejVF5XjHluu9iVJ57Pk7levl8lefVXuj36dPHuvnmm922tW/f3nrwwQfL3f/++++32rdv77btpptusvr16+e1GC2r6nGWp2PHjtZjjz3m6dDcnGicl19+ufXvf//bevTRR6vly6KqcX733XdWYmKilZWV5fXYHKoa4//+9z+rZcuWbtteeOEFq0mTJl6LsazKfFkESg75Ik7luWcFQp5bVuDluvL85CnXPUd57j3K9eqNsTzKcxflundUZ55Xa9f9wsJClixZwrBhw9y2Dxs2jHnz5pX7mvnz5x+1//Dhw1m8eDFFRUV+E2dZJSUlHDx4kNq1a3sjRODE45w0aRIbN27k0Ucf9VpspZ1InF9++SW9evViwoQJNG7cmLZt23LvvfeSn5/vNzEOGDCAHTt28O2332JZFnv27GH69Omce+65XonxRAVKDlV3nMpzzwqEPD/ROAMh15Xnno2zLOW6oTz3vUDJIR3TyxcIeQ7KdV/zVP6EeTqwY8nMzMRut9OgQQO37Q0aNCA9Pb3c16Snp5e7f3FxMZmZmSQnJ/tFnGU988wz5Obmctlll3k8PocTiXP9+vU8+OCDzJkzh7Cw6vn1n0icmzZtYu7cuURFRTFjxgwyMzO55ZZb2Ldvn1fG+pxIjAMGDODDDz/k8ssv5/DhwxQXF3PBBRfw4osvejy+kxEoOVTdcSrPPSsQ8vxE4wyEXFeeezbOspTrJx6j8tyzAiWHdEwvXyDkOSjXfc1T+eOTyfhsNpvbY8uyjtp2vP3L2+5pVY3TYerUqaSmpjJt2jTq16/vrfCcKhun3W7nqquu4rHHHqNt27Zej6usqvz3LCkpwWaz8eGHH9KnTx9GjBjBs88+y+TJk716ZbAqMa5evZrbb7+dRx55hCVLljBz5kw2b97MzTff7LX4TlSg5JAv4lSee1Yg5HlV4wyUXFeeH5ty3XOU574VKDmkY3rFAiHPQbnuS57In2pt0a9bty6hoaFHXWHJyMg46qqFQ8OGDcvdPywsjDp16vhNnA7Tpk3jhhtu4JNPPuHMM8/0SnwOVY3z4MGDLF68mGXLljF27FjAJKVlWYSFhfHDDz9w+umn+zxOgOTkZBo3bkxiYqJzW4cOHbAsix07dtCmTRufxzh+/HgGDhzIfffdB0CXLl2IjY3l1FNP5b///a9XrqqfiEDJoeqOU3nu2zih+vP8ROMMhFxXnns2Tgfl+snFCMpzTwuUHNIxvXyBkOcnEico1z3JU/lTrS36ERER9OzZk1mzZrltnzVrFgMGDCj3Nf379z9q/x9++IFevXoRHh7uN3GCuRp47bXXMmXKlGoZ51HVOBMSEli5ciXLly933m6++WbatWvH8uXL6du3r1/ECTBw4EB27drFoUOHnNvWrVtHSEgITZo08YsY8/LyCAlxT6HQ0FDAddXNHwRKDlV3nMpz38YJ1Z/nJxpnIOS68tyzcYJy3RMxgvLc0wIlh3RML18g5PmJxAnKdU/yWP5Uaeo+D3AsgfD2229bq1evtu68804rNjbW2rJli2VZlvXggw9a11xzjXN/x/ICd911l7V69Wrr7bffrtZlRCob55QpU6ywsDDr5Zdftnbv3u28HThwwK/iLKu6Zu6sapwHDx60mjRpYl166aXWqlWrrNmzZ1tt2rSx/v73v/tNjJMmTbLCwsKsV155xdq4caM1d+5cq1evXlafPn28FqNlmf82y5Yts5YtW2YB1rPPPmstW7bMuYxIoOaQL+JUnvs2Tl/k+YnE6YtcV577Nk7luudiVJ4fm3LddzEqzz0bp3K9Yr7K82ov9C3Lsl5++WWrWbNmVkREhNWjRw9r9uzZzufGjBljDRkyxG3/tLQ0q3v37lZERITVvHlz69VXX/W7OIcMGWIBR93GjBnjV3GWVV1fFpZV9TjXrFljnXnmmVZ0dLTVpEkT6+6777by8vL8KsYXXnjB6tixoxUdHW0lJydbV199tbVjxw6vxvjLL78c828tUHPIV3Eqzz0rEPL8ROKs7lxXnvs2TuW6Z2NUnldMue67GJXnx6dc9wxf5bnNsvykj4KIiIiIiIiInDSfzLovIiIiIiIiIt6hQl9EREREREQkiKjQFxEREREREQkiKvRFREREREREgogKfREREREREZEgokJfREREREREJIio0BcREREREREJIir0RURERERERIKICn0RERERERGRIKJCXypUUlJC+/bteeCBB9y2f//990RERPDJJ5/4KDIR8STlukjwU56LBD/luZSmQl8qFBISwrhx43j11VfZv38/AH/88QejRo3iySefZNSoUT6OUEQ8QbkuEvyU5yLBT3kupdksy7J8HYT4r+LiYtq2bcuYMWO44YYb6NevHxdeeCEvv/yyr0MTEQ9SrosEP+W5SPBTnouDCn05rtdff51//etfNG7cmObNmzNjxgxCQ0N9HZaIeJhyXST4Kc9Fgp/yXEBd96USrr76avLy8rAsi6lTpx71RTFy5EiSkpK49NJLfRShiHjCsXJ9+/btDB06lI4dO9KlSxeN8xMJUDqmiwQ/Hc8FVOhLJYwdOxaAzMzMcq8G3n777bz33nvVHZaIeNixcj0sLIyJEyeyevVqfvzxR+666y5yc3N9EaaInAQd00WCn47nAir05TgefvhhvvnmGxYsWEBxcTFvv/32UfucdtppxMfH+yA6EfGU4+V6cnIy3bp1A6B+/frUrl2bffv2+SBSETlROqaLBD8dz8VBhb5U6K233uKZZ57hq6++omvXrtx5551MmDCBoqIiX4cmIh5U1VxfvHgxJSUlpKSkVHOkInKidEwXCX46nktpKvSlXN999x233norH3zwAf369QPgtttuIycnh/fff9/H0YmIp1Q117Oyshg9ejRvvPFGdYcqIidIx3SR4KfjuZSlQl+OsmTJEkaNGsWECRO4+OKLndsTEhK47bbb+L//+z/sdrsPIxQRT6hqrhcUFDBy5EjGjRvHgAEDfBGyiFSRjukiwU/HcymPltcTj0hLS+Oll15i+vTpvg5FRLzAsiyuuuoq2rVrR2pqqq/DEREv0jFdJHjpeF5zqNCXkzZ8+HCWLl1Kbm4utWvXZsaMGfTu3dvXYYmIB82dO5fBgwfTpUsX57b333+fU045xYdRiYin6ZguEtx0PK85VOiLiIiIiIiIBBGN0RcREREREREJIir0RURERERERIKICn0RERERERGRIKJCX0RERERERCSIqNAXERERERERCSIq9EVERERERESCiAp9ERERERERkSCiQl9EREREREQkiKjQFxEREREREQkiKvRFREREREREgogKfREREREREZEgokJfREREREREJIj8P8RmfclTbogjAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 1200x250 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# plot the distribution\n",
    "x = np.linspace(0, 1, 500)\n",
    "fig = plt.figure(figsize=(12, 2.5))\n",
    "\n",
    "# group a and X1\n",
    "plt.subplot(1,4,1)\n",
    "plt.ylim(0.1, 11.6)\n",
    "plt.xlim(0, 1)\n",
    "plot_beta(x, params_1['a'] ['n'][0], params_1['a'] ['n'][1], 0, 1, color='blue', lw=2, ls='-')\n",
    "plot_beta(x, params_1['a'] ['p'][0], params_1['a'] ['p'][1], 0, 1, color='red', lw=2, ls='-')\n",
    "plt.hist(df_a_n['x1'], density=True, color = 'blue', bins=10, label='unqualified',alpha=0.5)\n",
    "plt.hist(df_a_p['x1'], density=True, bins=100, color = 'red', label='qualified',alpha=0.5)\n",
    "plt.title(r\"Group $i$\")\n",
    "plt.xlabel(r'$X_1$')\n",
    "plt.legend()\n",
    "\n",
    "\n",
    "# group a and X2\n",
    "plt.subplot(1,4,2)\n",
    "plt.ylim(0.1, 11.6)\n",
    "plt.xlim(0, 1)\n",
    "plot_beta(x, params_2['a'] ['n'][0], params_2['a'] ['n'][1], 0, 1, color='blue', lw=2, ls='-')\n",
    "plot_beta(x, params_2['a'] ['p'][0], params_2['a'] ['p'][1], 0, 1, color='red', lw=2, ls='-')\n",
    "plt.hist(df_a_n['x2'], density=True, color = 'blue', bins=10, label='unqualified',alpha=0.5)\n",
    "plt.hist(df_a_p['x2'], density=True, bins=100, color = 'red', label='qualified',alpha=0.5)\n",
    "plt.title(r\"Group $i$\")\n",
    "plt.xlabel(r'$X_2$')\n",
    "plt.legend()\n",
    "\n",
    "\n",
    "# group b and X1\n",
    "plt.subplot(1,4,3)\n",
    "plt.ylim(0.1, 11.6)\n",
    "plt.xlim(0, 1)\n",
    "plot_beta(x, params_1['b'] ['n'][0], params_1['b'] ['n'][1], 0, 1, color='blue', lw=2, ls='-')\n",
    "plot_beta(x, params_1['b'] ['p'][0], params_1['b'] ['p'][1], 0, 1, color='red', lw=2, ls='-')\n",
    "plt.hist(df_b_n['x1'], density=True, color = 'blue', bins=10, label='unqualified',alpha=0.5)\n",
    "plt.hist(df_b_p['x1'], density=True, bins=100, color = 'red', label='qualified',alpha=0.5)\n",
    "plt.title(r\"Group $j$\")\n",
    "plt.xlabel(r'$X_1$')\n",
    "plt.legend()\n",
    "\n",
    "\n",
    "# group b and X2\n",
    "plt.subplot(1,4,4)\n",
    "plt.ylim(0.1, 11.6)\n",
    "plt.xlim(0, 1)\n",
    "plot_beta(x, params_2['b'] ['n'][0], params_2['b'] ['n'][1], 0, 1, color='blue', lw=2, ls='-')\n",
    "plot_beta(x, params_2['b'] ['p'][0], params_2['b'] ['p'][1], 0, 1, color='red', lw=2, ls='-')\n",
    "plt.hist(df_b_n['x2'], density=True, color = 'blue', bins=10, label='unqualified',alpha=0.5)\n",
    "plt.hist(df_b_p['x2'], density=True, bins=100, color = 'red', label='qualified',alpha=0.5)\n",
    "plt.title(r\"Group $j$\")\n",
    "plt.xlabel(r'$X_2$')\n",
    "plt.legend()\n",
    "\n",
    "plt.subplots_adjust(left=0.1,\n",
    "                    bottom=0.1,\n",
    "                    right=0.9,\n",
    "                    top=0.9,\n",
    "                    wspace=0.2,\n",
    "                    hspace=0.4)\n",
    "plt.show()\n",
    "fig.savefig('plots_new/feature_dist_real.pdf', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "04f2902c",
   "metadata": {},
   "source": [
    "### Verify the monotone likelihood "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1320bd23",
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_monotone(x_range, a0, b0, a1, b1, mu=0, sigma=1, **kwargs):\n",
    "    '''\n",
    "    Plots the f distribution function for a given x range, a and b\n",
    "    If mu and sigma are not provided, standard beta is plotted\n",
    "    If cdf=True cumulative distribution is plotted\n",
    "    Passes any keyword arguments to matplotlib plot function\n",
    "    '''\n",
    "    x = x_range\n",
    "    y0 = beta.pdf(x, a0, b0, mu, sigma)\n",
    "    y1 = beta.pdf(x, a1, b1, mu, sigma)\n",
    "    ratio_10 = y1/y0\n",
    "    plt.plot(x, ratio_10, **kwargs)\n",
    "    plt.yscale('log')\n",
    "\n",
    "\n",
    "fig = plt.figure(figsize=(6,2.5))   \n",
    "ax = fig.add_subplot(121)\n",
    "plt.xlim(0, 1)\n",
    "plt.ylim(0.1, 10**5)\n",
    "plot_monotone(x,params_1['a'] ['n'][0],params_1['a'] ['n'][1],params_1['a'] ['p'][0],params_1['a'] ['p'][1], 0, 1, lw=1.5, ls='-',label = 'Group a')\n",
    "plot_monotone(x,params_1['b'] ['n'][0],params_1['b'] ['n'][1],params_1['b'] ['p'][0],params_1['b'] ['p'][1], 0, 1, lw=1.5, ls='-',label = 'Group b')\n",
    "ax.yaxis.set_major_locator(LogLocator(base=10**5))\n",
    "ax.set_xlabel(r'$X_1$')\n",
    "plt.legend()\n",
    "ax = fig.add_subplot(122)\n",
    "plt.xlim(0, 1)\n",
    "plt.ylim(0.1, 10**5)\n",
    "plot_monotone(x,params_2['a'] ['n'][0],params_2['a'] ['n'][1],params_2['a'] ['p'][0],params_2['a'] ['p'][1], 0, 1, lw=1.5, ls='-',label = 'Group a')\n",
    "plot_monotone(x,params_2['b'] ['n'][0],params_2['b'] ['n'][1],params_2['b'] ['p'][0],params_2['b'] ['p'][1], 0, 1, lw=1.5, ls='-',label = 'Group b')\n",
    "ax.yaxis.set_major_locator(LogLocator(base=10**5))\n",
    "ax.set_xlabel(r'$X_2$')\n",
    "plt.legend()\n",
    "plt.minorticks_off()\n",
    "fig.savefig('plots_new/monotone.pdf', bbox_inches='tight')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3ccefba6",
   "metadata": {},
   "source": [
    "### Experiment Begins"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "72337589",
   "metadata": {},
   "outputs": [],
   "source": [
    "n = 100\n",
    "T = 15\n",
    "Q = np.array([[5,0], [0,5]])\n",
    "N = 2000\n",
    "alphas = {'a':alpha_a, 'b':alpha_b}\n",
    "tp=2"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "fa38e7a4",
   "metadata": {},
   "source": [
    "Group $i$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "db97bc3f",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "# ratio = 0.1\n",
    "ratio = 0.1\n",
    "np.random.seed(42)\n",
    "r = 0.1\n",
    "bias = 'up'\n",
    "mag = 0.1\n",
    "des = f\"real_setting_ratio{r}_bias{bias}_mag{mag}\"\n",
    "At, Qt, At_sd, Qt_sd = simulation(Q,N,n,T,alphas,bias,mag,tp,r,params_1=params_1,params_2=params_2,sd=True)\n",
    "plot_save_single(At, Qt, des, True)\n",
    "plot_save_single_err(At, Qt, At_sd, Qt_sd, des, True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8a3dd9d3",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "# ratio = 0.05\n",
    "np.random.seed(42)\n",
    "r = 0.05\n",
    "bias = 'up'\n",
    "mag = 0.1\n",
    "des = f\"real_setting_ratio{r}_bias{bias}_mag{mag}\"\n",
    "At, Qt, At_sd, Qt_sd = simulation(Q,N,n,T,alphas,bias,mag,tp,r,params_1=params_1,params_2=params_2,sd=True)\n",
    "plot_save_single(At, Qt, des, True)\n",
    "plot_save_single_err(At, Qt, At_sd, Qt_sd, des, True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ac9d9dc1",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "# ratio = 0\n",
    "np.random.seed(42)\n",
    "r = 0\n",
    "bias = 'up'\n",
    "mag = 0.1\n",
    "des = f\"real_setting_ratio{r}_bias{bias}_mag{mag}\"\n",
    "At, Qt, At_sd, Qt_sd = simulation(Q,N,n,T,alphas,bias,mag,tp,r,params_1=params_1,params_2=params_2,sd=True)\n",
    "plot_save_single(At, Qt, des, True)\n",
    "plot_save_single_err(At, Qt, At_sd, Qt_sd, des, True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fadbc334",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "#infinite horizon to verify the limit\n",
    "n = 20\n",
    "T = 45\n",
    "np.random.seed(42)\n",
    "r = 0\n",
    "bias = 'up'\n",
    "mag = 0.1\n",
    "des = f\"infinite_real_ratio{r}_bias{bias}_mag{mag}\"\n",
    "At, Qt, At_sd, Qt_sd = simulation(Q,N,n,T,alphas,bias,mag,tp,r,params_1=params_1,params_2=params_2,sd=True)\n",
    "plot_save_single(At, Qt, des, save=True,limit=True)\n",
    "plot_save_single_err(At, Qt, At_sd, Qt_sd, des,save=True,limit=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e15767c8",
   "metadata": {},
   "source": [
    "Group $j$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e7f6ee3f",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "# ratio = 0.1\n",
    "np.random.seed(42)\n",
    "r = 0.1\n",
    "bias = 'up'\n",
    "mag = 0.1\n",
    "des = f\"real_setting_ratio{r}_bias{bias}_mag{mag}\"\n",
    "At, Qt, At_sd, Qt_sd = simulation(Q,N,n,T,alphas,bias,mag,tp,r,params_1=params_1,params_2=params_2,group='b',sd=True)\n",
    "plot_save_single(At, Qt, des, True)\n",
    "plot_save_single_err(At, Qt, At_sd, Qt_sd, des, True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0400a83a",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "# ratio 0.05\n",
    "np.random.seed(42)\n",
    "r = 0.05\n",
    "bias = 'down'\n",
    "mag = 0.1\n",
    "des = f\"real_setting_ratio{r}_bias{bias}_mag{mag}\"\n",
    "At, Qt, At_sd, Qt_sd = simulation(Q,N,n,T,alphas,bias,mag,tp,r,params_1=params_1,params_2=params_2,group='b',sd=True)\n",
    "plot_save_single(At, Qt, des,True)\n",
    "plot_save_single_err(At, Qt, At_sd, Qt_sd, des,True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dff6ba55",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "# ratio 0\n",
    "np.random.seed(42)\n",
    "r = 0\n",
    "bias = 'down'\n",
    "mag = 0.1\n",
    "des = f\"real_setting_ratio{r}_bias{bias}_mag{mag}\"\n",
    "# At, Qt, At_sd, Qt_sd = simulation(Q,N,n,T,alphas,bias,mag,tp,r,params_1=params_1,params_2=params_2,group='b',sd=True)\n",
    "plot_save_single(At, Qt, des, True)\n",
    "plot_save_single_err(At, Qt, At_sd, Qt_sd, des, True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c581e941",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "#infinite horizon to verify the limit\n",
    "np.random.seed(42)\n",
    "n = 5\n",
    "T = 45\n",
    "r = 0\n",
    "bias = 'down'\n",
    "mag = 0.1\n",
    "des = f\"infinite_real_ratio{r}_bias{bias}_mag{mag}\"\n",
    "At, Qt, At_sd, Qt_sd = simulation(Q,N,n,T,alphas,bias,mag,tp,r,params_1=params_1,params_2=params_2,group='b',sd=True)\n",
    "plot_save_single(At, Qt, des,save=True,limit=True)\n",
    "plot_save_single_err(At, Qt, At_sd, Qt_sd, des,save=True,limit=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "6ea8d022",
   "metadata": {},
   "source": [
    "Refined retraining process for $i$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "aaa48b00",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "# ratio 0.1\n",
    "np.random.seed(42)\n",
    "r = 0.1\n",
    "bias = 'up'\n",
    "mag = 0.1\n",
    "des = f\"real_sampler_ratio{r}_bias{bias}_mag{mag}\"\n",
    "At, Qt, At_sd, Qt_sd = simulation(Q,N,n,T,alphas,bias,mag,tp,r,params_1=params_1,params_2=params_2,group='a',sd=True,refined = True)\n",
    "plot_save_single(At, Qt, des, True)\n",
    "plot_save_single_err(At, Qt, At_sd, Qt_sd, des, True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "884bccd2",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "# ratio 0.05\n",
    "np.random.seed(42)\n",
    "r = 0.05\n",
    "bias = 'up'\n",
    "mag = 0.1\n",
    "des = f\"real_sampler_ratio{r}_bias{bias}_mag{mag}\"\n",
    "At, Qt, At_sd, Qt_sd = simulation(Q,N,n,T,alphas,bias,mag,tp,r,params_1=params_1,params_2=params_2,group='a',sd=True,refined = True)\n",
    "plot_save_single(At, Qt, des, True)\n",
    "plot_save_single_err(At, Qt, At_sd, Qt_sd, des, True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "848023fc",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "# ratio 0\n",
    "np.random.seed(42)\n",
    "r = 0\n",
    "bias = 'up'\n",
    "mag = 0.1\n",
    "des = f\"real_sampler_ratio{r}_bias{bias}_mag{mag}\"\n",
    "At, Qt, At_sd, Qt_sd = simulation(Q,N,n,T,alphas,bias,mag,tp,r,params_1=params_1,params_2=params_2,group='a',sd=True,refined = True)\n",
    "plot_save_single(At, Qt, des, True)\n",
    "plot_save_single_err(At, Qt, At_sd, Qt_sd, des, True)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9961e0b8",
   "metadata": {},
   "source": [
    "Refined retraining process for $j$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "123811bf",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "# ratio 0.1\n",
    "np.random.seed(42)\n",
    "r = 0.1\n",
    "bias = 'down'\n",
    "mag = 0\n",
    "des = f\"real_sampler_ratio{r}_bias{bias}_mag{mag}\"\n",
    "At, Qt, At_sd, Qt_sd = simulation(Q,N,n,T,alphas,bias,mag,tp,r,params_1=params_1,params_2=params_2,group='b',sd=True,refined = True)\n",
    "plot_save_single(At, Qt, des, True)\n",
    "plot_save_single_err(At, Qt, At_sd, Qt_sd, des, True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ca9086ed",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "# ratio 0.05\n",
    "np.random.seed(42)\n",
    "r = 0.05\n",
    "bias = 'down'\n",
    "mag = 0.1\n",
    "des = f\"real_sampler_ratio{r}_bias{bias}_mag{mag}\"\n",
    "At, Qt, At_sd, Qt_sd = simulation(Q,N,n,T,alphas,bias,mag,tp,r,params_1=params_1,params_2=params_2,group='b',sd=True,refined = True)\n",
    "plot_save_single(At, Qt, des, True)\n",
    "plot_save_single_err(At, Qt, At_sd, Qt_sd, des, True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fcbc3445",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "# ratio 0\n",
    "np.random.seed(42)\n",
    "r = 0\n",
    "bias = 'down'\n",
    "mag = 0.1\n",
    "des = f\"real_sampler_ratio{r}_bias{bias}_mag{mag}\"\n",
    "At, Qt, At_sd, Qt_sd = simulation(Q,N,n,T,alphas,bias,mag,tp,r,params_1=params_1,params_2=params_2,group='b',sd=True,refined = True)\n",
    "plot_save_single(At, Qt, des, True)\n",
    "plot_save_single_err(At, Qt, At_sd, Qt_sd, des, True)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "fac0e0b2",
   "metadata": {},
   "source": [
    "Unfairness and bias"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d4d645e9",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "# ratio = 0.1\n",
    "# read i\n",
    "r = 0.1\n",
    "bias = 'up'\n",
    "mag = 0.1\n",
    "des = f\"real_sampler_ratio{r}_bias{bias}_mag{mag}\"\n",
    "Ati_mean, Qti_mean, Ati_sd, Qti_sd = read_results(des)\n",
    "    \n",
    "# read j\n",
    "r = 0.1\n",
    "bias = 'down'\n",
    "mag = 0.1\n",
    "des = f\"real_setting_ratio{r}_bias{bias}_mag{mag}\"\n",
    "Atj_mean, Qtj_mean, Atj_sd, Qtj_sd = read_results(des)\n",
    "    \n",
    "\n",
    "# Plot\n",
    "des = f\"real_setting_ratio{r}_mag{mag}\"\n",
    "plot_save_fairness(Ati_mean, Atj_mean, Qti_mean, Qtj_mean, des, True)\n",
    "plot_save_fairness_err(Ati_mean, Atj_mean, Qti_mean, Qtj_mean, Ati_sd, Qti_sd, Atj_sd, Qtj_sd, des, True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a3437fbe",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "# ratio = 0.05\n",
    "# read i\n",
    "r = 0.05\n",
    "bias = 'up'\n",
    "mag = 0.1\n",
    "des = f\"real_sampler_ratio{r}_bias{bias}_mag{mag}\"\n",
    "Ati_mean, Qti_mean, Ati_sd, Qti_sd = read_results(des)\n",
    "    \n",
    "# read j\n",
    "r = 0.05\n",
    "bias = 'down'\n",
    "mag = 0.1\n",
    "des = f\"real_setting_ratio{r}_bias{bias}_mag{mag}\"\n",
    "Atj_mean, Qtj_mean, Atj_sd, Qtj_sd = read_results(des)\n",
    "    \n",
    "\n",
    "# Plot\n",
    "des = f\"real_setting_ratio{r}_mag{mag}\"\n",
    "plot_save_fairness(Ati_mean, Atj_mean, Qti_mean, Qtj_mean, des, True)\n",
    "plot_save_fairness_err(Ati_mean, Atj_mean, Qti_mean, Qtj_mean, Ati_sd, Qti_sd, Atj_sd, Qtj_sd, des, True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1236ede1",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "# ratio = 0\n",
    "# read i\n",
    "r = 0\n",
    "bias = 'up'\n",
    "mag = 0.1\n",
    "des = f\"real_sampler_ratio{r}_bias{bias}_mag{mag}\"\n",
    "Ati_mean, Qti_mean, Ati_sd, Qti_sd = read_results(des)\n",
    "    \n",
    "# read j\n",
    "r = 0\n",
    "bias = 'down'\n",
    "mag = 0.1\n",
    "des = f\"real_setting_ratio{r}_bias{bias}_mag{mag}\"\n",
    "Atj_mean, Qtj_mean, Atj_sd, Qtj_sd = read_results(des)\n",
    "    \n",
    "\n",
    "# Plot\n",
    "des = f\"real_setting_ratio{r}_mag{mag}\"\n",
    "plot_save_fairness(Ati_mean, Atj_mean, Qti_mean, Qtj_mean, des, True)\n",
    "plot_save_fairness_err(Ati_mean, Atj_mean, Qti_mean, Qtj_mean, Ati_sd, Qti_sd, Atj_sd, Qtj_sd, des, True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f36ce460",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.9.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
