{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "23a576a6-2ae6-4bec-95cc-c971e5a5c5bc",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from sklearn.cluster import KMeans\n",
    "from sklearn.mixture import GaussianMixture\n",
    "from snorkel.labeling.analysis import LFAnalysis\n",
    "from sklearn.metrics import classification_report\n",
    "from snorkel.labeling.model import LabelModel, MajorityLabelVoter"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "0edcf269-82f6-46d7-a549-f6f3face994b",
   "metadata": {},
   "outputs": [],
   "source": [
    "seed = 123\n",
    "mode = \"grad-mimic\"\n",
    "opt = \"adamw\"\n",
    "method = \"normed_proj\"\n",
    "total_epoch = 5\n",
    "dataset = \"cifar10\"\n",
    "backbone = \"vit-b\"\n",
    "norm_way = \"l2\"\n",
    "starting_epoch = 0\n",
    "lambda_value = 0.0\n",
    "temperature = 0.7\n",
    "# sieve_layer = \"heads.head.weight\"\n",
    "# calibrate_sieve_layer_only = \"only\"\n",
    "sub_folder = \"pretrained_fine_tune_all\"\n",
    "noisy_levels = [0.3, 0.5]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "74f85478-121e-4af5-b92d-6f35f6965e0a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "\"\\nsaved_info_collection = []\\nfor n in noisy_levels:\\n    with open(f'./saved_logs/{sub_folder}/{backbone}_{sieve_layer}_{calibrate_sieve_layer_only}_{dataset}_{method}_temp{temperature}_run{total_epoch}epochs_{mode}_opt{opt}_startat{starting_epoch}_noisy{n}_reg{lambda_value}_{norm_way}norm_seed{seed}_weights.pkl', 'rb') as f:\\n        saved_info = pickle.load(f)\\n        saved_info_collection.append(saved_info)\\n\""
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "\"\"\"\n",
    "saved_info_collection = []\n",
    "for n in noisy_levels:\n",
    "    with open(f'./saved_logs/{sub_folder}/{backbone}_{sieve_layer}_{calibrate_sieve_layer_only}_{dataset}_{method}_temp{temperature}_run{total_epoch}epochs_{mode}_opt{opt}_startat{starting_epoch}_noisy{n}_reg{lambda_value}_{norm_way}norm_seed{seed}_weights.pkl', 'rb') as f:\n",
    "        saved_info = pickle.load(f)\n",
    "        saved_info_collection.append(saved_info)\n",
    "\"\"\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "a1836c81-83ab-46b5-8714-eef153a3c791",
   "metadata": {},
   "outputs": [],
   "source": [
    "saved_info_collection = []\n",
    "with open(f'./saved_logs/{sub_folder}/vit-b_heads.head.weight_only_cifar10_normed_proj_temp0.7_run5epochs_grad-mimic_optadamw_startat0_noisy0.3_reg0.0_l2norm_seed123_weights.pkl', 'rb') as f:\n",
    "    saved_info = pickle.load(f)\n",
    "    saved_info_collection.append(saved_info)\n",
    "\n",
    "with open(f'./saved_logs/{sub_folder}/vit-b_heads.head.weight_only_cifar10_normed_proj_temp0.7_run5epochs_grad-mimic_optadamw_startat0_noisy0.5_reg0.0_l2norm_seed123_weights.pkl', 'rb') as f:\n",
    "    saved_info = pickle.load(f)\n",
    "    saved_info_collection.append(saved_info)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "658c0d26-df4e-43a1-ac0b-8e5bfc6fd62d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 172,
   "id": "6828526a-0ca7-4bf8-bf05-ba8325fe2f8f",
   "metadata": {},
   "outputs": [],
   "source": [
    "correct_datapoint_indices_collection = []\n",
    "noisy_datapoint_indices_collection = []\n",
    "weights_collection = []\n",
    "golden_labels_collection = []\n",
    "\n",
    "for info in saved_info_collection:\n",
    "    correct_datapoint_indices = []\n",
    "    noisy_datapoint_indices = []\n",
    "    weights = []\n",
    "    golden_labels = []\n",
    "    \n",
    "    for key, small_dict in info.items():\n",
    "        if small_dict[\"status\"] == \"correct\":\n",
    "            correct_datapoint_indices.append(key)\n",
    "            golden_labels.append(1)\n",
    "        else:\n",
    "            noisy_datapoint_indices.append(key)\n",
    "            golden_labels.append(0)\n",
    "\n",
    "        if \"weights\" in small_dict:\n",
    "            grab_key = \"weights\"\n",
    "        else:\n",
    "            grab_key = \"per_sample_weights\"\n",
    "        weights.append(small_dict[grab_key])\n",
    "\n",
    "    correct_datapoint_indices_collection.append(correct_datapoint_indices)\n",
    "    noisy_datapoint_indices_collection.append(noisy_datapoint_indices)\n",
    "    weights_collection.append(weights)\n",
    "    golden_labels_collection.append(golden_labels)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 173,
   "id": "87c2ee0f-10d7-4f2b-9697-910f45e77cf0",
   "metadata": {},
   "outputs": [],
   "source": [
    "weights_collection = np.array(weights_collection)\n",
    "golden_labels_collection = np.array(golden_labels_collection)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 174,
   "id": "8d3acc79-bdb2-4635-9013-a55000f83360",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "((2, 50000, 5), (2, 50000))"
      ]
     },
     "execution_count": 174,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "weights_collection.shape, golden_labels_collection.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 179,
   "id": "f636cfc4-d6a4-4362-9e8c-ad19f54082f1",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(0.3, (50000,))"
      ]
     },
     "execution_count": 179,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "idx = 0\n",
    "noisy_portion = len(noisy_datapoint_indices_collection[idx]) / len(saved_info_collection[idx])\n",
    "weight_collection_average = np.average(weights_collection[idx], axis=1)\n",
    "noisy_portion, weight_collection_average.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 180,
   "id": "3863704d-9612-4841-890e-8d3194fee569",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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xQoAwKhRo9CrV69iL3IlIiKiqletScnt27cxaNAg/Pvvv6hbty46dOiAo0ePwsXFBQAwdepUZGdnY8yYMUhLS4O3tzdiYmJgbm4u1bFw4UIYGBhgwIAByM7ORteuXREVFQV9fX0pZv369Rg/frx0l06fPn2wePHiqu0sERERlahak5JNmzaV+L5CoUBYWBjCwsKKjTEyMkJERAQiIiKKjbGxscG6devK20wiIiKqArK6poSIiIhqLyYlREREJAtMSoiIiEgWmJQQERGRLDApISIiIllgUkJERESywKSEiIiIZIFJCREREckCkxIiIiKSBSYlREREJAtMSoiIiEgWmJQQERGRLDApISIiIllgUkJERESywKSEiIiIZIFJCREREckCkxIiIiKSBSYlREREJAtMSoiIiEgWmJQQERGRLDApISIiIllgUkJERESywKSEiIiIZIFJCREREckCkxIiIiKSBSYlREREJAtMSoiIiEgWmJQQERGRLDApISIiIllgUkJERESywKSEiIiIZIFJCREREckCkxIiIiKSBSYlREREJAtMSoiIiEgWZJOUzJo1CwqFAhMnTpTKhBAICwuDk5MTjI2N0alTJ1y4cEFjvZycHIwbNw516tSBqakp+vTpg9u3b2vEpKWlISQkBJaWlrC0tERISAgePHhQBb0iIiKi0pJFUnLixAl89913aNWqlUb5nDlzsGDBAixevBgnTpyAg4MDAgICkJGRIcVMnDgRW7duxaZNm3Do0CFkZmaiV69eyMvLk2KCg4ORkJCA6OhoREdHIyEhASEhIVXWPyIiInq+ak9KMjMzMXjwYKxcuRLW1tZSuRACixYtwieffIJ+/frB09MTa9asQVZWFjZs2AAASE9Px+rVqzF//nx069YNbdq0wbp163Du3Dns2bMHAJCYmIjo6GisWrUKPj4+8PHxwcqVK7Fjxw4kJSVVS5+JiIhIm0F1N2Ds2LF47bXX0K1bN8ycOVMqv3btGlJSUhAYGCiVGRoawt/fH/Hx8Rg9ejROnToFtVqtEePk5ARPT0/Ex8cjKCgIR44cgaWlJby9vaWYDh06wNLSEvHx8WjSpEmR7crJyUFOTo60/PDhQwCAWq2GWq0uV18L1ivv+qRbJY2HXhnSdQ6nbvD4kA+OhbzUhPEobdurNSnZtGkTTp8+jRMnTmi9l5KSAgCwt7fX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i6SkJHTs2FF3ja+BKnM8vvjiC9StWxfDhw/XfcNroMoci8zMTLi4uKB+/fro1asXzpw5o/sO1DCVNR6//fYbfHx8MHbsWNjb28PT0xPh4eHIy8urnI5UIiYl5fTvv/8iLy9P6wf97O3ttX74r0BKSkqR8U+ePMG///5b5DofffQR6tWrh27duumm4TVQZY5Feno6zMzMoFKp8NprryEiIgIBAQG670QNUlnjcfjwYaxevRorV66snIbXQJU1Fk2bNkVUVBR+++03bNy4EUZGRvDz88Ply5crpyM1RGWNx9WrV/HLL78gLy8PO3fuxKeffor58+fjq6++qpyOVKJa85j5yqJQKDSWhRBaZc+LL6ocAObMmYONGzfiwIEDMDIy0kFra7bKGAtzc3MkJCQgMzMTe/fuxaRJk+Dm5oZOnTrpruE1lC7HIyMjA2+//TZWrlyJOnXq6L6xNZyuj40OHTqgQ4cO0vt+fn54+eWXERERgW+//VZXza6xdD0e+fn5sLOzw3fffQd9fX20bdsW//zzD+bOnYvPP/9cx62vXExKyqlOnTrQ19fXym5TU1O1stoCDg4ORcYbGBjA1tZWo3zevHkIDw/Hnj170KpVK902voapzLHQ09ND48aNAQAvvfQSEhMTMWvWLCYlJaiM8bhw4QKuX7+O3r17S+/n5+cDAAwMDJCUlIRGjRrpuCcvvsr+O1VAT08P7dq140zJc1TWeDg6OkKpVEJfX1+KadasGVJSUpCbmwuVSqXjnlQenr4pJ5VKhbZt2yI2NlajPDY2Fr6+vkWu4+PjoxUfExMDLy8vKJVKqWzu3Ln48ssvER0dDS8vL903voapzLEoTAiBnJycije6BquM8WjatCnOnTuHhIQE6dWnTx907twZCQkJcHZ2rrT+vMiq6tgQQiAhIQGOjo66aXgNVVnj4efnhytXrkiJOgBcunQJjo6OL1RCAoC3BFdEwa1dq1evFhcvXhQTJ04Upqam4vr160IIIT766CMREhIixRfc2vX++++LixcvitWrV2vd2jV79myhUqnEL7/8onGrXUZGRpX370VSGWMRHh4uYmJixF9//SUSExPF/PnzhYGBgVi5cmWV9+9FUxnjURjvvimdyhiLsLAwER0dLf766y9x5swZMWzYMGFgYCCOHTtW5f170VTGeNy8eVOYmZmJ//73vyIpKUns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",
      "text/plain": [
       "<Figure size 600x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Plot histograms\n",
    "plt.figure(figsize=(6, 4))\n",
    "plt.hist(weight_collection_average[noisy_datapoint_indices_collection[idx]], density=False, alpha=0.5, color='red', bins=100, label='Incorrect')\n",
    "plt.hist(weight_collection_average[correct_datapoint_indices_collection[idx]], density=False, alpha=0.5, color='blue', bins=100, label='Correct')\n",
    "\n",
    "# Add labels and legend\n",
    "plt.xlabel(f'Resampling Weights (using {method})')\n",
    "plt.ylabel('Frequency')\n",
    "plt.legend(loc='upper right')\n",
    "plt.title(f\"{dataset} -- convert {noisy_portion * 100:.0f}% label into noisy label\")\n",
    "\n",
    "# Show plot\n",
    "plt.grid()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 181,
   "id": "2a866f76-a4a5-4300-9f5b-1ff6e6205d22",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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0SLuuusuPv/8c4qKiggJCTFiNm7cyP33309qaipTpkwhODiYvXv3Osyufumll4iLiyMpKYmkpCTGjh3Lrl27ejRfEel9OqoZ27dv57/+679UM0REBHD+XGPs2LFkZWWxZs0a1Q0RkT6qo5pRUFDAq6++ytixY/vUuYbJ1t5C8dIl9fX1mM1m6urqCA0Ndeo9VquVN954g29/+9sec3+tzMz2/727eGIfuUNP9tOlS5c4efIkw4cPJzAwsFv35UotLS3U19cTGhra4b3wvNn1jl9Xvseka/paX3vSd3nr2tYTtc4ZntSHrfWGuqEa0HX24zds2DDefvtt42+wr32PuZu7+9uTv4M6cr3c7DWgt9SCzvLU4+Zs3fDm73ZPzU3nGr1Db+9rT/1u6si18urp39Fcrbcfrxs51/DU79qOeFJe1zp+vf17zNv0VH/39u8TV2gvx/a++z2xHth5+nF0pm540vdoV3lijq441/CMTEVERERERERERERERERERLpAg+IiIiIiIiIiIiIiIiIiIuK1NCguIiIiIiIiIiIiIiIiIiJeS4PiIiIiIiIiIiIiIiIiIiLitTQoLiIiIiIiIiIiIiIiIiIiXkuD4iIiIiIiIiIiIh34/PPPefDBBxk8eDDBwcF89atfpby83HjdZrORmZlJVFQUQUFBTJs2jePHjzt8hsViYcmSJQwZMoT+/fsze/ZsTp8+7RBTW1tLeno6ZrMZs9lMeno6586d64kURURERES8lgbFRURERERERP4hM/PLh4iIXW1tLVOmTMHPz48333yTDz74gPXr1zNw4EAjJicnhw0bNpCXl8eRI0eIjIwkMTGR8+fPGzEZGRns2bOHgoICDhw4wIULF0hJSaG5udmISUtLo6KigsLCQgoLC6moqCA9Pb0n0xURkRukiVQiIr2PBsVFRERERERERESuY926dURHR7N9+3YmTpzIrbfeyvTp07n99tuBK4MbmzZtYvXq1cyZM4fY2Fh27txJQ0MDu3fvBqCuro5t27axfv16ZsyYwfjx48nPz+fo0aPs27cPgBMnTlBYWMgLL7xAQkICCQkJbN26lddff53Kykq35S8iIs7TRCoRkd6pn7sbICIiIiIiIiIi0pu99tprJCcn8/3vf5+SkhK+8pWvsGjRIubPnw/AyZMnqa6uJikpyXhPQEAAU6dOpbS0lIUL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zuDBgwkLC2PFihXExcUxY8YMAEaNGsXMmTOZP38+zz//PAALFiwgJSVF94UVEfFwmkzV8/txp6tzbG+SlDek39eOo7fylhydzUGD4iIiIiIiIiIiItdx+vRpfvSjH/G3v/2Nm266iUmTJlFWVsYtt9wCwMqVK2lsbGTRokXU1tYSHx9PUVERISEhxmds3LiRfv36kZqaSmNjI9OnT2fHjh34+voaMS+99BJLly4lKSkJgNmzZ5OXl9ezyYqIyA3TZCoRkd5Hg+IiIiIiIiIiIiLXUVBQcN3XTSYTmZmZZGZmXjMmMDCQ3NxccnNzrxkTFhZGfn5+V5spIiK9hCZT9W3Z2e1fIS4i7qVBcRERERERERERERERERfRZCoRkd5Hg+IiIiIiIiIiIiIiIiIiPeDquRDXmRchIi7m4+4GiIiIiHgCnaSIiIiIiIiIiIiIeCYNiouIiIiIiIiIiIiIiIiIiNfSoLiIiIiIiIiIiIiIiIiIiHitXj0ofvnyZf7t3/6N4cOHExQUxG233cYvfvELWlpajBibzUZmZiZRUVEEBQUxbdo0jh8/7vA5FouFJUuWMGTIEPr378/s2bM5ffq0Q0xtbS3p6emYzWbMZjPp6emcO3euJ9IUEREREREREREREREREZFu0qsHxdetW8dzzz1HXl4eJ06cICcnh6effprc3FwjJicnhw0bNpCXl8eRI0eIjIwkMTGR8+fPGzEZGRns2bOHgoICDhw4wIULF0hJSaG5udmISUtLo6KigsLCQgoLC6moqCA9Pb1H8xUREREREREREREREREREdfq0qD4yZMnXd2Odh08eJDvfOc73Hvvvdx6661873vfIykpiXfffRe4cpX4pk2bWL16NXPmzCE2NpadO3fS0NDA7t27Aairq2Pbtm2sX7+eGTNmMH78ePLz8zl69Cj79u0D4MSJExQWFvLCCy+QkJBAQkICW7du5fXXX6eysrJHchUR6et6qraIiIjnU80QEZHOUN0QERFnqWaIiHivfl150x133ME999zDvHnz+N73vkdgYKCr2wXA17/+dZ577jk+/PBDRowYwR//+EcOHDjApk2bgCsFqrq6mqSkJOM9AQEBTJ06ldLSUhYuXEh5eTlWq9UhJioqitjYWEpLS0lOTubgwYOYzWbi4+ONmEmTJmE2myktLWXkyJHtts9isWCxWIzn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zk+Q8rQu8ebjaKccPYezOfh0cztEREREREREREQ82uLFi8nPz2f37t2EhIRQXV1NdXU1jY2NwJUr9TIyMsjKymLPnj0cO3aMuXPnEhwcTFpaGgBms5l58+axfPly3nrrLd5//30efPBB4uLimDFjBgCjRo1i5syZzJ8/n7KyMsrKypg/fz4pKSnXvDesiIj0LjabjUcffZRXX32Vt99++7oTqezsE6nsA95XT6Sys0+kssdcPZHKThOpRESuTVeKi4iIiIiIiIiIXMfmzZsBmDZtmsP27du3M3fuXABWrlxJY2MjixYtora2lvj4eIqKiggJCTHiN27cSL9+/UhNTaWxsZHp06ezY8cOfH19jZiXXnqJpUuXkpSUBMDs2bPJy8vr3gRFRMRlFi9ezO7du/nd735nTKSCK5OjgoKCHCZSxcTEEBMTQ1ZW1jUnUg0ePJiwsDBWrFhxzYlUzz//PAALFizQRCoRkWvQoLiIiIiIiIiIiMh12Gy2DmNMJhOZmZlkZmZeMyYwMJDc3Fxyc3OvGRMWFkZ+fn5XmikiIr2AJlKJiPROGhQXERERERERERERERFxAU2kEhHpnXRPcRERERERERERERERERER8VoaFBcREREREREREREREREREa+lQXEREREREREREREREREREfFaGhQXERERERERERERERERERGvpUFxERERERERERERERERERHxWhoUFxERERERERERERERERERr6VBcRERERERERERERERERER8Vr93N0AERERERERERERERERkb4qM7P9fxcR19GguLiEvrBFRMRjvfPOlX9Om+bOVoiIiIiIiIiIiIhIN9Hy6SIi4lX279/PfffdR1RUFCaTid/+9rcOr9tsNjIzM4mKiiIoKIhp06Zx/PhxhxiLxcKSJUsYMmQI/fv3Z/bs2Zw+fdohpra2lvT0dMxmM2azmfT0dM6dO9fN2UmPeeedLx8iIiIiIiIiIiIi4tE0KC4iIl7l4sWLjBs3jry8vHZfz8nJYcOGDeTl5XHkyBEiIyNJTEzk/PnzRkxGRgZ79uyhoKCAAwcOcOHCBVJSUmhubjZi0tLSqKiooLCwkMLCQioqKkhPT+/2/KR30eooIiIiIiIiIiIiIr2flk8XERGvMmvWLGbNmtXuazabjU2bNrF69WrmzJkDwM6dO4mIiGD37t0sXLiQ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",
      "text/plain": [
       "<Figure size 2000x300 with 5 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Plot histograms\n",
    "fig, axes = plt.subplots(1, total_epoch, figsize=(20, 3))\n",
    "for e in range(total_epoch):\n",
    "    axes[e].hist(weights_collection[idx][:, e][noisy_datapoint_indices_collection[idx]], density=False, alpha=0.5, color='red', bins=100, label='Incorrect')\n",
    "    axes[e].hist(weights_collection[idx][:, e][correct_datapoint_indices_collection[idx]], density=False, alpha=0.5, color='blue', bins=100, label='Correct')\n",
    "\n",
    "    # Add labels and legend\n",
    "    axes[e].set_xlabel(f'Epoch {e + 1}')\n",
    "    axes[e].set_ylabel('Frequency')\n",
    "    axes[e].legend(loc='upper right')\n",
    "    # axes[e].set_title(f\"{dataset} -- convert {noisy_portion * 100:.0f}% label into noisy label\")\n",
    "    axes[e].grid()\n",
    "    \n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "67ff5289-b3cf-454f-a30c-f6aebc1fdc97",
   "metadata": {},
   "source": [
    "### Using Selection Weights"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 182,
   "id": "d3179c1b-3508-4059-abd4-7d89a0d52e58",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "------------------------------------\n",
      "Noisy Level: 0.3\n",
      "Class balance: positive 0.76, negative 0.24\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 500/500 [00:00<00:00, 821.56epoch/s]\n",
      "WARNING:root:Metrics calculated over data points with non-abstain labels only\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'accuracy': 0.7, 'precision': 0.7, 'recall': 1.0, 'f1': 0.8235294117647058}\n",
      "  Polarity  Coverage  Overlaps  Conflicts  Correct  Incorrect  Emp. Acc.\n",
      "0   [0, 1]       1.0       1.0    0.97592    35100      14900    0.70200\n",
      "1   [0, 1]       1.0       1.0    0.97592    36749      13251    0.73498\n",
      "2   [0, 1]       1.0       1.0    0.97592    13273      36727    0.26546\n",
      "3   [0, 1]       1.0       1.0    0.97592    36714      13286    0.73428\n",
      "4   [0, 1]       1.0       1.0    0.97592    36878      13122    0.73756\n",
      "[0.745 0.769 0.26  0.767 0.768]\n",
      "------------------------------------\n",
      "Noisy Level: 0.5\n",
      "Class balance: positive 0.23, negative 0.77\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 500/500 [00:00<00:00, 817.99epoch/s]\n",
      "WARNING:root:Metrics calculated over data points with non-abstain labels only\n",
      "/miniforge/envs/iris/lib/python3.10/site-packages/sklearn/metrics/_classification.py:1531: UndefinedMetricWarning: Precision is ill-defined and being set to 0.0 due to no predicted samples. Use `zero_division` parameter to control this behavior.\n",
      "  _warn_prf(average, modifier, f\"{metric.capitalize()} is\", len(result))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'accuracy': 0.5, 'precision': 0.0, 'recall': 0.0, 'f1': 0.0}\n",
      "  Polarity  Coverage  Overlaps  Conflicts  Correct  Incorrect  Emp. Acc.\n",
      "0   [0, 1]       1.0       1.0    0.99066    24612      25388    0.49224\n",
      "1   [0, 1]       1.0       1.0    0.99066    23725      26275    0.47450\n",
      "2   [0, 1]       1.0       1.0    0.99066    24687      25313    0.49374\n",
      "3   [0, 1]       1.0       1.0    0.99066    25542      24458    0.51084\n",
      "4   [0, 1]       1.0       1.0    0.99066    23667      26333    0.47334\n",
      "[0.773 0.78  0.774 0.235 0.778]\n"
     ]
    }
   ],
   "source": [
    "hard_labels_collection = []\n",
    "soft_labels_collection = []\n",
    "\n",
    "for i, (weights, golden_labels) in enumerate(zip(weights_collection, golden_labels_collection)):\n",
    "    \n",
    "    print(\"------------------------------------\")\n",
    "    print(f\"Noisy Level: {noisy_levels[i]}\")\n",
    "    # if method == \"opt\": L = (weights > 0.002).astype(int)\n",
    "    # elif method == \"cos\": L = (weights > 0.005).astype(int)\n",
    "    # elif method == \"proj\": L = (weights > 0).astype(int)\n",
    "\n",
    "    # L = (weights > 0).astype(int)\n",
    "    \n",
    "    ## automated binarization ##\n",
    "    L = []\n",
    "    for t in range(weights.shape[1]):\n",
    "        one_epoch_weights = weights[:, t].reshape(-1, 1)\n",
    "        # kmeans = KMeans(n_clusters=2, random_state=0, n_init=\"auto\").fit(one_epoch_weights)\n",
    "        # clusters = kmeans.labels_\n",
    "        gmm = GaussianMixture(n_components=2, random_state=0).fit(one_epoch_weights)\n",
    "        clusters = gmm.predict(one_epoch_weights)\n",
    "        max_index, min_index = np.argmax(one_epoch_weights), np.argmin(one_epoch_weights)\n",
    "        if clusters[max_index] == 0 and clusters[min_index] == 1:\n",
    "            ## need to flip cluster ##\n",
    "            clusters = 1 - clusters\n",
    "        L.append(clusters)\n",
    "    L = np.array(L).T\n",
    "    \n",
    "    pos_balance = (np.sum(L) / (L.shape[0] * L.shape[1]))\n",
    "    neg_balance = (1 - pos_balance)\n",
    "    print(f\"Class balance: positive {round(pos_balance, 2)}, negative {round(neg_balance, 2)}\")\n",
    "    label_model = LabelModel(verbose=False, cardinality=2)\n",
    "    label_model.fit(L, seed=123, n_epochs=500, class_balance=[neg_balance, pos_balance], optimizer=\"adam\")\n",
    "    performance = label_model.score(L, Y=np.array(golden_labels), metrics=[\"accuracy\", \"precision\", \"recall\", \"f1\"])\n",
    "    print(performance)\n",
    "    print(LFAnalysis(L).lf_summary(Y=np.array(golden_labels)))\n",
    "    print(np.round(label_model.get_weights(), 3))\n",
    "    \n",
    "    hard_labels = label_model.predict(L)\n",
    "    soft_labels = label_model.predict_proba(L)\n",
    "    hard_labels_collection.append(hard_labels)\n",
    "    soft_labels_collection.append(soft_labels[:, 1])\n",
    "    \n",
    "hard_labels_collection = np.array(hard_labels_collection)\n",
    "soft_labels_collection = np.array(soft_labels_collection)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d600a81c-bb81-4d65-b0e2-918fd279cff0",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 155,
   "id": "210c9bf2-af5c-47fa-a715-ddc4bbfa53cb",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(5, 3, 2)"
      ]
     },
     "execution_count": 155,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "label_model.get_conditional_probs().shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 156,
   "id": "4892829c-d774-419f-bb23-b70c6fa283fa",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 600x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "x = noisy_levels\n",
    "y = np.average(soft_labels_collection, axis=1)\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(6, 4))\n",
    "ax.scatter(x, y, s=60, alpha=0.7, edgecolors=\"k\")\n",
    "\n",
    "b, a = np.polyfit(x, y, deg=1)\n",
    "xseq = np.linspace(0, 0.7, num=50)\n",
    "\n",
    "ax.plot(xseq, a + b * xseq, color=\"k\", lw=2, label=f\"y = {round(a, 2)} x {round(b, 2)}\")\n",
    "ax.plot(xseq, 1 - xseq, color=\"red\", lw=2, label=\"Perfect Line\", linestyle=\"--\")\n",
    "plt.ylabel(\"Average Confidence Score (Dataset Quality)\")\n",
    "plt.xlabel(\"Add x% of Noisy Levels into Dataset\")\n",
    "plt.title(f\"{dataset} dataset\")\n",
    "plt.legend()\n",
    "plt.grid()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 157,
   "id": "6b5827dc-0686-4dca-b514-76ca45b78f71",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Convert 30.0% of Labels into Noisy Labels\n",
      "               precision    recall  f1-score   support\n",
      "\n",
      "           0       0.30      1.00      0.46      1104\n",
      "           1       0.00      0.00      0.00      2576\n",
      "\n",
      "    accuracy                           0.30      3680\n",
      "   macro avg       0.15      0.50      0.23      3680\n",
      "weighted avg       0.09      0.30      0.14      3680\n",
      "\n",
      "Convert 50.0% of Labels into Noisy Labels\n",
      "               precision    recall  f1-score   support\n",
      "\n",
      "           0       0.70      0.97      0.81      1840\n",
      "           1       0.96      0.58      0.72      1840\n",
      "\n",
      "    accuracy                           0.78      3680\n",
      "   macro avg       0.83      0.78      0.77      3680\n",
      "weighted avg       0.83      0.78      0.77      3680\n",
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/miniforge/envs/iris/lib/python3.10/site-packages/sklearn/metrics/_classification.py:1531: UndefinedMetricWarning: Precision is ill-defined and being set to 0.0 in labels with no predicted samples. Use `zero_division` parameter to control this behavior.\n",
      "  _warn_prf(average, modifier, f\"{metric.capitalize()} is\", len(result))\n",
      "/miniforge/envs/iris/lib/python3.10/site-packages/sklearn/metrics/_classification.py:1531: UndefinedMetricWarning: Precision is ill-defined and being set to 0.0 in labels with no predicted samples. Use `zero_division` parameter to control this behavior.\n",
      "  _warn_prf(average, modifier, f\"{metric.capitalize()} is\", len(result))\n",
      "/miniforge/envs/iris/lib/python3.10/site-packages/sklearn/metrics/_classification.py:1531: UndefinedMetricWarning: Precision is ill-defined and being set to 0.0 in labels with no predicted samples. Use `zero_division` parameter to control this behavior.\n",
      "  _warn_prf(average, modifier, f\"{metric.capitalize()} is\", len(result))\n"
     ]
    }
   ],
   "source": [
    "for i, n in enumerate(noisy_levels):\n",
    "    report = classification_report(golden_labels_collection[i], hard_labels_collection[i])\n",
    "    print(f\"Convert {100 * n}% of Labels into Noisy Labels\\n\", report)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4e222216-1be0-40de-a43f-1a03cf8770af",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7eb9d225-29be-4d58-8c9c-8efbb2fff4f9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4f1fdbfb-761d-4889-aae7-85dc74bc18c8",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.14"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
