{
 "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",
    "\n",
    "from sklearn.kernel_ridge import KernelRidge\n",
    "\n",
    "from sklearn.metrics import pairwise_distances\n",
    "from sklearn.neighbors import kneighbors_graph\n",
    "from utils import  get_transition_mat\n",
    "\n",
    "import networkx as nx\n",
    "import matplotlib.pyplot as plt\n",
    "from extension import alpha_from_LPA, LPA_with_dongle_with_labeled_inds_custom_alpha, LPA_with_dongle_with_labeled_inds, Adaboost_weight_norm, Adaboost_weight\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 200/200 [00:04<00:00, 40.10epoch/s]\n"
     ]
    }
   ],
   "source": [
    "X, L, labels, W_x, S_x, W_x_large, S_x_large = load_data('youtube', 10, 10, 1)\n",
    "# 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)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "num_labels = 100\n",
    "labeled_inds = np.random.choice(range(W_x.shape[0]), size= num_labels, replace=False)\n",
    "unlabeled_inds = np.array(list(set(range(X.shape[0])) - set(labeled_inds)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "def Generate_data(X,L, labels, labeled_inds, i):\n",
    "    idx = (L[labeled_inds,i]!= -1) # idx for points that the weak labeler i make a prediciton\n",
    "    X_train = X[labeled_inds][idx]\n",
    "    y_train = (labels[labeled_inds][idx] == L[labeled_inds,i][idx]).long()\n",
    "\n",
    "    # Generate test data\n",
    "    idx_test = (L[unlabeled_inds,i] != -1)\n",
    "    X_test = X[unlabeled_inds][idx_test]\n",
    "    y_test = (labels[unlabeled_inds][idx_test] == L[unlabeled_inds,i][idx_test]).long()\n",
    "\n",
    "    return X_train, y_train, X_test, y_test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 tensor(0.8430)\n",
      "1 tensor(0.9788)\n",
      "2 tensor(0.7412)\n",
      "3 tensor(0.9821)\n",
      "4 tensor(0.7746)\n",
      "5 tensor(1.)\n",
      "6 tensor(0.8526)\n",
      "7 tensor(0.7476)\n",
      "8 tensor(0.8148)\n",
      "9 tensor(0.7268)\n"
     ]
    }
   ],
   "source": [
    "for i in range(L.shape[1]):\n",
    "    X_train, y_train, X_test, y_test = Generate_data(X,L, labels, labeled_inds, i)\n",
    "    krr = KernelRidge(alpha=1, kernel = 'polynomial', gamma = 1)\n",
    "    if X_train.shape[0] > 0:\n",
    "        krr.fit(X_train, y_train)\n",
    "        pred = torch.tensor((krr.predict(X_test) > 0.5).astype(int))\n",
    "        print(i,(pred == y_test).float().mean())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([ 85.85208893,  98.46939087,  93.8888855 ,  98.2857132 ,\n",
       "        75.21367645, 100.        ,  68.71657562,  69.46902466,\n",
       "        83.60655975,  59.25297165])"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "L_acc_oracle"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([ 14.,  46.,  78., 109., 144.,  81.,  41.,  19.,  14.,   3.]),\n",
       " array([-0.54990748, -0.28786956, -0.02583163,  0.23620629,  0.49824421,\n",
       "         0.76028214,  1.02232006,  1.28435798,  1.54639591,  1.80843383,\n",
       "         2.07047175]),\n",
       " <BarContainer object of 10 artists>)"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(krr.predict(X_test))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# GNN"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Using backend: pytorch\n"
     ]
    }
   ],
   "source": [
    "import dgl\n",
    "from gnn import GCN, train, eval, adjmat_to_graph_wl"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "def experiment_GCN(data_name, euc_th, wl_th, num_labels):\n",
    "\n",
    "    X, L, labels, W_x, S_x, W_x_large, S_x_large = load_data(data_name = data_name, euc_th = euc_th, wl_th = wl_th, seed = 1)\n",
    "    # Random label\n",
    "    np.random.seed(1)\n",
    "    labeled_inds = np.random.choice(range(len(X)), size=num_labels, replace=False)\n",
    "    result = []\n",
    "    for i in range(L.shape[1]):\n",
    "        g = adjmat_to_graph_wl(W_x, X, L, labels, labeled_inds,i)\n",
    "        result.append(100*eval(g).item()) \n",
    "    return result"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[86.48648858070374, 98.37837815284729, 93.20987462997437, 98.22485446929932, 70.79645991325378, 100.0, 88.95184397697449, 71.49532437324524, 71.9298243522644, 81.50182962417603]\n"
     ]
    }
   ],
   "source": [
    "result = experiment_GCN('youtube', euc_th = 10, wl_th = 10, num_labels = 100)\n",
    "print(result)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Exemplar idea + Label propagation"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "If x is close to x' that is wrong in the training dataset then, we also assume that x is also wrong"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 200/200 [00:00<00:00, 1995.95epoch/s]\n"
     ]
    }
   ],
   "source": [
    "X, L, labels, W_x, S_x, W_x_large, S_x_large = load_data('youtube', 10, 10, 1)\n",
    "# continue as uaual\n",
    "L_acc, snorkel_pred = Snorkel(L)\n",
    "L_acc_oracle, Coverage = CheckLFs_Acc(L, labels, show = False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of points with prediction 374\n",
      "Accuracy 0.6871657754010695\n"
     ]
    }
   ],
   "source": [
    "i = 6\n",
    "idx = (L[:,i] !=-1)\n",
    "print('Number of points with prediction {}'.format(idx.sum()))\n",
    "correct_nodes = (labels[idx] == L[idx,i]).float().numpy()\n",
    "print('Accuracy {}'.format(correct_nodes.sum()/correct_nodes.shape[0]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "thresh = 5\n",
    "N = X[idx].shape[0]\n",
    "euc_mat = pairwise_distances(X[idx], Y = None, metric='euclidean') \n",
    "threshold = np.quantile(euc_mat, thresh/N)\n",
    "A= get_transition_mat(euc_mat, threshold)\n",
    "\n",
    "# A = kneighbors_graph(X[idx], 5, mode='connectivity', include_self=False).toarray()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 600x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "G= nx.from_numpy_array(A)\n",
    "G.remove_edges_from(nx.selfloop_edges(G))\n",
    "pos = nx.spring_layout(G, k=2*1/np.sqrt(len(G.nodes())), iterations=40)\n",
    "\n",
    "plt.figure(dpi = 100)\n",
    "nx.draw(G,node_color = correct_nodes, pos = pos, node_size = 50, cmap=plt.cm.Set1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "num_labels = 100\n",
    "labeled_inds = np.random.choice(range(W_x.shape[0]), size= num_labels, replace=False)\n",
    "unlabeled_inds = np.array(list(set(range(X.shape[0])) - set(labeled_inds)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "X_train,y_train,X_test, y_test = Generate_data(X,L, labels, labeled_inds, i)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([1, 1, 1, 0, 0, 1, 0, 1, 0, 1, 1, 1, 0, 1, 1, 0, 1, 1, 1, 1, 1, 1])"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "y_train"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([1600, 1197,  431, 1241, 1238,  551, 1305, 1054, 1581, 1167,  379,\n",
       "       1531, 1595, 1009,  444, 1551,  914,  360, 1036,  699,  505,  140,\n",
       "        666,    1,  542,  971,  190,  466,  503,  582,  404,  989,  118,\n",
       "       1327,  516,  468, 1112,  924,  795, 1013, 1111,  501,  257,  407,\n",
       "       1358, 1599, 1371,   80,    8, 1522, 1103,  447,  993,  920,  469,\n",
       "        442,  750,  893, 1146,  171,  392,  279,  101,   30, 1523,  170,\n",
       "       1441,  128, 1401,  647,  916,  220,  757,    3,   16,  852, 1178,\n",
       "        530, 1048, 1345,  876,  164,  805,  895,  322,  457,  242, 1073,\n",
       "       1037, 1208,  246,  299,  573,  623,  792,  990, 1025, 1601, 1223,\n",
       "        739])"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "labeled_inds"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "new_idx_i = np.array([i  for i in range(idx.shape[0]) if idx[i] == True] )\n",
    "labeled_inds_in_i = [i in labeled_inds for i in new_idx_i]\n",
    "labeled_inds_i = [j for j in range(new_idx_i.shape[0]) if labeled_inds_in_i[j] == True]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([  10,   14,   21,   27,   31,   33,   49,   54,   59,   60,   70,\n",
       "         73,   75,   78,   82,   83,   88,   91,   95,   96,   97,  100,\n",
       "        102,  109,  117,  120,  122,  123,  124,  128,  136,  139,  140,\n",
       "        143,  145,  149,  155,  159,  165,  167,  171,  178,  179,  180,\n",
       "        183,  195,  196,  197,  199,  204,  208,  218,  238,  239,  240,\n",
       "        241,  247,  253,  262,  266,  269,  281,  284,  291,  296,  298,\n",
       "        299,  304,  318,  319,  321,  322,  325,  327,  334,  337,  341,\n",
       "        347,  350,  351,  355,  363,  370,  375,  376,  377,  399,  400,\n",
       "        401,  409,  410,  418,  419,  425,  428,  431,  436,  438,  440,\n",
       "        444,  447,  448,  450,  451,  452,  454,  457,  459,  461,  463,\n",
       "        464,  473,  476,  485,  497,  500,  505,  510,  511,  527,  528,\n",
       "        531,  537,  543,  549,  555,  556,  572,  574,  585,  586,  591,\n",
       "        593,  595,  596,  600,  601,  604,  609,  611,  617,  619,  622,\n",
       "        625,  627,  634,  637,  640,  641,  644,  648,  649,  662,  664,\n",
       "        665,  666,  673,  674,  680,  688,  691,  692,  696,  697,  698,\n",
       "        702,  703,  707,  709,  725,  733,  737,  745,  756,  771,  773,\n",
       "        778,  785,  791,  794,  795,  799,  801,  805,  808,  811,  814,\n",
       "        815,  816,  830,  834,  835,  836,  838,  844,  846,  851,  858,\n",
       "        862,  886,  888,  890,  894,  896,  897,  898,  899,  905,  920,\n",
       "        928,  934,  936,  937,  938,  943,  944,  945,  946,  956,  958,\n",
       "        960,  964,  965,  972,  974, 1001, 1009, 1020, 1022, 1029, 1031,\n",
       "       1032, 1033, 1039, 1041, 1045, 1046, 1051, 1052, 1054, 1056, 1060,\n",
       "       1063, 1067, 1070, 1077, 1079, 1081, 1083, 1084, 1087, 1088, 1089,\n",
       "       1090, 1091, 1098, 1106, 1107, 1115, 1120, 1122, 1128, 1135, 1138,\n",
       "       1140, 1141, 1143, 1146, 1148, 1149, 1151, 1157, 1159, 1168, 1169,\n",
       "       1170, 1171, 1173, 1182, 1187, 1192, 1221, 1223, 1236, 1237, 1240,\n",
       "       1241, 1249, 1254, 1258, 1259, 1262, 1268, 1273, 1282, 1287, 1290,\n",
       "       1293, 1295, 1306, 1308, 1309, 1313, 1317, 1318, 1323, 1340, 1347,\n",
       "       1350, 1351, 1352, 1353, 1354, 1358, 1360, 1366, 1376, 1383, 1385,\n",
       "       1387, 1407, 1418, 1423, 1425, 1426, 1430, 1432, 1436, 1441, 1442,\n",
       "       1445, 1446, 1451, 1460, 1463, 1470, 1474, 1478, 1479, 1482, 1484,\n",
       "       1485, 1487, 1488, 1489, 1492, 1495, 1498, 1499, 1504, 1509, 1511,\n",
       "       1516, 1521, 1523, 1527, 1539, 1540, 1541, 1543, 1549, 1553, 1554,\n",
       "       1565, 1567, 1569, 1574, 1575, 1579, 1582, 1585, 1588, 1589, 1596])"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "new_idx_i"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "labels_i = (L[idx,i] == labels[idx]).long()\n",
    "L_acc_i = L_acc[i]* np.ones((X[idx].shape[0]))/100\n",
    "L_acc_i = L_acc_oracle[i]* np.ones((X[idx].shape[0]))/100\n",
    "base_acc_i = np.stack((1- L_acc_i, L_acc_i), axis = 1)\n",
    "alpha_i = PropagationHard(base_acc_i, A, labels = labels_i , labeled_inds = labeled_inds_i, alpha = 1)[:,1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.collections.PathCollection at 0x7fb4ebdfda30>"
      ]
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.scatter(x = alpha_i, y = labels_i)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(0.7086)"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "(torch.tensor(alpha_i > 0.5) == labels_i).float().mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(0.2736, dtype=torch.float64)"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "((1-labels_i)* alpha_i).sum()/alpha_i.sum()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([ 22.,   0.,  14.,  12., 203.,   5.,   8.,  33.,  21.,  56.]),\n",
       " array([0.        , 0.07081006, 0.14162012, 0.21243019, 0.28324025,\n",
       "        0.35405031, 0.42486037, 0.49567043, 0.56648049, 0.63729056,\n",
       "        0.70810062]),\n",
       " <BarContainer object of 10 artists>)"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(np.abs(labels_i - alpha_i).numpy())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(0.3839, dtype=torch.float64)"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.abs(labels_i - alpha_i).mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(0.4055, dtype=torch.float64)"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "L_acc_i[labeled_inds_i] = labels_i[labeled_inds_i]\n",
    "np.abs(labels_i - L_acc_i).mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [],
   "source": [
    "Alpha = np.zeros_like(L).astype(float)\n",
    "Alpha[idx,i] = alpha_i"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0.68716576, 0.81599321, 0.68716576, 0.68716576, 0.5868255 ,\n",
       "       0.68716576, 0.68716576, 0.68716576, 0.68716576, 0.68036192,\n",
       "       0.69790556, 0.68716576, 0.68716576, 0.68716576, 0.68716576,\n",
       "       0.77633395, 0.68716576, 0.68716576, 0.68716576, 0.68716576,\n",
       "       0.4686822 , 0.68716576, 0.68716576, 0.68769761, 0.68716576,\n",
       "       0.68716576, 0.68716576, 0.63497096, 0.68716576, 1.        ,\n",
       "       0.68716576, 0.68716576, 0.        , 0.68716576, 0.59092075,\n",
       "       0.69600101, 0.68827039, 0.68716576, 0.50705032, 0.68716576,\n",
       "       1.        , 0.7058785 , 0.68716576, 0.53050731, 0.68716576,\n",
       "       0.68716576, 0.48542264, 0.68716576, 0.68716576, 0.38159333,\n",
       "       0.68716576, 0.68716576, 0.68716576, 0.68716576, 0.68716576,\n",
       "       0.68716576, 0.68716576, 0.68716576, 0.70828639, 0.68716576,\n",
       "       0.68716576, 0.68716576, 0.50204676, 0.68716576, 0.69170701,\n",
       "       0.68716576, 1.        , 0.68716576, 0.68716576, 0.68716576,\n",
       "       0.54593033, 1.        , 0.68716576, 0.68716576, 0.65114319,\n",
       "       0.53276978, 0.68716576, 0.62611855, 0.68716576, 0.70288687,\n",
       "       0.68716576, 0.68716576, 0.58623392, 0.81599321, 0.6876567 ,\n",
       "       0.68716576, 0.51552799, 0.46793242, 0.69683127, 0.68716576,\n",
       "       0.7069021 , 0.68716576, 0.68716576, 0.59312934, 0.54572048,\n",
       "       1.        , 0.68716576, 0.68716576, 0.69404845, 0.        ,\n",
       "       1.        , 0.55354355, 0.68716576, 0.56265533, 0.69140515,\n",
       "       0.68716576, 1.        , 0.68716576, 0.68716576, 0.56081319,\n",
       "       0.68716576, 0.68221785, 0.68716576, 0.52224419, 0.68999202,\n",
       "       0.68221785, 1.        , 0.59216999, 0.68716576, 0.70913124,\n",
       "       0.68716576, 0.68716576, 0.55233757, 0.68716576, 0.68716576,\n",
       "       0.68716576, 0.68716576, 0.69600101, 0.68716576, 0.68716576,\n",
       "       0.68716576, 0.70072378, 0.59077715, 0.68716576, 0.68937861,\n",
       "       0.61618816, 0.65623381, 0.68716576, 0.59083443, 0.68716576,\n",
       "       0.74241923, 0.68716576, 0.69111961, 0.72325505, 0.82249261,\n",
       "       0.68627595, 0.74241923, 0.68716576, 0.68716576, 0.65223205,\n",
       "       0.72855943, 0.82347246, 0.68716576, 0.48185221, 0.70231294,\n",
       "       1.        , 0.43723139, 0.54676148, 0.68716576, 0.40905738,\n",
       "       0.68716576, 0.68716576, 0.69197041, 0.69683127, 0.75934434,\n",
       "       0.49820858, 0.68716576, 0.54989303, 0.70275081, 0.79767271,\n",
       "       0.52116038, 0.68716576, 0.73097571, 0.68716576, 0.69401591,\n",
       "       0.68716576, 0.68716576, 0.41599298, 0.75279719, 0.68716576,\n",
       "       0.        , 0.68716576, 0.59863591, 1.        , 0.55066356,\n",
       "       0.68716576, 0.68716576, 0.68716576, 0.69111961, 0.66106836,\n",
       "       0.70791623, 0.68190417, 0.69772607, 0.68716576, 0.68716576,\n",
       "       0.69507346, 0.54555243, 0.84358288, 0.68526815, 0.68769761,\n",
       "       0.58165985, 0.68716576, 0.68716576, 0.68716576, 0.59620238,\n",
       "       0.69140515, 0.68716576, 0.70802577, 1.        , 0.68716576,\n",
       "       0.68716576, 0.68716576, 0.68716576, 0.68716576, 0.54756075,\n",
       "       0.68716576, 0.60815128, 0.68716576, 0.53276978, 0.68716576,\n",
       "       0.56608315, 0.68716576, 0.68538615, 0.68716576, 0.68716576,\n",
       "       0.68716576, 0.        , 0.68716576, 0.68716576, 0.54623601,\n",
       "       0.59261805, 0.70810062, 0.68716576, 0.79876567, 0.68716576,\n",
       "       0.68716576, 0.55464127, 0.56130972, 0.68716576, 1.        ,\n",
       "       0.81675186, 0.68716576, 0.38260493, 0.68716576, 0.84358288,\n",
       "       0.68716576, 0.68716576, 0.68716576, 0.68716576, 0.68716576,\n",
       "       0.65922931, 0.68769761, 0.5428953 , 0.68353661, 0.65114319,\n",
       "       0.68716576, 0.68716576, 0.68716576, 0.68716576, 0.54916322,\n",
       "       0.68999202, 0.54267554, 0.68716576, 0.68716576, 0.68716576,\n",
       "       0.63129287, 0.68716576, 0.        , 0.84358288, 0.68716576,\n",
       "       0.68716576, 0.70896535, 0.71161807, 0.68716576, 0.68716576,\n",
       "       0.37350052, 0.55327221, 0.68716576, 0.55619308, 0.68337055,\n",
       "       0.73496886, 0.68716576, 1.        , 0.69491075, 0.68716576,\n",
       "       0.68716576, 1.        , 0.68716576, 0.68716576, 0.68716576,\n",
       "       0.54529392, 0.68716576, 0.68716576, 0.68716576, 0.68716576,\n",
       "       0.54623601, 0.72665226, 0.68716576, 0.68716576, 0.54847369,\n",
       "       0.68716576, 0.68716576, 0.84358288, 0.68716576, 0.68716576,\n",
       "       0.84358288, 0.68716576, 0.68716576, 0.68716576, 0.68716576,\n",
       "       0.55190491, 0.5419817 , 0.68716576, 1.        , 0.68716576,\n",
       "       0.68716576, 0.68948725, 0.68716576, 0.53378974, 0.68716576,\n",
       "       0.68716576, 0.68716576, 0.68716576, 0.68716576, 0.64488703,\n",
       "       0.38159333, 0.68716576, 0.60773111, 0.        , 0.72758134,\n",
       "       0.68548943, 0.68716576, 0.69048504, 0.68716576, 0.68716576,\n",
       "       0.68716576, 0.68716576, 0.68716576, 0.68716576, 0.68716576,\n",
       "       0.73940205, 0.68716576, 0.58417041, 0.82863242, 0.68716576,\n",
       "       0.68716576, 0.68716576, 0.68716576, 0.68716576, 0.68716576,\n",
       "       0.68716576, 0.57297134, 0.68716576, 0.81675186, 1.        ,\n",
       "       0.68716576, 0.69360943, 0.68716576, 0.68716576, 0.69600101,\n",
       "       0.68716576, 0.69048504, 0.4367636 , 0.68741123, 0.68716576,\n",
       "       0.68716576, 0.68943638, 0.69866338, 0.68716576, 0.68716576,\n",
       "       0.38159333, 0.68716576, 0.68716576, 0.68526815])"
      ]
     },
     "execution_count": 29,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "Alpha[idx,i]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 200/200 [00:00<00:00, 1575.03epoch/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "LPA weight\n",
      "0.2733881672010087\n",
      "74.40588134723885\n",
      "Snorkel + L\n",
      "0.3736801935518666\n",
      "70.78133014190459\n"
     ]
    }
   ],
   "source": [
    "# Examplar idea\n",
    "\n",
    "X, L, labels, W_x, S_x, W_x_large, S_x_large = load_data('cdr', 10, 10, 1)\n",
    "L_acc, snorkel_pred = Snorkel(L)\n",
    "# L_acc_oracle, Coverage = CheckLFs_Acc(L, labels, show = False)\n",
    "\n",
    "\n",
    "# Random label points\n",
    "num_labels = 100\n",
    "labeled_inds = np.random.choice(range(W_x.shape[0]), size= num_labels, replace=False)\n",
    "unlabeled_inds = np.array(list(set(range(X.shape[0])) - set(labeled_inds)))\n",
    "\n",
    "# Update snorkel\n",
    "snorkel_pred[labeled_inds,:] = np.stack((1-labels[labeled_inds], labels[labeled_inds]), axis = 1)\n",
    "\n",
    "Alpha = np.zeros_like(L).astype(float)\n",
    "\n",
    "for i in range(L.shape[1]):\n",
    "    idx = (L[:,i] !=-1)\n",
    "\n",
    "    # Construct a euclidean graph\n",
    "    thresh = 5\n",
    "    try:\n",
    "        N = X[idx].shape[0]\n",
    "        if N >= thresh + 1:\n",
    "            euc_mat = pairwise_distances(X[idx], Y = None, metric='euclidean') \n",
    "            threshold = np.quantile(euc_mat, thresh/N)\n",
    "            A= get_transition_mat(euc_mat, threshold)\n",
    "\n",
    "            idx_i = np.array([i  for i in range(idx.shape[0]) if idx[i] == True] )\n",
    "            labeled_inds_i_array = [i in labeled_inds for i in idx_i]\n",
    "            labeled_inds_i = [j for j in range(N) if labeled_inds_i_array[j] == True]\n",
    "            # LPA\n",
    "            labels_i = (L[idx,i] == labels[idx]).long()\n",
    "            L_acc_i = L_acc[i]* np.ones((X[idx].shape[0]))/100\n",
    "            L_acc_i[labeled_inds_i] = labels_i[labeled_inds_i]\n",
    "            base_acc_i = np.stack((1- L_acc_i, L_acc_i), axis = 1)\n",
    "            alpha_i = PropagationHard(base_acc_i, A, labels = labels_i , labeled_inds = labeled_inds_i, alpha = 1)[:,1]\n",
    "            Alpha[idx,i] = alpha_i\n",
    "        else:\n",
    "            L_acc_i = L_acc[i]* np.ones((X[idx].shape[0]))/100\n",
    "            Alpha[idx,i] = L_acc_i\n",
    "\n",
    "    except:\n",
    "        L_acc_i = L_acc[i]* np.ones((X[idx].shape[0]))/100\n",
    "        Alpha[idx,i] = L_acc_i\n",
    "\n",
    "# Eval\n",
    "not_abs_idx = (L.sum(axis = 1) != -L.shape[1])\n",
    "pred = np.nan_to_num((Alpha * L.numpy()).sum(axis = 1)/(Alpha.sum(axis = 1)))\n",
    "\n",
    "\n",
    "print('LPA weight')\n",
    "print(np.abs((labels - pred))[not_abs_idx].mean().item())\n",
    "print(((pred > 0.5) == labels.numpy()).astype(float)[not_abs_idx].mean()*100)\n",
    "\n",
    "print('Snorkel + L')\n",
    "print(np.abs(labels - snorkel_pred[:,1])[not_abs_idx].mean().item())\n",
    "print(((snorkel_pred[:,1] > 0.5) == labels.numpy())[not_abs_idx].mean()*100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Examplar idea\n",
    "def LPA_alpha(data_name):\n",
    "    X, L, labels, W_x, S_x, W_x_large, S_x_large = load_data(data_name, 10, 10, 1)\n",
    "    L_acc, snorkel_pred = Snorkel(L)\n",
    "    # L_acc_oracle, Coverage = CheckLFs_Acc(L, labels, show = False)\n",
    "\n",
    "\n",
    "    # Random label points\n",
    "    num_labels = 100\n",
    "    labeled_inds = np.random.choice(range(W_x.shape[0]), size= num_labels, replace=False)\n",
    "    unlabeled_inds = np.array(list(set(range(X.shape[0])) - set(labeled_inds)))\n",
    "\n",
    "    # Update snorkel\n",
    "    snorkel_pred[labeled_inds,:] = np.stack((1-labels[labeled_inds], labels[labeled_inds]), axis = 1)\n",
    "\n",
    "    Alpha = np.zeros_like(L).astype(float)\n",
    "\n",
    "    for i in range(L.shape[1]):\n",
    "        idx = (L[:,i] !=-1)\n",
    "\n",
    "        # Construct a euclidean graph\n",
    "        thresh = 5\n",
    "        try:\n",
    "            N = X[idx].shape[0]\n",
    "            if N >= thresh + 1:\n",
    "                euc_mat = pairwise_distances(X[idx], Y = None, metric='euclidean') \n",
    "                threshold = np.quantile(euc_mat, thresh/N)\n",
    "                A= get_transition_mat(euc_mat, threshold)\n",
    "\n",
    "                idx_i = np.array([i  for i in range(idx.shape[0]) if idx[i] == True] )\n",
    "                labeled_inds_i_array = [i in labeled_inds for i in idx_i]\n",
    "                labeled_inds_i = [j for j in range(N) if labeled_inds_i_array[j] == True]\n",
    "                # LPA\n",
    "                labels_i = (L[idx,i] == labels[idx]).long()\n",
    "                L_acc_i = L_acc[i]* np.ones((X[idx].shape[0]))/100\n",
    "                L_acc_i[labeled_inds_i] = labels_i[labeled_inds_i]\n",
    "                base_acc_i = np.stack((1- L_acc_i, L_acc_i), axis = 1)\n",
    "                alpha_i = PropagationHard(base_acc_i, A, labels = labels_i , labeled_inds = labeled_inds_i, alpha = 1)[:,1]\n",
    "                Alpha[idx,i] = alpha_i\n",
    "            else:\n",
    "                L_acc_i = L_acc[i]* np.ones((X[idx].shape[0]))/100\n",
    "                Alpha[idx,i] = L_acc_i\n",
    "\n",
    "        except:\n",
    "            L_acc_i = L_acc[i]* np.ones((X[idx].shape[0]))/100\n",
    "            Alpha[idx,i] = L_acc_i\n",
    "\n",
    "    # Eval\n",
    "    not_abs_idx = (L.sum(axis = 1) != -L.shape[1])\n",
    "    pred = np.nan_to_num((Alpha * L.numpy()).sum(axis = 1)/(Alpha.sum(axis = 1)))\n",
    "\n",
    "\n",
    "    print('LPA weight')\n",
    "    print(np.abs((labels - pred))[not_abs_idx].mean().item())\n",
    "    print(((pred > 0.5) == labels.numpy()).astype(float)[not_abs_idx].mean()*100)\n",
    "\n",
    "    print('Snorkel + L')\n",
    "    print(np.abs(labels - snorkel_pred[:,1])[not_abs_idx].mean().item())\n",
    "    print(((snorkel_pred[:,1] > 0.5) == labels.numpy())[not_abs_idx].mean()*100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "basketball\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 200/200 [00:00<00:00, 2039.65epoch/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "LPA weight\n",
      "0.3558977629079888\n",
      "69.62524654832347\n",
      "Snorkel + L\n",
      "0.42557115777741533\n",
      "70.01972386587771\n",
      "cdr\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 200/200 [00:00<00:00, 1508.18epoch/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "LPA weight\n",
      "0.2733881672010087\n",
      "74.40588134723885\n",
      "Snorkel + L\n",
      "0.3736801935518666\n",
      "70.78133014190459\n",
      "sms\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 200/200 [00:00<00:00, 703.36epoch/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "LPA weight\n",
      "0.09372782601267873\n",
      "90.73724007561437\n",
      "Snorkel + L\n",
      "0.2862630989188465\n",
      "91.68241965973534\n",
      "tennis\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 200/200 [00:00<00:00, 2091.83epoch/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "LPA weight\n",
      "0.16604037889451548\n",
      "86.50959860383945\n",
      "Snorkel + L\n",
      "0.14089868319180346\n",
      "85.96858638743456\n",
      "youtube\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 200/200 [00:00<00:00, 2062.28epoch/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "LPA weight\n",
      "0.15079687117268095\n",
      "87.82365290412876\n",
      "Snorkel + L\n",
      "0.2371094335391973\n",
      "78.93631910426872\n"
     ]
    }
   ],
   "source": [
    "for data_name in ['basketball','cdr', 'sms','tennis','youtube']:\n",
    "    print(data_name)\n",
    "    LPA_alpha(data_name)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# LPA with dongle + alpha prediction"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "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",
    "\n",
    "def LPA_with_dongle_with_labeled_inds_custom_alpha(W_x, L, alpha_mat, 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.hstack([alpha_mat, alpha_mat])\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",
    "\n",
    "def LPA_with_dongle_with_custom_alpha(W_x, L, alpha_mat, 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_custom_alpha(W_x, L, alpha_mat, labels, labeled_inds, lamb)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def alpha_from_LPA(X, L, labels, L_acc, labeled_inds, thresh = 5, alpha_LPA = 1):\n",
    "\n",
    "    # Update snorkel\n",
    "    Alpha = np.zeros_like(L).astype(float)\n",
    "    for i in range(L.shape[1]):\n",
    "        idx = (L[:,i] !=-1)\n",
    "        try:\n",
    "            N = X[idx].shape[0]\n",
    "            if N >= thresh + 1:\n",
    "                # Construct a euclidean graph\n",
    "                euc_mat = pairwise_distances(X[idx], Y = None, metric='euclidean') \n",
    "                threshold = np.quantile(euc_mat, thresh/N)\n",
    "                A= get_transition_mat(euc_mat, threshold)\n",
    "\n",
    "                idx_i = np.array([i  for i in range(idx.shape[0]) if idx[i] == True] )\n",
    "                labeled_inds_i_array = [i in labeled_inds for i in idx_i]\n",
    "                labeled_inds_i = [j for j in range(N) if labeled_inds_i_array[j] == True]\n",
    "                # LPA\n",
    "                labels_i = (L[idx,i] == labels[idx]).long()\n",
    "                L_acc_i = L_acc[i]* np.ones((X[idx].shape[0]))/100\n",
    "                L_acc_i[labeled_inds_i] = labels_i[labeled_inds_i]\n",
    "                base_acc_i = np.stack((1- L_acc_i, L_acc_i), axis = 1)\n",
    "                alpha_i = PropagationHard(base_acc_i, A, labels = labels_i , labeled_inds = labeled_inds_i, alpha = alpha_LPA)[:,1]\n",
    "                Alpha[idx,i] = alpha_i\n",
    "            else:\n",
    "                L_acc_i = L_acc[i]* np.ones((X[idx].shape[0]))/100\n",
    "                Alpha[idx,i] = L_acc_i\n",
    "\n",
    "        except:\n",
    "            L_acc_i = L_acc[i]* np.ones((X[idx].shape[0]))/100\n",
    "            Alpha[idx,i] = L_acc_i   \n",
    "    return Alpha\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 200/200 [00:00<00:00, 2114.19epoch/s]\n"
     ]
    }
   ],
   "source": [
    "\n",
    "# Examplar idea\n",
    "\n",
    "X, L, labels, W_x, S_x, W_x_large, S_x_large = load_data('basketball', 10, 10, 1)\n",
    "L_acc, snorkel_pred = Snorkel(L)\n",
    "# L_acc_oracle, Coverage = CheckLFs_Acc(L, labels, show = False)\n",
    "\n",
    "\n",
    "# Random label points\n",
    "num_labels = 100\n",
    "labeled_inds = np.random.choice(range(W_x.shape[0]), size= num_labels, replace=False)\n",
    "unlabeled_inds = np.array(list(set(range(X.shape[0])) - set(labeled_inds)))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(73.8905325443787, 100.0, 73.8905325443787)\n",
      "(74.3836291913215, 100.0, 74.3836291913215)\n",
      "(74.45759368836292, 100.0, 74.45759368836292)\n",
      "(74.89519112207151, 99.97534516765286, 74.88905325443785)\n",
      "(75.07396449704143, 100.0, 75.07396449704143)\n"
     ]
    }
   ],
   "source": [
    "for alpha_LPA in [1,10,100,1000]:\n",
    "    alpha_mat = alpha_from_LPA(X,L,labels, L_acc, labeled_inds, thresh = 10, alpha_LPA = alpha_LPA)\n",
    "    pseudolabels = LPA_with_dongle_with_labeled_inds_custom_alpha(W_x, L, alpha_mat, labels, labeled_inds, lamb = 1)\n",
    "    print(GetStats(pseudolabels, labels))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Variance regression"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def Generate_data_var_reg(X,L, labels, labeled_inds, i, clip = 1e-5):\n",
    "    unlabeled_inds = np.array(list(set(range(X.shape[0])) - set(labeled_inds)))\n",
    "    idx = (L[labeled_inds,i]!= -1) # idx for points that the weak labeler i make a prediciton\n",
    "    X_train = X[labeled_inds][idx]\n",
    "    labels_train = (labels[labeled_inds][idx])\n",
    "    L_train = L[labeled_inds,i][idx]\n",
    "    y_train = np.log(np.square(L_train - labels_train) + 1e-5)\n",
    "\n",
    "    # Generate test data\n",
    "    idx_test = (L[unlabeled_inds,i] != -1)\n",
    "    X_test = X[unlabeled_inds][idx_test]\n",
    "    labels_test = (labels[unlabeled_inds][idx_test])\n",
    "    L_test = L[unlabeled_inds,i][idx_test]\n",
    "    y_test = np.log(np.square(L_test - labels_test) + clip)\n",
    "\n",
    "    return X_train, y_train, X_test,y_test\n",
    "\n",
    "def alpha_from_reg(X,L, labels, L_acc,labeled_inds):\n",
    "    Alpha = np.zeros_like(L).astype(float)\n",
    "    for i in range(L.shape[1]):\n",
    "        X_train, y_train, X_test, y_test = Generate_data_var_reg(X,L, labels, labeled_inds, i, clip = 1e-10)\n",
    "        krr = KernelRidge(alpha=1, kernel = 'linear', gamma = 1)\n",
    "        if X_train.shape[0] > 0 :\n",
    "            if y_train.unique().shape[0] > 1:\n",
    "                krr.fit(X_train, y_train)\n",
    "                # print(krr.score(X_test, y_test))\n",
    "                Alpha[:,i] = 1/np.exp(krr.predict(X)/2)\n",
    "            else:\n",
    "                Alpha[:,i] = 316.22*L_acc[i]/100.0\n",
    "        else:\n",
    "            Alpha[:,i] = 316.22*L_acc[i]/100.0\n",
    "    Alpha_reg = np.clip(Alpha, a_min = 1 , a_max = 316.22)/316.22\n",
    "    return Alpha_reg"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 252,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 200/200 [00:00<00:00, 1697.27epoch/s]\n"
     ]
    }
   ],
   "source": [
    "X, L, labels, W_x, S_x, W_x_large, S_x_large = load_data('tennis', 10, 10, 1)\n",
    "# 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",
    "\n",
    "\n",
    "num_labels = 100\n",
    "labeled_inds = np.random.choice(range(W_x.shape[0]), size= num_labels, replace=False)\n",
    "unlabeled_inds = np.array(list(set(range(X.shape[0])) - set(labeled_inds)))\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 253,
   "metadata": {},
   "outputs": [],
   "source": [
    "Alpha = np.zeros_like(L).astype(float)\n",
    "for i in range(L.shape[1]):\n",
    "    X_train, y_train, X_test, y_test = Generate_data_var_reg(X,L, labels, labeled_inds, i, clip = 1e-10)\n",
    "    krr = KernelRidge(alpha=1, kernel = 'linear', gamma = 1)\n",
    "    if X_train.shape[0] > 0 :\n",
    "        if y_train.unique().shape[0] > 1:\n",
    "            krr.fit(X_train, y_train)\n",
    "            # print(krr.score(X_test, y_test))\n",
    "            Alpha[:,i] = 1/np.exp(krr.predict(X)/2)\n",
    "        else:\n",
    "            Alpha[:,i] = 316.22*L_acc[i]/100.0\n",
    "    else:\n",
    "        Alpha[:,i] = 316.22*L_acc[i]/100.0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 254,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "2"
      ]
     },
     "execution_count": 254,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "y_train.unique().shape[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 255,
   "metadata": {},
   "outputs": [],
   "source": [
    "# L_acc"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 256,
   "metadata": {},
   "outputs": [],
   "source": [
    "# 1/np.exp(krr.predict(X)/2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 257,
   "metadata": {},
   "outputs": [],
   "source": [
    "X_train, y_train, X_test,y_test = Generate_data_var_reg(X,L, labels, labeled_inds, 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 258,
   "metadata": {},
   "outputs": [],
   "source": [
    "Alpha_reg = np.clip(Alpha, a_min = 1 , a_max = 316.22)/316.22"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 261,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for i in range(L.shape[1]):\n",
    "    plt.hist(Alpha_reg[:,i])\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 260,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(87.43455497382199, 100.0, 87.434554973822)"
      ]
     },
     "execution_count": 260,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pseudolabels = LPA_with_dongle_with_labeled_inds_custom_alpha(W_x, L, Alpha_reg, labels, labeled_inds, lamb = 1)\n",
    "GetStats(pseudolabels, labels)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Cotraining with weak labels"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 153,
   "metadata": {},
   "outputs": [],
   "source": [
    "def WeightedVote(Alpha, L):\n",
    "    Alpha_not_abstain = torch.tensor(Alpha)*((L != -1).float())\n",
    "\n",
    "    pred = (Alpha_not_abstain * L.numpy()).sum(axis = 1)/(Alpha_not_abstain.sum(axis = 1))\n",
    "    \n",
    "    return torch.tensor(np.nan_to_num(x = pred, nan = 0.5))\n",
    "\n",
    "def Gen_pseudolabel_not_i(L, Alpha_0, i, threshold = 1, confidence_level = 0.01):\n",
    "    idx_j = [j for j in range(Alpha_0.shape[1]) if j != i]\n",
    "    Alpha_not_i = Alpha_0[:, idx_j]\n",
    "    L_not_i = L[:, idx_j]\n",
    "\n",
    "\n",
    "    multiple_wl_predict_idx = ((L != -1).float()).sum(axis = 1) > threshold\n",
    "    pseudolabels_not_i = -1*np.ones_like(labels)\n",
    "\n",
    "    pred = WeightedVote(Alpha_not_i, L_not_i)\n",
    "    pseudolabels_not_i[(pred > (0.5 + confidence_level)) * multiple_wl_predict_idx] = 1\n",
    "    pseudolabels_not_i[(pred < (0.5 - confidence_level)) * multiple_wl_predict_idx] = 0\n",
    "    return pseudolabels_not_i\n",
    "\n",
    "def Generate_data_var_reg_cotrain(X,L, labels, pseudolabels_not_i, labeled_inds, i, clip = 1e-5):\n",
    "\n",
    "    pseudolabels_not_i[labeled_inds] = labels[labeled_inds]\n",
    "    labeled_inds_i = (pseudolabels_not_i!= -1)\n",
    "    X_train, y_train, _, _ = Generate_data_var_reg(X,L, pseudolabels_not_i, labeled_inds_i, i, clip = clip)\n",
    "\n",
    "    return X_train, y_train\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 188,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 200/200 [00:00<00:00, 1914.68epoch/s]\n"
     ]
    }
   ],
   "source": [
    "X, L, labels, W_x, S_x, W_x_large, S_x_large = load_data('youtube', 10, 10, 1)\n",
    "# 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",
    "\n",
    "\n",
    "num_labels = 100\n",
    "labeled_inds = np.random.choice(range(W_x.shape[0]), size= num_labels, replace=False)\n",
    "unlabeled_inds = np.array(list(set(range(X.shape[0])) - set(labeled_inds)))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 131,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([144])\n",
      "torch.Size([89])\n",
      "torch.Size([51])\n",
      "torch.Size([119])\n",
      "torch.Size([91])\n",
      "torch.Size([100])\n",
      "torch.Size([97])\n",
      "torch.Size([54])\n",
      "torch.Size([35])\n",
      "torch.Size([190])\n"
     ]
    }
   ],
   "source": [
    "Alpha_0 = (L != -1).float()\n",
    "for i in range(L.shape[1]):\n",
    "    pseudolabels_not_i = Gen_pseudolabel_not_i(L, Alpha_0, i, threshold = 1)\n",
    "    X_train, y_train = Generate_data_var_reg_cotrain(X,L, labels, pseudolabels_not_i, labeled_inds, i)\n",
    "    print(y_train.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 168,
   "metadata": {},
   "outputs": [],
   "source": [
    "def alpha_from_cotrain(Alpha_0, X, L, L_acc, labeled_inds, labels, threshold = 1, confidence_level = 0.01):\n",
    "    Alpha = np.zeros_like(L).astype(float)\n",
    "    for i in range(L.shape[1]):\n",
    "        pseudolabels_not_i = Gen_pseudolabel_not_i(L, Alpha_0, i, threshold = threshold, confidence_level = confidence_level)\n",
    "        X_train, y_train = Generate_data_var_reg_cotrain(X,L, labels, pseudolabels_not_i, labeled_inds, i)\n",
    "        krr = KernelRidge(alpha=1, kernel = 'linear', gamma = 1)\n",
    "        if X_train.shape[0] > 0 :\n",
    "            # print(y_train.shape)\n",
    "            krr.fit(X_train, y_train)\n",
    "            # print(krr.score(X_test, y_test))\n",
    "            Alpha[:,i] = 1/np.exp(krr.predict(X)/2)\n",
    "        else:\n",
    "            Alpha[:,i] = 316.22*L_acc[i]/100.0\n",
    "    return np.clip(Alpha, a_min = 1 , a_max = 316.22)/316.22"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 272,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 200/200 [00:00<00:00, 1917.53epoch/s]\n"
     ]
    }
   ],
   "source": [
    "X, L, labels, W_x, S_x, W_x_large, S_x_large = load_data('youtube', 10, 10, 1)\n",
    "# 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",
    "\n",
    "\n",
    "num_labels = 100\n",
    "labeled_inds = np.random.choice(range(W_x.shape[0]), size= num_labels, replace=False)\n",
    "unlabeled_inds = np.array(list(set(range(X.shape[0])) - set(labeled_inds)))\n",
    "Alpha_0 = (L != -1).float()\n",
    "for _ in range(10):\n",
    "    # print(Alpha_0[1,:])\n",
    "    Alpha_0 = alpha_from_cotrain(Alpha_0, X, L, L_acc, labeled_inds, labels, threshold = 2, confidence_level = 0.4)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 273,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(89.33333333333333, 93.63295880149813, 86.82896379525593)"
      ]
     },
     "execution_count": 273,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pseudolabels = LPA_with_dongle_with_labeled_inds_custom_alpha(W_x, L, Alpha_0, labels, labeled_inds, lamb = 1)\n",
    "GetStats(pseudolabels, labels)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 274,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "143"
      ]
     },
     "execution_count": 274,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "Alpha_00 = (L != -1).float()\n",
    "(Gen_pseudolabel_not_i(L, Alpha_00, 4, threshold = 2, confidence_level = 0.4) != -1).sum()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 275,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([0.9942, 0.0000, 0.9983,  ..., 1.0000, 0.0000, 1.0000],\n",
       "       dtype=torch.float64)"
      ]
     },
     "execution_count": 275,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "WeightedVote(Alpha_0, L)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Revisit LPA for alpha"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "# Examplar idea\n",
    "\n",
    "X, L, labels, W_x, S_x, W_x_large, S_x_large = load_data('basketball', 10, 10, 1)\n",
    "L_acc, snorkel_pred = Snorkel(L)\n",
    "# L_acc_oracle, Coverage = CheckLFs_Acc(L, labels, show = False)\n",
    "\n",
    "\n",
    "# Random label points\n",
    "num_labels = 100\n",
    "labeled_inds = np.random.choice(range(W_x.shape[0]), size= num_labels, replace=False)\n",
    "unlabeled_inds = np.array(list(set(range(X.shape[0])) - set(labeled_inds)))\n"
   ]
  },
  {
   "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
}
