{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "048c26ff",
   "metadata": {},
   "source": [
    "# Libraries"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "f74e1483",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-03T00:45:33.711134Z",
     "start_time": "2021-10-03T00:45:31.963490Z"
    }
   },
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import matplotlib\n",
    "from sklearn.metrics import zero_one_loss\n",
    "\n",
    "%matplotlib inline"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "95d83700",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-03T00:45:40.449383Z",
     "start_time": "2021-10-03T00:45:40.444537Z"
    }
   },
   "outputs": [],
   "source": [
    "from utils.data_gen import compute_bayes_risk_binary, compute_bayes_risk_binary_label_shift,\\\n",
    "    generate_2d_example\n",
    "\n",
    "from utils.concentrations import hoeffding_ci_lower_limit,\\\n",
    "    hoeffding_ci_upper_limit\n",
    "from utils.concentrations import pm_bernstein_ci_upper_limit,\\\n",
    "    pm_bernstein_ci_lower_limit\n",
    "\n",
    "from utils.concentrations import pm_bernstein_lower_limit, pm_bernstein_upper_limit\n",
    "from utils.concentrations import pm_hoeffding_upper_limit, pm_hoeffding_lower_limit\n",
    "\n",
    "from utils.data_gen import LDA_predictor\n",
    "\n",
    "from utils.concentrations import betting_ci_lower_limit, betting_ci_upper_limit\n",
    "\n",
    "from utils.tests import Drop_tester,misclas_losses"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "b4623a92",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-03T00:45:45.341886Z",
     "start_time": "2021-10-03T00:45:45.337564Z"
    }
   },
   "outputs": [],
   "source": [
    "sns.set(\n",
    "    style=\"whitegrid\",\n",
    "    font_scale=1.4,\n",
    "    rc={\n",
    "        \"lines.linewidth\": 2,\n",
    "        #             \"axes.facecolor\": \".9\",\n",
    "        'figure.figsize': (12, 6)\n",
    "    })\n",
    "sns.set_palette('Set2')\n",
    "matplotlib.rcParams['text.usetex'] = True"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "6d4367f4",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-03T00:45:50.685390Z",
     "start_time": "2021-10-03T00:45:50.649934Z"
    }
   },
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "301fba61",
   "metadata": {},
   "source": [
    "# Data generation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 166,
   "id": "3c0ce119",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-03T01:31:56.043897Z",
     "start_time": "2021-10-03T01:31:56.010155Z"
    }
   },
   "outputs": [],
   "source": [
    "num_of_repeats = 250\n",
    "num_of_batches_to_sample = 80\n",
    "\n",
    "size_of_batch = 20\n",
    "size_source_sample = 1000"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 167,
   "id": "bc30d8bd",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-03T01:31:56.265728Z",
     "start_time": "2021-10-03T01:31:56.232732Z"
    }
   },
   "outputs": [],
   "source": [
    "increase_tracker = 0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 168,
   "id": "75a3d40e",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-03T01:31:58.385229Z",
     "start_time": "2021-10-03T01:31:58.346152Z"
    }
   },
   "outputs": [],
   "source": [
    "mu_1 = np.array([1, 0])\n",
    "mu_0 = np.array([-1, 0])\n",
    "prob_class_1 = 0.25\n",
    "prob_class_0 = 1 - prob_class_1\n",
    "cov = np.eye(2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 169,
   "id": "74211063",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-03T01:31:58.572048Z",
     "start_time": "2021-10-03T01:31:58.532382Z"
    }
   },
   "outputs": [],
   "source": [
    "X_val_source, y_val_source = generate_2d_example(0.25, mu_0, mu_1,\n",
    "                                                 size_source_sample)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 170,
   "id": "6da019b6",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-03T01:31:58.723113Z",
     "start_time": "2021-10-03T01:31:58.689550Z"
    }
   },
   "outputs": [],
   "source": [
    "class_1_probs = list()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 171,
   "id": "5269dbd9",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-03T01:31:58.899176Z",
     "start_time": "2021-10-03T01:31:58.865909Z"
    }
   },
   "outputs": [],
   "source": [
    "batches_per_prob = 10"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 172,
   "id": "fdb7a8b6",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-03T01:31:59.276977Z",
     "start_time": "2021-10-03T01:31:59.241928Z"
    }
   },
   "outputs": [],
   "source": [
    "class_1_probs += np.repeat(0.25,batches_per_prob).tolist()\n",
    "class_1_probs += np.repeat(0.35,batches_per_prob).tolist()\n",
    "class_1_probs += np.repeat(0.45,batches_per_prob).tolist()\n",
    "class_1_probs += np.repeat(0.55,batches_per_prob).tolist()\n",
    "class_1_probs += np.repeat(0.65,batches_per_prob).tolist()\n",
    "class_1_probs += np.repeat(0.75,batches_per_prob).tolist()\n",
    "class_1_probs += np.repeat(0.85,num_of_batches_to_sample - 6 * batches_per_prob).tolist()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 173,
   "id": "c00b6d7d",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-03T01:31:59.483775Z",
     "start_time": "2021-10-03T01:31:59.449669Z"
    },
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "80"
      ]
     },
     "execution_count": 173,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(class_1_probs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 174,
   "id": "b834ba57",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-03T01:31:59.827295Z",
     "start_time": "2021-10-03T01:31:59.794132Z"
    }
   },
   "outputs": [],
   "source": [
    "clf = LDA_predictor()\n",
    "\n",
    "clf.mean_class_0 = mu_0\n",
    "clf.mean_class_1 = mu_1\n",
    "clf.class_0_prior = prob_class_0\n",
    "clf.class_1_prior = prob_class_1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 175,
   "id": "86c1fa75",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-03T01:32:00.014466Z",
     "start_time": "2021-10-03T01:31:59.980723Z"
    }
   },
   "outputs": [],
   "source": [
    "eps_tol = 0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 176,
   "id": "d87f5462",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-03T01:32:00.159183Z",
     "start_time": "2021-10-03T01:32:00.125867Z"
    }
   },
   "outputs": [],
   "source": [
    "tester_conj_bernstein = Drop_tester()\n",
    "\n",
    "tester_conj_bernstein.eps_tol = eps_tol\n",
    "tester_conj_bernstein.target_conc_type = 'conj-bern'\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 177,
   "id": "0a0a9251",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-03T01:32:00.299472Z",
     "start_time": "2021-10-03T01:32:00.265349Z"
    }
   },
   "outputs": [],
   "source": [
    "conj_bern_target_lower_bounds = list()\n",
    "conj_bern_source_upper_bounds = list()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 178,
   "id": "142153c8",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-03T01:39:26.148235Z",
     "start_time": "2021-10-03T01:32:00.419375Z"
    }
   },
   "outputs": [],
   "source": [
    "for cur_sim in range(num_of_repeats):\n",
    "    conj_bern_target_lower_bounds+=[[]]\n",
    "    X_val_source, y_val_source = generate_2d_example(0.25, mu_0, mu_1,\n",
    "                                                     size_source_sample)\n",
    "\n",
    "    y_pred_val = clf.predict(X_val_source)\n",
    "    ind_loss_source = misclas_losses(y_pred_val, y_val_source)\n",
    "\n",
    "    tester_conj_bernstein.estimate_risk_source(ind_loss_source)\n",
    "\n",
    "    conj_bern_source_upper_bounds += [\n",
    "        tester_conj_bernstein.source_rejection_threshold\n",
    "    ]\n",
    "\n",
    "    X_target = []\n",
    "    y_target = []\n",
    "\n",
    "    for cur_class_1_prob in class_1_probs:\n",
    "        X_new_target, y_new_target = generate_2d_example(\n",
    "            cur_class_1_prob, mu_0, mu_1, size_of_batch)\n",
    "\n",
    "        X_target += [X_new_target]\n",
    "        y_target += [y_new_target]\n",
    "\n",
    "    X_target = np.vstack(X_target)\n",
    "    y_target = np.hstack(y_target)\n",
    "\n",
    "    y_pred_target = clf.predict(X_target)\n",
    "    ind_loss_target = misclas_losses(y_pred_target, y_target)\n",
    "\n",
    "    for cur_batch in range(num_of_batches_to_sample):\n",
    "        cur_losses = ind_loss_target[0:(cur_batch + 1) * size_of_batch]\n",
    "        tester_conj_bernstein.estimate_risk_target(cur_losses)\n",
    "        conj_bern_target_lower_bounds[cur_sim] += [\n",
    "            tester_conj_bernstein.target_risk_lower_bound\n",
    "        ]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 179,
   "id": "77242562",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-03T01:39:26.281650Z",
     "start_time": "2021-10-03T01:39:26.151167Z"
    }
   },
   "outputs": [],
   "source": [
    "sample_sizes = np.arange(size_of_batch,size_of_batch*(num_of_batches_to_sample+1), step=size_of_batch)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 180,
   "id": "5d6399e2",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-03T01:39:26.317091Z",
     "start_time": "2021-10-03T01:39:26.284059Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "80"
      ]
     },
     "execution_count": 180,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(sample_sizes)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 182,
   "id": "77095da1",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-03T01:39:44.889658Z",
     "start_time": "2021-10-03T01:39:44.469078Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 864x432 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "l1, = plt.plot(sample_sizes,np.mean(conj_bern_target_lower_bounds, axis=0),\n",
    "               color='indianred')\n",
    "\n",
    "\n",
    "plt.fill_between(\n",
    "    sample_sizes,\n",
    "    y1=np.mean(conj_bern_target_lower_bounds, axis=0) -\n",
    "    2 * np.std(conj_bern_target_lower_bounds, axis=0) / np.sqrt(num_of_repeats),\n",
    "    y2=np.mean(conj_bern_target_lower_bounds, axis=0) +\n",
    "    2 * np.std(conj_bern_target_lower_bounds, axis=0) / np.sqrt(num_of_repeats),\n",
    "    alpha=0.3,\n",
    "    color='indianred')\n",
    "\n",
    "l2, = plt.plot(sample_sizes,\n",
    "               np.repeat(np.mean(conj_bern_source_upper_bounds, axis=0),num_of_batches_to_sample\n",
    "                         ),\n",
    "               linestyle='dashed',\n",
    "               color='goldenrod',\n",
    "               alpha=0.7)\n",
    "\n",
    "plt.fill_between(\n",
    "    sample_sizes,\n",
    "    y1=np.mean(conj_bern_source_upper_bounds, axis=0) - 2 *\n",
    "    np.std(conj_bern_source_upper_bounds, axis=0) / np.sqrt(num_of_repeats),\n",
    "    y2=np.mean(conj_bern_source_upper_bounds, axis=0) +\n",
    "    2 * np.std(conj_bern_source_upper_bounds, axis=0) / np.sqrt(num_of_repeats),\n",
    "    alpha=0.3,\n",
    "    color='goldenrod')\n",
    "\n",
    "categories = [\n",
    "     'LCB on the target risk via CM-EB','UCB on the source risk'\n",
    "]\n",
    "\n",
    "leg4 = plt.legend([l1, l2],\n",
    "                  categories,\n",
    "                  loc=4,\n",
    "                  ncol=1,\n",
    "                  prop={'size': 20})  # Two columns, horizontal group labels\n",
    "\n",
    "plt.ylabel('Misclassification risk', fontsize=23)\n",
    "plt.xlabel('Number of samples from the target domain', fontsize=23)\n",
    "plt.savefig('img/gradual_change.pdf', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 112,
   "id": "4caa6f80",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-03T01:07:10.940789Z",
     "start_time": "2021-10-03T01:07:10.895894Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[0.0,\n",
       " 0.0,\n",
       " 0.0,\n",
       " 0.0,\n",
       " 0.0,\n",
       " 0.022889261300762714,\n",
       " 0.04195205278501282,\n",
       " 0.04175468455189922,\n",
       " 0.041429784490946406,\n",
       " 0.04578490825621781,\n",
       " 0.04556783522680004,\n",
       " 0.050922545924624224,\n",
       " 0.0588216554429023,\n",
       " 0.0646834619501955,\n",
       " 0.06819385534191476,\n",
       " 0.07895258919756418,\n",
       " 0.0894275656112861,\n",
       " 0.09545576772325498,\n",
       " 0.09999515651914787,\n",
       " 0.10747447241134726,\n",
       " 0.11010528383691401,\n",
       " 0.1141576588255856,\n",
       " 0.1166107095607631,\n",
       " 0.12129729984630166,\n",
       " 0.12255029647197958,\n",
       " 0.12742868169412871,\n",
       " 0.12903575920974691,\n",
       " 0.12941324569787774,\n",
       " 0.13557455315925887,\n",
       " 0.1358845664340108,\n",
       " 0.13788148695620947,\n",
       " 0.13899063373011747,\n",
       " 0.13896163162270153,\n",
       " 0.14483511486587575,\n",
       " 0.14683719433665948,\n",
       " 0.1502245713948177,\n",
       " 0.15141548398415391,\n",
       " 0.15253481107368314,\n",
       " 0.1572818993559109,\n",
       " 0.15938365717511654,\n",
       " 0.16038401235015345,\n",
       " 0.16088803904011584,\n",
       " 0.16420895941284536,\n",
       " 0.1662921920712003,\n",
       " 0.167021260305191,\n",
       " 0.16700600702301457,\n",
       " 0.1678058374892488,\n",
       " 0.1684147126142052,\n",
       " 0.16840041528503907,\n",
       " 0.16952125322040212,\n",
       " 0.17525555974887203,\n",
       " 0.18078902384480647,\n",
       " 0.18258430222132613,\n",
       " 0.18257366027727856,\n",
       " 0.18291121709272593,\n",
       " 0.18441434017025654,\n",
       " 0.1868807905267073,\n",
       " 0.1890684750245228,\n",
       " 0.1890600792252734,\n",
       " 0.1917223458734425,\n",
       " 0.19297484312430746,\n",
       " 0.19784765184751366,\n",
       " 0.1991873296920848,\n",
       " 0.1991804161575298,\n",
       " 0.19982242966534647,\n",
       " 0.20018599238874552,\n",
       " 0.20087131993532115,\n",
       " 0.2029087420993151,\n",
       " 0.20462880360351932,\n",
       " 0.20462291956837153,\n",
       " 0.20461663361468418,\n",
       " 0.20799301338371096,\n",
       " 0.20993326672368245,\n",
       " 0.20995053947837033,\n",
       " 0.21103770607319897,\n",
       " 0.21103275981314484,\n",
       " 0.21102748658230477,\n",
       " 0.21141332765840654,\n",
       " 0.21171709766903535,\n",
       " 0.21196312484166402,\n",
       " 0.0,\n",
       " 0.0,\n",
       " 0.0,\n",
       " 0.0,\n",
       " 0.0,\n",
       " 0.0,\n",
       " 0.023528904569539627,\n",
       " 0.029407894580196492,\n",
       " 0.04304908053896411,\n",
       " 0.04456201210792682,\n",
       " 0.06185983916621647,\n",
       " 0.06680586748807542,\n",
       " 0.07647047135201683,\n",
       " 0.07973072982065704,\n",
       " 0.09021476118366017,\n",
       " 0.10114113915677446,\n",
       " 0.11524490278715353,\n",
       " 0.1192019071968833,\n",
       " 0.12242633076430982,\n",
       " 0.12475493280744555,\n",
       " 0.12917232162154693,\n",
       " 0.13368376954814232,\n",
       " 0.1336413524538153,\n",
       " 0.13835224748138153,\n",
       " 0.14636502266188187,\n",
       " 0.14718436893092424,\n",
       " 0.15205513715624627,\n",
       " 0.15372384366895442,\n",
       " 0.15446301716825894,\n",
       " 0.1579605178100587,\n",
       " 0.1662673667916681,\n",
       " 0.17472554598071344,\n",
       " 0.17471031375334248,\n",
       " 0.1748330560719733,\n",
       " 0.17496496559968963,\n",
       " 0.17495024725871466,\n",
       " 0.17815587620868278,\n",
       " 0.1801438724208763,\n",
       " 0.18441824865907006,\n",
       " 0.18535704542305464,\n",
       " 0.18646036734231186,\n",
       " 0.18765064413163945,\n",
       " 0.18884220408644667,\n",
       " 0.19034468986847278,\n",
       " 0.1917817092659763,\n",
       " 0.19177197652795142,\n",
       " 0.1928083704156499,\n",
       " 0.19313415538365572,\n",
       " 0.19427432520720894,\n",
       " 0.19767021599918133,\n",
       " 0.20106394375015518,\n",
       " 0.20615659950600945,\n",
       " 0.20859196318816828,\n",
       " 0.20878849565450114,\n",
       " 0.208782107539645,\n",
       " 0.2087749521840083,\n",
       " 0.20908941165964595,\n",
       " 0.21002077536375452,\n",
       " 0.2132313898348537,\n",
       " 0.2157245782775989,\n",
       " 0.2161416419334563,\n",
       " 0.21613583831915534,\n",
       " 0.21612946616916096,\n",
       " 0.21633970088183357,\n",
       " 0.21745897062545105,\n",
       " 0.21745397435325764,\n",
       " 0.21860924001013682,\n",
       " 0.22129106583894584,\n",
       " 0.22208400148204213,\n",
       " 0.22223427837863372,\n",
       " 0.22327798923196368,\n",
       " 0.22407654320404685,\n",
       " 0.22846270028999893,\n",
       " 0.2284588548049114,\n",
       " 0.23003905651753048,\n",
       " 0.23003543884804317,\n",
       " 0.23003148389180453,\n",
       " 0.23002720122568474,\n",
       " 0.2300226000542556,\n",
       " 0.2307150183345358,\n",
       " 0.0,\n",
       " 0.0,\n",
       " 0.0,\n",
       " 0.0,\n",
       " 0.0,\n",
       " 0.0,\n",
       " 0.0010180436009647603,\n",
       " 0.005352372887422685,\n",
       " 0.027925047331694125,\n",
       " 0.027662607976134623,\n",
       " 0.035650406525377334,\n",
       " 0.04178295480395654,\n",
       " 0.060194694350926614,\n",
       " 0.060680924986535226,\n",
       " 0.0605273742678257,\n",
       " 0.06273425090764134,\n",
       " 0.06735863403435054,\n",
       " 0.06722939900643433,\n",
       " 0.07008751974082073,\n",
       " 0.07443382069552501,\n",
       " 0.08691399745771089,\n",
       " 0.09429170787423076,\n",
       " 0.09941317131448124,\n",
       " 0.10599439252633597,\n",
       " 0.10731212116192954,\n",
       " 0.10725631371607533,\n",
       " 0.10727935993910434,\n",
       " 0.10939374526271092,\n",
       " 0.11088569719686434,\n",
       " 0.1129199138708516,\n",
       " 0.11615313074901112,\n",
       " 0.12041464580888558,\n",
       " 0.12343986330689272,\n",
       " 0.12898132112125626,\n",
       " 0.13104561009357937,\n",
       " 0.1323030144385827,\n",
       " 0.1332742674665999,\n",
       " 0.13556835262784925,\n",
       " 0.14037581813404376,\n",
       " 0.14366547713147276,\n",
       " 0.14731014141255494,\n",
       " 0.14934442726847966,\n",
       " 0.14932532266768506,\n",
       " 0.15386836435341963,\n",
       " 0.1568225791790414,\n",
       " 0.15832383300944003,\n",
       " 0.1583072588680978,\n",
       " 0.15913294985382395,\n",
       " 0.15911796719910265,\n",
       " 0.16213451035743734,\n",
       " 0.16441696022418661,\n",
       " 0.16588948011841437,\n",
       " 0.16659693866315567,\n",
       " 0.1673395377636031,\n",
       " 0.16883612844332968,\n",
       " 0.16957735469108934,\n",
       " 0.1695656240380401,\n",
       " 0.16955324398361918,\n",
       " 0.17054223658895545,\n",
       " 0.17167393413646823,\n",
       " 0.1737989107558674,\n",
       " 0.17547691161141296,\n",
       " 0.17620764605170675,\n",
       " 0.17619824167965442,\n",
       " 0.1769050405945139,\n",
       " 0.17911420340308262,\n",
       " 0.17992689505461787,\n",
       " 0.18134163000998196,\n",
       " 0.18265066177039083,\n",
       " 0.18510882657480862,\n",
       " 0.18629898362743819,\n",
       " 0.18629177301239624,\n",
       " 0.18664837987279198,\n",
       " 0.18664121875279632,\n",
       " 0.18663372177503312,\n",
       " 0.18662589893783155,\n",
       " 0.18661775983880133,\n",
       " 0.18660931369579423,\n",
       " 0.1889115867314471,\n",
       " 0.1893616137763971,\n",
       " 0.0,\n",
       " 0.0,\n",
       " 0.0,\n",
       " 0.0,\n",
       " 0.0,\n",
       " 0.00471908572043335,\n",
       " 0.0128737727858656,\n",
       " 0.02425218377935573,\n",
       " 0.028921478147393792,\n",
       " 0.045582971043630655,\n",
       " 0.07265329509450373,\n",
       " 0.08022926030025229,\n",
       " 0.08010693079032086,\n",
       " 0.07995221357317121,\n",
       " 0.07977037496693108,\n",
       " 0.08230937292677715,\n",
       " 0.08564477868377715,\n",
       " 0.09298656880715538,\n",
       " 0.09614152078831685,\n",
       " 0.10164488738712904,\n",
       " 0.1045780260685796,\n",
       " 0.10951165579864773,\n",
       " 0.12045928037726897,\n",
       " 0.12395652323139818,\n",
       " 0.12917756143282952,\n",
       " 0.13607090094190197,\n",
       " 0.14335773019296782,\n",
       " 0.1496058680307103,\n",
       " 0.15502658426838778,\n",
       " 0.15642893499678648,\n",
       " 0.15949264733507904,\n",
       " 0.16321176638847504,\n",
       " 0.16471824313475258,\n",
       " 0.16508611419375818,\n",
       " 0.16844588766979326,\n",
       " 0.1684279481632829,\n",
       " 0.1713726624449654,\n",
       " 0.17250591347224623,\n",
       " 0.1743354498284442,\n",
       " 0.1768233724614363,\n",
       " 0.17962753502618029,\n",
       " 0.18322636647883503,\n",
       " 0.1832139921518744,\n",
       " 0.18433676383955866,\n",
       " 0.18723503777788628,\n",
       " 0.18733757057718764,\n",
       " 0.18732628946314617,\n",
       " 0.1873138753463648,\n",
       " 0.18902287761692116,\n",
       " 0.18901293470296832,\n",
       " 0.19004636751238535,\n",
       " 0.1900367670630144,\n",
       " 0.19002630140618232,\n",
       " 0.190015006714704,\n",
       " 0.19201645764180678,\n",
       " 0.19433741243120412,\n",
       " 0.19864139387002627,\n",
       " 0.19989966284878272,\n",
       " 0.20178122544396715,\n",
       " 0.2019719960499252,\n",
       " 0.2019648841419785,\n",
       " 0.2054883034710106,\n",
       " 0.20564979028741226,\n",
       " 0.20638311437583315,\n",
       " 0.20774632857307723,\n",
       " 0.20845431669671965,\n",
       " 0.20917752017330044,\n",
       " 0.20921909051414408,\n",
       " 0.2098429544102012,\n",
       " 0.21152844491490638,\n",
       " 0.21170434405304583,\n",
       " 0.21169905562818067,\n",
       " 0.21169338858783018,\n",
       " 0.2116873543602367,\n",
       " 0.21168096390451852,\n",
       " 0.21167422773590008,\n",
       " 0.2116671559488072,\n",
       " 0.21165975823906616,\n",
       " 0.21165204392413897,\n",
       " 0.2116440219624619,\n",
       " 0.0,\n",
       " 0.0,\n",
       " 0.0,\n",
       " 0.0,\n",
       " 0.0007921666251142212,\n",
       " 0.017135723358438743,\n",
       " 0.021172001494678364,\n",
       " 0.022729727876055913,\n",
       " 0.0377151401610686,\n",
       " 0.03747539382503913,\n",
       " 0.05068219999257101,\n",
       " 0.05798270317248648,\n",
       " 0.06487463494750442,\n",
       " 0.076179954150035,\n",
       " 0.08283471945560174,\n",
       " 0.08769107273732255,\n",
       " 0.09889760742770112,\n",
       " 0.09882544521783442,\n",
       " 0.0990395058915841,\n",
       " 0.10304502206665113,\n",
       " 0.10588410123221441,\n",
       " 0.11101577293222502,\n",
       " 0.1120342339799711,\n",
       " 0.11349650455780265,\n",
       " 0.11656298495962185,\n",
       " 0.12072827285265536,\n",
       " 0.12068586698497005,\n",
       " 0.12238995214876036,\n",
       " 0.12703329284347706,\n",
       " 0.1333550869732965,\n",
       " 0.13424311755198215,\n",
       " 0.13694061425024712,\n",
       " 0.1399327159069064,\n",
       " 0.14325300962666943,\n",
       " 0.14616200966197823,\n",
       " 0.14657991674280132,\n",
       " 0.15282976584497202,\n",
       " 0.15400787799460222,\n",
       " 0.15551853813571967,\n",
       " 0.1587514358079383,\n",
       " 0.16715353805924107,\n",
       " 0.16792076466657604,\n",
       " 0.16880958502440346,\n",
       " 0.16965878137076673,\n",
       " 0.17112718796917661,\n",
       " 0.1711135908729774,\n",
       " 0.17109884062289282,\n",
       " 0.17153189288708393,\n",
       " 0.1733279158634087,\n",
       " 0.18074568572767954,\n",
       " 0.18334341521335257,\n",
       " 0.18495580125271613,\n",
       " 0.18561040922978977,\n",
       " 0.18696072743721426,\n",
       " 0.18740565816936874,\n",
       " 0.18816673655573368,\n",
       " 0.1890249541550755,\n",
       " 0.19184328761752686,\n",
       " 0.19236512780781206,\n",
       " 0.19300232468698095,\n",
       " 0.1929944242107652,\n",
       " 0.1929859566788997,\n",
       " 0.1949246273556411,\n",
       " 0.19639039117661472,\n",
       " 0.19839134995947455,\n",
       " 0.19842940620866067,\n",
       " 0.20120594989925744,\n",
       " 0.20290267613319557,\n",
       " 0.20531461539615828,\n",
       " 0.2062298618698571,\n",
       " 0.20719834402593718,\n",
       " 0.20843339600533217,\n",
       " 0.21001251146589087,\n",
       " 0.2110297550857268,\n",
       " 0.21196030943146144,\n",
       " 0.21195539967969884,\n",
       " 0.2123682083323092,\n",
       " 0.21437963126678422,\n",
       " 0.21437492764498137,\n",
       " 0.21448416627383368]"
      ]
     },
     "execution_count": 112,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "conj_bern_target_lower_bounds"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5250c6e7",
   "metadata": {},
   "outputs": [],
   "source": [
    "l1, = plt.plot(bet_target_sample_sizes[0],\n",
    "               np.mean(bet_target_lower_bounds, axis=0),\n",
    "               label='Lower bound on the target risk, Betting',\n",
    "               color='indianred')\n",
    "\n",
    "plt.fill_between(\n",
    "    bet_target_sample_sizes[0],\n",
    "    y1=np.mean(bet_target_lower_bounds, axis=0) -\n",
    "    2 * np.std(bet_target_lower_bounds, axis=0) / np.sqrt(num_of_repeats),\n",
    "    y2=np.mean(bet_target_lower_bounds, axis=0) +\n",
    "    2 * np.std(bet_target_lower_bounds, axis=0) / np.sqrt(num_of_repeats),\n",
    "    alpha=0.3,\n",
    "    color='indianred')\n",
    "\n",
    "l2, = plt.plot(pm_bern_target_sample_sizes[0],\n",
    "               np.mean(pm_bern_target_lower_bounds, axis=0),\n",
    "               label='Lower bound on the target risk, PM-EB',\n",
    "               color='steelblue')\n",
    "\n",
    "plt.fill_between(\n",
    "    pm_bern_target_sample_sizes[0],\n",
    "    y1=np.mean(pm_bern_target_lower_bounds, axis=0) -\n",
    "    2 * np.std(pm_bern_target_lower_bounds, axis=0) / np.sqrt(num_of_repeats),\n",
    "    y2=np.mean(pm_bern_target_lower_bounds, axis=0) +\n",
    "    2 * np.std(pm_bern_target_lower_bounds, axis=0) / np.sqrt(num_of_repeats),\n",
    "    alpha=0.3,\n",
    "    color='steelblue')\n",
    "\n",
    "l3, = plt.plot(conj_bern_target_sample_sizes[0],\n",
    "               np.mean(conj_bern_target_lower_bounds, axis=0),\n",
    "               label='Lower bound on the target risk,  conj mixtures',\n",
    "               color='mediumaquamarine')\n",
    "\n",
    "plt.fill_between(\n",
    "    conj_bern_target_sample_sizes[0],\n",
    "    y1=np.mean(conj_bern_target_lower_bounds, axis=0) - 2 *\n",
    "    np.std(conj_bern_target_lower_bounds, axis=0) / np.sqrt(num_of_repeats),\n",
    "    y2=np.mean(conj_bern_target_lower_bounds, axis=0) + 2 *\n",
    "    np.std(conj_bern_target_lower_bounds, axis=0) / np.sqrt(num_of_repeats),\n",
    "    alpha=0.3,\n",
    "    color='mediumaquamarine')\n",
    "\n",
    "p5, = plt.plot([0.15], marker='None', linestyle='None', label='dummy-tophead')\n",
    "\n",
    "l4, = plt.plot(conj_bern_target_sample_sizes[0],\n",
    "               np.repeat(np.mean(conj_bern_rej_thrs, axis=0),\n",
    "                         len(conj_bern_target_sample_sizes[0])),\n",
    "               linestyle='dashed',\n",
    "               color='goldenrod',\n",
    "               alpha=0.7)\n",
    "\n",
    "# l4 = plt.axhline(y=np.mean(conj_bern_rej_thrs),\n",
    "#                  linestyle='dashed',\n",
    "#                  c='goldenrod',\n",
    "#                  alpha=0.7)\n",
    "\n",
    "plt.fill_between(\n",
    "    conj_bern_target_sample_sizes[0],\n",
    "    y1=np.mean(conj_bern_rej_thrs, axis=0) - 2 *\n",
    "    np.std(conj_bern_target_lower_bounds, axis=0) / np.sqrt(num_of_repeats),\n",
    "    y2=np.mean(conj_bern_rej_thrs, axis=0) +\n",
    "    2 * np.std(conj_bern_rej_thrs, axis=0) / np.sqrt(num_of_repeats),\n",
    "    alpha=0.3,\n",
    "    color='goldenrod')\n",
    "\n",
    "categories = [\n",
    "    'UCB on the source risk', r'$\\textbf{LCB on the target risk via:}$ ',\n",
    "    'Betting', 'PM-EB', 'CM-EB'\n",
    "]\n",
    "\n",
    "leg4 = plt.legend([l4, p5, l1, l2, l3],\n",
    "                  categories,\n",
    "                  loc=4,\n",
    "                  ncol=1,\n",
    "                  prop={'size': 20})  # Two columns, horizontal group labels\n",
    "\n",
    "plt.ylabel('Misclassification risk', fontsize=23)\n",
    "plt.xlabel('Number of samples from the target domain', fontsize=23)\n",
    "# plt.savefig('img/lower_bounds_misclas.pdf', bbox_inches='tight')"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.7.7"
  },
  "toc": {
   "base_numbering": 1,
   "nav_menu": {},
   "number_sections": true,
   "sideBar": true,
   "skip_h1_title": false,
   "title_cell": "Table of Contents",
   "title_sidebar": "Contents",
   "toc_cell": false,
   "toc_position": {},
   "toc_section_display": true,
   "toc_window_display": false
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
