{
  "cells": [
    {
      "cell_type": "code",
      "execution_count": 1,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "Byp3mifeSOyx",
        "outputId": "06c08728-92f7-494e-86ab-6b5a27417619"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Drive already mounted at /content/drive; to attempt to forcibly remount, call drive.mount(\"/content/drive\", force_remount=True).\n"
          ]
        }
      ],
      "source": [
        "from google.colab import drive\n",
        "import sys\n",
        "drive.mount('/content/drive')\n",
        "sys.path.append('/content/drive/MyDrive/project')"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 2,
      "metadata": {
        "id": "409IAOssTMyf"
      },
      "outputs": [],
      "source": [
        "import pandas as pd\n",
        "\n",
        "# Replace this with the path to your CSV file\n",
        "file_path = '/content/drive/MyDrive/project/dataset_2186_pbc.arff'"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 69,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 224
        },
        "id": "nBIAmM4ffhTL",
        "outputId": "28fccaba-9b7f-4376-8232-3c9e2867389b"
      },
      "outputs": [
        {
          "data": {
            "application/vnd.google.colaboratory.intrinsic+json": {
              "summary": "{\n  \"name\": \"df\",\n  \"rows\": 418,\n  \"fields\": [\n    {\n      \"column\": \"'D'\",\n      \"properties\": {\n        \"dtype\": \"category\",\n        \"num_unique_values\": 2,\n        \"samples\": [\n          \"b'0'\",\n          \"b'1'\"\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z1\",\n      \"properties\": {\n        \"dtype\": \"category\",\n        \"num_unique_values\": 3,\n        \"samples\": [\n          \"b'1'\",\n          \"b'2'\"\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z2\",\n      \"properties\": {\n        \"dtype\": \"number\",\n        \"std\": 10.447174233915172,\n        \"min\": 26.2779,\n        \"max\": 78.4394,\n        \"num_unique_values\": 345,\n        \"samples\": [\n          44.627,\n          45.7604\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z3\",\n      \"properties\": {\n        \"dtype\": \"category\",\n        \"num_unique_values\": 3,\n        \"samples\": [\n          \"b'1'\",\n          \"b'0'\"\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z4\",\n      \"properties\": {\n        \"dtype\": \"category\",\n        \"num_unique_values\": 3,\n        \"samples\": [\n          \"b'1'\",\n          \"b'0'\"\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z5\",\n      \"properties\": {\n        \"dtype\": \"category\",\n        \"num_unique_values\": 3,\n        \"samples\": [\n          \"b'1'\",\n          \"b'0'\"\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z6\",\n      \"properties\": {\n        \"dtype\": \"category\",\n        \"num_unique_values\": 3,\n        \"samples\": [\n          \"b'1'\",\n          \"b'0'\"\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z7\",\n      \"properties\": {\n        \"dtype\": \"category\",\n        \"num_unique_values\": 3,\n        \"samples\": [\n          \"b'1'\",\n          \"b'0'\"\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z8\",\n      \"properties\": {\n        \"dtype\": \"number\",\n        \"std\": 4.407506384141376,\n        \"min\": 0.3,\n        \"max\": 28.0,\n        \"num_unique_values\": 98,\n        \"samples\": [\n          8.5,\n          6.3\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z9\",\n      \"properties\": {\n        \"dtype\": \"number\",\n        \"std\": 231.94454503787398,\n        \"min\": 120.0,\n        \"max\": 1775.0,\n        \"num_unique_values\": 201,\n        \"samples\": [\n          390.0,\n          274.0\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z10\",\n      \"properties\": {\n        \"dtype\": \"number\",\n        \"std\": 0.42497160577961945,\n        \"min\": 1.96,\n        \"max\": 4.64,\n        \"num_unique_values\": 154,\n        \"samples\": [\n          3.66,\n          3.79\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z11\",\n      \"properties\": {\n        \"dtype\": \"number\",\n        \"std\": 85.61391990897141,\n        \"min\": 4.0,\n        \"max\": 588.0,\n        \"num_unique_values\": 158,\n        \"samples\": [\n          141.0,\n          158.0\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z12\",\n      \"properties\": {\n        \"dtype\": \"number\",\n        \"std\": 2140.38882445176,\n        \"min\": 289.0,\n        \"max\": 13862.4,\n        \"num_unique_values\": 295,\n        \"samples\": [\n          1768.0,\n          964.0\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z13\",\n      \"properties\": {\n        \"dtype\": \"number\",\n        \"std\": 56.69952486331303,\n        \"min\": 26.35,\n        \"max\": 457.25,\n        \"num_unique_values\": 179,\n        \"samples\": [\n          111.6,\n          117.8\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z14\",\n      \"properties\": {\n        \"dtype\": \"number\",\n        \"std\": 65.14863866583947,\n        \"min\": 33.0,\n        \"max\": 598.0,\n        \"num_unique_values\": 146,\n        \"samples\": [\n          124.0,\n          218.0\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z15\",\n      \"properties\": {\n        \"dtype\": \"number\",\n        \"std\": 98.32558454996843,\n        \"min\": 62.0,\n        \"max\": 721.0,\n        \"num_unique_values\": 243,\n        \"samples\": [\n          421.0,\n          373.0\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z16\",\n      \"properties\": {\n        \"dtype\": \"number\",\n        \"std\": 1.022000346410421,\n        \"min\": 9.0,\n        \"max\": 18.0,\n        \"num_unique_values\": 48,\n        \"samples\": [\n          11.9,\n          9.0\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z17\",\n      \"properties\": {\n        \"dtype\": \"category\",\n        \"num_unique_values\": 5,\n        \"samples\": [\n          \"b'3'\",\n          \"b'?'\"\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"class\",\n      \"properties\": {\n        \"dtype\": \"number\",\n        \"std\": 1104.6729923907324,\n        \"min\": 41.0,\n        \"max\": 4795.0,\n        \"num_unique_values\": 399,\n        \"samples\": [\n          2272.0,\n          359.0\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    }\n  ]\n}",
              "type": "dataframe",
              "variable_name": "df"
            },
            "text/html": [
              "\n",
              "  <div id=\"df-7ca4dae7-ac2a-40a9-a1f4-cf3cfe95ee54\" class=\"colab-df-container\">\n",
              "    <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>'D'</th>\n",
              "      <th>Z1</th>\n",
              "      <th>Z2</th>\n",
              "      <th>Z3</th>\n",
              "      <th>Z4</th>\n",
              "      <th>Z5</th>\n",
              "      <th>Z6</th>\n",
              "      <th>Z7</th>\n",
              "      <th>Z8</th>\n",
              "      <th>Z9</th>\n",
              "      <th>Z10</th>\n",
              "      <th>Z11</th>\n",
              "      <th>Z12</th>\n",
              "      <th>Z13</th>\n",
              "      <th>Z14</th>\n",
              "      <th>Z15</th>\n",
              "      <th>Z16</th>\n",
              "      <th>Z17</th>\n",
              "      <th>class</th>\n",
              "    </tr>\n",
              "  </thead>\n",
              "  <tbody>\n",
              "    <tr>\n",
              "      <th>0</th>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>58.7652</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>14.5</td>\n",
              "      <td>261.0</td>\n",
              "      <td>2.60</td>\n",
              "      <td>156.0</td>\n",
              "      <td>1718.0</td>\n",
              "      <td>137.95</td>\n",
              "      <td>172.0</td>\n",
              "      <td>190.0</td>\n",
              "      <td>12.2</td>\n",
              "      <td>b'4'</td>\n",
              "      <td>400.0</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>1</th>\n",
              "      <td>b'0'</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>56.4463</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'0'</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'0'</td>\n",
              "      <td>1.1</td>\n",
              "      <td>302.0</td>\n",
              "      <td>4.14</td>\n",
              "      <td>54.0</td>\n",
              "      <td>7394.8</td>\n",
              "      <td>113.52</td>\n",
              "      <td>88.0</td>\n",
              "      <td>221.0</td>\n",
              "      <td>10.6</td>\n",
              "      <td>b'3'</td>\n",
              "      <td>4500.0</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>2</th>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>70.0726</td>\n",
              "      <td>b'0'</td>\n",
              "      <td>b'0'</td>\n",
              "      <td>b'0'</td>\n",
              "      <td>b'0'</td>\n",
              "      <td>b'0.500000'</td>\n",
              "      <td>1.4</td>\n",
              "      <td>176.0</td>\n",
              "      <td>3.48</td>\n",
              "      <td>210.0</td>\n",
              "      <td>516.0</td>\n",
              "      <td>96.10</td>\n",
              "      <td>55.0</td>\n",
              "      <td>151.0</td>\n",
              "      <td>12.0</td>\n",
              "      <td>b'4'</td>\n",
              "      <td>1012.0</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>3</th>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>54.7406</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'0'</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'0.500000'</td>\n",
              "      <td>1.8</td>\n",
              "      <td>244.0</td>\n",
              "      <td>2.54</td>\n",
              "      <td>64.0</td>\n",
              "      <td>6121.8</td>\n",
              "      <td>60.63</td>\n",
              "      <td>92.0</td>\n",
              "      <td>183.0</td>\n",
              "      <td>10.3</td>\n",
              "      <td>b'4'</td>\n",
              "      <td>1925.0</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>4</th>\n",
              "      <td>b'0'</td>\n",
              "      <td>b'2'</td>\n",
              "      <td>38.1054</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'0'</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'0'</td>\n",
              "      <td>3.4</td>\n",
              "      <td>279.0</td>\n",
              "      <td>3.53</td>\n",
              "      <td>143.0</td>\n",
              "      <td>671.0</td>\n",
              "      <td>113.15</td>\n",
              "      <td>72.0</td>\n",
              "      <td>136.0</td>\n",
              "      <td>10.9</td>\n",
              "      <td>b'3'</td>\n",
              "      <td>1504.0</td>\n",
              "    </tr>\n",
              "  </tbody>\n",
              "</table>\n",
              "</div>\n",
              "    <div class=\"colab-df-buttons\">\n",
              "\n",
              "  <div class=\"colab-df-container\">\n",
              "    <button class=\"colab-df-convert\" onclick=\"convertToInteractive('df-7ca4dae7-ac2a-40a9-a1f4-cf3cfe95ee54')\"\n",
              "            title=\"Convert this dataframe to an interactive table.\"\n",
              "            style=\"display:none;\">\n",
              "\n",
              "  <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\">\n",
              "    <path d=\"M120-120v-720h720v720H120Zm60-500h600v-160H180v160Zm220 220h160v-160H400v160Zm0 220h160v-160H400v160ZM180-400h160v-160H180v160Zm440 0h160v-160H620v160ZM180-180h160v-160H180v160Zm440 0h160v-160H620v160Z\"/>\n",
              "  </svg>\n",
              "    </button>\n",
              "\n",
              "  <style>\n",
              "    .colab-df-container {\n",
              "      display:flex;\n",
              "      gap: 12px;\n",
              "    }\n",
              "\n",
              "    .colab-df-convert {\n",
              "      background-color: #E8F0FE;\n",
              "      border: none;\n",
              "      border-radius: 50%;\n",
              "      cursor: pointer;\n",
              "      display: none;\n",
              "      fill: #1967D2;\n",
              "      height: 32px;\n",
              "      padding: 0 0 0 0;\n",
              "      width: 32px;\n",
              "    }\n",
              "\n",
              "    .colab-df-convert:hover {\n",
              "      background-color: #E2EBFA;\n",
              "      box-shadow: 0px 1px 2px rgba(60, 64, 67, 0.3), 0px 1px 3px 1px rgba(60, 64, 67, 0.15);\n",
              "      fill: #174EA6;\n",
              "    }\n",
              "\n",
              "    .colab-df-buttons div {\n",
              "      margin-bottom: 4px;\n",
              "    }\n",
              "\n",
              "    [theme=dark] .colab-df-convert {\n",
              "      background-color: #3B4455;\n",
              "      fill: #D2E3FC;\n",
              "    }\n",
              "\n",
              "    [theme=dark] .colab-df-convert:hover {\n",
              "      background-color: #434B5C;\n",
              "      box-shadow: 0px 1px 3px 1px rgba(0, 0, 0, 0.15);\n",
              "      filter: drop-shadow(0px 1px 2px rgba(0, 0, 0, 0.3));\n",
              "      fill: #FFFFFF;\n",
              "    }\n",
              "  </style>\n",
              "\n",
              "    <script>\n",
              "      const buttonEl =\n",
              "        document.querySelector('#df-7ca4dae7-ac2a-40a9-a1f4-cf3cfe95ee54 button.colab-df-convert');\n",
              "      buttonEl.style.display =\n",
              "        google.colab.kernel.accessAllowed ? 'block' : 'none';\n",
              "\n",
              "      async function convertToInteractive(key) {\n",
              "        const element = document.querySelector('#df-7ca4dae7-ac2a-40a9-a1f4-cf3cfe95ee54');\n",
              "        const dataTable =\n",
              "          await google.colab.kernel.invokeFunction('convertToInteractive',\n",
              "                                                    [key], {});\n",
              "        if (!dataTable) return;\n",
              "\n",
              "        const docLinkHtml = 'Like what you see? Visit the ' +\n",
              "          '<a target=\"_blank\" href=https://colab.research.google.com/notebooks/data_table.ipynb>data table notebook</a>'\n",
              "          + ' to learn more about interactive tables.';\n",
              "        element.innerHTML = '';\n",
              "        dataTable['output_type'] = 'display_data';\n",
              "        await google.colab.output.renderOutput(dataTable, element);\n",
              "        const docLink = document.createElement('div');\n",
              "        docLink.innerHTML = docLinkHtml;\n",
              "        element.appendChild(docLink);\n",
              "      }\n",
              "    </script>\n",
              "  </div>\n",
              "\n",
              "\n",
              "<div id=\"df-ad517588-03b0-43aa-a348-1a1f51f891b0\">\n",
              "  <button class=\"colab-df-quickchart\" onclick=\"quickchart('df-ad517588-03b0-43aa-a348-1a1f51f891b0')\"\n",
              "            title=\"Suggest charts\"\n",
              "            style=\"display:none;\">\n",
              "\n",
              "<svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\"viewBox=\"0 0 24 24\"\n",
              "     width=\"24px\">\n",
              "    <g>\n",
              "        <path d=\"M19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zM9 17H7v-7h2v7zm4 0h-2V7h2v10zm4 0h-2v-4h2v4z\"/>\n",
              "    </g>\n",
              "</svg>\n",
              "  </button>\n",
              "\n",
              "<style>\n",
              "  .colab-df-quickchart {\n",
              "      --bg-color: #E8F0FE;\n",
              "      --fill-color: #1967D2;\n",
              "      --hover-bg-color: #E2EBFA;\n",
              "      --hover-fill-color: #174EA6;\n",
              "      --disabled-fill-color: #AAA;\n",
              "      --disabled-bg-color: #DDD;\n",
              "  }\n",
              "\n",
              "  [theme=dark] .colab-df-quickchart {\n",
              "      --bg-color: #3B4455;\n",
              "      --fill-color: #D2E3FC;\n",
              "      --hover-bg-color: #434B5C;\n",
              "      --hover-fill-color: #FFFFFF;\n",
              "      --disabled-bg-color: #3B4455;\n",
              "      --disabled-fill-color: #666;\n",
              "  }\n",
              "\n",
              "  .colab-df-quickchart {\n",
              "    background-color: var(--bg-color);\n",
              "    border: none;\n",
              "    border-radius: 50%;\n",
              "    cursor: pointer;\n",
              "    display: none;\n",
              "    fill: var(--fill-color);\n",
              "    height: 32px;\n",
              "    padding: 0;\n",
              "    width: 32px;\n",
              "  }\n",
              "\n",
              "  .colab-df-quickchart:hover {\n",
              "    background-color: var(--hover-bg-color);\n",
              "    box-shadow: 0 1px 2px rgba(60, 64, 67, 0.3), 0 1px 3px 1px rgba(60, 64, 67, 0.15);\n",
              "    fill: var(--button-hover-fill-color);\n",
              "  }\n",
              "\n",
              "  .colab-df-quickchart-complete:disabled,\n",
              "  .colab-df-quickchart-complete:disabled:hover {\n",
              "    background-color: var(--disabled-bg-color);\n",
              "    fill: var(--disabled-fill-color);\n",
              "    box-shadow: none;\n",
              "  }\n",
              "\n",
              "  .colab-df-spinner {\n",
              "    border: 2px solid var(--fill-color);\n",
              "    border-color: transparent;\n",
              "    border-bottom-color: var(--fill-color);\n",
              "    animation:\n",
              "      spin 1s steps(1) infinite;\n",
              "  }\n",
              "\n",
              "  @keyframes spin {\n",
              "    0% {\n",
              "      border-color: transparent;\n",
              "      border-bottom-color: var(--fill-color);\n",
              "      border-left-color: var(--fill-color);\n",
              "    }\n",
              "    20% {\n",
              "      border-color: transparent;\n",
              "      border-left-color: var(--fill-color);\n",
              "      border-top-color: var(--fill-color);\n",
              "    }\n",
              "    30% {\n",
              "      border-color: transparent;\n",
              "      border-left-color: var(--fill-color);\n",
              "      border-top-color: var(--fill-color);\n",
              "      border-right-color: var(--fill-color);\n",
              "    }\n",
              "    40% {\n",
              "      border-color: transparent;\n",
              "      border-right-color: var(--fill-color);\n",
              "      border-top-color: var(--fill-color);\n",
              "    }\n",
              "    60% {\n",
              "      border-color: transparent;\n",
              "      border-right-color: var(--fill-color);\n",
              "    }\n",
              "    80% {\n",
              "      border-color: transparent;\n",
              "      border-right-color: var(--fill-color);\n",
              "      border-bottom-color: var(--fill-color);\n",
              "    }\n",
              "    90% {\n",
              "      border-color: transparent;\n",
              "      border-bottom-color: var(--fill-color);\n",
              "    }\n",
              "  }\n",
              "</style>\n",
              "\n",
              "  <script>\n",
              "    async function quickchart(key) {\n",
              "      const quickchartButtonEl =\n",
              "        document.querySelector('#' + key + ' button');\n",
              "      quickchartButtonEl.disabled = true;  // To prevent multiple clicks.\n",
              "      quickchartButtonEl.classList.add('colab-df-spinner');\n",
              "      try {\n",
              "        const charts = await google.colab.kernel.invokeFunction(\n",
              "            'suggestCharts', [key], {});\n",
              "      } catch (error) {\n",
              "        console.error('Error during call to suggestCharts:', error);\n",
              "      }\n",
              "      quickchartButtonEl.classList.remove('colab-df-spinner');\n",
              "      quickchartButtonEl.classList.add('colab-df-quickchart-complete');\n",
              "    }\n",
              "    (() => {\n",
              "      let quickchartButtonEl =\n",
              "        document.querySelector('#df-ad517588-03b0-43aa-a348-1a1f51f891b0 button');\n",
              "      quickchartButtonEl.style.display =\n",
              "        google.colab.kernel.accessAllowed ? 'block' : 'none';\n",
              "    })();\n",
              "  </script>\n",
              "</div>\n",
              "\n",
              "    </div>\n",
              "  </div>\n"
            ],
            "text/plain": [
              "    'D'    Z1       Z2    Z3    Z4    Z5    Z6           Z7    Z8     Z9  \\\n",
              "0  b'1'  b'1'  58.7652  b'1'  b'1'  b'1'  b'1'         b'1'  14.5  261.0   \n",
              "1  b'0'  b'1'  56.4463  b'1'  b'0'  b'1'  b'1'         b'0'   1.1  302.0   \n",
              "2  b'1'  b'1'  70.0726  b'0'  b'0'  b'0'  b'0'  b'0.500000'   1.4  176.0   \n",
              "3  b'1'  b'1'  54.7406  b'1'  b'0'  b'1'  b'1'  b'0.500000'   1.8  244.0   \n",
              "4  b'0'  b'2'  38.1054  b'1'  b'0'  b'1'  b'1'         b'0'   3.4  279.0   \n",
              "\n",
              "    Z10    Z11     Z12     Z13    Z14    Z15   Z16   Z17   class  \n",
              "0  2.60  156.0  1718.0  137.95  172.0  190.0  12.2  b'4'   400.0  \n",
              "1  4.14   54.0  7394.8  113.52   88.0  221.0  10.6  b'3'  4500.0  \n",
              "2  3.48  210.0   516.0   96.10   55.0  151.0  12.0  b'4'  1012.0  \n",
              "3  2.54   64.0  6121.8   60.63   92.0  183.0  10.3  b'4'  1925.0  \n",
              "4  3.53  143.0   671.0  113.15   72.0  136.0  10.9  b'3'  1504.0  "
            ]
          },
          "execution_count": 69,
          "metadata": {},
          "output_type": "execute_result"
        }
      ],
      "source": [
        "import pandas as pd\n",
        "from scipy.io import arff\n",
        "\n",
        "# Load the ARFF file\n",
        "data, meta = arff.loadarff(file_path)\n",
        "\n",
        "# Convert to a pandas DataFrame\n",
        "df = pd.DataFrame(data)\n",
        "\n",
        "# Display the first few rows\n",
        "df.head()\n"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 70,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "Pqkv76gZKzar",
        "outputId": "45b57f32-e529-434a-f5d2-4588900bf2ed"
      },
      "outputs": [
        {
          "data": {
            "text/plain": [
              "(418, 19)"
            ]
          },
          "execution_count": 70,
          "metadata": {},
          "output_type": "execute_result"
        }
      ],
      "source": [
        "df.shape"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 45,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "ynofjfHj9Bot",
        "outputId": "c81151b1-ceca-4e04-c8fa-78dd079a3920"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "0      b'1'\n",
            "1      b'0'\n",
            "2      b'1'\n",
            "3      b'1'\n",
            "4      b'0'\n",
            "       ... \n",
            "413    b'1'\n",
            "414    b'0'\n",
            "415    b'0'\n",
            "416    b'0'\n",
            "417    b'0'\n",
            "Name: 'D', Length: 418, dtype: object\n"
          ]
        }
      ],
      "source": [
        "first_column = df.iloc[:, 0]\n",
        "print(first_column)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 46,
      "metadata": {
        "id": "Fre1fcnWft4c"
      },
      "outputs": [],
      "source": [
        "df = df.replace('.', pd.NA)  # Replace \".\" with NA\n",
        "df['Z3'] = df['Z3'].astype('category')  # Convert 'Z3' (Sex) to categorical\n",
        "df['D'] = first_column.astype('category')\n",
        "df.dropna(inplace=True)  # Optionally drop rows with missing data"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 48,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 224
        },
        "id": "XOoX4S2N9QCH",
        "outputId": "c0bdde38-8b04-4b3d-ffc0-fa15970152e6"
      },
      "outputs": [
        {
          "data": {
            "application/vnd.google.colaboratory.intrinsic+json": {
              "summary": "{\n  \"name\": \"df\",\n  \"rows\": 276,\n  \"fields\": [\n    {\n      \"column\": \"'D'\",\n      \"properties\": {\n        \"dtype\": \"category\",\n        \"num_unique_values\": 2,\n        \"samples\": [\n          \"b'0'\",\n          \"b'1'\"\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z1\",\n      \"properties\": {\n        \"dtype\": \"category\",\n        \"num_unique_values\": 2,\n        \"samples\": [\n          \"b'2'\",\n          \"b'1'\"\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z2\",\n      \"properties\": {\n        \"dtype\": \"number\",\n        \"std\": 10.523080836774545,\n        \"min\": 26.2779,\n        \"max\": 78.4394,\n        \"num_unique_values\": 275,\n        \"samples\": [\n          51.2827,\n          45.7604\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z3\",\n      \"properties\": {\n        \"dtype\": \"category\",\n        \"num_unique_values\": 2,\n        \"samples\": [\n          \"b'0'\",\n          \"b'1'\"\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z4\",\n      \"properties\": {\n        \"dtype\": \"category\",\n        \"num_unique_values\": 2,\n        \"samples\": [\n          \"b'0'\",\n          \"b'1'\"\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z5\",\n      \"properties\": {\n        \"dtype\": \"category\",\n        \"num_unique_values\": 2,\n        \"samples\": [\n          \"b'0'\",\n          \"b'1'\"\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z6\",\n      \"properties\": {\n        \"dtype\": \"category\",\n        \"num_unique_values\": 2,\n        \"samples\": [\n          \"b'0'\",\n          \"b'1'\"\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z7\",\n      \"properties\": {\n        \"dtype\": \"category\",\n        \"num_unique_values\": 3,\n        \"samples\": [\n          \"b'1'\",\n          \"b'0'\"\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z8\",\n      \"properties\": {\n        \"dtype\": \"number\",\n        \"std\": 4.601073641676091,\n        \"min\": 0.3,\n        \"max\": 28.0,\n        \"num_unique_values\": 82,\n        \"samples\": [\n          2.3,\n          14.5\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z9\",\n      \"properties\": {\n        \"dtype\": \"number\",\n        \"std\": 234.7883628631716,\n        \"min\": 120.0,\n        \"max\": 1775.0,\n        \"num_unique_values\": 198,\n        \"samples\": [\n          247.0,\n          168.0\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z10\",\n      \"properties\": {\n        \"dtype\": \"number\",\n        \"std\": 0.40478858321529926,\n        \"min\": 1.96,\n        \"max\": 4.4,\n        \"num_unique_values\": 125,\n        \"samples\": [\n          3.83,\n          3.8\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z11\",\n      \"properties\": {\n        \"dtype\": \"number\",\n        \"std\": 88.26874582093626,\n        \"min\": 4.0,\n        \"max\": 588.0,\n        \"num_unique_values\": 152,\n        \"samples\": [\n          77.0,\n          33.0\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z12\",\n      \"properties\": {\n        \"dtype\": \"number\",\n        \"std\": 2115.4778941737513,\n        \"min\": 289.0,\n        \"max\": 13862.4,\n        \"num_unique_values\": 269,\n        \"samples\": [\n          1840.0,\n          1636.0\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z13\",\n      \"properties\": {\n        \"dtype\": \"number\",\n        \"std\": 56.719952453506735,\n        \"min\": 28.38,\n        \"max\": 457.25,\n        \"num_unique_values\": 166,\n        \"samples\": [\n          237.15,\n          71.0\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z14\",\n      \"properties\": {\n        \"dtype\": \"number\",\n        \"std\": 65.2807606229422,\n        \"min\": 33.0,\n        \"max\": 598.0,\n        \"num_unique_values\": 143,\n        \"samples\": [\n          57.0,\n          230.0\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z15\",\n      \"properties\": {\n        \"dtype\": \"number\",\n        \"std\": 93.12885734908511,\n        \"min\": 62.0,\n        \"max\": 563.0,\n        \"num_unique_values\": 193,\n        \"samples\": [\n          365.0,\n          381.0\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z16\",\n      \"properties\": {\n        \"dtype\": \"number\",\n        \"std\": 1.0083145775104243,\n        \"min\": 9.0,\n        \"max\": 17.1,\n        \"num_unique_values\": 41,\n        \"samples\": [\n          11.1,\n          11.4\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z17\",\n      \"properties\": {\n        \"dtype\": \"category\",\n        \"num_unique_values\": 4,\n        \"samples\": [\n          \"b'3'\",\n          \"b'1'\"\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"class\",\n      \"properties\": {\n        \"dtype\": \"number\",\n        \"std\": 1112.3802952282638,\n        \"min\": 41.0,\n        \"max\": 4556.0,\n        \"num_unique_values\": 267,\n        \"samples\": [\n          611.0,\n          1360.0\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"D\",\n      \"properties\": {\n        \"dtype\": \"category\",\n        \"num_unique_values\": 2,\n        \"samples\": [\n          \"b'0'\",\n          \"b'1'\"\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    }\n  ]\n}",
              "type": "dataframe",
              "variable_name": "df"
            },
            "text/html": [
              "\n",
              "  <div id=\"df-182d0559-0f33-421d-a0a8-a8e74784ec06\" class=\"colab-df-container\">\n",
              "    <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>'D'</th>\n",
              "      <th>Z1</th>\n",
              "      <th>Z2</th>\n",
              "      <th>Z3</th>\n",
              "      <th>Z4</th>\n",
              "      <th>Z5</th>\n",
              "      <th>Z6</th>\n",
              "      <th>Z7</th>\n",
              "      <th>Z8</th>\n",
              "      <th>Z9</th>\n",
              "      <th>Z10</th>\n",
              "      <th>Z11</th>\n",
              "      <th>Z12</th>\n",
              "      <th>Z13</th>\n",
              "      <th>Z14</th>\n",
              "      <th>Z15</th>\n",
              "      <th>Z16</th>\n",
              "      <th>Z17</th>\n",
              "      <th>class</th>\n",
              "      <th>D</th>\n",
              "    </tr>\n",
              "  </thead>\n",
              "  <tbody>\n",
              "    <tr>\n",
              "      <th>0</th>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>58.7652</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>14.5</td>\n",
              "      <td>261.0</td>\n",
              "      <td>2.60</td>\n",
              "      <td>156.0</td>\n",
              "      <td>1718.0</td>\n",
              "      <td>137.95</td>\n",
              "      <td>172.0</td>\n",
              "      <td>190.0</td>\n",
              "      <td>12.2</td>\n",
              "      <td>b'4'</td>\n",
              "      <td>400.0</td>\n",
              "      <td>b'1'</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>1</th>\n",
              "      <td>b'0'</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>56.4463</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'0'</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'0'</td>\n",
              "      <td>1.1</td>\n",
              "      <td>302.0</td>\n",
              "      <td>4.14</td>\n",
              "      <td>54.0</td>\n",
              "      <td>7394.8</td>\n",
              "      <td>113.52</td>\n",
              "      <td>88.0</td>\n",
              "      <td>221.0</td>\n",
              "      <td>10.6</td>\n",
              "      <td>b'3'</td>\n",
              "      <td>4500.0</td>\n",
              "      <td>b'0'</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>2</th>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>70.0726</td>\n",
              "      <td>b'0'</td>\n",
              "      <td>b'0'</td>\n",
              "      <td>b'0'</td>\n",
              "      <td>b'0'</td>\n",
              "      <td>b'0.500000'</td>\n",
              "      <td>1.4</td>\n",
              "      <td>176.0</td>\n",
              "      <td>3.48</td>\n",
              "      <td>210.0</td>\n",
              "      <td>516.0</td>\n",
              "      <td>96.10</td>\n",
              "      <td>55.0</td>\n",
              "      <td>151.0</td>\n",
              "      <td>12.0</td>\n",
              "      <td>b'4'</td>\n",
              "      <td>1012.0</td>\n",
              "      <td>b'1'</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>3</th>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>54.7406</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'0'</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'0.500000'</td>\n",
              "      <td>1.8</td>\n",
              "      <td>244.0</td>\n",
              "      <td>2.54</td>\n",
              "      <td>64.0</td>\n",
              "      <td>6121.8</td>\n",
              "      <td>60.63</td>\n",
              "      <td>92.0</td>\n",
              "      <td>183.0</td>\n",
              "      <td>10.3</td>\n",
              "      <td>b'4'</td>\n",
              "      <td>1925.0</td>\n",
              "      <td>b'1'</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>4</th>\n",
              "      <td>b'0'</td>\n",
              "      <td>b'2'</td>\n",
              "      <td>38.1054</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'0'</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'0'</td>\n",
              "      <td>3.4</td>\n",
              "      <td>279.0</td>\n",
              "      <td>3.53</td>\n",
              "      <td>143.0</td>\n",
              "      <td>671.0</td>\n",
              "      <td>113.15</td>\n",
              "      <td>72.0</td>\n",
              "      <td>136.0</td>\n",
              "      <td>10.9</td>\n",
              "      <td>b'3'</td>\n",
              "      <td>1504.0</td>\n",
              "      <td>b'0'</td>\n",
              "    </tr>\n",
              "  </tbody>\n",
              "</table>\n",
              "</div>\n",
              "    <div class=\"colab-df-buttons\">\n",
              "\n",
              "  <div class=\"colab-df-container\">\n",
              "    <button class=\"colab-df-convert\" onclick=\"convertToInteractive('df-182d0559-0f33-421d-a0a8-a8e74784ec06')\"\n",
              "            title=\"Convert this dataframe to an interactive table.\"\n",
              "            style=\"display:none;\">\n",
              "\n",
              "  <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\">\n",
              "    <path d=\"M120-120v-720h720v720H120Zm60-500h600v-160H180v160Zm220 220h160v-160H400v160Zm0 220h160v-160H400v160ZM180-400h160v-160H180v160Zm440 0h160v-160H620v160ZM180-180h160v-160H180v160Zm440 0h160v-160H620v160Z\"/>\n",
              "  </svg>\n",
              "    </button>\n",
              "\n",
              "  <style>\n",
              "    .colab-df-container {\n",
              "      display:flex;\n",
              "      gap: 12px;\n",
              "    }\n",
              "\n",
              "    .colab-df-convert {\n",
              "      background-color: #E8F0FE;\n",
              "      border: none;\n",
              "      border-radius: 50%;\n",
              "      cursor: pointer;\n",
              "      display: none;\n",
              "      fill: #1967D2;\n",
              "      height: 32px;\n",
              "      padding: 0 0 0 0;\n",
              "      width: 32px;\n",
              "    }\n",
              "\n",
              "    .colab-df-convert:hover {\n",
              "      background-color: #E2EBFA;\n",
              "      box-shadow: 0px 1px 2px rgba(60, 64, 67, 0.3), 0px 1px 3px 1px rgba(60, 64, 67, 0.15);\n",
              "      fill: #174EA6;\n",
              "    }\n",
              "\n",
              "    .colab-df-buttons div {\n",
              "      margin-bottom: 4px;\n",
              "    }\n",
              "\n",
              "    [theme=dark] .colab-df-convert {\n",
              "      background-color: #3B4455;\n",
              "      fill: #D2E3FC;\n",
              "    }\n",
              "\n",
              "    [theme=dark] .colab-df-convert:hover {\n",
              "      background-color: #434B5C;\n",
              "      box-shadow: 0px 1px 3px 1px rgba(0, 0, 0, 0.15);\n",
              "      filter: drop-shadow(0px 1px 2px rgba(0, 0, 0, 0.3));\n",
              "      fill: #FFFFFF;\n",
              "    }\n",
              "  </style>\n",
              "\n",
              "    <script>\n",
              "      const buttonEl =\n",
              "        document.querySelector('#df-182d0559-0f33-421d-a0a8-a8e74784ec06 button.colab-df-convert');\n",
              "      buttonEl.style.display =\n",
              "        google.colab.kernel.accessAllowed ? 'block' : 'none';\n",
              "\n",
              "      async function convertToInteractive(key) {\n",
              "        const element = document.querySelector('#df-182d0559-0f33-421d-a0a8-a8e74784ec06');\n",
              "        const dataTable =\n",
              "          await google.colab.kernel.invokeFunction('convertToInteractive',\n",
              "                                                    [key], {});\n",
              "        if (!dataTable) return;\n",
              "\n",
              "        const docLinkHtml = 'Like what you see? Visit the ' +\n",
              "          '<a target=\"_blank\" href=https://colab.research.google.com/notebooks/data_table.ipynb>data table notebook</a>'\n",
              "          + ' to learn more about interactive tables.';\n",
              "        element.innerHTML = '';\n",
              "        dataTable['output_type'] = 'display_data';\n",
              "        await google.colab.output.renderOutput(dataTable, element);\n",
              "        const docLink = document.createElement('div');\n",
              "        docLink.innerHTML = docLinkHtml;\n",
              "        element.appendChild(docLink);\n",
              "      }\n",
              "    </script>\n",
              "  </div>\n",
              "\n",
              "\n",
              "<div id=\"df-06455457-f256-402c-8ec7-da6d80873f3f\">\n",
              "  <button class=\"colab-df-quickchart\" onclick=\"quickchart('df-06455457-f256-402c-8ec7-da6d80873f3f')\"\n",
              "            title=\"Suggest charts\"\n",
              "            style=\"display:none;\">\n",
              "\n",
              "<svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\"viewBox=\"0 0 24 24\"\n",
              "     width=\"24px\">\n",
              "    <g>\n",
              "        <path d=\"M19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zM9 17H7v-7h2v7zm4 0h-2V7h2v10zm4 0h-2v-4h2v4z\"/>\n",
              "    </g>\n",
              "</svg>\n",
              "  </button>\n",
              "\n",
              "<style>\n",
              "  .colab-df-quickchart {\n",
              "      --bg-color: #E8F0FE;\n",
              "      --fill-color: #1967D2;\n",
              "      --hover-bg-color: #E2EBFA;\n",
              "      --hover-fill-color: #174EA6;\n",
              "      --disabled-fill-color: #AAA;\n",
              "      --disabled-bg-color: #DDD;\n",
              "  }\n",
              "\n",
              "  [theme=dark] .colab-df-quickchart {\n",
              "      --bg-color: #3B4455;\n",
              "      --fill-color: #D2E3FC;\n",
              "      --hover-bg-color: #434B5C;\n",
              "      --hover-fill-color: #FFFFFF;\n",
              "      --disabled-bg-color: #3B4455;\n",
              "      --disabled-fill-color: #666;\n",
              "  }\n",
              "\n",
              "  .colab-df-quickchart {\n",
              "    background-color: var(--bg-color);\n",
              "    border: none;\n",
              "    border-radius: 50%;\n",
              "    cursor: pointer;\n",
              "    display: none;\n",
              "    fill: var(--fill-color);\n",
              "    height: 32px;\n",
              "    padding: 0;\n",
              "    width: 32px;\n",
              "  }\n",
              "\n",
              "  .colab-df-quickchart:hover {\n",
              "    background-color: var(--hover-bg-color);\n",
              "    box-shadow: 0 1px 2px rgba(60, 64, 67, 0.3), 0 1px 3px 1px rgba(60, 64, 67, 0.15);\n",
              "    fill: var(--button-hover-fill-color);\n",
              "  }\n",
              "\n",
              "  .colab-df-quickchart-complete:disabled,\n",
              "  .colab-df-quickchart-complete:disabled:hover {\n",
              "    background-color: var(--disabled-bg-color);\n",
              "    fill: var(--disabled-fill-color);\n",
              "    box-shadow: none;\n",
              "  }\n",
              "\n",
              "  .colab-df-spinner {\n",
              "    border: 2px solid var(--fill-color);\n",
              "    border-color: transparent;\n",
              "    border-bottom-color: var(--fill-color);\n",
              "    animation:\n",
              "      spin 1s steps(1) infinite;\n",
              "  }\n",
              "\n",
              "  @keyframes spin {\n",
              "    0% {\n",
              "      border-color: transparent;\n",
              "      border-bottom-color: var(--fill-color);\n",
              "      border-left-color: var(--fill-color);\n",
              "    }\n",
              "    20% {\n",
              "      border-color: transparent;\n",
              "      border-left-color: var(--fill-color);\n",
              "      border-top-color: var(--fill-color);\n",
              "    }\n",
              "    30% {\n",
              "      border-color: transparent;\n",
              "      border-left-color: var(--fill-color);\n",
              "      border-top-color: var(--fill-color);\n",
              "      border-right-color: var(--fill-color);\n",
              "    }\n",
              "    40% {\n",
              "      border-color: transparent;\n",
              "      border-right-color: var(--fill-color);\n",
              "      border-top-color: var(--fill-color);\n",
              "    }\n",
              "    60% {\n",
              "      border-color: transparent;\n",
              "      border-right-color: var(--fill-color);\n",
              "    }\n",
              "    80% {\n",
              "      border-color: transparent;\n",
              "      border-right-color: var(--fill-color);\n",
              "      border-bottom-color: var(--fill-color);\n",
              "    }\n",
              "    90% {\n",
              "      border-color: transparent;\n",
              "      border-bottom-color: var(--fill-color);\n",
              "    }\n",
              "  }\n",
              "</style>\n",
              "\n",
              "  <script>\n",
              "    async function quickchart(key) {\n",
              "      const quickchartButtonEl =\n",
              "        document.querySelector('#' + key + ' button');\n",
              "      quickchartButtonEl.disabled = true;  // To prevent multiple clicks.\n",
              "      quickchartButtonEl.classList.add('colab-df-spinner');\n",
              "      try {\n",
              "        const charts = await google.colab.kernel.invokeFunction(\n",
              "            'suggestCharts', [key], {});\n",
              "      } catch (error) {\n",
              "        console.error('Error during call to suggestCharts:', error);\n",
              "      }\n",
              "      quickchartButtonEl.classList.remove('colab-df-spinner');\n",
              "      quickchartButtonEl.classList.add('colab-df-quickchart-complete');\n",
              "    }\n",
              "    (() => {\n",
              "      let quickchartButtonEl =\n",
              "        document.querySelector('#df-06455457-f256-402c-8ec7-da6d80873f3f button');\n",
              "      quickchartButtonEl.style.display =\n",
              "        google.colab.kernel.accessAllowed ? 'block' : 'none';\n",
              "    })();\n",
              "  </script>\n",
              "</div>\n",
              "\n",
              "    </div>\n",
              "  </div>\n"
            ],
            "text/plain": [
              "    'D'    Z1       Z2    Z3    Z4    Z5    Z6           Z7    Z8     Z9  \\\n",
              "0  b'1'  b'1'  58.7652  b'1'  b'1'  b'1'  b'1'         b'1'  14.5  261.0   \n",
              "1  b'0'  b'1'  56.4463  b'1'  b'0'  b'1'  b'1'         b'0'   1.1  302.0   \n",
              "2  b'1'  b'1'  70.0726  b'0'  b'0'  b'0'  b'0'  b'0.500000'   1.4  176.0   \n",
              "3  b'1'  b'1'  54.7406  b'1'  b'0'  b'1'  b'1'  b'0.500000'   1.8  244.0   \n",
              "4  b'0'  b'2'  38.1054  b'1'  b'0'  b'1'  b'1'         b'0'   3.4  279.0   \n",
              "\n",
              "    Z10    Z11     Z12     Z13    Z14    Z15   Z16   Z17   class     D  \n",
              "0  2.60  156.0  1718.0  137.95  172.0  190.0  12.2  b'4'   400.0  b'1'  \n",
              "1  4.14   54.0  7394.8  113.52   88.0  221.0  10.6  b'3'  4500.0  b'0'  \n",
              "2  3.48  210.0   516.0   96.10   55.0  151.0  12.0  b'4'  1012.0  b'1'  \n",
              "3  2.54   64.0  6121.8   60.63   92.0  183.0  10.3  b'4'  1925.0  b'1'  \n",
              "4  3.53  143.0   671.0  113.15   72.0  136.0  10.9  b'3'  1504.0  b'0'  "
            ]
          },
          "execution_count": 48,
          "metadata": {},
          "output_type": "execute_result"
        }
      ],
      "source": [
        "df.head()"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "LB4iSU8fT--b"
      },
      "source": [
        "## MCAR"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 5,
      "metadata": {
        "id": "byZ2qGWeioa8"
      },
      "outputs": [],
      "source": [
        "import numpy as np\n",
        "\n",
        "class MCAR:\n",
        "    def __init__(self, means, gamma):\n",
        "        self.arm_means = means\n",
        "        self.num_arms = len(means)\n",
        "        self.gamma = gamma\n",
        "        self.best_arm = np.argmax(means)\n",
        "\n",
        "    def pull_arm(self, arm):\n",
        "        reward = np.random.normal(self.arm_means[arm], 1)\n",
        "\n",
        "        observed = np.random.rand() < self.gamma\n",
        "\n",
        "        return (reward, observed) if observed else (None, observed)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 6,
      "metadata": {
        "id": "-ifkT5lmg2cQ"
      },
      "outputs": [],
      "source": [
        "class MCAR_algo:\n",
        "    def __init__(self, bandit_env, alpha):\n",
        "        self.bandit_env = bandit_env\n",
        "        self.num_arms = bandit_env.num_arms\n",
        "        self.counts = np.zeros(self.num_arms)\n",
        "        self.means = np.zeros(self.num_arms)\n",
        "        self.total_pulls = 0\n",
        "        self.alpha = alpha\n",
        "\n",
        "    def select_arm(self, round_number):\n",
        "        if self.total_pulls < self.num_arms:\n",
        "            return self.total_pulls\n",
        "\n",
        "        ucb_values = np.zeros(self.num_arms)\n",
        "        for arm in range(self.num_arms):\n",
        "            if self.counts[arm] == 0:\n",
        "                ucb_values[arm] = float('inf')\n",
        "            else:\n",
        "                confidence_bound = np.sqrt(self.alpha * np.log(round_number) / self.counts[arm])\n",
        "                ucb_values[arm] = self.means[arm] + confidence_bound\n",
        "\n",
        "        return np.argmax(ucb_values)\n",
        "\n",
        "    def update(self, arm, reward, observed):\n",
        "        if observed:\n",
        "            self.counts[arm] += 1\n",
        "            self.means[arm] += (reward - self.means[arm]) / self.counts[arm]\n",
        "\n",
        "        self.total_pulls += 1\n",
        "\n",
        "    def update_regret(self, arm, cu_regret, regrets):\n",
        "        regret = self.bandit_env.arm_means[self.bandit_env.best_arm] - self.bandit_env.arm_means[arm]\n",
        "        cu_regret += regret\n",
        "        regrets.append(cu_regret)\n",
        "        return cu_regret\n",
        "\n",
        "    def run(self, num_rounds):\n",
        "        results = []\n",
        "        regrets = []\n",
        "        cu_regret = 0\n",
        "        for round_number in range(num_rounds):\n",
        "            arm = self.select_arm(round_number)\n",
        "\n",
        "            reward, observed = self.bandit_env.pull_arm(arm)\n",
        "\n",
        "            cu_regret = self.update_regret(arm, cu_regret, regrets)\n",
        "            self.update(arm, reward, observed)\n",
        "\n",
        "            results.append((arm, reward, observed))\n",
        "\n",
        "        return results, regrets"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 7,
      "metadata": {
        "id": "tsdaGhivhv4n"
      },
      "outputs": [],
      "source": [
        "# Calculate mean rewards for each arm (Z1)\n",
        "arm_means = df.groupby('Z1')['class'].mean().values\n",
        "\n",
        "arm_means /= np.mean(arm_means)\n",
        "\n",
        "# Step 4: Run the Algorithm\n",
        "alpha = 1  # Exploration-exploitation trade-off parameter\n",
        "gamma = 0.8  # Probability of observing the reward\n",
        "bandit_env = MCAR(arm_means, gamma)\n",
        "\n",
        "ucb_algo = MCAR_algo(bandit_env, alpha)\n",
        "\n",
        "# Number of rounds for the simulation\n",
        "num_rounds = 10000000  # Adjust based on how long you want to run the simulation\n",
        "\n",
        "# Run the UCB algorithm\n",
        "results, regrets = ucb_algo.run(num_rounds)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 27,
      "metadata": {
        "id": "Nn_SNfAKkBlR"
      },
      "outputs": [],
      "source": [
        "# print(arm_means/np.mean(arm_means))"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 8,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 564
        },
        "id": "stuhVCD9i-oO",
        "outputId": "ec8cd6f8-6890-4da2-8717-f577d4e6e5a6"
      },
      "outputs": [
        {
          "data": {
            "image/png": "iVBORw0KGgoAAAANSUhEUgAAA1IAAAIjCAYAAAAJLyrXAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAABsGElEQVR4nO3dd3gU1f7H8c8m2fRGKAkl9C4oCAqhqRgITQVRilwBfxQvgl5FUFG6NLHrxQqCDUFQuV5AICCISlCkCFhQkGIhAaWEAEk2yfz+2LsLaxLIhCQ7Ce/X8+yzu2dmZ76bHOP5cGbP2gzDMAQAAAAAKDAfbxcAAAAAAKUNQQoAAAAATCJIAQAAAIBJBCkAAAAAMIkgBQAAAAAmEaQAAAAAwCSCFAAAAACYRJACAAAAAJMIUgAAAABgEkEKAC4TgwcPVs2aNYv0mAsWLJDNZtOBAweK9Li4fGzYsEE2m00bNmzwdikAYApBCgBM2Ldvn+6++27Vrl1bgYGBCg8PV9u2bfX888/r7Nmz3i6v2MyYMUPLli3zdhlurgDnuvn5+alq1aoaPHiwfv/9d2+Xd1FnzpzR5MmTTYeHQ4cO6Z///Kdq1qypgIAAVapUST179tSXX35ZPIUW0uDBgz1+P/ndBg8e7O1SAaDQ/LxdAACUFitWrNDtt9+ugIAADRw4UE2aNFFmZqa++OILjR07Vt99951ee+01b5dZLGbMmKHbbrtNPXv29Gi/88471a9fPwUEBHilrqlTp6pWrVpKT0/X5s2btWDBAn3xxRfavXu3AgMDvVJTQZw5c0ZTpkyRJF1//fUFes2XX36pbt26SZKGDh2qxo0bKzk5WQsWLFD79u31/PPP69577y2ukk25++67FR8f736+f/9+TZw4UcOHD1f79u3d7XXq1FGrVq109uxZ+fv7e6NUACg0ghQAFMD+/fvVr18/1ahRQ59++qkqV67s3jZy5Ejt3btXK1as8GKF3uHr6ytfX1+vnb9r165q2bKlJGe4qFChgp544gl9/PHH6tOnT4nVYRiG0tPTFRQUVCzHP378uG677TYFBQXpyy+/VJ06ddzbRo8erYSEBN1///1q0aKF2rRpUyw15CU9PV3+/v7y8fG8wCUuLk5xcXHu5998840mTpyouLg4/eMf/8h1HCuHXgDID5f2AUABzJ49W2lpaZo3b55HiHKpW7eu/vWvf0mSDhw4IJvNpgULFuTaz2azafLkye7nkydPls1m008//aR//OMfioiIUMWKFTVhwgQZhqFff/1Vt9xyi8LDwxUTE6Onn37a43j5fUapoJ87eeqpp9SmTRuVL19eQUFBatGihZYuXZqr5tOnT+vNN9/MdUnW38/fo0cP1a5dO89zxcXFuUOPyzvvvKMWLVooKChIUVFR6tevn3799dcL1nwhrtmOffv2ebT/+OOPuu222xQVFaXAwEC1bNlSH3/8ca7X79y5U9ddd52CgoJUrVo1TZs2TfPnz8/1M65Zs6Z69Oih1atXq2XLlgoKCtKrr74qSTpx4oTuv/9+xcbGKiAgQHXr1tUTTzyhnJwcSc7+UbFiRUnSlClT3D/T8/vF37366qtKTk7Wk08+6RGiJCkoKMj9u5k6daokZ3Cx2Wx68803cx1r9erVstlsWr58ubvt999/1//93/8pOjpaAQEBuuKKK/TGG294vM7VpxYtWqTx48eratWqCg4OVmpqar51F0ReffX6669XkyZN3L+P4OBg1a1b1903P/vsM7Vq1UpBQUFq0KCB1q5dm+u4BXlPAHApmJECgAL473//q9q1axfbv/b37dtXjRo10qxZs7RixQpNmzZNUVFRevXVV9WxY0c98cQTevfddzVmzBhdc8016tChQ5Gc9/nnn9fNN9+sAQMGKDMzU4sWLdLtt9+u5cuXq3v37pKkt99+W0OHDtW1116r4cOHS1Kuwfz572PgwIHasmWLrrnmGnf7wYMHtXnzZj355JPutunTp2vChAnq06ePhg4dqqNHj+rFF19Uhw4dtH37dkVGRpp+P66wU65cOXfbd999p7Zt26pq1ap65JFHFBISovfff189e/bUBx98oF69eklyDrxvuOEG2Ww2jRs3TiEhIZo7d26+ly3u2bNH/fv31913361hw4apQYMGOnPmjK677jr9/vvvuvvuu1W9enVt2rRJ48aN0+HDh/Xcc8+pYsWKevnllzVixAj16tVLt956qyTpyiuvzPd9/fe//1VgYGC+s2y1atVSu3bt9Omnn+rs2bNq2bKlateurffff1+DBg3y2Hfx4sUqV66cEhISJEkpKSlq3bq1bDabRo0apYoVK+qTTz7RkCFDlJqaqvvvv9/j9Y8//rj8/f01ZswYZWRkFNslecePH1ePHj3Ur18/3X777Xr55ZfVr18/vfvuu7r//vv1z3/+U3fccYeefPJJ3Xbbbfr1118VFhZWqPcEAIViAAAu6OTJk4Yk45ZbbinQ/vv37zckGfPnz8+1TZIxadIk9/NJkyYZkozhw4e727Kysoxq1aoZNpvNmDVrlrv9+PHjRlBQkDFo0CB32/z58w1Jxv79+z3Os379ekOSsX79enfboEGDjBo1anjsd+bMGY/nmZmZRpMmTYyOHTt6tIeEhHicN7/znzx50ggICDAefPBBj/1mz55t2Gw24+DBg4ZhGMaBAwcMX19fY/r06R777dq1y/Dz88vVnt95165daxw9etT49ddfjaVLlxoVK1Y0AgICjF9//dW974033mg0bdrUSE9Pd7fl5OQYbdq0MerVq+duu/feew2bzWZs377d3fbXX38ZUVFRuX7GNWrUMCQZq1at8qjr8ccfN0JCQoyffvrJo/2RRx4xfH19jUOHDhmGYRhHjx7N1RcuJDIy0rjqqqsuuM99991nSDJ27txpGIZhjBs3zrDb7caxY8fc+2RkZBiRkZHG//3f/7nbhgwZYlSuXNn4888/PY7Xr18/IyIiwt1HXH2qdu3aufrNxWzZsiXf/yby6qvXXXedIclYuHChu+3HH380JBk+Pj7G5s2b3e2rV6/OdeyCvicAuBRc2gcAF+G6dMn1r93FYejQoe7Hvr6+atmypQzD0JAhQ9ztkZGRatCggX755ZciO+/5n+k5fvy4Tp48qfbt22vbtm2FOl54eLi6du2q999/X4ZhuNsXL16s1q1bq3r16pKkDz/8UDk5OerTp4/+/PNP9y0mJkb16tXT+vXrC3S++Ph4VaxYUbGxsbrtttsUEhKijz/+WNWqVZMkHTt2TJ9++qn69OmjU6dOuc/z119/KSEhQT///LN7lb9Vq1YpLi5OzZo1cx8/KipKAwYMyPPctWrVcs/quCxZskTt27dXuXLlPN5XfHy8srOztXHjxgL/LM936tSpi/Y/13ZXf+3bt68cDoc+/PBD9z5r1qzRiRMn1LdvX0nOz3Z98MEHuummm2QYhkfNCQkJOnnyZK6+MGjQoGL7LNj5QkND1a9fP/fzBg0aKDIyUo0aNVKrVq3c7a7Hrv8uCvOeAKAwuLQPAC4iPDxcknMwW1xcAcMlIiJCgYGBqlChQq72v/76q8jOu3z5ck2bNk07duxQRkaGu91msxX6mH379tWyZcuUlJSkNm3aaN++fdq6dauee+459z4///yzDMNQvXr18jyG3W4v0LnmzJmj+vXr6+TJk3rjjTe0ceNGj0vx9u7dK8MwNGHCBE2YMCHPYxw5ckRVq1bVwYMHPRZIcKlbt26er6tVq1autp9//lk7d+50fwYqr3MVRlhY2EX7n2u7K1BdddVVatiwoRYvXuwO5IsXL1aFChXUsWNHSdLRo0d14sQJvfbaa/muOPn3mvN638WhWrVqufphRESEYmNjc7VJzn8IkAr3ngCgMAhSAHAR4eHhqlKlinbv3l2g/fMLIdnZ2fm+Jq+V7/JbDe/8mZ7CnMvl888/180336wOHTropZdeUuXKlWW32zV//nwtXLjwoq/Pz0033aTg4GC9//77atOmjd5//335+Pjo9ttvd++Tk5Mjm82mTz75JM/3GRoaWqBzXXvtte4FLHr27Kl27drpjjvu0J49exQaGupe4GHMmDG5Zo9c8gtKF5PXrExOTo46deqkhx56KM/X1K9fv1DnatSokbZv366MjIx8P7O1c+dO2e12j3Dat29fTZ8+XX/++afCwsL08ccfq3///vLz83PXK0n/+Mc/cn2WyuXvn90qidkoKf/+f7H/LgrzngCgMAhSAFAAPXr00GuvvaakpKQ8Zy3O51ro4MSJEx7tBw8eLPK6LuVcH3zwgQIDA7V69WqPwfn8+fNz7WtmhiokJEQ9evTQkiVL9Mwzz2jx4sVq3769qlSp4t6nTp06MgxDtWrVKnS4+DtfX1/NnDlTN9xwg/7973/rkUceca8gaLfbPb7XKC81atTQ3r17c7Xn1ZafOnXqKC0t7aLnMjvj16NHDyUlJWnJkiV5Lh9+4MABff7554qPj/cIOn379tWUKVP0wQcfKDo6WqmpqR6Xy1WsWFFhYWHKzs6+aM2lRVl8TwCsic9IAUABPPTQQwoJCdHQoUOVkpKSa/u+ffv0/PPPS3LOYFWoUCHX52FeeumlIq/LtXre+efKzs4u0BcD+/r6ymazecxeHThwQMuWLcu1b0hISK6wdiF9+/bVH3/8oblz5+rbb791fybH5dZbb5Wvr6+mTJniMcMmOWcWCnv54vXXX69rr71Wzz33nNLT01WpUiVdf/31evXVV3X48OFc+x89etT9OCEhQUlJSdqxY4e77dixY3r33XcLfP4+ffooKSlJq1evzrXtxIkTysrKkiQFBwe72wri7rvvVqVKlTR27Nhcn5FLT0/XXXfdJcMwNHHiRI9tjRo1UtOmTbV48WItXrxYlStX9ljx0dfXV71799YHH3yQ54zr+T+f0qIsvicA1sSMFAAUQJ06dbRw4UL3MuUDBw5UkyZNlJmZqU2bNmnJkiXu71aSnItHzJo1S0OHDlXLli21ceNG/fTTT0Ve1xVXXKHWrVtr3LhxOnbsmKKiorRo0SL3gP1CunfvrmeeeUZdunTRHXfcoSNHjmjOnDmqW7eudu7c6bFvixYttHbtWj3zzDOqUqWKatWq5fGB/7/r1q2bwsLCNGbMGPfA9nx16tTRtGnTNG7cOB04cEA9e/ZUWFiY9u/fr48++kjDhw/XmDFjCvUzGTt2rG6//XYtWLBA//znPzVnzhy1a9dOTZs21bBhw1S7dm2lpKQoKSlJv/32m7799ltJzrD8zjvvqFOnTrr33nvdy59Xr15dx44dK9As0tixY/Xxxx+rR48eGjx4sFq0aKHTp09r165dWrp0qQ4cOKAKFSooKChIjRs31uLFi1W/fn1FRUWpSZMmatKkSZ7HLV++vJYuXaru3bvr6quv1tChQ9W4cWMlJydrwYIF2rt3r55//vk8l+fv27evJk6cqMDAQA0ZMiTXl+fOmjVL69evV6tWrTRs2DA1btxYx44d07Zt27R27VodO3asEL8F7yqL7wmABXljqUAAKK1++uknY9iwYUbNmjUNf39/IywszGjbtq3x4osveiyvfebMGWPIkCFGRESEERYWZvTp08c4cuRIvsufHz161OM8gwYNMkJCQnKd/7rrrjOuuOIKj7Z9+/YZ8fHxRkBAgBEdHW08+uijRmJiYoGWP583b55Rr149IyAgwGjYsKExf/58d03n+/HHH40OHToYQUFBhiT3Uuj5Lb9uGIYxYMAAQ5IRHx+f78/zgw8+MNq1a2eEhIQYISEhRsOGDY2RI0cae/bsyfc15593y5YtubZlZ2cbderUMerUqWNkZWW5f0YDBw40YmJiDLvdblStWtXo0aOHsXTpUo/Xbt++3Wjfvr0REBBgVKtWzZg5c6bxwgsvGJKM5ORk9341atQwunfvnmdtp06dMsaNG2fUrVvX8Pf3NypUqGC0adPGeOqpp4zMzEz3fps2bTJatGhh+Pv7F3gp9P379xvDhg0zqlevbtjtdqNChQrGzTffbHz++ef5vubnn382JBmSjC+++CLPfVJSUoyRI0casbGxht1uN2JiYowbb7zReO2119z7uJYpX7JkyUXr/LvCLH/+935uGPn/3CUZI0eONP2eAOBS2Azjb9dUAAAAt/vvv1+vvvqq0tLS8l3oAABw+eEzUgAA/M/Zs2c9nv/11196++231a5dO0IUAMADn5ECAOB/4uLidP3116tRo0ZKSUnRvHnzlJqamu93UAEALl8EKQAA/qdbt25aunSpXnvtNdlsNl199dWaN2+ex0p3AABIEp+RAgAAAACT+IwUAAAAAJhEkAIAAAAAk/iMlKScnBz98ccfCgsLK9AXLgIAAAAomwzD0KlTp1SlSpVcX2J+PoKUpD/++EOxsbHeLgMAAACARfz666+qVq1avtsJUpLCwsIkOX9Y4eHhXq3F4XBozZo16ty5s+x2u1drQelAn4FZ9BmYRZ+BWfQZmGG1/pKamqrY2Fh3RsgPQUpyX84XHh5uiSAVHBys8PBwS3QkWB99BmbRZ2AWfQZm0WdghlX7y8U+8sNiEwAAAABgEkEKAAAAAEwiSAEAAACASXxGqoCys7PlcDiK/TwOh0N+fn5KT09XdnZ2sZ8PpV9B+oyvr6/8/PxY3h8AAKCIEKQKIC0tTb/99psMwyj2cxmGoZiYGP36668MelEgBe0zwcHBqly5svz9/UuwOgAAgLKJIHUR2dnZ+u233xQcHKyKFSsWe7jJyclRWlqaQkNDL/gFYIDLxfqMYRjKzMzU0aNHtX//ftWrV4++BQAAcIkIUhfhcDhkGIYqVqyooKCgYj9fTk6OMjMzFRgYyGAXBVKQPhMUFCS73a6DBw+69wUAAEDhMVIvIC6zQ2lHMAcAACg6jKwAAAAAwCSCFAAAAACYRJCC19hsNi1btswyxwEAAAAKiiBVhiUnJ+vee+9V7dq1FRAQoNjYWN10001at26dt0srlMmTJ6tZs2a52g8fPqyuXbsW67lr1qwpm80mm82m4OBgNW3aVHPnzi3Wc5pxzz33qFevXt4uAwAA4LLBqn1l1IEDB9S2bVtFRkbqySefVNOmTeVwOLR69WqNHDlSP/74o7dLLDIxMTElcp6pU6dq2LBhOnPmjJYsWaJhw4apatWqxRriMjMz+d4nAAAAC2JGyiTDkE6f9s7NzPcB33PPPbLZbPr666/Vu3dv1a9fX1dccYVGjx6tzZs3S3KGLZvNph07drhfd+LECdlsNm3YsEGStGHDBtlsNq1evVrNmzdXUFCQOnbsqCNHjuiTTz5Ro0aNFB4erjvuuENnzpxxH6dmzZp67rnnPGpq1qyZJk+enG/NDz/8sOrXr6/g4GDVrl1bEyZMkMPhkCQtWLBAU6ZM0bfffuueGVqwYIEkz0v72rRpo4cfftjjuEePHpXdbtfGjRslSRkZGRozZoyqVq2qkJAQtWrVyv1+LyQsLEwxMTGqXbu2Hn74YUVFRSkxMdHjZzd06FBVrFhR4eHh6tixo7799luPY0ybNk2VKlVSWFiYhg4dqkceecRjlm3w4MHq2bOnpk+fripVqqhBgwaSpF9//VV9+vRRZGSkoqKidMstt+jAgQOSpClTpui9997Txx9/7P7ZFOT9AAAAoPCYkTLpzBkpNLQ4z+AjKTLPLWlpUkjIxY9w7NgxrVq1StOnT1dIHi+IjMz7+BcyefJk/fvf/1ZwcLD69OmjPn36KCAgQAsXLlRaWpp69eqlF198MVeIMSMsLEwLFixQlSpVtGvXLg0bNkxhYWF66KGH1LdvX+3evVurVq3S2rVrJUkRERG5jjFgwADNnj1bs2bNci9Zv3jxYlWpUkXt27eXJI0aNUrff/+9Fi1apCpVquijjz5Sly5dtGvXLtWrV++idebk5Oijjz7S8ePHPWaLbr/9dgUFBemTTz5RRESEXn31Vd1444366aefFBUVpXfffVfTp0/XSy+9pLZt22rRokV6+umnVatWLY/jr1u3TuHh4e6Q5nA4lJCQoLi4OH3++efy8/PTtGnT1KVLF+3cuVMPPvigdu3apTNnzrjDZVRUlPlfAAAAAAqMIFUG7d27V4ZhqGHDhkV2zGnTpqlt27aSpCFDhmjcuHHat2+fateuLUm67bbbtH79+ksKUuPHj3c/rlmzpsaMGaNFixbpoYceUlBQkEJDQ+Xn53fBS/n69Omj+++/X1988YU7OC1cuFD9+/eXzWbToUOHNH/+fB06dEhVqlSRJI0ZM0arVq3S/PnzNWPGjHyP/fDDD2v8+PHKyMhQVlaWoqKiNHToUEnSF198oa+//lpHjhxRQECAJOmpp57SsmXLtHTpUg0fPlwvvviihgwZorvuukuSNHHiRK1Zs0ZpaWke5wkJCdHcuXPdIe2dd95RTk6O5s6d6w6H8+fPV2RkpDZs2KD4+HgFBgYqOzu7xC5zBAAAuNwRpEwKDnbODBWXnJwcpaamKjw8PNcXqAYHF+wYhplrAAvoyiuvdD+Ojo52X353ftvXX399SedYvHixXnjhBe3bt09paWnKyspSeHi4qWNUrFhRnTt31rvvvqv27dtr//79SkpK0quvvipJ2rVrl7Kzs1W/fn2P12VkZKh8+fIXPPbYsWM1ePBgHT58WGPHjtU999yjunXrSpK+/fZbpaWl5TrG2bNntW/fPknSnj17dM8993hsv/baa/Xpp596tDVt2tRjpuvbb7/V3r17FRYW5rFfenq69u3bp/j4+Iv9WAAAQBn2xx/SwYPnPgZyKfdFcQyzx3Q4bNq2rbLq1JGaNCn4+/Y2gpRJNlvBLq8rrJwcKTvbeQ6fQn6CrV69erLZbBddUMIV1M4PXq7PJP2d3W53P7bZbB7PXW05OTkex/57oMvv2JKUlJSkAQMGaMqUKUpISFBERIT70jezBgwYoPvuu08vvviiFi5cqKZNm6pp06aSpLS0NPn6+mrr1q3y9fX1eF3oRa7ZrFChgurWrau6detqyZIlatq0qVq2bKnGjRsrLS1NlStXzvOzSWYvpfz75ZhpaWlq0aKF3n333Vz7VqxY0dSxAQBA2fLbb1Lt2tIFhlmlgJ+kaxUenk2QgndFRUUpISFBc+bM0X333ZdrYH7ixAlFRka6B+GHDx9W8+bNJclj4YlLUbFiRR0+fNj9PDU1Vfv37893/02bNqlGjRp67LHH3G0HDx702Mff31/Z2dkXPfctt9yi4cOHa9WqVVq4cKEGDhzo3ta8eXNlZ2fryJEj7kv/CiM2NlZ9+/bVuHHj9J///EdXX321kpOT5efnp5o1a+b5mgYNGmjLli0e9WzZsuWi57r66qu1ePFiVapUKc8ZupycHPn7+ys1NbXQ7wcAAJQuDof01lvSxo3Ox/7+Umysc9v/PglQoHsz+xbFa/NqM4wcHT9+XFWq5P78u5URpMqoOXPmqG3btrr22ms1depUXXnllcrKylJiYqJefvll/fDDDwoKClLr1q01a9Ys1apVS0eOHPH4nNKl6NixoxYsWKCbbrpJkZGRmjhxYq4ZoPPVq1dPhw4d0qJFi3TNNddoxYoV+uijjzz2qVmzpvbv368dO3aoWrVqCgsLc38e6XwhISHq2bOnJkyYoB9++EH9+/d3b6tfv74GDBiggQMH6umnn1bz5s119OhRrVu3TldeeaW6d+9e4Pf4r3/9S02aNNE333yj+Ph4xcXFqWfPnpo9e7bq16+vP/74QytWrFCvXr3UsmVL3XvvvRo2bJhatmypNm3aaPHixdq5c6fHJZJ5GTBggJ588kndcsstmjp1qqpVq6aDBw/qww8/1EMPPaQqVaooNjZW69ev1549e1S+fHlFRETkmjUEAABlx3/+I/3vo9qSpPh4acUK79VzKRyObK1c+YW6devm7VJMIUiVUbVr19a2bds0ffp0Pfjggzp8+LAqVqyoFi1a6OWXX3bv98Ybb2jIkCFq0aKFGjRooNmzZ6tz586XfP5x48Zp//796tGjhyIiIvT4449fcEbq5ptv1gMPPKBRo0YpIyND3bt314QJEzyWS+/du7c+/PBD3XDDDTpx4oTmz5+vwYMH53m8AQMGqFu3burQoYOqV6/usW3+/PmaNm2aHnzwQf3++++qUKGCWrdurR49eph6j40bN1bnzp01ceJErVy5UitXrtRjjz2mu+66S0ePHlVMTIw6dOig6Ohod02//PKLxowZo/T0dPXp00eDBw++6GfLgoODtXHjRj388MO69dZbderUKVWtWlU33nije4Zq0KBB2rx5s1q2bKm0tDStX79e119/van3AwAoGoYh7dmT92eq8/sYc1G0F+exzbZnZdm0e3d5hYba5Od38f3za7fSeyqq9qI69po1zvsGDaTevaVBg/LeD8XHZhTHygSlTGpqqiIiInTy5Mlcl06lp6dr//79qlWrlgIDA4u9lgstNoGyp1OnToqJidHbb79d6GMUtM+UdF+GdTkcDq1cuVLdunVj5hIFQp8x55VXpBEjvF0FLhcjRkgvveTtKi6N1f7GXCgbnI8ZKaCEnDlzRq+88ooSEhLk6+ur9957T2vXrvX4Ul8AKK2OH5d++UVKT5eyspy37GznfUaG9OWX0u+/e/7remFXAbPia7Oznd81mZ4uff/9uf3/dlGEpHOfDbFCe3Ed2zAMnT6dptDQUPdXd5TEeUui3Uq1hIR4Xt6HkkWQAkqIzWbTypUrNX36dKWnp6tBgwb64IMPWL4cQKliGM4VZh0OZ0hyOKT//pfLivKyapWUkODtKrzD4cjSypWf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AAAAWE2hPs0yYMAADRgwIN/tQUFBhS4IJWfhwnOPb71V8vd33ipUkGJjpdBQycen4Dd/f6lDB++9HwAAAKCkFCpInThxQkuXLtUvv/yiMWPGKCoqStu2bVN0dLSqVq1a1DWimPz1l/P+kUekmTO9WwsAAABQmpgOUjt37lR8fLwiIiJ04MABDR06VFFRUfrwww916NAhvfXWW8VRJ4rB2bPO+5AQ79YBAAAAlDamV+0bPXq0Bg8erJ9//tljZb5u3bpp48aNRVocikdWljRqlLRypfM5V2ICAAAA5piekdqyZYteffXVXO1Vq1ZVcnJykRSF4nHkiDRtmvTii57ttWp5px4AAACgtDIdpAICApSampqr/aefflLFihWLpCgUnexs6YknpB9/lFatko4ePbdtyBBp8GCWKwcAAADMMh2kbr75Zk2dOlXvv/++JMlms+nQoUN6+OGH1bt37yIvEJdm82bpscc82+68Uxo7Vmra1Ds1AQAAAKWd6c9IPf3000pLS1OlSpV09uxZXXfddapbt65CQ0M1ffr04qgRlyAtzXlftao0Z460bZv01luEKAAAAOBSmJ6RioiIUGJior744gvt3LlTaWlpuvrqqxUfH18c9eES5eQ472NipHvu8W4tAAAAQFlRqO+RkqR27dqpXbt27ufbtm3TxIkTtXz58iIpDEXDFaR8TM89AgAAAMiPqeH16tWrNWbMGD366KP65ZdfJEk//vijevbsqWuuuUY5rlE7LIMgBQAAABS9As9IzZs3T8OGDVNUVJSOHz+uuXPn6plnntG9996rvn37avfu3WrUqFFx1opCIEgBAAAARa/Aw+vnn39eTzzxhP7880+9//77+vPPP/XSSy9p165deuWVVwhRFkWQAgAAAIpegYfX+/bt0+233y5JuvXWW+Xn56cnn3xS1apVK7bicOmys533BCkAAACg6BR4eH327FkFBwdLcn53VEBAgCpXrlxshaFoMCMFAAAAFD1Tq/bNnTtXoaGhkqSsrCwtWLBAFSpU8NjnvvvuK7rqcMlcQcrX17t1AAAAAGVJgYNU9erV9frrr7ufx8TE6O233/bYx2azEaQshhkpAAAAoOgVOEgdOHCgGMtAcSFIAQAAAEWP4XUZR5ACAAAAih7D6zKOIAUAAAAUPYbXZRzLnwMAAABFj+F1GceMFAAAAFD0GF6X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AAAAADCJIOUFc+bMUc2aNRUYGKhWrVrp66+/vuD+S5YsUcOGDRUYGKimTZtq5cqVJVQprMJMn3n99dfVvn17lStXTuXKlVN8fPxF+xjKHrN/Z1wWLVokm82mnj17Fm+BsBSz/eXEiRMaOXKkKleurICAANWvX5//N11mzPaZ5557Tg0aNFBQUJBiY2P1wAMPKD09vYSqhbdt3LhRN910k6pUqSKbzaZly5Zd9DUbNmzQ1VdfrYCAANWtW1cLFiwo9jrNIkiVsMWLF2v06NGaNGmStm3bpquuukoJCQk6cuRInvtv2rRJ/fv315AhQ7R9+3b17NlTPXv21O7du0u4cniL2T6zYcMG9e/fX+vXr1dSUpJiY2PVuXNn/f777yVcObzFbJ9xOXDggMaMGaP27duXUKWwArP9JTMzU506ddKBAwe0dOlS7dmzR6+//rqqVq1awpXDW8z2mYULF+qRRx7RpEmT9MMPP2jevHlavHixHn300RKuHN5y+vRpXXXVVZozZ06B9t+/f7+6d++uG264QTt27ND999+voUOHavXq1cVcqUkGStS1115rjBw50v08OzvbqFKlijFz5sw89+/Tp4/RvXt3j7ZWrVoZd999d7HWCesw22f+LisrywgLCzPefPPN4ioRFlOYPpOVlWW0adPGmDt3rjFo0CDjlltuKYFKYQVm+8vLL79s1K5d28jMzCypEmExZvvMyJEjjY4dO3q0jR492mjbtm2x1glrkmR89NFHF9znoYceMq644gqPtr59+xoJCQnFWJl5zEiVoMzMTG3dulXx8fHuNh8fH8XHxyspKSnP1yQlJXnsL0kJCQn57o+ypTB95u/OnDkjh8OhqKio4ioTFlLYPjN16lRVqlRJQ4YMKYkyYRGF6S8ff/yx4uLiNHLkSEVHR6tJkyaaMWOGsrOzS6pseFFh+kybNm20detW9+V/v/zyi1auXKlu3bqVSM0ofUrL+NfP2wVcTv78809lZ2crOjraoz06Olo//vhjnq9JTk7Oc//k5ORiqxPWUZg+83cPP/ywqlSpkusPEsqmwvSZL774QvPmzdOOHTtKoEJYSWH6yy+//KJPP/1UAwYM0MqVK7V3717dc889cjgcmjRpUkmUDS8qTJ+544479Oeff6pdu3YyDENZWVn65z//yaV9yFd+49/U1FSdPXtWQUFBXqrMEzNS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",
            "text/plain": [
              "<Figure size 1000x600 with 1 Axes>"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "import matplotlib.pyplot as plt\n",
        "\n",
        "# Plot the cumulative regrets over time\n",
        "plt.figure(figsize=(10, 6))\n",
        "plt.plot(regrets, label='Cumulative Regret', color='blue')\n",
        "plt.title('Cumulative Regret Over Time')\n",
        "plt.xlabel('Rounds')\n",
        "plt.ylabel('Cumulative Regret')\n",
        "plt.grid(True)\n",
        "plt.legend()\n",
        "plt.show()"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "lnvDpzCgmZEV"
      },
      "source": [
        "## MAR"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 9,
      "metadata": {
        "id": "7SVk8o_kpzWS"
      },
      "outputs": [],
      "source": [
        "class UCB_algo:\n",
        "    def __init__(self, bandit_env, alpha):\n",
        "        self.bandit_env = bandit_env\n",
        "        self.num_arms = bandit_env.num_arms\n",
        "        self.counts = np.zeros(self.num_arms)\n",
        "        self.means = np.zeros(self.num_arms)\n",
        "        self.total_pulls = 0\n",
        "        self.alpha = alpha\n",
        "\n",
        "    def select_arm(self, round_number):\n",
        "        if self.total_pulls < self.num_arms:\n",
        "            return self.total_pulls\n",
        "\n",
        "        ucb_values = np.zeros(self.num_arms)\n",
        "        for arm in range(self.num_arms):\n",
        "            if self.counts[arm] == 0:\n",
        "                ucb_values[arm] = float('inf')\n",
        "            else:\n",
        "                confidence_bound = np.sqrt(self.alpha / 2 * np.log(self.total_pulls) / self.counts[arm])\n",
        "                ucb_values[arm] = self.means[arm] + confidence_bound\n",
        "\n",
        "        return np.argmax(ucb_values)\n",
        "\n",
        "    def update(self, arm, reward, observed):\n",
        "        if observed:\n",
        "            self.counts[arm] += 1\n",
        "            self.means[arm] += (reward - self.means[arm]) / self.counts[arm]\n",
        "\n",
        "        self.total_pulls += 1\n",
        "\n",
        "    def update_regret(self, arm, cu_regret, regrets):\n",
        "        regret = np.sum(self.bandit_env.p[self.bandit_env.best_arm] * self.bandit_env.means[self.bandit_env.best_arm]) - np.sum(self.bandit_env.p[arm] * self.bandit_env.means[arm])\n",
        "        cu_regret += regret\n",
        "        regrets.append(cu_regret)\n",
        "        return cu_regret\n",
        "\n",
        "    def run(self, num_rounds):\n",
        "        results = []\n",
        "        regrets = []\n",
        "        cu_regret = 0\n",
        "        for round_number in range(num_rounds):\n",
        "            arm = self.select_arm(round_number)\n",
        "\n",
        "            reward, observed, context = self.bandit_env.pull_arm(arm)\n",
        "\n",
        "            cu_regret = self.update_regret(arm, cu_regret, regrets)\n",
        "            self.update(arm, reward, observed)\n",
        "\n",
        "            results.append((arm, reward, observed))\n",
        "\n",
        "        return results, regrets"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 10,
      "metadata": {
        "id": "PxTQ1db8m00E"
      },
      "outputs": [],
      "source": [
        "class MAR:\n",
        "    def __init__(self, means, gamma, prob):\n",
        "        self.means = means\n",
        "        self.gamma = gamma\n",
        "        self.p = prob\n",
        "        self.num_arms = means.shape[0]  # Number of arms (n)\n",
        "        self.num_contexts = means.shape[1]  # Number of contexts (k)\n",
        "        self.best_arm = np.argmax(np.sum(self.p * self.means , axis=1))\n",
        "\n",
        "    def pull_arm(self, arm):\n",
        "        if arm >= self.num_arms:\n",
        "            raise ValueError(\"Invalid arm index\")\n",
        "\n",
        "        # Select a context based on the probability distribution p[arm]\n",
        "        context = np.random.choice(self.num_contexts, p=self.p[arm])\n",
        "\n",
        "        # Reward is drawn from a normal distribution centered at the means[arm, context]\n",
        "        reward = np.random.normal(self.means[arm, context], 1)\n",
        "\n",
        "        # Determine if the reward is observed based on the gamma[arm, context]\n",
        "        observed = np.random.rand() < self.gamma[arm, context]\n",
        "        if observed:\n",
        "            return reward, observed, context\n",
        "        else:\n",
        "            return None, observed, context"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 11,
      "metadata": {
        "id": "A41rdwkNm1tw"
      },
      "outputs": [],
      "source": [
        "class MAR_algo:\n",
        "    def __init__(self, bandit_env, alpha, p_known):\n",
        "\n",
        "        self.bandit_env = bandit_env\n",
        "        self.num_arms = bandit_env.num_arms\n",
        "        self.num_contexts = bandit_env.num_contexts\n",
        "        # self.p = bandit_env.p\n",
        "        self.alpha = alpha\n",
        "        self.p_known = p_known\n",
        "        self.p = np.zeros((self.num_arms, self.num_contexts))\n",
        "\n",
        "        self.counts = np.zeros((self.num_arms, self.num_contexts))  # Keeps track of how many times each arm-context pair has been pulled\n",
        "        self.means = np.zeros((self.num_arms, self.num_contexts))  # Estimate of the mean reward for each arm-context pair\n",
        "        self.s = np.zeros((self.num_arms, self.num_contexts))\n",
        "\n",
        "    def select_arm(self, round_number):\n",
        "\n",
        "        # Calculate UCB values for each arm based on all contexts\n",
        "        ucb_values = np.zeros(self.num_arms)\n",
        "        for arm in range(self.num_arms):\n",
        "            if self.p_known:\n",
        "              self.p = bandit_env.p\n",
        "            else:\n",
        "              self.p[arm, :] = self.s[arm, :] / np.sum(self.counts[arm])\n",
        "\n",
        "            if np.any(self.counts[arm] == 0):\n",
        "                ucb_values[arm] = float('inf')  # If no context has been explored for this arm, set UCB to infinity\n",
        "            else:\n",
        "                # Calculate the mean reward over all contexts weighted by pulls\n",
        "                mean_reward = np.sum(self.p[arm] * self.means[arm])\n",
        "\n",
        "                # UCB confidence bound using total counts\n",
        "                if self.p_known:\n",
        "                  confidence_bound = np.sqrt(self.alpha / 2 * np.log(round_number) * np.sum((p[arm] ** 2) / self.counts[arm]))\n",
        "                else:\n",
        "                  confidence_bound = 8 * np.sqrt(self.alpha / 2 * np.log(round_number) * np.sum((p[arm] ** 2) / self.counts[arm]))\n",
        "                ucb_values[arm] = mean_reward + confidence_bound\n",
        "\n",
        "        # Select the arm with the highest UCB value\n",
        "        return np.argmax(ucb_values)\n",
        "\n",
        "    def update(self, arm, context, reward, observed):\n",
        "        self.s[arm, context] += 1\n",
        "\n",
        "        if observed:\n",
        "            # Increment the count for the pulled arm-context pair\n",
        "            self.counts[arm, context] += 1\n",
        "\n",
        "            # Update the estimated mean reward for this arm-context pair\n",
        "            self.means[arm, context] = (reward + self.means[arm, context] * (self.counts[arm, context] - 1)) / self.counts[arm, context]\n",
        "\n",
        "    def update_regret(self, arm, context, cu_regret, regrets):\n",
        "\n",
        "        regret = np.sum(self.bandit_env.p[self.bandit_env.best_arm] * self.bandit_env.means[self.bandit_env.best_arm]) - np.sum(self.bandit_env.p[arm] * self.bandit_env.means[arm])\n",
        "\n",
        "        cu_regret += regret  # Add this round's regret to the cumulative regret\n",
        "        regrets.append(cu_regret)  # Store the cumulative regret\n",
        "        return cu_regret\n",
        "\n",
        "    def run(self, num_rounds):\n",
        "\n",
        "        results = []\n",
        "        regrets = []\n",
        "        cu_regret = 0\n",
        "\n",
        "        for arm in range(self.num_arms):\n",
        "          for _ in range(int(np.log(num_rounds)**2)):\n",
        "            reward, observed, context = self.bandit_env.pull_arm(arm)\n",
        "            cu_regret = self.update_regret(arm, context, cu_regret, regrets)\n",
        "            self.update(arm, context, reward, observed)\n",
        "            results.append((arm, reward, observed, context))\n",
        "\n",
        "        for round_number in range(num_rounds - self.num_arms * int(np.log(num_rounds)**2)):\n",
        "            # Select an arm using the UCB strategy\n",
        "            arm = self.select_arm(round_number)\n",
        "\n",
        "            # Pull the arm and observe the reward and context\n",
        "            reward, observed, context = self.bandit_env.pull_arm(arm)\n",
        "\n",
        "            # Update the cumulative regret and store the result\n",
        "            cu_regret = self.update_regret(arm, context, cu_regret, regrets)\n",
        "\n",
        "            # Update the means and counts based on the observed reward\n",
        "            self.update(arm, context, reward, observed)\n",
        "\n",
        "            # Store the results for this round\n",
        "            results.append((arm, reward, observed, context))\n",
        "\n",
        "        return results, regrets"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 28,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "_r1V1UPExUUd",
        "outputId": "fe0f9be5-1cf1-4dd7-f6d5-1099c5418635"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Z8_interval            0            1      2           3       4\n",
            "Z1                                                              \n",
            "b'1'         2125.547826  1222.230769  695.2  800.666667     NaN\n",
            "b'2'         2226.384615   993.454545  864.0  575.750000  717.75\n"
          ]
        }
      ],
      "source": [
        "import pandas as pd\n",
        "\n",
        "k=5\n",
        "\n",
        "# Step 1: Discretize the Z8 (mediator) into 5 intervals\n",
        "df['Z8_interval'] = pd.cut(df['Z8'], bins=k, labels=False)  # You can also add labels=True for actual intervals\n",
        "\n",
        "# Step 2: Group by Z1 (arm) and Z8_interval and calculate the mean reward (class)\n",
        "grouped = df.groupby(['Z1', 'Z8_interval'])['class'].mean().unstack()\n",
        "\n",
        "# Step 3: Display the matrix of arm × intervals\n",
        "print(grouped)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 29,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "Id48gAAnoILQ",
        "outputId": "041cf637-ccdc-4e5e-a3ef-d2755ada6239"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Z8_interval         0         1         2         3         4\n",
            "Z1                                                           \n",
            "b'1'         0.438832  0.252337  0.143528  0.165302  0.000000\n",
            "b'2'         0.414031  0.184748  0.160674  0.107070  0.133477\n"
          ]
        }
      ],
      "source": [
        "import pandas as pd\n",
        "\n",
        "# Step 1: Discretize the Z8 (mediator) into 5 intervals\n",
        "df['Z8_interval'] = pd.cut(df['Z8'], bins=k, labels=False)\n",
        "\n",
        "# Step 2: Group by Z1 (arm) and Z8_interval and calculate the mean reward (class)\n",
        "mean_reward_matrix = df.groupby(['Z1', 'Z8_interval'])['class'].mean().unstack()\n",
        "\n",
        "# Step 3: Replace NaN values with 0\n",
        "mean_reward_matrix.fillna(0, inplace=True)\n",
        "\n",
        "# Step 4: Construct the probability matrix\n",
        "# Normalize each row by dividing by the row sum (sum of rewards per arm)\n",
        "probability_matrix = mean_reward_matrix.div(mean_reward_matrix.sum(axis=1), axis=0)\n",
        "\n",
        "# Step 5: Replace any NaN resulting from 0/0 divisions with 0 (if rows sum to 0)\n",
        "probability_matrix.fillna(0, inplace=True)\n",
        "\n",
        "# Step 6: Display the final probability matrix\n",
        "print(probability_matrix)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 30,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "GlnbTPT8nIXN",
        "outputId": "9e75e9f4-56cf-4181-fdde-74f792642e92"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "[[0.43883227 0.25233697 0.14352826 0.1653025  0.        ]\n",
            " [0.41403091 0.18474835 0.16067426 0.10706968 0.1334768 ]]\n",
            "[[2125.54782609 1222.23076923  695.2         800.66666667    0.        ]\n",
            " [2226.38461538  993.45454545  864.          575.75        717.75      ]]\n"
          ]
        }
      ],
      "source": [
        "n = 2\n",
        "k = 5\n",
        "\n",
        "np.random.seed(5)\n",
        "\n",
        "gamma = np.random.uniform(0.7, 1.0, size=(n, k))\n",
        "\n",
        "# Randomly generate a probability matrix for the categorical distribution (each row sums to 1)\n",
        "p = probability_matrix.to_numpy()\n",
        "means = mean_reward_matrix.to_numpy()\n",
        "\n",
        "print(p)\n",
        "print(means)\n",
        "\n",
        "bandit_env = MAR(means, gamma, p)\n",
        "\n",
        "alpha = 1\n",
        "p_known = 1\n",
        "algo = MAR_algo(bandit_env, alpha, p_known)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 31,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "WNpLPqczoTCb",
        "outputId": "886807ba-e34c-42ff-f945-a471ab7c829e"
      },
      "outputs": [
        {
          "name": "stderr",
          "output_type": "stream",
          "text": [
            "<ipython-input-11-1b3319606638>:34: RuntimeWarning: divide by zero encountered in log\n",
            "  confidence_bound = np.sqrt(self.alpha / 2 * np.log(round_number) * np.sum((p[arm] ** 2) / self.counts[arm]))\n",
            "<ipython-input-11-1b3319606638>:34: RuntimeWarning: invalid value encountered in sqrt\n",
            "  confidence_bound = np.sqrt(self.alpha / 2 * np.log(round_number) * np.sum((p[arm] ** 2) / self.counts[arm]))\n"
          ]
        }
      ],
      "source": [
        "np.random.seed(42)\n",
        "T = 1000\n",
        "results, regrets1 = algo.run(T)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 32,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 307
        },
        "id": "pSEhEo5KoYdU",
        "outputId": "603bd174-bdbc-4a8e-867d-9ce6268a5b50"
      },
      "outputs": [
        {
          "data": {
            "image/png": "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llOTjNRITmokJzWjuuPYgQMHyM7O5qKLLmLx4sUcPnwYgEcffZTbbrvN7g10R/v27XP4Oq1Fevx48Hbqvc/UOSMnVyMZqZGc1EhOahyZ05CL9E033URBQQHt7e0256UvueQS1q5da9fGCftxtXG7hRBCnMb9pP/zn/+wceNGfH19bV5PSkriyy+/tFvD3FlWVpZD19fVBd3dg89dqUg7OidXJBmpkZzUSE5qHJnTkPekLRYLAwMDJ7x+8OBBgoOD7dIod3fw4EGHrs8VO42B43NyRZKRGslJjeSkxpE5DblIz5kzh6efflr/28PDg87OTu6//34uvPBCe7bNbXV0dDh0fa5apB2dkyuSjNRITmokJzWOzGnIh7t/+9vfcv7555ORkYHZbObKK69kz549RERE8Pe//30k2uh2vnqqYKS5apF2dE6uSDJSIzmpkZzUODKnIe9JJyQksHXrVn75y19y8803M336dB555BG2bNlC1BArwPLlyyksLCQ4OJioqCguvvhidu3aZTPP2WefjYeHh81j0aJFNvPU19czd+5cAgICiIqK4vbbbz/hJiCffvopeXl5+Pn5kZqayooVK4b60e0mNzfXoetz1SLt6JxckWSkRnJSIzmpcWROQyrSfX19pKSksGfPHubPn89jjz3G888/z3XXXWfT01vV+vXrWbx4MV988QVr1qyhr6+POXPm0NXVZTPf9ddfz6FDh/THY489pk8bGBhg7ty59Pb2snHjRl599VVWrFjBsmXL9Hnq6uqYO3cu55xzDpWVlSxdupTrrruODz/8cMhttofNmzc7dH2uWqQdnZMrkozUSE5qJCc1jsxpSIe7fXx8MJvNdlv56tWrbf5esWIFUVFRlJeXM2vWLP31gIAAYmJiTrqMjz76iB07dvDxxx8THR1Nbm4uv/rVr7jzzjt54IEH8PX15cUXXyQ5OZknnngCgPT0dD777DOeeuopiouL7fZ5RitXLdJCCDHWDflw9+LFi3n00UdPek/p4TIajQCEh4fbvP76668TERFBVlYWd999N93W64mATZs2kZ2dTXR0tP5acXExJpOJ7du36/PMnj3bZpnFxcVs2rTJ7p9Bxdf94BgprlqkHZ2TK5KM1EhOaiQnNY7Macgdx0pLS1m7di0fffQR2dnZJ4zh/c4775xWQywWC0uXLuXb3/62zTVoV155JRMnTiQuLo6qqiruvPNOdu3apa+nqanJpkAD+t9NTU3fOI/JZOLYsWMnHKrv6emhp6dH/9veN/gOCgqy6/JOxVWLtKNzckWSkRrJSY3kpMaROQ25SIeGhjJv3jy7N2Tx4sVUV1fz2Wef2bx+ww036M+zs7OJjY3lvPPOo7a2lpSUFLu3AwY7tD344IMnvF5WVkZgYCB5eXnU1NRw7NgxgoODSU5OpqqqCoCJEydisVhoaGgABjsY7N27l87OTgIDA5kyZQqlpaWEhYURHx+Pl5cXBw4cACAnJ4f9+/djMpnw9/cnMzOT8vJyYHBAd39/f304uqysLA4ePEhHRwe+vr7k5ubq50liYmIICgpi7969ADQ1FQBe+PhY2LNnCwUF+WzevBlN04iMjCQsLIzdu3cDMHXqVNra2jh8+DCenp4UFhZSVlbGwMAA48ePJyoqipqaGgAmT56MyWSiubkZgJkzZ1JRUUFfXx9hYWHExcXpRzNSUlLo7u7m0KFDABQUFFBdXY3ZbCYkJITExES2bdsGDA6M09/fz7Zt2wgLCyMvL4+dO3fS3d1NUFAQKSkpbN26FYDExERgsPMgwLRp06itraWzs5OAgADS0tKoqKgAID4+Hm9vb/bv3w8Mbk/19fUYjUb8/f3JysqirKwMgNjYWAICAqitrQUG7x/b2NhIe3s7Pj4+5OXlUVJSAgz+4DMYDOzZswcYPJ3S0tLCkSNH8PLyoqCggNLSUiwWC5GRkYSHh+sdJKdMmUJ7ezuHDx/Gw8ODGTNmUF5eTn9/P+Hh4URHR+t5p6am0tnZqf/4tM4bEhJCaGgo8fHxVFdXAzBp0iTMZjONjY0A5Ofns337dsxmMwaDgaSkJJttdmBgQL/2c/r06ezevZuuri6CgoJITU2lsrISGOw46unpabPN1tXVcfToUcaNG0d6erqe94QJE/D19aWurk7Pu6GhgY6ODvz8/MjJyaG0tFTfZgMDA/W8MzIyaGpqoq2t7YS8o6KiCAkJ0fNOS0ujtbWV1tZWfZu15h0REUFERIT+f27y5MkYjUZa/vvL9fhtNjw8nJiYGHbs2KFvs11dXXrehYWFVFVV0dPTQ2hoKAkJCfo2m5ycTG9vrz6g03C/I7Zs2aJvs474jkhPT6e5uZna2loiIyPJz3eN7wjrNuvo74j29nYyMjKG9R1hfd8paaPA4sWLtfj4eG3fvn2nnLezs1MDtNWrV2uapmn33XefNm3aNJt59u3bpwFaRUWFpmmadtZZZ2k33XSTzTwvv/yyZjAYTroOs9msGY1G/dHQ0KABmtFoHPqHO4kvvvjCLstRFROjaaBp8fEOXe2wOTonVyQZqZGc1EhOauyRk9FoVKorQz4nbU+aprFkyRLeffdd1q1bR3Jy8infY/1FHxsbC0BRURHbtm3TfxkDrFmzBoPBQEZGhj7PV8cVX7NmDUVFRSddh5+fHwaDweZhT+np6XZd3jexWOC/90AhMtJhq7ULR+bkqiQjNZKTGslJjSNzGvLh7unTp+Ph4XHC6x4eHvj7+5Oamso111zDOeecc8plLV68mL/97W/885//JDg4WD+sFBISwrhx46itreVvf/sbF154IePHj6eqqoqbb76ZWbNmkZOTAwyOgJaRkcFVV13FY489RlNTE/feey+LFy/Gz88PgEWLFvH73/+eO+64g5/85CesW7eOt956iw8++GCoH98umpub7V74v057O1hHcXWl89Hg2JxclWSkRnJSIzmpcWROQ96TPv/889m3bx+BgYGcc845nHPOOQQFBVFbW0thYSGHDh1i9uzZ/POf/zzlsl544QWMRiNnn302sbGx+uPNN98EBkd1+fjjj5kzZw5paWnceuutzJs3j/fff19fhpeXFytXrsTLy4uioiJ+/OMfc/XVV/PQQw/p8yQnJ/PBBx+wZs0apk2bxhNPPMFLL73ktMuv2traHLYuV+00Bo7NyVVJRmokJzWSkxpH5jTkPenW1lZuvfVW7rvvPpvXf/3rX3PgwAE++ugj7r//fn71q19x0UUXfeOyNE37xukJCQmsX7/+lG2aOHEiq1at+sZ5zj77bL0zhrN5O/CGzq5cpB2Zk6uSjNRITmokJzWOzMlDO1Wl/IqQkBDKy8tJTU21eX3v3r3k5+djNBrZuXMnhYWFHD161K6NdRaTyURISAhGo9HlDgW9/Tb83/8NPn/0UbjjDue2RwghhHpdGfLhbn9/fzZu3HjC6xs3bsTf3x8YvObZ+lycyJFDyrnynrQMUXhqkpEayUmN5KRm1A4LCvDzn/+cRYsWUV5eTmFhITA4wMlLL73EPffcA8CHH34oA7V/gyEevBgWVy7SjszJVUlGaiQnNZKTGkfmNOQife+995KcnMzvf/97XnvtNWDw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fSjh7OxsGhoa6OjowM/Pj5ycHEpLSwGIiYkhMDBQzzsjI4Ompiba2tpOyDsqKoqQkBA977S0NFpbW2ltbdW3WWveERERRERE6NvS5MmTMRqNtPz3l+3x22x4eDgxMTHs2LFD32a7urr0vAsLC6mqqqKnp4fQ0FASEhL0bTY5OZne3l6+/PJLgGF/R2zZskXfZu3xHeHr60tubi6bN2/W8z7Zd0R3dzfl5eUu8x1h3WYd/R3R3d1NfX39sL4jrO87JW2IPDw8NA8PD83T09PmYX3tdAHau+++q/9dW1urAdqWLVts5ps1a5b2i1/8QtM0Tfvzn/+shYaG2kzv6+vTvLy8tHfeeUfTNE276qqrtIsuushmnnXr1mmA1tbWdtK2mM1mzWg06o+GhgYN0IxG42l/vuMdOXLELsuxuuoqTYPBx44ddl20U9k7J3ckGamRnNRITmrskZPRaFSqK0M+J/3JJ5/wySefsG7dOpuH9TV7SU5OJiYmhrVr1+qvmUwmSkpKKCoqAqCoqIiOjg79lyTAunXrsFgs+m3EioqK2LBhA319ffo8a9asYerUqSc91A3g5+eHwWCwedjTVy8jGy53Pdxt75zckWSkRnJSIzmpcWROQz7c/Z3vfMduK+/s7NQPt8BgZ7HKykrCw8NJTExk6dKl/PrXv2by5MkkJydz3333ERcXp/cAT09P5/zzz+f666/nxRdfpK+vjyVLlnD55ZcTFxcHwJVXXsmDDz7IwoULufPOO6muruaZZ5454ZabrsxapL28BocFFUII4R6GfAnWhg0bvnH6rFmzlJf16aefcs4555zw+oIFC1ixYgWapnH//ffzxz/+kY6ODs4880yef/55pkyZos/b1tbGkiVLeP/99/H09GTevHk8++yzNkO2VVVVsXjxYkpLS4mIiODnP/85d955p3I77X0JlslksuveeXw8fPklxMTAf0/nuAV75+SOJCM1kpMayUmNPXJSrStDLtKeniceIT/+WumBgYGhLM4l2LtI7927l9TUVDu0bPBMtJ8f9PVBTg78t6+EW7BnTu5KMlIjOamRnNTYI6cRu066vb3d5tHS0sLq1aspLCzko48+Glajx4ojR47YbVlG42CBBvc6Hw32zcldSUZqJCc1kpMaR+Y05HPSISEhJ7z23e9+F19fX2655RabTlzi5Ly8vOy2LHftNAb2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",
            "text/plain": [
              "<Figure size 500x300 with 1 Axes>"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "plt.figure(figsize=(5, 3))\n",
        "plt.plot(regrets1, label='Cumulative Regret', color='blue', linewidth=2)\n",
        "plt.xlabel('Iteration')\n",
        "plt.ylabel('Cumulative Regret')\n",
        "# plt.legend(loc='upper left', fontsize=12)\n",
        "plt.grid(True, which='both', linestyle='--', linewidth=0.5)\n",
        "\n",
        "# Adjust the ticks for better readability\n",
        "# plt.xticks(fontsize=12)\n",
        "# plt.yticks(fontsize=12)\n",
        "\n",
        "# Save the figure with high resolution\n",
        "plt.tight_layout()\n",
        "plt.savefig('cumulative_regret_plot_paper.png', dpi=300)\n",
        "\n",
        "# Display the plot\n",
        "plt.show()"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 33,
      "metadata": {
        "id": "URhhE-5hozUD"
      },
      "outputs": [],
      "source": [
        "np.random.seed(42)\n",
        "\n",
        "algo = UCB_algo(bandit_env, alpha)\n",
        "results, regrets2 = algo.run(1000)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 34,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 507
        },
        "id": "nVOrHEcUqM4-",
        "outputId": "287c8a62-428a-4282-8ef9-96913af79655"
      },
      "outputs": [
        {
          "data": {
            "image/png": "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DiQ3N5evv/6aPn36sHLlSrp27QrAF198wbBhw2jevDlPPvkkAGFhYdf9PQYNGsS2bdto1qyZ3n7y5Em2bt3KO++8o7e98cYbvPrqq/Tt25dhw4aRmJjIRx99RJs2bdi5c+ctfY1c0MEpX7683rZ//35atWpF1apVefHFF/H09GTp0qV0796db775hh49egBw9uxZ2rVrh8FgYOLEiXh6ejJ37tzrDps4dOgQjzzyCCNGjGD48OHUrl2bzMxM2rZty9mzZxkxYgTVqlVj8+bNTJw4kfPnzzNz5kz8/f355JNPePrpp+nRowc9e/YEoGHDhgD06tWL/fv3M3r0aEJCQkhISGDdunWcOnVKH8v53XffMXToUObPn3/LX98W/MF15X4ubiaffPIJo0aN4t5772Xs2LGcOHGC7t27U758eYKCgops6/XXX8fFxYXnn3+enJwcXFxcWL9+PQ888ABRUVFMnjwZBwcH5s+fT/v27fn9999p3rw5PXv25PDhw3z11Ve8//77VKxYEQB/f3/2799Pt27daNiwIa+99hqurq4cPXrUoiNc0pydnenRowfffvstc+bMwcXFRX/u+++/Jycnh/79+wPw+eef88wzz9C7d2+effZZsrOz2bNnD3/99RcDBgywetvXOraLc7yBuQP64IMP8vfff/P0008TERHBDz/8wODBg6+5rfz8fGJiYmjdujXvvvsuHh4eAIwYMYIFCxYwdOhQnnnmGeLi4vj444/ZuXMnf/75J87OzsycOZPRo0fj5eXFyy+/DEClSpUA8x8m06dP1z9P0tLS2L59O7GxsXTq1MnqfRIfH68fE+Iupwkhris1NVUDtIcffrhYy8fFxWmANn/+/CLPAdrkyZP1x5MnT9YA7cknn9Tb8vPztaCgIM1gMGhvvfWW3p6cnKy5u7trgwcP1tvmz5+vAVpcXJzFdn777TcN0H777Te9bfDgwVr16tUtlsvMzLR4nJubq9WvX19r3769Rbunp6fFdq+3/dTUVM3V1VV77rnnLJb7z3/+oxkMBu3kyZOapmnaiRMnNEdHR+2NN96wWG7v3r2ak5NTkfbrbfeXX37REhMTtdOnT2vLly/X/P39NVdXV+306dP6sh06dNAaNGigZWdn620mk0m75557tJo1a+pto0eP1gwGg7Zz50697dKlS5qfn1+RfVy9enUN0Fav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",
            "text/plain": [
              "<Figure size 700x500 with 1 Axes>"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "# Plot the regrets on the same figure\n",
        "plt.figure(figsize=(7, 5))\n",
        "\n",
        "# Plot regrets1\n",
        "plt.plot(regrets1, label='MAR algo', linewidth=2)\n",
        "\n",
        "# Plot regrets2\n",
        "plt.plot(regrets2, label='UCB algo', linewidth=2)\n",
        "\n",
        "# Plot settings\n",
        "plt.xlabel('Iteration')\n",
        "plt.ylabel('Cumulative Regret')\n",
        "plt.title('Cumulative Regrets: Regrets 1 vs Regrets 2')\n",
        "plt.legend(loc='upper left', fontsize=12)\n",
        "plt.grid(True, which='both', linestyle='--', linewidth=0.5)\n",
        "\n",
        "# Save and display the plot\n",
        "plt.tight_layout()\n",
        "plt.savefig('regrets1_vs_regrets2.png', dpi=300)\n",
        "plt.show()"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 35,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 375
        },
        "id": "zCnDEOnx0Ip-",
        "outputId": "2010e300-7421-445c-bcaf-5d7fe130b3ef"
      },
      "outputs": [
        {
          "name": "stderr",
          "output_type": "stream",
          "text": [
            "<ipython-input-11-1b3319606638>:34: RuntimeWarning: divide by zero encountered in log\n",
            "  confidence_bound = np.sqrt(self.alpha / 2 * np.log(round_number) * np.sum((p[arm] ** 2) / self.counts[arm]))\n",
            "<ipython-input-11-1b3319606638>:34: RuntimeWarning: invalid value encountered in sqrt\n",
            "  confidence_bound = np.sqrt(self.alpha / 2 * np.log(round_number) * np.sum((p[arm] ** 2) / self.counts[arm]))\n"
          ]
        },
        {
          "data": {
            "image/png": "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",
            "text/plain": [
              "<Figure size 500x300 with 1 Axes>"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "num_repeats = 20  # Number of repetitions to average over\n",
        "\n",
        "# Initialize arrays to store the cumulative regrets\n",
        "regrets1_avg = np.zeros(T)\n",
        "regrets2_avg = np.zeros(T)\n",
        "regrets1_all = np.zeros((num_repeats, T))\n",
        "regrets2_all = np.zeros((num_repeats, T))\n",
        "\n",
        "# Loop over the number of repeats\n",
        "for i in range(num_repeats):\n",
        "    # MAR Algorithm\n",
        "    algo1 = MAR_algo(bandit_env, alpha, p_known)\n",
        "    _, regrets1 = algo1.run(T)\n",
        "    regrets1_avg += regrets1\n",
        "    regrets1_all[i] = regrets1\n",
        "\n",
        "    # UCB Algorithm\n",
        "    algo2 = UCB_algo(bandit_env, alpha)\n",
        "    _, regrets2 = algo2.run(T)\n",
        "    regrets2_avg += regrets2\n",
        "    regrets2_all[i] = regrets2\n",
        "\n",
        "# Average the regrets over the number of repetitions\n",
        "regrets1_avg /= num_repeats\n",
        "regrets2_avg /= num_repeats\n",
        "\n",
        "# Calculate standard deviation for error shading\n",
        "std_regrets1 = np.std(regrets1_all, axis=0)\n",
        "std_regrets2 = np.std(regrets2_all, axis=0)\n",
        "\n",
        "# Plot the averaged regrets with error shading\n",
        "plt.figure(figsize=(5, 3))\n",
        "\n",
        "# Plot MAR Algorithm cumulative regret\n",
        "plt.plot(regrets1_avg, label=r'MAR', color='blue', linewidth=2)\n",
        "plt.fill_between(np.arange(T), regrets1_avg - std_regrets1, regrets1_avg + std_regrets1, color='blue', alpha=0.2)\n",
        "\n",
        "# Plot UCB Algorithm cumulative regret\n",
        "plt.plot(regrets2_avg, label=r'UCB', color='red', linewidth=2)\n",
        "plt.fill_between(np.arange(T), regrets2_avg - std_regrets2, regrets2_avg + std_regrets2, color='red', alpha=0.2)\n",
        "\n",
        "# Labeling and formatting\n",
        "plt.xlabel('Time Steps')\n",
        "plt.ylabel('Cumulative Regret')\n",
        "\n",
        "# LaTeX formatted legend\n",
        "plt.legend(loc='upper left')\n",
        "\n",
        "# Grid and layout\n",
        "plt.grid(False)\n",
        "plt.tight_layout()\n",
        "\n",
        "# Save and display the plot\n",
        "plt.savefig('cumulative_regret_MAR_vs_UCB.png', dpi=300)\n",
        "plt.show()"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 50,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 204
        },
        "id": "Yz_iASvc9h2X",
        "outputId": "d3af8cd8-673b-42f3-c6bc-b91ab43e7938"
      },
      "outputs": [
        {
          "data": {
            "application/vnd.google.colaboratory.intrinsic+json": {
              "summary": "{\n  \"name\": \"df\",\n  \"rows\": 276,\n  \"fields\": [\n    {\n      \"column\": \"'D'\",\n      \"properties\": {\n        \"dtype\": \"category\",\n        \"num_unique_values\": 2,\n        \"samples\": [\n          \"b'0'\",\n          \"b'1'\"\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z1\",\n      \"properties\": {\n        \"dtype\": \"category\",\n        \"num_unique_values\": 2,\n        \"samples\": [\n          \"b'2'\",\n          \"b'1'\"\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z2\",\n      \"properties\": {\n        \"dtype\": \"number\",\n        \"std\": 10.523080836774545,\n        \"min\": 26.2779,\n        \"max\": 78.4394,\n        \"num_unique_values\": 275,\n        \"samples\": [\n          51.2827,\n          45.7604\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z3\",\n      \"properties\": {\n        \"dtype\": \"category\",\n        \"num_unique_values\": 2,\n        \"samples\": [\n          \"b'0'\",\n          \"b'1'\"\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z4\",\n      \"properties\": {\n        \"dtype\": \"category\",\n        \"num_unique_values\": 2,\n        \"samples\": [\n          \"b'0'\",\n          \"b'1'\"\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z5\",\n      \"properties\": {\n        \"dtype\": \"category\",\n        \"num_unique_values\": 2,\n        \"samples\": [\n          \"b'0'\",\n          \"b'1'\"\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z6\",\n      \"properties\": {\n        \"dtype\": \"category\",\n        \"num_unique_values\": 2,\n        \"samples\": [\n          \"b'0'\",\n          \"b'1'\"\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z7\",\n      \"properties\": {\n        \"dtype\": \"category\",\n        \"num_unique_values\": 3,\n        \"samples\": [\n          \"b'1'\",\n          \"b'0'\"\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z8\",\n      \"properties\": {\n        \"dtype\": \"number\",\n        \"std\": 4.601073641676091,\n        \"min\": 0.3,\n        \"max\": 28.0,\n        \"num_unique_values\": 82,\n        \"samples\": [\n          2.3,\n          14.5\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z9\",\n      \"properties\": {\n        \"dtype\": \"number\",\n        \"std\": 234.7883628631716,\n        \"min\": 120.0,\n        \"max\": 1775.0,\n        \"num_unique_values\": 198,\n        \"samples\": [\n          247.0,\n          168.0\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z10\",\n      \"properties\": {\n        \"dtype\": \"number\",\n        \"std\": 0.40478858321529926,\n        \"min\": 1.96,\n        \"max\": 4.4,\n        \"num_unique_values\": 125,\n        \"samples\": [\n          3.83,\n          3.8\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z11\",\n      \"properties\": {\n        \"dtype\": \"number\",\n        \"std\": 88.26874582093626,\n        \"min\": 4.0,\n        \"max\": 588.0,\n        \"num_unique_values\": 152,\n        \"samples\": [\n          77.0,\n          33.0\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z12\",\n      \"properties\": {\n        \"dtype\": \"number\",\n        \"std\": 2115.4778941737513,\n        \"min\": 289.0,\n        \"max\": 13862.4,\n        \"num_unique_values\": 269,\n        \"samples\": [\n          1840.0,\n          1636.0\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z13\",\n      \"properties\": {\n        \"dtype\": \"number\",\n        \"std\": 56.719952453506735,\n        \"min\": 28.38,\n        \"max\": 457.25,\n        \"num_unique_values\": 166,\n        \"samples\": [\n          237.15,\n          71.0\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z14\",\n      \"properties\": {\n        \"dtype\": \"number\",\n        \"std\": 65.2807606229422,\n        \"min\": 33.0,\n        \"max\": 598.0,\n        \"num_unique_values\": 143,\n        \"samples\": [\n          57.0,\n          230.0\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z15\",\n      \"properties\": {\n        \"dtype\": \"number\",\n        \"std\": 93.12885734908511,\n        \"min\": 62.0,\n        \"max\": 563.0,\n        \"num_unique_values\": 193,\n        \"samples\": [\n          365.0,\n          381.0\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z16\",\n      \"properties\": {\n        \"dtype\": \"number\",\n        \"std\": 1.0083145775104243,\n        \"min\": 9.0,\n        \"max\": 17.1,\n        \"num_unique_values\": 41,\n        \"samples\": [\n          11.1,\n          11.4\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"Z17\",\n      \"properties\": {\n        \"dtype\": \"category\",\n        \"num_unique_values\": 4,\n        \"samples\": [\n          \"b'3'\",\n          \"b'1'\"\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"class\",\n      \"properties\": {\n        \"dtype\": \"number\",\n        \"std\": 1112.3802952282638,\n        \"min\": 41.0,\n        \"max\": 4556.0,\n        \"num_unique_values\": 267,\n        \"samples\": [\n          611.0,\n          1360.0\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    },\n    {\n      \"column\": \"D\",\n      \"properties\": {\n        \"dtype\": \"category\",\n        \"num_unique_values\": 2,\n        \"samples\": [\n          0,\n          1\n        ],\n        \"semantic_type\": \"\",\n        \"description\": \"\"\n      }\n    }\n  ]\n}",
              "type": "dataframe",
              "variable_name": "df"
            },
            "text/html": [
              "\n",
              "  <div id=\"df-8dd6e3f0-100c-4c17-a7a3-35a220d68795\" class=\"colab-df-container\">\n",
              "    <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>'D'</th>\n",
              "      <th>Z1</th>\n",
              "      <th>Z2</th>\n",
              "      <th>Z3</th>\n",
              "      <th>Z4</th>\n",
              "      <th>Z5</th>\n",
              "      <th>Z6</th>\n",
              "      <th>Z7</th>\n",
              "      <th>Z8</th>\n",
              "      <th>Z9</th>\n",
              "      <th>Z10</th>\n",
              "      <th>Z11</th>\n",
              "      <th>Z12</th>\n",
              "      <th>Z13</th>\n",
              "      <th>Z14</th>\n",
              "      <th>Z15</th>\n",
              "      <th>Z16</th>\n",
              "      <th>Z17</th>\n",
              "      <th>class</th>\n",
              "      <th>D</th>\n",
              "    </tr>\n",
              "  </thead>\n",
              "  <tbody>\n",
              "    <tr>\n",
              "      <th>0</th>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>58.7652</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>14.5</td>\n",
              "      <td>261.0</td>\n",
              "      <td>2.60</td>\n",
              "      <td>156.0</td>\n",
              "      <td>1718.0</td>\n",
              "      <td>137.95</td>\n",
              "      <td>172.0</td>\n",
              "      <td>190.0</td>\n",
              "      <td>12.2</td>\n",
              "      <td>b'4'</td>\n",
              "      <td>400.0</td>\n",
              "      <td>1</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>1</th>\n",
              "      <td>b'0'</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>56.4463</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'0'</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'0'</td>\n",
              "      <td>1.1</td>\n",
              "      <td>302.0</td>\n",
              "      <td>4.14</td>\n",
              "      <td>54.0</td>\n",
              "      <td>7394.8</td>\n",
              "      <td>113.52</td>\n",
              "      <td>88.0</td>\n",
              "      <td>221.0</td>\n",
              "      <td>10.6</td>\n",
              "      <td>b'3'</td>\n",
              "      <td>4500.0</td>\n",
              "      <td>0</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>2</th>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>70.0726</td>\n",
              "      <td>b'0'</td>\n",
              "      <td>b'0'</td>\n",
              "      <td>b'0'</td>\n",
              "      <td>b'0'</td>\n",
              "      <td>b'0.500000'</td>\n",
              "      <td>1.4</td>\n",
              "      <td>176.0</td>\n",
              "      <td>3.48</td>\n",
              "      <td>210.0</td>\n",
              "      <td>516.0</td>\n",
              "      <td>96.10</td>\n",
              "      <td>55.0</td>\n",
              "      <td>151.0</td>\n",
              "      <td>12.0</td>\n",
              "      <td>b'4'</td>\n",
              "      <td>1012.0</td>\n",
              "      <td>1</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>3</th>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>54.7406</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'0'</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'0.500000'</td>\n",
              "      <td>1.8</td>\n",
              "      <td>244.0</td>\n",
              "      <td>2.54</td>\n",
              "      <td>64.0</td>\n",
              "      <td>6121.8</td>\n",
              "      <td>60.63</td>\n",
              "      <td>92.0</td>\n",
              "      <td>183.0</td>\n",
              "      <td>10.3</td>\n",
              "      <td>b'4'</td>\n",
              "      <td>1925.0</td>\n",
              "      <td>1</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>4</th>\n",
              "      <td>b'0'</td>\n",
              "      <td>b'2'</td>\n",
              "      <td>38.1054</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'0'</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'1'</td>\n",
              "      <td>b'0'</td>\n",
              "      <td>3.4</td>\n",
              "      <td>279.0</td>\n",
              "      <td>3.53</td>\n",
              "      <td>143.0</td>\n",
              "      <td>671.0</td>\n",
              "      <td>113.15</td>\n",
              "      <td>72.0</td>\n",
              "      <td>136.0</td>\n",
              "      <td>10.9</td>\n",
              "      <td>b'3'</td>\n",
              "      <td>1504.0</td>\n",
              "      <td>0</td>\n",
              "    </tr>\n",
              "  </tbody>\n",
              "</table>\n",
              "</div>\n",
              "    <div class=\"colab-df-buttons\">\n",
              "\n",
              "  <div class=\"colab-df-container\">\n",
              "    <button class=\"colab-df-convert\" onclick=\"convertToInteractive('df-8dd6e3f0-100c-4c17-a7a3-35a220d68795')\"\n",
              "            title=\"Convert this dataframe to an interactive table.\"\n",
              "            style=\"display:none;\">\n",
              "\n",
              "  <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\">\n",
              "    <path d=\"M120-120v-720h720v720H120Zm60-500h600v-160H180v160Zm220 220h160v-160H400v160Zm0 220h160v-160H400v160ZM180-400h160v-160H180v160Zm440 0h160v-160H620v160ZM180-180h160v-160H180v160Zm440 0h160v-160H620v160Z\"/>\n",
              "  </svg>\n",
              "    </button>\n",
              "\n",
              "  <style>\n",
              "    .colab-df-container {\n",
              "      display:flex;\n",
              "      gap: 12px;\n",
              "    }\n",
              "\n",
              "    .colab-df-convert {\n",
              "      background-color: #E8F0FE;\n",
              "      border: none;\n",
              "      border-radius: 50%;\n",
              "      cursor: pointer;\n",
              "      display: none;\n",
              "      fill: #1967D2;\n",
              "      height: 32px;\n",
              "      padding: 0 0 0 0;\n",
              "      width: 32px;\n",
              "    }\n",
              "\n",
              "    .colab-df-convert:hover {\n",
              "      background-color: #E2EBFA;\n",
              "      box-shadow: 0px 1px 2px rgba(60, 64, 67, 0.3), 0px 1px 3px 1px rgba(60, 64, 67, 0.15);\n",
              "      fill: #174EA6;\n",
              "    }\n",
              "\n",
              "    .colab-df-buttons div {\n",
              "      margin-bottom: 4px;\n",
              "    }\n",
              "\n",
              "    [theme=dark] .colab-df-convert {\n",
              "      background-color: #3B4455;\n",
              "      fill: #D2E3FC;\n",
              "    }\n",
              "\n",
              "    [theme=dark] .colab-df-convert:hover {\n",
              "      background-color: #434B5C;\n",
              "      box-shadow: 0px 1px 3px 1px rgba(0, 0, 0, 0.15);\n",
              "      filter: drop-shadow(0px 1px 2px rgba(0, 0, 0, 0.3));\n",
              "      fill: #FFFFFF;\n",
              "    }\n",
              "  </style>\n",
              "\n",
              "    <script>\n",
              "      const buttonEl =\n",
              "        document.querySelector('#df-8dd6e3f0-100c-4c17-a7a3-35a220d68795 button.colab-df-convert');\n",
              "      buttonEl.style.display =\n",
              "        google.colab.kernel.accessAllowed ? 'block' : 'none';\n",
              "\n",
              "      async function convertToInteractive(key) {\n",
              "        const element = document.querySelector('#df-8dd6e3f0-100c-4c17-a7a3-35a220d68795');\n",
              "        const dataTable =\n",
              "          await google.colab.kernel.invokeFunction('convertToInteractive',\n",
              "                                                    [key], {});\n",
              "        if (!dataTable) return;\n",
              "\n",
              "        const docLinkHtml = 'Like what you see? Visit the ' +\n",
              "          '<a target=\"_blank\" href=https://colab.research.google.com/notebooks/data_table.ipynb>data table notebook</a>'\n",
              "          + ' to learn more about interactive tables.';\n",
              "        element.innerHTML = '';\n",
              "        dataTable['output_type'] = 'display_data';\n",
              "        await google.colab.output.renderOutput(dataTable, element);\n",
              "        const docLink = document.createElement('div');\n",
              "        docLink.innerHTML = docLinkHtml;\n",
              "        element.appendChild(docLink);\n",
              "      }\n",
              "    </script>\n",
              "  </div>\n",
              "\n",
              "\n",
              "<div id=\"df-741aa38f-95f1-4ace-8d8b-70e8d36dbbdd\">\n",
              "  <button class=\"colab-df-quickchart\" onclick=\"quickchart('df-741aa38f-95f1-4ace-8d8b-70e8d36dbbdd')\"\n",
              "            title=\"Suggest charts\"\n",
              "            style=\"display:none;\">\n",
              "\n",
              "<svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\"viewBox=\"0 0 24 24\"\n",
              "     width=\"24px\">\n",
              "    <g>\n",
              "        <path d=\"M19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zM9 17H7v-7h2v7zm4 0h-2V7h2v10zm4 0h-2v-4h2v4z\"/>\n",
              "    </g>\n",
              "</svg>\n",
              "  </button>\n",
              "\n",
              "<style>\n",
              "  .colab-df-quickchart {\n",
              "      --bg-color: #E8F0FE;\n",
              "      --fill-color: #1967D2;\n",
              "      --hover-bg-color: #E2EBFA;\n",
              "      --hover-fill-color: #174EA6;\n",
              "      --disabled-fill-color: #AAA;\n",
              "      --disabled-bg-color: #DDD;\n",
              "  }\n",
              "\n",
              "  [theme=dark] .colab-df-quickchart {\n",
              "      --bg-color: #3B4455;\n",
              "      --fill-color: #D2E3FC;\n",
              "      --hover-bg-color: #434B5C;\n",
              "      --hover-fill-color: #FFFFFF;\n",
              "      --disabled-bg-color: #3B4455;\n",
              "      --disabled-fill-color: #666;\n",
              "  }\n",
              "\n",
              "  .colab-df-quickchart {\n",
              "    background-color: var(--bg-color);\n",
              "    border: none;\n",
              "    border-radius: 50%;\n",
              "    cursor: pointer;\n",
              "    display: none;\n",
              "    fill: var(--fill-color);\n",
              "    height: 32px;\n",
              "    padding: 0;\n",
              "    width: 32px;\n",
              "  }\n",
              "\n",
              "  .colab-df-quickchart:hover {\n",
              "    background-color: var(--hover-bg-color);\n",
              "    box-shadow: 0 1px 2px rgba(60, 64, 67, 0.3), 0 1px 3px 1px rgba(60, 64, 67, 0.15);\n",
              "    fill: var(--button-hover-fill-color);\n",
              "  }\n",
              "\n",
              "  .colab-df-quickchart-complete:disabled,\n",
              "  .colab-df-quickchart-complete:disabled:hover {\n",
              "    background-color: var(--disabled-bg-color);\n",
              "    fill: var(--disabled-fill-color);\n",
              "    box-shadow: none;\n",
              "  }\n",
              "\n",
              "  .colab-df-spinner {\n",
              "    border: 2px solid var(--fill-color);\n",
              "    border-color: transparent;\n",
              "    border-bottom-color: var(--fill-color);\n",
              "    animation:\n",
              "      spin 1s steps(1) infinite;\n",
              "  }\n",
              "\n",
              "  @keyframes spin {\n",
              "    0% {\n",
              "      border-color: transparent;\n",
              "      border-bottom-color: var(--fill-color);\n",
              "      border-left-color: var(--fill-color);\n",
              "    }\n",
              "    20% {\n",
              "      border-color: transparent;\n",
              "      border-left-color: var(--fill-color);\n",
              "      border-top-color: var(--fill-color);\n",
              "    }\n",
              "    30% {\n",
              "      border-color: transparent;\n",
              "      border-left-color: var(--fill-color);\n",
              "      border-top-color: var(--fill-color);\n",
              "      border-right-color: var(--fill-color);\n",
              "    }\n",
              "    40% {\n",
              "      border-color: transparent;\n",
              "      border-right-color: var(--fill-color);\n",
              "      border-top-color: var(--fill-color);\n",
              "    }\n",
              "    60% {\n",
              "      border-color: transparent;\n",
              "      border-right-color: var(--fill-color);\n",
              "    }\n",
              "    80% {\n",
              "      border-color: transparent;\n",
              "      border-right-color: var(--fill-color);\n",
              "      border-bottom-color: var(--fill-color);\n",
              "    }\n",
              "    90% {\n",
              "      border-color: transparent;\n",
              "      border-bottom-color: var(--fill-color);\n",
              "    }\n",
              "  }\n",
              "</style>\n",
              "\n",
              "  <script>\n",
              "    async function quickchart(key) {\n",
              "      const quickchartButtonEl =\n",
              "        document.querySelector('#' + key + ' button');\n",
              "      quickchartButtonEl.disabled = true;  // To prevent multiple clicks.\n",
              "      quickchartButtonEl.classList.add('colab-df-spinner');\n",
              "      try {\n",
              "        const charts = await google.colab.kernel.invokeFunction(\n",
              "            'suggestCharts', [key], {});\n",
              "      } catch (error) {\n",
              "        console.error('Error during call to suggestCharts:', error);\n",
              "      }\n",
              "      quickchartButtonEl.classList.remove('colab-df-spinner');\n",
              "      quickchartButtonEl.classList.add('colab-df-quickchart-complete');\n",
              "    }\n",
              "    (() => {\n",
              "      let quickchartButtonEl =\n",
              "        document.querySelector('#df-741aa38f-95f1-4ace-8d8b-70e8d36dbbdd button');\n",
              "      quickchartButtonEl.style.display =\n",
              "        google.colab.kernel.accessAllowed ? 'block' : 'none';\n",
              "    })();\n",
              "  </script>\n",
              "</div>\n",
              "\n",
              "    </div>\n",
              "  </div>\n"
            ],
            "text/plain": [
              "    'D'    Z1       Z2    Z3    Z4    Z5    Z6           Z7    Z8     Z9  \\\n",
              "0  b'1'  b'1'  58.7652  b'1'  b'1'  b'1'  b'1'         b'1'  14.5  261.0   \n",
              "1  b'0'  b'1'  56.4463  b'1'  b'0'  b'1'  b'1'         b'0'   1.1  302.0   \n",
              "2  b'1'  b'1'  70.0726  b'0'  b'0'  b'0'  b'0'  b'0.500000'   1.4  176.0   \n",
              "3  b'1'  b'1'  54.7406  b'1'  b'0'  b'1'  b'1'  b'0.500000'   1.8  244.0   \n",
              "4  b'0'  b'2'  38.1054  b'1'  b'0'  b'1'  b'1'         b'0'   3.4  279.0   \n",
              "\n",
              "    Z10    Z11     Z12     Z13    Z14    Z15   Z16   Z17   class  D  \n",
              "0  2.60  156.0  1718.0  137.95  172.0  190.0  12.2  b'4'   400.0  1  \n",
              "1  4.14   54.0  7394.8  113.52   88.0  221.0  10.6  b'3'  4500.0  0  \n",
              "2  3.48  210.0   516.0   96.10   55.0  151.0  12.0  b'4'  1012.0  1  \n",
              "3  2.54   64.0  6121.8   60.63   92.0  183.0  10.3  b'4'  1925.0  1  \n",
              "4  3.53  143.0   671.0  113.15   72.0  136.0  10.9  b'3'  1504.0  0  "
            ]
          },
          "execution_count": 50,
          "metadata": {},
          "output_type": "execute_result"
        }
      ],
      "source": [
        "df.head()"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 49,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 803
        },
        "id": "XRNxZ4I88NYq",
        "outputId": "76b3a068-1d05-4080-f37d-9e5109dfa45e"
      },
      "outputs": [
        {
          "name": "stderr",
          "output_type": "stream",
          "text": [
            "<ipython-input-49-e05bc55fa7d9>:11: FutureWarning: The default of observed=False is deprecated and will be changed to True in a future version of pandas. Pass observed=False to retain current behavior or observed=True to adopt the future default and silence this warning.\n",
            "  mean_reward_matrix = df.groupby(['Z1', 'D'])['class'].mean().unstack()\n",
            "<ipython-input-11-1b3319606638>:34: RuntimeWarning: divide by zero encountered in log\n",
            "  confidence_bound = np.sqrt(self.alpha / 2 * np.log(round_number) * np.sum((p[arm] ** 2) / self.counts[arm]))\n",
            "<ipython-input-11-1b3319606638>:34: RuntimeWarning: invalid value encountered in sqrt\n",
            "  confidence_bound = np.sqrt(self.alpha / 2 * np.log(round_number) * np.sum((p[arm] ** 2) / self.counts[arm]))\n"
          ]
        },
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Probability Matrix:\n",
            "D            0         1\n",
            "Z1                      \n",
            "b'1'  0.598865  0.401135\n",
            "b'2'  0.607951  0.392049\n",
            "Mean Reward Matrix:\n",
            "D               0            1\n",
            "Z1                            \n",
            "b'1'  2271.759494  1521.684211\n",
            "b'2'  2317.813953  1494.685185\n",
            "\n",
            "Gamma Matrix:\n",
            "[[0.76659795 0.96121969]\n",
            " [0.76201575 0.97558327]]\n",
            "\n",
            "Probability Matrix (p):\n",
            "[[0.59886469 0.40113531]\n",
            " [0.60795134 0.39204866]]\n",
            "\n",
            "Means Matrix:\n",
            "[[2271.75949367 1521.68421053]\n",
            " [2317.81395349 1494.68518519]]\n"
          ]
        },
        {
          "data": {
            "image/png": "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",
            "text/plain": [
              "<Figure size 500x300 with 1 Axes>"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "import pandas as pd\n",
        "import numpy as np\n",
        "import matplotlib.pyplot as plt\n",
        "\n",
        "# Step 1: Convert byte strings in 'D' to integers (0 and 1)\n",
        "df['D'] = df['D'].apply(lambda x: int(x.decode('utf-8')))  # Convert b'1' and b'0' to integers 1 and 0\n",
        "\n",
        "# Step 2: Group by 'Z1' (arm) and 'D' (now binary 0 or 1), and calculate the mean reward ('class')\n",
        "mean_reward_matrix = df.groupby(['Z1', 'D'])['class'].mean().unstack()\n",
        "\n",
        "# # Step 3: Replace NaN values with 0 (if any)\n",
        "# mean_reward_matrix.fillna(0, inplace=True)\n",
        "\n",
        "# Step 4: Construct the probability matrix\n",
        "# Normalize each row by dividing by the row sum (sum of rewards per arm)\n",
        "probability_matrix = mean_reward_matrix.div(mean_reward_matrix.sum(axis=1), axis=0)\n",
        "\n",
        "# # Step 5: Replace any NaN resulting from 0/0 divisions with 0 (if rows sum to 0)\n",
        "# probability_matrix.fillna(0, inplace=True)\n",
        "\n",
        "# Step 6: Display the final probability matrix and mean reward matrix\n",
        "print(\"Probability Matrix:\")\n",
        "print(probability_matrix)\n",
        "\n",
        "print(\"Mean Reward Matrix:\")\n",
        "print(mean_reward_matrix)\n",
        "\n",
        "# Step 7: Set the number of arms and binary values (n = number of arms, k = 2 since D is binary)\n",
        "n = mean_reward_matrix.shape[0]  # Number of arms\n",
        "k = mean_reward_matrix.shape[1]  # Number of binary values (0 and 1)\n",
        "\n",
        "# Step 8: Generate random gamma values for each arm and binary value\n",
        "np.random.seed(5)\n",
        "gamma = np.random.uniform(0.7, 1.0, size=(n, k))\n",
        "\n",
        "# Convert matrices to numpy arrays for use in the bandit environment\n",
        "p = probability_matrix.to_numpy()\n",
        "means = mean_reward_matrix.to_numpy()\n",
        "\n",
        "print(\"\\nGamma Matrix:\")\n",
        "print(gamma)\n",
        "\n",
        "print(\"\\nProbability Matrix (p):\")\n",
        "print(p)\n",
        "\n",
        "print(\"\\nMeans Matrix:\")\n",
        "print(means)\n",
        "\n",
        "# Example Bandit Environment initialization (replace with your actual environment)\n",
        "bandit_env = MAR(means, gamma, p)\n",
        "\n",
        "alpha = 1  # Exploration-exploitation parameter\n",
        "p_known = 1\n",
        "T = 1000  # Number of time steps\n",
        "\n",
        "num_repeats = 20  # Number of repetitions to average over\n",
        "\n",
        "# Initialize arrays to store the cumulative regrets\n",
        "regrets1_avg = np.zeros(T)\n",
        "regrets2_avg = np.zeros(T)\n",
        "regrets1_all = np.zeros((num_repeats, T))\n",
        "regrets2_all = np.zeros((num_repeats, T))\n",
        "\n",
        "# Loop over the number of repeats\n",
        "for i in range(num_repeats):\n",
        "    # MAR Algorithm\n",
        "    algo1 = MAR_algo(bandit_env, alpha, p_known)\n",
        "    _, regrets1 = algo1.run(T)\n",
        "    regrets1_avg += regrets1\n",
        "    regrets1_all[i] = regrets1\n",
        "\n",
        "    # UCB Algorithm\n",
        "    algo2 = UCB_algo(bandit_env, alpha)\n",
        "    _, regrets2 = algo2.run(T)\n",
        "    regrets2_avg += regrets2\n",
        "    regrets2_all[i] = regrets2\n",
        "\n",
        "# Average the regrets over the number of repetitions\n",
        "regrets1_avg /= num_repeats\n",
        "regrets2_avg /= num_repeats\n",
        "\n",
        "# Calculate standard deviation for error shading\n",
        "std_regrets1 = np.std(regrets1_all, axis=0)\n",
        "std_regrets2 = np.std(regrets2_all, axis=0)\n",
        "\n",
        "# Step 10: Plot the averaged regrets with error shading\n",
        "plt.figure(figsize=(5, 3))\n",
        "\n",
        "# Plot MAR Algorithm cumulative regret\n",
        "plt.plot(regrets1_avg, label=r'MAR', color='blue', linewidth=2)\n",
        "plt.fill_between(np.arange(T), regrets1_avg - std_regrets1, regrets1_avg + std_regrets1, color='blue', alpha=0.2)\n",
        "\n",
        "# Plot UCB Algorithm cumulative regret\n",
        "plt.plot(regrets2_avg, label=r'UCB', color='red', linewidth=2)\n",
        "plt.fill_between(np.arange(T), regrets2_avg - std_regrets2, regrets2_avg + std_regrets2, color='red', alpha=0.2)\n",
        "\n",
        "# Labeling and formatting\n",
        "plt.xlabel('Time Steps')\n",
        "plt.ylabel('Cumulative Regret')\n",
        "\n",
        "# LaTeX formatted legend\n",
        "plt.legend(loc='upper left')\n",
        "\n",
        "# Grid and layout\n",
        "plt.grid(False)\n",
        "plt.tight_layout()\n",
        "\n",
        "# Save and display the plot\n",
        "plt.savefig('cumulative_regret_MAR_vs_UCB.png', dpi=300)\n",
        "plt.show()\n"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "CbiKssj9x5Ad"
      },
      "source": [
        "## MNAR"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 37,
      "metadata": {
        "id": "-J5XiJcHqRX6"
      },
      "outputs": [],
      "source": [
        "import numpy as np\n",
        "import matplotlib.pyplot as plt\n",
        "\n",
        "class MNAR:\n",
        "    def __init__(self, means, gamma, prob, rewards):\n",
        "        self.means = means\n",
        "        self.gamma = gamma\n",
        "        self.p = prob\n",
        "        self.num_arms = means.shape[0]  # Number of arms (n)\n",
        "        self.num_contexts = means.shape[1]  # Number of contexts (k)\n",
        "        self.num_reward = means.shape[1]\n",
        "        self.rewards = rewards\n",
        "        self.mu = np.zeros((self.num_arms))\n",
        "        self.best_arm = -1\n",
        "        self.best_mu = -1\n",
        "\n",
        "        for a in range(self.num_arms):\n",
        "          mu = 0\n",
        "          for m in range(self.num_contexts):\n",
        "            for y in range(self.num_reward):\n",
        "              mu += self.p[a, m] * self.means[a, m, y] * self.rewards[y]\n",
        "\n",
        "          self.mu[a] = mu\n",
        "          if mu > self.best_mu:\n",
        "            self.best_mu = mu\n",
        "            self.best_arm = a\n",
        "\n",
        "        self.A_matrix = np.zeros((self.num_arms, self.num_contexts, self.num_reward))\n",
        "        for a in range(self.num_arms):\n",
        "          for m in range(self.num_contexts):\n",
        "            for y in range(self.num_reward):\n",
        "              self.A_matrix[a, m, y] = prob[a, m] * means[a, m, y] * gamma[a, y]\n",
        "        self.k_A = [np.linalg.cond(self.A_matrix[a]) for a in range(self.num_arms)]\n",
        "\n",
        "    def pull_arm(self, arm):\n",
        "        if arm >= self.num_arms:\n",
        "            raise ValueError(\"Invalid arm index\")\n",
        "\n",
        "        # Select a context based on the probability distribution p[arm]\n",
        "        context = int(np.random.choice(self.num_contexts, p=self.p[arm]))\n",
        "\n",
        "        # Reward is drawn from a normal distribution centered at the means[arm, context]\n",
        "        reward_i = np.random.choice([i for i in range(self.num_reward)], p=list(self.means[arm, context]))\n",
        "        reward = self.rewards[reward_i]\n",
        "\n",
        "        # Determine if the reward is observed based on the gamma[arm, context]\n",
        "        observed = np.random.rand() < self.gamma[arm, reward_i]\n",
        "        if observed:\n",
        "            return reward_i, reward, observed, context\n",
        "        else:\n",
        "            return None, None, observed, context"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 38,
      "metadata": {
        "id": "7XRhHpMWx7QQ"
      },
      "outputs": [],
      "source": [
        "class MNAR_algo:\n",
        "    def __init__(self, bandit_env):\n",
        "\n",
        "        self.bandit_env = bandit_env\n",
        "        self.num_arms = bandit_env.num_arms\n",
        "        self.num_contexts = bandit_env.num_contexts\n",
        "        self.num_rewards = bandit_env.num_reward\n",
        "        self.k_A = bandit_env.k_A\n",
        "        self.rewards_value = bandit_env.rewards\n",
        "\n",
        "        self.m0_matrix = np.zeros((bandit_env.num_arms, bandit_env.num_contexts))\n",
        "        self.my1_matrix = np.zeros((bandit_env.num_arms, bandit_env.num_contexts, bandit_env.num_reward))\n",
        "        self.my_given_1_matrix = np.zeros((bandit_env.num_arms, bandit_env.num_contexts, bandit_env.num_reward))\n",
        "\n",
        "        self.T_a = np.zeros(bandit_env.num_arms)\n",
        "        self.n_a = np.zeros(bandit_env.num_arms)\n",
        "\n",
        "\n",
        "    def select_arm(self, round_number):\n",
        "        ucb_values = np.zeros(self.num_arms)\n",
        "        means = np.zeros(self.num_arms)\n",
        "        for arm in range(self.num_arms):\n",
        "          m0_vector = self.m0_matrix[arm]/self.T_a[arm] # K * 1\n",
        "          my1_matrix = self.my1_matrix[arm]/self.T_a[arm] # K * L\n",
        "          my_given_1_matrix = self.my_given_1_matrix[arm]/self.n_a[arm] # K * L\n",
        "          #################\n",
        "          if np.linalg.det(my1_matrix) == 0:\n",
        "            ucb_values[arm] = float('inf')\n",
        "            means[arm] = float('inf')\n",
        "          else:\n",
        "            inverse_mymatrix = np.linalg.inv(my1_matrix)\n",
        "            OR_vector = inverse_mymatrix @ m0_vector\n",
        "            Ov_gamma_vector = OR_vector + 1 # L * 1\n",
        "            my_a_matrx = np.zeros((bandit_env.num_contexts, bandit_env.num_reward))\n",
        "            for i in range(bandit_env.num_contexts):\n",
        "              for j in range(bandit_env.num_reward):\n",
        "                my_a_matrx[i, j] = my_given_1_matrix[i, j] * Ov_gamma_vector[j]\n",
        "\n",
        "            y_a_vector = np.zeros((bandit_env.num_reward))\n",
        "            for j in range(bandit_env.num_reward):\n",
        "              for i in range(bandit_env.num_contexts):\n",
        "                y_a_vector[j] += my_a_matrx[i, j]\n",
        "\n",
        "            mean = sum(y_a_vector * self.rewards_value)\n",
        "\n",
        "            cb1 = (self.k_A[arm] / np.linalg.norm(my1_matrix, ord=np.inf)) * np.sqrt(np.log(round_number) / (2 * self.T_a[arm]))\n",
        "            cb2 = self.num_contexts * np.sqrt(np.log(round_number) / (2 * self.n_a[arm]))\n",
        "\n",
        "            cb = cb1 + cb2\n",
        "            means[arm] = mean\n",
        "            ucb_values[arm] = mean + 100 * cb\n",
        "\n",
        "        arm = np.argmax(ucb_values)\n",
        "\n",
        "        return arm, means[arm], ucb_values[arm]\n",
        "\n",
        "    def update(self, arm, context, reward_i, reward, observed):\n",
        "        int_obs = 1 if observed else 0\n",
        "        self.T_a[arm] += 1\n",
        "        self.n_a[arm] += int_obs\n",
        "        if observed:\n",
        "          self.m0_matrix[arm, context] += 1\n",
        "          self.my1_matrix[arm, context, reward_i] += 1\n",
        "          self.my_given_1_matrix[arm, context, reward_i] += 1\n",
        "\n",
        "    def update_regret(self, arm, context, cu_regret, regrets):\n",
        "        regret = self.bandit_env.mu[self.bandit_env.best_arm] - self.bandit_env.mu[arm]\n",
        "\n",
        "        cu_regret += regret  # Add this round's regret to the cumulative regret\n",
        "        regrets.append(cu_regret)  # Store the cumulative regret\n",
        "        return cu_regret\n",
        "\n",
        "    def run(self, num_rounds):\n",
        "\n",
        "        results = []\n",
        "        regrets = []\n",
        "        cu_regret = 0\n",
        "\n",
        "        for arm in range(self.num_arms):\n",
        "          for _ in range(100):\n",
        "            reward_i, reward, observed, context = self.bandit_env.pull_arm(arm)\n",
        "            cu_regret = self.update_regret(arm, context, cu_regret, regrets)\n",
        "            self.update(arm, context, reward_i, reward, observed)\n",
        "\n",
        "        for round_number in range(num_rounds - (100 * self.num_arms)):\n",
        "            # Select an arm using the UCB strategy\n",
        "            arm, mean, ucb = self.select_arm(round_number)\n",
        "\n",
        "            # Pull the arm and observe the reward and context\n",
        "            reward_i, reward, observed, context = self.bandit_env.pull_arm(arm)\n",
        "\n",
        "            # Update the cumulative regret and store the result\n",
        "            cu_regret = self.update_regret(arm, context, cu_regret, regrets)\n",
        "\n",
        "            # Update the means and counts based on the observed reward\n",
        "            self.update(arm, context, reward_i, reward, observed)\n",
        "\n",
        "            # Store the results for this round\n",
        "            results.append((arm, mean, ucb, reward, observed, context))\n",
        "\n",
        "        return results, regrets"
      ]
    }
  ],
  "metadata": {
    "colab": {
      "collapsed_sections": [
        "LB4iSU8fT--b",
        "lnvDpzCgmZEV",
        "CbiKssj9x5Ad"
      ],
      "provenance": []
    },
    "kernelspec": {
      "display_name": "Python 3",
      "name": "python3"
    },
    "language_info": {
      "name": "python"
    }
  },
  "nbformat": 4,
  "nbformat_minor": 0
}
