{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "import seaborn as sns\n",
    "import torch\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "from main import load_data\n",
    "from utils import Acc, NotAbstainAcc, AdjustAcc, Flip_L, CheckLFs_Acc, Snorkel, GetStats\n",
    "from label_prop import PropagationSoft, PropagationHard\n",
    "from snorkel.labeling.model import LabelModel\n",
    "from extension import alpha_from_LPA, LPA_with_dongle_with_labeled_inds_custom_alpha, LPA_with_dongle_with_labeled_inds\n",
    "from extension import Adaboost_weight_norm, Adaboost_weight\n",
    "from extension import Generate_data_var_reg, alpha_from_reg\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {},
   "outputs": [],
   "source": [
    "X, L, labels, W_x, S_x, W_x_large, S_x_large = load_data('sms', 10, 10, 1)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Calculate accuracy for each weak label"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 200/200 [00:00<00:00, 781.44epoch/s]\n"
     ]
    }
   ],
   "source": [
    "Acc_oracle, Coverage = CheckLFs_Acc(L, labels, show = False)\n",
    "Acc_snorkel, snorkel_pred = Snorkel(L)\n",
    "Original_Acc, Original_Coverage, Original_AdjustedAcc = GetStats(snorkel_pred, labels)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 1200x600 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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mq6SmppKYGAg9evXL9/WokULzp49S25urhMjq17z5s1599130Wg05du2bNlCdHQ0R44cwWQysXDhQrp27UqfPn14++23MZvNToz42sxmM4cPH+a7776jR48e3HbbbTzzzDNcvnyZ1NRUoqKiLMpHRERw5MgRJ0VrvfXr15OWlsaTTz4J4BbnpVu3bnz99df07dvXYnt15yEtLc1tz5MjuXObU8aT2p4yntoGXc0d26MyzmyXJGm6SkFBAXq93mJb2fPCwkJnhHRdFEVhwYIFbNu2jRkzZpCXl0fHjh154IEH+P7773nppZf46KOPWLp0qbNDrVRWVhZt2rShT58+bNq0iZUrV3Ly5EmmTp1a6Tny8fFx+fNjNpt58803eeSRR/D39wdwi/NSr149tFpthe3VnQd3PU+O5iltThl3b3vKeGIbdDV3bY/KOLNdqnjUWszX15eioiKLbWXP/fz8nBGSzfLz83nqqac4fPgwy5cvp2XLlrRs2ZKEhITyMnFxcfzzn/9k06ZNPPTQQ06MtnKhoaEWXd16vZ6pU6dy7733MmjQIAwGg0V5g8Hg8ucnOTmZixcvMmTIkPJtCQkJbnVerqbX68nLy7PYdvV50Ov1lZ6noKAgh8XoDjyhzSnjCW1PGU9sg67mae1RGUe0S9LTdJXIyEhycnLIyMgo33b8+HHCwsIICAhwYmTWSU9PZ/DgweTn57N69WpatmwJwDfffMPKlSstypaUlODj4+OMMKt15MgRXn75ZRRFKd9WUlKCWq0mLi6O1NRUi/JpaWlERkY6OkybbNmyhd69e+Pr61u+zd3Oy9WioqKqPA+RkZFueZ4czd3bnDKe0vaU8cQ26Gqe1h6VcUS7JEnTVcLDw2nXrh1z5swhPz+f06dPs3jxYots3FVdvnyZf/7zn9x666289957BAcHl+9TFIW5c+eya9cuFEVh//79fPjhhwwbNsyJEV9bYGAgK1as4N1338VkMnH27Fleeukl7rnnHvr06UNGRgbLli3DaDSye/duNm7cyODBg50ddpV++uknOnToYLHN3c7L1Xr37l3leRgyZAgbN25k9+7dGI1Gli1bRmZmJr1793Zy5K7FnducMp7U9pTxxDboap7WHpVxSLtkp7v/PMalS5eUCRMmKB07dlQ6d+6szJs3TzGZTM4Oq1pLly5VoqKilFtuuUVp27atxUNRFOWTTz5R7rzzTuWWW25RevXqpSxfvtzJEVctOTlZGTZsmBIfH6907txZef755xWDwaAoiqIcPHiwfF+vXr2Uzz//3MnRVq9t27bKd999V2G7O52Xq2/tVZTqz8O6deuUPn36KG3btlWGDBmi/PLLL44O2S24a5tTxtPanjKe1gZdzRPaozKObpdUinJV/6MQQgghhKiUXJ4TQgghhLCCJE1CCCGEEFaQpEkIIYQQwgqSNAkhhBBCWEGSJiGEEEIIK0jSJIQQQghhBUmahBBCCCGsIEmTEEIIIYQVJGkSN2TFihW0bNmSZcuWOTuUG5KcnFy+XpYQwr1JuyRqiiRN4oasWLGCf/zjH3z44YeYTCZnhyOEENIuiRojSZO4brt27SIzM5Mnn3wSs9nMli1byvdlZWXxxBNP0KFDBzp16sTkyZO5fPkyAKdPn+aRRx6hXbt2dOnShVmzZlFSUlLpMfbt28fw4cNp3749PXv25NVXXy0v+/rrrzNq1CgGDx5Mx44d2bt3L8ePH+fhhx/m9ttvJy4ujr59+7Jt27by9zt8+DAPPPAA8fHxdOvWjddee43KVhJKT0/nkUceoVOnTvTo0YMFCxZcM0YhhOuQdknUJEmaxHX76KOPuPfee/Hx8eG+++5j6dKl5fsmTZpEfn4+W7du5b///S+5ubnMnj0bk8nE6NGjqVevHj/88ANffPEFv/zyC6+//nqF9z9x4gQjR47kzjvv5Mcff+T999/n22+/Zf78+eVldu3axRNPPMG2bduIj49nwoQJREVF8fXXX7Nv3z66devGrFmzAMjJyWHUqFF06tSJ5ORkPv74Y9asWcOnn35qcdzCwkJGjBhBZGQkP/zwAx9//DE//vhjpTEKIVyLtEuiRt3wEsOiVvrjjz+UmJgY5dy5c4qiKEp2drYSFxenJCcnK3/88YcSFRWlnDhxorz8xYsXlWPHjinJyclKmzZtlMLCwvJ9p0+fVk6dOlXhGK+++qoyePBgi23fffedEhcXp5SWlioLFy5UevfubbE/PT1dKS4uVoqLi5UTJ04or7/+utKyZUtFURRlzZo1Svfu3RWz2Vxe/vjx48q5c+eU3bt3K1FRUYqiKMqXX36pJCQkWJTbvn27Eh8ff71/LiGEA0i7JGqa1tlJm3BPH3/8MSaTicTExPJtJpOJpUuX8sgjjwDQqFGj8n316tWjXr16fPnllwQFBaHX68v3NW7cuNJjZGZm0qRJE4ttjRs3xmAwkJmZCcBNN91ksf/IkSOMGzeOS5cu0aJFC4KDg8u7uS9dukSDBg1QqVTl5Zs3bw7AqVOnyredOXOGrKwsOnToUL5NURSMRiOZmZmEhIRY8RcSQjiatEuipknSJGxWXFzM6tWrSUpKomvXruXbjx07xtixYxkzZgwAZ8+eJTw8HIC0tDS++OILunfvTnZ2NkVFReUN1L59+zh06BAjRoywOE6jRo3YunWrxbb09HS8vLyoW7cugEVDc+HCBSZNmsSiRYvo2bMnAFu2bCl/j7CwMM6dO4eiKOWv++abb8jPz6dBgwbl7xMWFkbTpk3ZvHlz+bb8/HwyMzMJDg6+7r+bEKLmSLskHEHGNAmbbdy4EZVKRf/+/QkLCyt/3HbbbURFRbFu3ToSEhKYP38+ubm55Ofn89JLL3H69Gni4uIIDw/nxRdfpKioiIyMDObOnUtWVlaF49x9990cP36cDz74gJKSEtLT0/nPf/5D//798fLyqlC+oKCA0tLS8kYvLS2NN954A4CSkhJuv/12TCYTb731Vvn7zZkzh+LiYov36dGjBwUFBbz77ruUlJSQm5vL9OnTmTx5skVjKIRwHdIuCUeQpEnY7OOPP6Z///7odLoK+4YNG8b69euZP38+/v7+3HXXXfTq1Yvg4GBmz56NTqfjrbfe4sKFC9x+++0kJibSoUMHJk6cWOG9GjduzLvvvsuWLVvo2rUr9913HwkJCTz77LOVxtW8eXOmTZvG1KlTadeuHZMmTWLw4MHodDqOHTtGnTp1eO+999i1axfdunXjgQce4P/+7/8YNmyYxfv4+/uzbNkykpOTue2227jjjjtQq9W8+eab9vkDCiHsTtol4QgqRankvkYhhBBCCGFBepqEEEIIIawgSZMQQgghhBUkaRJCCCGEsIIkTUIIIYQQVpCkSQghhBDCCpI0CSGEEEJYQZImIYQQQggrSNIkhBBCCGEFSZqEEEIIIawgSZMQQgghhBUkaRJCCCGEsIIkTUIIIYQQVvh/Y/IeT+Pjf8QAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 600x300 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "df = pd.DataFrame({'Acc oracle': Acc_oracle, 'Acc snorkel': Acc_snorkel, 'Coverage': Coverage})\n",
    "\n",
    "plt.figure(figsize = (6,3),dpi = 200)\n",
    "fig, axs = plt.subplots(1,2, figsize = (6,3),dpi = 100)\n",
    "\n",
    "sns.scatterplot(data = df, x = 'Acc oracle',y = 'Acc snorkel', ax = axs[0])\n",
    "axs[0].axline((1, 1), slope=1, ls = '--')\n",
    "sns.scatterplot(data = df, x = 'Acc oracle',y = 'Coverage', ax = axs[1])\n",
    "\n",
    "plt.xlim([0, 105])\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Smooth each weak labeler -> round up/ round down"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {},
   "outputs": [],
   "source": [
    "def SmoothLFs(L, W_x, labels, alpha = 1, threshold = 0.51):\n",
    "    L_tf = (-1)* (L == 0) + (L == 1)\n",
    "    new_L = -1*np.ones_like(L)\n",
    "    for i in range(L.shape[1]):\n",
    "        wl_preds = ((L_tf[:,i].numpy() + 1)/2).reshape(-1,1)\n",
    "        base_preds = np.hstack((1- wl_preds, wl_preds))\n",
    "        smooth_wl = PropagationSoft(base_preds, W_x, labels , labeled_inds = [], alpha = alpha)\n",
    "        idx = (np.max(smooth_wl, 1)> threshold)\n",
    "        new_L[idx, i] = smooth_wl[idx].argmax(1)\n",
    "    return torch.tensor(new_L)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 200/200 [00:00<00:00, 766.02epoch/s]\n"
     ]
    },
    {
     "ename": "ValueError",
     "evalue": "too many values to unpack (expected 2)",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mValueError\u001b[0m                                Traceback (most recent call last)",
      "\u001b[0;32m/var/folders/7c/nfrp6kqn1f1bw1r2q74054gr0000gr/T/ipykernel_26422/1889737756.py\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      4\u001b[0m     \u001b[0mnew_Acc_oracle\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mnew_Coverage\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mCheckLFs_Acc\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnew_L\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlabels\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mshow\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;32mFalse\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      5\u001b[0m     \u001b[0mAcc_snorkel\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mnew_snorkel_pred\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mSnorkel\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnew_L\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 6\u001b[0;31m     \u001b[0mAccuracy\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mCoverage\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mGetStats\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnew_snorkel_pred\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlabels\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m      7\u001b[0m     \u001b[0mresult\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m'Accuracy'\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mappend\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mAccuracy\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      8\u001b[0m     \u001b[0mresult\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m'Coverage'\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mappend\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mCoverage\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mValueError\u001b[0m: too many values to unpack (expected 2)"
     ]
    }
   ],
   "source": [
    "result = {'Accuracy': [],'Coverage': [], 'Threshold' : []}\n",
    "for th in np.linspace(0.5, 0.95, 20):\n",
    "    new_L = SmoothLFs(L, W_x, labels, alpha = 1, threshold = th)\n",
    "    new_Acc_oracle, new_Coverage = CheckLFs_Acc(new_L, labels, show = False)\n",
    "    Acc_snorkel, new_snorkel_pred = Snorkel(new_L)\n",
    "    Accuracy, Coverage = GetStats(new_snorkel_pred, labels)\n",
    "    result['Accuracy'].append(Accuracy)\n",
    "    result['Coverage'].append(Coverage)\n",
    "    result['Threshold'].append(th)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.DataFrame(result)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 1200x600 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 600x300 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize = (6,3),dpi = 200)\n",
    "fig, axs = plt.subplots(1,2, figsize = (6,3),dpi = 100)\n",
    "sns.lineplot(data = df, x = 'Threshold', y = 'Accuracy', ax = axs[0])\n",
    "axs[0].hlines(y = Original_Acc, xmin = np.min(result['Threshold']), xmax = np.max(result['Threshold']), ls = '--', color = 'red')\n",
    "sns.lineplot(data = df, x = 'Threshold', y = 'Coverage', ax = axs[1])\n",
    "axs[1].hlines(y = Original_Coverage, xmin = np.min(result['Threshold']), xmax = np.max(result['Threshold']), ls = '--', color = 'red')\n",
    "plt.ylim([0, 105])\n",
    "plt.tight_layout()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<AxesSubplot:xlabel='Accuracy', ylabel='Coverage'>"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAScAAAEdCAYAAABOu6GKAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8/fFQqAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAmB0lEQVR4nO3de1xUdf4/8NcMMzjDpYAB19VYLzvgNTZcFQ1cDTO3kkAU/bXkZlpmWq49NrRN2jTD61qulWYpkYmVUkpoK+xuuhoqmRko/Sym2gJv3AnBkRnm8/3DmG0ElQNzOcO8no8Hj8d6zpnP5/PG7eU5Zz7ncxRCCAEiIplRunoARERtYTgRkSwxnIhIlhhORCRLDCcikiWGExHJEsOJiGSJ4UREssRwIiJZUrl6AI5SVVWPzs59VygAnc7fLm25E9btOXU7u+aW/tqjy4aTELDbL9uebbkT1u055FgzL+uISJYYTkQkSwwnIpIlhhMRyZJHhpNZqUBNs8APDSbUNAuYlQpXD4mIrtJlv627lksKBRbvOoVDhirrttFhwUiLHwyt3L6uIPJgHnXmZFYqsHi3bTABwKGSSizOLuYZFJGMeFQ41ZssrYKpxaGSStSbLE4eERFdi2eFk9Hcqf1E5DweFU7+muvfYrvRfiJyHs8KJ7USo8OC29w3OiwY/mqP+nUQyZpH/deosgikxQ9uFVCjw4KxPH4IVBZ+W0ckFx53HaMVAqsTBqPeZEG90Qx/jQr+aiVUFt4MJ5ITjwsn4MoZVKCXAoG+6isbeMZEJDsedVlHRO6D4UTUBXWFR7Scfln34Ycf4rnnnrPZZjKZAACnTp1CYWEhXnjhBRgMBgQGBuKxxx5DUlKSs4dJ5La6yiNaTj9zuu+++3DixAnrz759+xAQEIC0tDTU1dVh9uzZSEhIwLFjx5CWloYVK1agqKjI2cMkcktd6REtl17WCSGQkpKCsWPHIj4+Hnl5eQgICEBycjJUKhVGjRqFuLg4ZGZmunKYRG6jKz2i5dJv67Kzs2EwGLBhwwYAQElJCcLDw22O0ev1yMrKkty2wg7/QLS0YY+23Anrdu04OqM9j2gF+amtf3Z2zVL6cVk4WSwWbNy4EXPmzIGfnx8AoKGhAVqt1uY4jUaDxsZGye239w0Pzm7LnbBu91NnuXjd/QE+3ggO9mu1XY41uyycCgoKUF5ejilTpli3abVa1NfX2xxnNBrh6+sruX2+GqrjWLf71u3jpcDosGAcKqlstW90WDB8vIDKyv/9N8ZXQ7UhNzcX48ePh4+Pj3VbeHg48vPzbY4zGAwICwuT3D5fDdV5rNv9qMSVR7QWZxfbBNT/HtGyoK3S5Fizy8Lp+PHj+OMf/2izbfz48VizZg0yMjKQnJyM48ePIycnx3pPiohurKs8ouWycCorK0P37t1ttgUGBiI9PR1paWlYv349goKCkJqaipEjR7polETuqSs8ouWycDpx4kSb22+99Va8++67Th4NEckNH18hIlliOBGRLDGciEiWGE5EJEsMJyKSJYYTEckSw4mIZInhRESyxHAiIlliOBGRLDGciEiWGE5EJEsMJyKSJYYTEckSw4mIZInhRESyxHAiIlliOBGRLDGciEiWGE5EJEsMJyKSJYYTEckSw4mIZInhRESyxHAiIllySTjV1tZi4cKFiIqKwvDhwzF37lyUl5cDAAoLC5GUlITIyEjExsZi586drhgiEbmYS8LpiSeeQGNjI/75z39i//798PLywrPPPou6ujrMnj0bCQkJOHbsGNLS0rBixQoUFRW5YphE5EIqZ3d46tQpFBYW4vDhw/Dz8wMALFu2DBUVFcjLy0NAQACSk5MBAKNGjUJcXBwyMzMREREhqR+FovNjbWnDHm25E9bt2nE4k7NrltKP08OpqKgIer0eO3bswDvvvINLly5h9OjRWLRoEUpKShAeHm5zvF6vR1ZWluR+dDp/ew3Zrm25E9btOeRYs9PDqa6uDl999RWGDBmCXbt2wWg0YuHChVi0aBGCg4Oh1WptjtdoNGhsbJTcT1VVPYTo3FgViit/afZoy52wbs+p29k1t/TXHk4PJ29vbwDA4sWL0a1bN/j5+WHBggWYOnUqEhMTYTQabY43Go3w9fWV3I8QsNsv255tuRPW7TnkWLPTb4jr9XpYLBaYTCbrNovFAgAYOHAgSkpKbI43GAwICwtz6hiJyPWcHk633347QkND8cwzz6ChoQHV1dV46aWXcOedd2LixImorKxERkYGTCYTjh49ipycHEyePNnZwyQiF3N6OKnVarz99tvw8vLChAkTMGHCBPTo0QPLly9HYGAg0tPTsW/fPkRFRSE1NRWpqakYOXKks4dJRC6mEEJuV5r2UVlpnxviwcH+dmnLnbBu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",
      "text/plain": [
       "<Figure size 300x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize = (3,3),dpi = 100)\n",
    "sns.scatterplot(data = df, x = 'Accuracy', y ='Coverage')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Label propagation with dongle node"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def GenerateDongleW(W_x, L):\n",
    "    n = W_x.shape[0]\n",
    "    m = L.shape[1]  \n",
    "    W_dongle = np.zeros((n+2*m, n+2*m))\n",
    "    W_dongle[:n, :n] = W_x\n",
    "    W_dongle[:n, n:n+m] = (L== 0).float().numpy()\n",
    "    W_dongle[n:n+m, :n] = np.transpose((L== 0).float().numpy())\n",
    "    W_dongle[:n, n+m:n+2*m] = (L== 1).float().numpy()\n",
    "    W_dongle[n+m:n+2*m, :n] = np.transpose((L== 1).float().numpy())\n",
    "    return W_dongle\n",
    "\n",
    "def LPA_with_dongle(W_x, L, L_acc, labels, num_labels = 0, lamb = 1):\n",
    "\n",
    "    m = L.shape[1]\n",
    "    n = W_x.shape[0]\n",
    "\n",
    "    labeled_inds = np.random.choice(range(n), size= num_labels, replace=False)\n",
    "\n",
    "    return LPA_with_dongle_with_labeled_inds(W_x, L, L_acc, labels, labeled_inds , lamb)\n",
    "\n",
    "def LPA_with_dongle_with_labeled_inds(W_x, L, L_acc, labels, labeled_inds, lamb = 1):\n",
    "    m = L.shape[1]\n",
    "    n = W_x.shape[0]\n",
    "\n",
    "    W_dongle = GenerateDongleW(W_x, L)\n",
    "    \n",
    "\n",
    "    # Create a weighted augmented dongle matrix\n",
    "    Acc_mat = (np.ones((n,2*m))*np.hstack([L_acc, L_acc]))/100\n",
    "    W_dongle_weighted = np.zeros_like(W_dongle)\n",
    "    W_dongle_weighted[:n, :n] = W_dongle[:n, :n]\n",
    "    W_dongle_weighted[:n, n:n+2*m] = W_dongle[:n, n:n+2*m]* Acc_mat * lamb\n",
    "    W_dongle_weighted[n:n+2*m, :n] = np.transpose(W_dongle[:n, n:n+2*m]* Acc_mat)*lamb\n",
    "\n",
    "    base_preds = 0.5*np.ones((n+2*m, 2))\n",
    "    labels_aug = np.hstack([labels.numpy(), np.hstack([np.zeros(m),np.ones(m)])])\n",
    "    labeled_inds_aug = np.hstack([labeled_inds, np.arange(n, n+2*m)]).astype(int)\n",
    "    smooth_wl = PropagationHard(base_preds, W_dongle_weighted, labels = labels_aug , labeled_inds = labeled_inds_aug, alpha = 1)\n",
    "\n",
    "    return smooth_wl[:n,:]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "num_labels = 100\n",
    "lamb = 10\n",
    "data_name = 'sms'\n",
    "X, L, labels, W_x, S_x, W_x_large, S_x_large = load_data(data_name, 10, 10, 1)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 200/200 [00:00<00:00, 713.81epoch/s]\n"
     ]
    }
   ],
   "source": [
    "# preprocess -> make sure accuracy > 0.5 for all weak labelers\n",
    "L_acc_oracle, Coverage = CheckLFs_Acc(L, labels, show = False)\n",
    "L = Flip_L(L, L_acc_oracle)\n",
    "\n",
    "# continue as uaual\n",
    "L_acc, snorkel_pred = Snorkel(L)\n",
    "L_acc_oracle, Coverage = CheckLFs_Acc(L, labels, show = False)\n",
    "L_acc_oracle = np.nan_to_num(L_acc_oracle)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Not Abstain Acc: 94.25\n",
      "Coverage: 76.09\n",
      "Adjusted Acc: 83.67\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "[94.24920127795528, 76.09400324149108, 83.67098865478121]"
      ]
     },
     "execution_count": 54,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Dongle + Snorkel Acc\n",
    "LPA_dongle_pred_snorkel_acc = LPA_with_dongle(W_x, L, L_acc_oracle, labels, num_labels = num_labels, lamb = lamb)\n",
    "list(GetStats(LPA_dongle_pred_snorkel_acc, labels, show = True))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [],
   "source": [
    "def Adaboost_weight(w, clip = 5, graph_acc = 0.95):\n",
    "    w_clip = np.clip(w, a_min = 0.01*clip, a_max = 1 - 0.01*clip)\n",
    "    return (0.5*np.log(w_clip/(1-w_clip)))/(0.5*np.log(graph_acc/(1-graph_acc)))\n",
    "\n",
    "def Adaboost_weight_norm(w, clip = 5):\n",
    "    w_clip = np.clip(w, a_min = 0.01*clip, a_max = 1 - 0.01*clip)\n",
    "    alpha_j = (0.5*np.log(w_clip/(1-w_clip)))\n",
    "    alpha_j_norm = alpha_j/np.max(alpha_j)\n",
    "    return alpha_j_norm*100\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'L_acc_oracle' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "\u001b[0;32m/var/folders/7c/nfrp6kqn1f1bw1r2q74054gr0000gr/T/ipykernel_39869/4184264370.py\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[0;32m----> 1\u001b[0;31m \u001b[0madaboost_weight\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0mAdaboost_weight\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mL_acc_oracle\u001b[0m\u001b[0;34m/\u001b[0m\u001b[0;36m100\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mgraph_acc\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;36m0.95\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0;36m100\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m: name 'L_acc_oracle' is not defined"
     ]
    }
   ],
   "source": [
    "adaboost_weight = (Adaboost_weight(L_acc_oracle/100, graph_acc = 0.95))*100"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'LPA_with_dongle' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "\u001b[0;32m/var/folders/7c/nfrp6kqn1f1bw1r2q74054gr0000gr/T/ipykernel_41684/1434149656.py\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[0;31m# Dongle + Snorkel Acc\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 2\u001b[0;31m \u001b[0mLPA_dongle_pred_snorkel_acc\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mLPA_with_dongle\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mW_x\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mL\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0madaboost_weight\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlabels\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mnum_labels\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mnum_labels\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlamb\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mlamb\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m      3\u001b[0m \u001b[0mlist\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mGetStats\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mLPA_dongle_pred_snorkel_acc\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlabels\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mshow\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;32mTrue\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mNameError\u001b[0m: name 'LPA_with_dongle' is not defined"
     ]
    }
   ],
   "source": [
    "# Dongle + Snorkel Acc\n",
    "LPA_dongle_pred_snorkel_acc = LPA_with_dongle(W_x, L, adaboost_weight, labels, num_labels = num_labels, lamb = lamb)\n",
    "list(GetStats(LPA_dongle_pred_snorkel_acc, labels, show = True))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Experiment result"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "def run_experiment(data_name, num_labels, lamb, seed, euc_th = 10, wl_th = 10, thresh = 10):\n",
    "    results = []\n",
    "    X, L, labels, W_x, S_x, W_x_large, S_x_large = load_data(data_name, euc_th, wl_th, seed)\n",
    "    \n",
    "    # Accuracy approx\n",
    "    L_acc, snorkel_pred = Snorkel(L)\n",
    "    L_acc_oracle, Coverage = CheckLFs_Acc(L, labels, show = False)\n",
    "    L_acc_oracle = np.nan_to_num(L_acc_oracle)\n",
    "\n",
    "\n",
    "    # labeled points\n",
    "    labeled_inds = np.random.choice(range(W_x.shape[0]), size= num_labels, replace=False)\n",
    "    snorkel_pred[labeled_inds,:] = np.stack((1-labels[labeled_inds], labels[labeled_inds]), axis = 1)\n",
    "\n",
    "    # LPA + WL\n",
    "    LPA_WL = PropagationHard(snorkel_pred, W_x, labels, labeled_inds, alpha = 1)\n",
    "\n",
    "    # Baseline\n",
    "    results.append(list(GetStats(snorkel_pred, labels)) + ['Snorkel', data_name, num_labels, lamb, seed, euc_th])\n",
    "    results.append(list(GetStats(LPA_WL, labels)) + ['LPA + WL', data_name, num_labels, lamb, seed, euc_th])\n",
    "    \n",
    "    # LPA with dongle nodes\n",
    "    alpha_s = L_acc\n",
    "    alpha_oracle = L_acc_oracle\n",
    "    alpha_one = np.ones_like(L_acc)\n",
    "    alpha_zero = np.zeros_like(L_acc)\n",
    "\n",
    "    list_alpha = [alpha_s, alpha_oracle, alpha_one, alpha_zero]\n",
    "    list_method1 = ['Dongle + alpha_s','Dongle + alpha_*','Dongle + alpha_1','LPA']\n",
    "\n",
    "    for alpha_j, Methods in zip(list_alpha, list_method1):\n",
    "        pseudolabels = LPA_with_dongle_with_labeled_inds(W_x, L, alpha_j, labels, labeled_inds, lamb = lamb)\n",
    "        results.append(list(GetStats(pseudolabels, labels)) + [Methods, data_name, num_labels, lamb, seed, euc_th])\n",
    "\n",
    "    # Optimal weight\n",
    "    opt_s = Adaboost_weight_norm(L_acc/100, clip = 5)\n",
    "    opt_oracle = Adaboost_weight_norm(L_acc_oracle/100, clip = 5)\n",
    "    list_alpha2 = [opt_s, opt_oracle]\n",
    "    list_method2 = ['Dongle + opt_s', 'Dongle + opt_*']\n",
    "\n",
    "    for alpha_j, Methods in zip(list_alpha2, list_method2):\n",
    "        pseudolabels = LPA_with_dongle_with_labeled_inds(W_x, L, alpha_j, labels, labeled_inds, lamb = lamb)\n",
    "        results.append(list(GetStats(pseudolabels, labels)) + [Methods, data_name, num_labels, lamb, seed, euc_th])\n",
    "\n",
    "\n",
    "    # Alpha_j depends on x\n",
    "    alpha_mat_lpa = alpha_from_LPA(X,L,labels, L_acc, labeled_inds, thresh = thresh)\n",
    "    alpha_mat_reg = alpha_from_reg(X, L, labels, L_acc,labeled_inds)\n",
    "\n",
    "    list_alpha_mat = [alpha_mat_lpa, alpha_mat_reg]\n",
    "    list_method3 = ['Dongle + LPA alpha', 'Dongle + Reg alpha']\n",
    "\n",
    "    for alpha_mat, Methods in zip(list_alpha_mat, list_method3):\n",
    "        pseudolabels = LPA_with_dongle_with_labeled_inds_custom_alpha(W_x, L, alpha_mat, labels, labeled_inds, lamb = 1)\n",
    "        results.append(list(GetStats(pseudolabels, labels)) + [Methods, data_name, num_labels, lamb, seed, euc_th])\n",
    "\n",
    "\n",
    "\n",
    "    return results  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 200/200 [00:00<00:00, 1806.96epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 2127.30epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 2147.70epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 2107.24epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 2177.68epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 473.47epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 456.11epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 547.07epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 574.62epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 519.36epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 2066.78epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 1996.60epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 2013.72epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 2070.31epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 2100.99epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 1558.87epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 1563.40epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 1549.45epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 1566.69epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 1507.25epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 2045.83epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 2013.34epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 1962.56epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 2026.55epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 2269.68epoch/s]\n"
     ]
    }
   ],
   "source": [
    "results = []\n",
    "for data_name in ['youtube','sms','basketball','cdr','tennis']:\n",
    "    for seed in [1,2,3,4,5]:\n",
    "        results += run_experiment(data_name, num_labels = 0, lamb = 1, seed = seed, euc_th = 10, wl_th = 10)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.DataFrame(results, columns = ['Not abstain Acc',' Coverage','Acc','Method','Data name', 'num_labels','lambda','seed','euc_th'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th>Data name</th>\n",
       "      <th>basketball</th>\n",
       "      <th>cdr</th>\n",
       "      <th>sms</th>\n",
       "      <th>tennis</th>\n",
       "      <th>youtube</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Method</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>Dongle + LPA alpha</th>\n",
       "      <td>67.13</td>\n",
       "      <td>72.76</td>\n",
       "      <td>81.65</td>\n",
       "      <td>86.70</td>\n",
       "      <td>83.33</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + Reg alpha</th>\n",
       "      <td>67.13</td>\n",
       "      <td>72.76</td>\n",
       "      <td>81.65</td>\n",
       "      <td>86.70</td>\n",
       "      <td>83.33</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + alpha_*</th>\n",
       "      <td>67.13</td>\n",
       "      <td>73.19</td>\n",
       "      <td>82.17</td>\n",
       "      <td>86.70</td>\n",
       "      <td>88.30</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + alpha_1</th>\n",
       "      <td>67.87</td>\n",
       "      <td>71.21</td>\n",
       "      <td>81.73</td>\n",
       "      <td>86.79</td>\n",
       "      <td>82.70</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + alpha_s</th>\n",
       "      <td>67.13</td>\n",
       "      <td>72.76</td>\n",
       "      <td>81.65</td>\n",
       "      <td>86.70</td>\n",
       "      <td>83.33</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + opt_*</th>\n",
       "      <td>68.46</td>\n",
       "      <td>70.05</td>\n",
       "      <td>81.43</td>\n",
       "      <td>86.67</td>\n",
       "      <td>85.67</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + opt_s</th>\n",
       "      <td>68.55</td>\n",
       "      <td>68.39</td>\n",
       "      <td>81.09</td>\n",
       "      <td>86.68</td>\n",
       "      <td>71.74</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>LPA</th>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>LPA + WL</th>\n",
       "      <td>67.11</td>\n",
       "      <td>69.24</td>\n",
       "      <td>81.25</td>\n",
       "      <td>86.17</td>\n",
       "      <td>72.62</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Snorkel</th>\n",
       "      <td>68.59</td>\n",
       "      <td>68.63</td>\n",
       "      <td>67.74</td>\n",
       "      <td>85.78</td>\n",
       "      <td>74.44</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "Data name           basketball    cdr    sms  tennis  youtube\n",
       "Method                                                       \n",
       "Dongle + LPA alpha       67.13  72.76  81.65   86.70    83.33\n",
       "Dongle + Reg alpha       67.13  72.76  81.65   86.70    83.33\n",
       "Dongle + alpha_*         67.13  73.19  82.17   86.70    88.30\n",
       "Dongle + alpha_1         67.87  71.21  81.73   86.79    82.70\n",
       "Dongle + alpha_s         67.13  72.76  81.65   86.70    83.33\n",
       "Dongle + opt_*           68.46  70.05  81.43   86.67    85.67\n",
       "Dongle + opt_s           68.55  68.39  81.09   86.68    71.74\n",
       "LPA                        NaN    NaN    NaN     NaN      NaN\n",
       "LPA + WL                 67.11  69.24  81.25   86.17    72.62\n",
       "Snorkel                  68.59  68.63  67.74   85.78    74.44"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df.groupby(['Data name','Method']).mean().round(2).loc[:,'Acc'].unstack().transpose()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>Not abstain Acc</th>\n",
       "      <th>Coverage</th>\n",
       "      <th>Acc</th>\n",
       "      <th>num_labels</th>\n",
       "      <th>lambda</th>\n",
       "      <th>seed</th>\n",
       "      <th>euc_th</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Data name</th>\n",
       "      <th>Method</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"10\" valign=\"top\">basketball</th>\n",
       "      <th>Dongle + LPA alpha</th>\n",
       "      <td>0.67</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.67</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + Reg alpha</th>\n",
       "      <td>0.67</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.67</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + alpha_*</th>\n",
       "      <td>0.67</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.67</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + alpha_1</th>\n",
       "      <td>0.59</td>\n",
       "      <td>0.40</td>\n",
       "      <td>0.51</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + alpha_s</th>\n",
       "      <td>0.67</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.67</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + opt_*</th>\n",
       "      <td>0.63</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.63</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + opt_s</th>\n",
       "      <td>0.61</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.61</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>LPA</th>\n",
       "      <td>NaN</td>\n",
       "      <td>0.00</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>LPA + WL</th>\n",
       "      <td>0.70</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.70</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Snorkel</th>\n",
       "      <td>0.67</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.67</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"10\" valign=\"top\">cdr</th>\n",
       "      <th>Dongle + LPA alpha</th>\n",
       "      <td>0.25</td>\n",
       "      <td>0.03</td>\n",
       "      <td>0.24</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + Reg alpha</th>\n",
       "      <td>0.25</td>\n",
       "      <td>0.03</td>\n",
       "      <td>0.24</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + alpha_*</th>\n",
       "      <td>0.20</td>\n",
       "      <td>0.04</td>\n",
       "      <td>0.19</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + alpha_1</th>\n",
       "      <td>0.30</td>\n",
       "      <td>0.16</td>\n",
       "      <td>0.27</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + alpha_s</th>\n",
       "      <td>0.25</td>\n",
       "      <td>0.03</td>\n",
       "      <td>0.24</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + opt_*</th>\n",
       "      <td>0.28</td>\n",
       "      <td>0.06</td>\n",
       "      <td>0.28</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + opt_s</th>\n",
       "      <td>0.39</td>\n",
       "      <td>0.06</td>\n",
       "      <td>0.38</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>LPA</th>\n",
       "      <td>NaN</td>\n",
       "      <td>0.00</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>LPA + WL</th>\n",
       "      <td>0.39</td>\n",
       "      <td>0.06</td>\n",
       "      <td>0.38</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Snorkel</th>\n",
       "      <td>0.38</td>\n",
       "      <td>0.32</td>\n",
       "      <td>0.35</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"10\" valign=\"top\">sms</th>\n",
       "      <th>Dongle + LPA alpha</th>\n",
       "      <td>0.35</td>\n",
       "      <td>1.29</td>\n",
       "      <td>0.75</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + Reg alpha</th>\n",
       "      <td>0.35</td>\n",
       "      <td>1.29</td>\n",
       "      <td>0.75</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + alpha_*</th>\n",
       "      <td>0.39</td>\n",
       "      <td>1.26</td>\n",
       "      <td>0.75</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + alpha_1</th>\n",
       "      <td>0.65</td>\n",
       "      <td>1.59</td>\n",
       "      <td>0.92</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + alpha_s</th>\n",
       "      <td>0.35</td>\n",
       "      <td>1.29</td>\n",
       "      <td>0.75</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + opt_*</th>\n",
       "      <td>0.90</td>\n",
       "      <td>1.27</td>\n",
       "      <td>0.97</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + opt_s</th>\n",
       "      <td>0.61</td>\n",
       "      <td>1.21</td>\n",
       "      <td>0.88</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>LPA</th>\n",
       "      <td>NaN</td>\n",
       "      <td>0.00</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>LPA + WL</th>\n",
       "      <td>0.59</td>\n",
       "      <td>1.26</td>\n",
       "      <td>0.72</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Snorkel</th>\n",
       "      <td>0.58</td>\n",
       "      <td>1.46</td>\n",
       "      <td>0.78</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"10\" valign=\"top\">tennis</th>\n",
       "      <th>Dongle + LPA alpha</th>\n",
       "      <td>0.05</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.05</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + Reg alpha</th>\n",
       "      <td>0.05</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.05</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + alpha_*</th>\n",
       "      <td>0.05</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.05</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + alpha_1</th>\n",
       "      <td>0.08</td>\n",
       "      <td>0.04</td>\n",
       "      <td>0.08</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + alpha_s</th>\n",
       "      <td>0.05</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.05</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + opt_*</th>\n",
       "      <td>0.05</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.05</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + opt_s</th>\n",
       "      <td>0.05</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.05</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>LPA</th>\n",
       "      <td>NaN</td>\n",
       "      <td>0.00</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>LPA + WL</th>\n",
       "      <td>0.14</td>\n",
       "      <td>0.01</td>\n",
       "      <td>0.14</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Snorkel</th>\n",
       "      <td>0.10</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.10</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"10\" valign=\"top\">youtube</th>\n",
       "      <th>Dongle + LPA alpha</th>\n",
       "      <td>0.48</td>\n",
       "      <td>0.14</td>\n",
       "      <td>0.49</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + Reg alpha</th>\n",
       "      <td>0.48</td>\n",
       "      <td>0.14</td>\n",
       "      <td>0.49</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + alpha_*</th>\n",
       "      <td>0.22</td>\n",
       "      <td>0.12</td>\n",
       "      <td>0.23</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + alpha_1</th>\n",
       "      <td>1.00</td>\n",
       "      <td>0.43</td>\n",
       "      <td>0.73</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + alpha_s</th>\n",
       "      <td>0.48</td>\n",
       "      <td>0.14</td>\n",
       "      <td>0.49</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + opt_*</th>\n",
       "      <td>0.23</td>\n",
       "      <td>0.14</td>\n",
       "      <td>0.21</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + opt_s</th>\n",
       "      <td>0.21</td>\n",
       "      <td>0.14</td>\n",
       "      <td>0.21</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>LPA</th>\n",
       "      <td>NaN</td>\n",
       "      <td>0.00</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>LPA + WL</th>\n",
       "      <td>0.07</td>\n",
       "      <td>0.11</td>\n",
       "      <td>0.07</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Snorkel</th>\n",
       "      <td>0.24</td>\n",
       "      <td>0.12</td>\n",
       "      <td>0.24</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.58</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                               Not abstain Acc   Coverage   Acc  num_labels  \\\n",
       "Data name  Method                                                             \n",
       "basketball Dongle + LPA alpha             0.67       0.00  0.67         0.0   \n",
       "           Dongle + Reg alpha             0.67       0.00  0.67         0.0   \n",
       "           Dongle + alpha_*               0.67       0.00  0.67         0.0   \n",
       "           Dongle + alpha_1               0.59       0.40  0.51         0.0   \n",
       "           Dongle + alpha_s               0.67       0.00  0.67         0.0   \n",
       "           Dongle + opt_*                 0.63       0.00  0.63         0.0   \n",
       "           Dongle + opt_s                 0.61       0.00  0.61         0.0   \n",
       "           LPA                             NaN       0.00   NaN         0.0   \n",
       "           LPA + WL                       0.70       0.00  0.70         0.0   \n",
       "           Snorkel                        0.67       0.00  0.67         0.0   \n",
       "cdr        Dongle + LPA alpha             0.25       0.03  0.24         0.0   \n",
       "           Dongle + Reg alpha             0.25       0.03  0.24         0.0   \n",
       "           Dongle + alpha_*               0.20       0.04  0.19         0.0   \n",
       "           Dongle + alpha_1               0.30       0.16  0.27         0.0   \n",
       "           Dongle + alpha_s               0.25       0.03  0.24         0.0   \n",
       "           Dongle + opt_*                 0.28       0.06  0.28         0.0   \n",
       "           Dongle + opt_s                 0.39       0.06  0.38         0.0   \n",
       "           LPA                             NaN       0.00   NaN         0.0   \n",
       "           LPA + WL                       0.39       0.06  0.38         0.0   \n",
       "           Snorkel                        0.38       0.32  0.35         0.0   \n",
       "sms        Dongle + LPA alpha             0.35       1.29  0.75         0.0   \n",
       "           Dongle + Reg alpha             0.35       1.29  0.75         0.0   \n",
       "           Dongle + alpha_*               0.39       1.26  0.75         0.0   \n",
       "           Dongle + alpha_1               0.65       1.59  0.92         0.0   \n",
       "           Dongle + alpha_s               0.35       1.29  0.75         0.0   \n",
       "           Dongle + opt_*                 0.90       1.27  0.97         0.0   \n",
       "           Dongle + opt_s                 0.61       1.21  0.88         0.0   \n",
       "           LPA                             NaN       0.00   NaN         0.0   \n",
       "           LPA + WL                       0.59       1.26  0.72         0.0   \n",
       "           Snorkel                        0.58       1.46  0.78         0.0   \n",
       "tennis     Dongle + LPA alpha             0.05       0.00  0.05         0.0   \n",
       "           Dongle + Reg alpha             0.05       0.00  0.05         0.0   \n",
       "           Dongle + alpha_*               0.05       0.00  0.05         0.0   \n",
       "           Dongle + alpha_1               0.08       0.04  0.08         0.0   \n",
       "           Dongle + alpha_s               0.05       0.00  0.05         0.0   \n",
       "           Dongle + opt_*                 0.05       0.00  0.05         0.0   \n",
       "           Dongle + opt_s                 0.05       0.00  0.05         0.0   \n",
       "           LPA                             NaN       0.00   NaN         0.0   \n",
       "           LPA + WL                       0.14       0.01  0.14         0.0   \n",
       "           Snorkel                        0.10       0.00  0.10         0.0   \n",
       "youtube    Dongle + LPA alpha             0.48       0.14  0.49         0.0   \n",
       "           Dongle + Reg alpha             0.48       0.14  0.49         0.0   \n",
       "           Dongle + alpha_*               0.22       0.12  0.23         0.0   \n",
       "           Dongle + alpha_1               1.00       0.43  0.73         0.0   \n",
       "           Dongle + alpha_s               0.48       0.14  0.49         0.0   \n",
       "           Dongle + opt_*                 0.23       0.14  0.21         0.0   \n",
       "           Dongle + opt_s                 0.21       0.14  0.21         0.0   \n",
       "           LPA                             NaN       0.00   NaN         0.0   \n",
       "           LPA + WL                       0.07       0.11  0.07         0.0   \n",
       "           Snorkel                        0.24       0.12  0.24         0.0   \n",
       "\n",
       "                               lambda  seed  euc_th  \n",
       "Data name  Method                                    \n",
       "basketball Dongle + LPA alpha     0.0  1.58     0.0  \n",
       "           Dongle + Reg alpha     0.0  1.58     0.0  \n",
       "           Dongle + alpha_*       0.0  1.58     0.0  \n",
       "           Dongle + alpha_1       0.0  1.58     0.0  \n",
       "           Dongle + alpha_s       0.0  1.58     0.0  \n",
       "           Dongle + opt_*         0.0  1.58     0.0  \n",
       "           Dongle + opt_s         0.0  1.58     0.0  \n",
       "           LPA                    0.0  1.58     0.0  \n",
       "           LPA + WL               0.0  1.58     0.0  \n",
       "           Snorkel                0.0  1.58     0.0  \n",
       "cdr        Dongle + LPA alpha     0.0  1.58     0.0  \n",
       "           Dongle + Reg alpha     0.0  1.58     0.0  \n",
       "           Dongle + alpha_*       0.0  1.58     0.0  \n",
       "           Dongle + alpha_1       0.0  1.58     0.0  \n",
       "           Dongle + alpha_s       0.0  1.58     0.0  \n",
       "           Dongle + opt_*         0.0  1.58     0.0  \n",
       "           Dongle + opt_s         0.0  1.58     0.0  \n",
       "           LPA                    0.0  1.58     0.0  \n",
       "           LPA + WL               0.0  1.58     0.0  \n",
       "           Snorkel                0.0  1.58     0.0  \n",
       "sms        Dongle + LPA alpha     0.0  1.58     0.0  \n",
       "           Dongle + Reg alpha     0.0  1.58     0.0  \n",
       "           Dongle + alpha_*       0.0  1.58     0.0  \n",
       "           Dongle + alpha_1       0.0  1.58     0.0  \n",
       "           Dongle + alpha_s       0.0  1.58     0.0  \n",
       "           Dongle + opt_*         0.0  1.58     0.0  \n",
       "           Dongle + opt_s         0.0  1.58     0.0  \n",
       "           LPA                    0.0  1.58     0.0  \n",
       "           LPA + WL               0.0  1.58     0.0  \n",
       "           Snorkel                0.0  1.58     0.0  \n",
       "tennis     Dongle + LPA alpha     0.0  1.58     0.0  \n",
       "           Dongle + Reg alpha     0.0  1.58     0.0  \n",
       "           Dongle + alpha_*       0.0  1.58     0.0  \n",
       "           Dongle + alpha_1       0.0  1.58     0.0  \n",
       "           Dongle + alpha_s       0.0  1.58     0.0  \n",
       "           Dongle + opt_*         0.0  1.58     0.0  \n",
       "           Dongle + opt_s         0.0  1.58     0.0  \n",
       "           LPA                    0.0  1.58     0.0  \n",
       "           LPA + WL               0.0  1.58     0.0  \n",
       "           Snorkel                0.0  1.58     0.0  \n",
       "youtube    Dongle + LPA alpha     0.0  1.58     0.0  \n",
       "           Dongle + Reg alpha     0.0  1.58     0.0  \n",
       "           Dongle + alpha_*       0.0  1.58     0.0  \n",
       "           Dongle + alpha_1       0.0  1.58     0.0  \n",
       "           Dongle + alpha_s       0.0  1.58     0.0  \n",
       "           Dongle + opt_*         0.0  1.58     0.0  \n",
       "           Dongle + opt_s         0.0  1.58     0.0  \n",
       "           LPA                    0.0  1.58     0.0  \n",
       "           LPA + WL               0.0  1.58     0.0  \n",
       "           Snorkel                0.0  1.58     0.0  "
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df.groupby(['Data name','Method']).std().round(2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 200/200 [00:00<00:00, 1897.59epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 2085.74epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 2074.15epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 2040.79epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 1919.63epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 362.52epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 389.26epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 388.89epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 395.25epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 368.98epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 1982.63epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 1740.54epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 1810.38epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 1760.94epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 1774.87epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 1325.50epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 1204.87epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 1305.75epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 1530.19epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 1438.67epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 1816.28epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 1859.69epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 1642.34epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 1704.27epoch/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 1847.12epoch/s]\n"
     ]
    }
   ],
   "source": [
    "results_labels = [] #\n",
    "for data_name in ['youtube','sms','basketball','cdr','tennis']:\n",
    "    for seed in [1,2,3,4,5]:\n",
    "        results_labels += run_experiment(data_name, num_labels = 100, lamb = 1, seed = seed, euc_th = 10, wl_th = 10, thresh = 5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_labels = pd.DataFrame(results_labels, columns = ['Not abstain Acc',' Coverage','Acc','Method','Data name', 'num_labels','lambda','seed','euc_th'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th>Data name</th>\n",
       "      <th>basketball</th>\n",
       "      <th>cdr</th>\n",
       "      <th>sms</th>\n",
       "      <th>tennis</th>\n",
       "      <th>youtube</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Method</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>Dongle + LPA alpha</th>\n",
       "      <td>71.56</td>\n",
       "      <td>73.48</td>\n",
       "      <td>83.45</td>\n",
       "      <td>86.97</td>\n",
       "      <td>85.66</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + Reg alpha</th>\n",
       "      <td>80.37</td>\n",
       "      <td>67.49</td>\n",
       "      <td>83.58</td>\n",
       "      <td>87.42</td>\n",
       "      <td>88.88</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + alpha_*</th>\n",
       "      <td>71.55</td>\n",
       "      <td>73.81</td>\n",
       "      <td>83.63</td>\n",
       "      <td>86.99</td>\n",
       "      <td>88.81</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + alpha_1</th>\n",
       "      <td>74.82</td>\n",
       "      <td>62.06</td>\n",
       "      <td>82.24</td>\n",
       "      <td>86.03</td>\n",
       "      <td>82.68</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + alpha_s</th>\n",
       "      <td>71.56</td>\n",
       "      <td>73.48</td>\n",
       "      <td>83.45</td>\n",
       "      <td>86.97</td>\n",
       "      <td>85.66</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + opt_*</th>\n",
       "      <td>73.96</td>\n",
       "      <td>70.20</td>\n",
       "      <td>83.29</td>\n",
       "      <td>86.98</td>\n",
       "      <td>87.53</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + opt_s</th>\n",
       "      <td>73.76</td>\n",
       "      <td>68.97</td>\n",
       "      <td>83.05</td>\n",
       "      <td>86.98</td>\n",
       "      <td>76.89</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>LPA</th>\n",
       "      <td>61.03</td>\n",
       "      <td>55.46</td>\n",
       "      <td>76.04</td>\n",
       "      <td>64.71</td>\n",
       "      <td>62.65</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>LPA + WL</th>\n",
       "      <td>73.63</td>\n",
       "      <td>69.15</td>\n",
       "      <td>83.06</td>\n",
       "      <td>86.47</td>\n",
       "      <td>77.58</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Snorkel</th>\n",
       "      <td>69.42</td>\n",
       "      <td>69.10</td>\n",
       "      <td>70.26</td>\n",
       "      <td>86.06</td>\n",
       "      <td>76.17</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "Data name           basketball    cdr    sms  tennis  youtube\n",
       "Method                                                       \n",
       "Dongle + LPA alpha       71.56  73.48  83.45   86.97    85.66\n",
       "Dongle + Reg alpha       80.37  67.49  83.58   87.42    88.88\n",
       "Dongle + alpha_*         71.55  73.81  83.63   86.99    88.81\n",
       "Dongle + alpha_1         74.82  62.06  82.24   86.03    82.68\n",
       "Dongle + alpha_s         71.56  73.48  83.45   86.97    85.66\n",
       "Dongle + opt_*           73.96  70.20  83.29   86.98    87.53\n",
       "Dongle + opt_s           73.76  68.97  83.05   86.98    76.89\n",
       "LPA                      61.03  55.46  76.04   64.71    62.65\n",
       "LPA + WL                 73.63  69.15  83.06   86.47    77.58\n",
       "Snorkel                  69.42  69.10  70.26   86.06    76.17"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_labels.groupby(['Data name','Method']).mean().round(2).loc[:,'Acc'].unstack().transpose()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th>Data name</th>\n",
       "      <th>basketball</th>\n",
       "      <th>cdr</th>\n",
       "      <th>sms</th>\n",
       "      <th>tennis</th>\n",
       "      <th>youtube</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Method</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>Dongle + LPA alpha</th>\n",
       "      <td>1.49</td>\n",
       "      <td>0.36</td>\n",
       "      <td>0.65</td>\n",
       "      <td>0.09</td>\n",
       "      <td>0.59</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + Reg alpha</th>\n",
       "      <td>0.68</td>\n",
       "      <td>1.81</td>\n",
       "      <td>0.67</td>\n",
       "      <td>0.23</td>\n",
       "      <td>0.68</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + alpha_*</th>\n",
       "      <td>1.48</td>\n",
       "      <td>0.29</td>\n",
       "      <td>0.66</td>\n",
       "      <td>0.10</td>\n",
       "      <td>0.35</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + alpha_1</th>\n",
       "      <td>0.54</td>\n",
       "      <td>1.50</td>\n",
       "      <td>0.59</td>\n",
       "      <td>1.36</td>\n",
       "      <td>0.28</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + alpha_s</th>\n",
       "      <td>1.49</td>\n",
       "      <td>0.36</td>\n",
       "      <td>0.65</td>\n",
       "      <td>0.09</td>\n",
       "      <td>0.59</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + opt_*</th>\n",
       "      <td>0.68</td>\n",
       "      <td>0.54</td>\n",
       "      <td>0.64</td>\n",
       "      <td>0.13</td>\n",
       "      <td>0.29</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dongle + opt_s</th>\n",
       "      <td>0.64</td>\n",
       "      <td>0.27</td>\n",
       "      <td>0.61</td>\n",
       "      <td>0.12</td>\n",
       "      <td>0.44</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>LPA</th>\n",
       "      <td>0.25</td>\n",
       "      <td>1.32</td>\n",
       "      <td>0.58</td>\n",
       "      <td>2.10</td>\n",
       "      <td>0.27</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>LPA + WL</th>\n",
       "      <td>0.86</td>\n",
       "      <td>0.50</td>\n",
       "      <td>0.56</td>\n",
       "      <td>0.20</td>\n",
       "      <td>0.55</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Snorkel</th>\n",
       "      <td>0.65</td>\n",
       "      <td>0.39</td>\n",
       "      <td>0.72</td>\n",
       "      <td>0.14</td>\n",
       "      <td>0.20</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "Data name           basketball   cdr   sms  tennis  youtube\n",
       "Method                                                     \n",
       "Dongle + LPA alpha        1.49  0.36  0.65    0.09     0.59\n",
       "Dongle + Reg alpha        0.68  1.81  0.67    0.23     0.68\n",
       "Dongle + alpha_*          1.48  0.29  0.66    0.10     0.35\n",
       "Dongle + alpha_1          0.54  1.50  0.59    1.36     0.28\n",
       "Dongle + alpha_s          1.49  0.36  0.65    0.09     0.59\n",
       "Dongle + opt_*            0.68  0.54  0.64    0.13     0.29\n",
       "Dongle + opt_s            0.64  0.27  0.61    0.12     0.44\n",
       "LPA                       0.25  1.32  0.58    2.10     0.27\n",
       "LPA + WL                  0.86  0.50  0.56    0.20     0.55\n",
       "Snorkel                   0.65  0.39  0.72    0.14     0.20"
      ]
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_labels.groupby(['Data name','Method']).std().round(2).loc[:,'Acc'].unstack().transpose()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "interpreter": {
   "hash": "39ca8058bc909080e5cc8b58cc5496375c0141f717bb9f1bcad8ab5053b7d3f8"
  },
  "kernelspec": {
   "display_name": "Python 3.9.7 ('nn-pruning')",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.7"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
