{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "1db6a160",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import pickle\n",
    "import torch\n",
    "import pandas as pd\n",
    "from sklearn import metrics\n",
    "import tqdm\n",
    "from tqdm import tqdm\n",
    "import seaborn as sns\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from scipy import stats\n",
    "from matplotlib.offsetbox import AnchoredText\n",
    "import matplotlib"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "7313a47c",
   "metadata": {},
   "outputs": [],
   "source": [
    "os.chdir('/makesense_dir_path/data/usim/Markup/UsageSimilarity/')\n",
    "data = pd.read_csv('usim2ratings.csv')\n",
    "data_all = pd.read_csv(\"/makesense_dir_path/data/usim_sents.csv\")\n",
    "data_all.columns = data_all.columns.str.strip()\n",
    "\n",
    "data = data[data.user_id != 'avg']\n",
    "# data = data.reset_index(drop = True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "ba8dce22",
   "metadata": {},
   "outputs": [],
   "source": [
    "lemmas = list(set(data.lemma))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "a793918d",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 26/26 [00:00<00:00, 399.97it/s]\n"
     ]
    }
   ],
   "source": [
    "umid = []\n",
    "\n",
    "for lemma_ in tqdm(lemmas):\n",
    "    num = len(data[(data.lemma == lemma_) & (data.judgment > 1) & (data.judgment < 5)])\n",
    "    denom = len(data[(data.lemma == lemma_)])\n",
    "    \n",
    "    umid.append(num/denom)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "a3e25a34",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 13/13 [00:23<00:00,  1.83s/it]\n"
     ]
    }
   ],
   "source": [
    "#for each word lemma, avg corr between annotators vs cluster homogeneity/separability/variance\n",
    "obest_sim = {}\n",
    "obest_n = {}\n",
    "abest_sim = {}\n",
    "abest_n = {}\n",
    "for l in tqdm(range(13)):\n",
    "    original = torch.load(f'/makesense_dir_path/data/usim/embeddings/original/layer_{l}.pt')\n",
    "    approx = torch.load(f'/makesense_dir_path/data/usim/embeddings/laser/layer_{l}.pt')\n",
    "\n",
    "    original_ = list(zip(data_all.lexsub_id1, original))\n",
    "    approx_ = list(zip(data_all.lexsub_id1, approx))\n",
    "\n",
    "    osim_ = []\n",
    "    asim_ = []\n",
    "    for lemma in lemmas:\n",
    "        ids = list(data_all[data_all.lemma == lemma].lexsub_id1)\n",
    "        embso = [np.array(x[1]) for x in original_ if x[0] in ids]\n",
    "        \n",
    "        n = 0\n",
    "        sim_all = 0\n",
    "        for emb1 in embso:\n",
    "            for emb2 in embso:\n",
    "                sim = metrics.pairwise.cosine_similarity(emb1.reshape(1,-1), emb2.reshape(1,-1))[0][0]\n",
    "                sim_all = sim_all + sim\n",
    "                n = n+1\n",
    "                \n",
    "        avg_sim = sim_all/n\n",
    "        osim_.append(avg_sim)\n",
    "        \n",
    "        embsa = [np.array(x[1]) for x in approx_ if x[0] in ids]\n",
    "        n = 0\n",
    "        sim_all = 0\n",
    "        for emb1 in embsa:\n",
    "            for emb2 in embsa:\n",
    "                sim = metrics.pairwise.cosine_similarity(emb1.reshape(1,-1), emb2.reshape(1,-1))[0][0]\n",
    "                sim_all = sim_all + sim\n",
    "                n = n+1\n",
    "                \n",
    "        avg_sim = sim_all/n\n",
    "        asim_.append(avg_sim)\n",
    "        \n",
    "            \n",
    "    obest_sim[l] = osim_\n",
    "    abest_sim[l] = asim_\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "bc6f94bb",
   "metadata": {},
   "outputs": [],
   "source": [
    "lemma_sims = pd.DataFrame(zip(lemmas, umid), columns = ['layer','umid'])\n",
    "\n",
    "for l in range(13):\n",
    "    ocol = 'o'+str(l)\n",
    "    acol = 'a'+str(l)\n",
    "    lemma_sims[ocol] = obest_sim[l]\n",
    "    lemma_sims[acol] = abest_sim[l]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "2e5c883d",
   "metadata": {},
   "outputs": [],
   "source": [
    "um_o = []\n",
    "for i in range(13):\n",
    "    colname = 'o'+str(i)\n",
    "    um_o.append(abs(stats.spearmanr(lemma_sims['umid'], lemma_sims[colname]).correlation))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "96b2a461",
   "metadata": {},
   "outputs": [],
   "source": [
    "um_a = []\n",
    "for i in range(13):\n",
    "    colname = 'a'+str(i)\n",
    "    um_a.append(abs(stats.spearmanr(lemma_sims['umid'], lemma_sims[colname]).correlation))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "63ec2a6b",
   "metadata": {},
   "outputs": [],
   "source": [
    "data_sim = pd.DataFrame(zip(list(range(13)), um_o, um_a), columns = ['layer','umid_o', 'umid_a'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 100,
   "id": "46b49df1",
   "metadata": {},
   "outputs": [],
   "source": [
    "data_sim.to_csv('/makesense_dir_path/analysis/usim_analysis/sim_gold.csv', index = False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "id": "043791db",
   "metadata": {},
   "outputs": [],
   "source": [
    "def set_style():\n",
    "    sns.set_context(\"paper\")\n",
    "    \n",
    "    sns.set(font='serif')\n",
    "    sns.set_style(\"whitegrid\", {\n",
    "        \"font.family\": \"serif\",\n",
    "        \"font.serif\": [\"Times\", \"Palatino\", \"serif\"]\n",
    "    })"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 79,
   "id": "8cf1778b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x360 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "set_style()\n",
    "plt.figure(figsize=(10, 5))\n",
    "\n",
    "a = list(range(13))\n",
    "ax1 = plt.plot(a, um_o,  color = 'blue', label = 'Original', marker = 'o')\n",
    "ax2 = plt.plot(a, um_a,  color = 'red', label = 'Makesense', marker = 'o')\n",
    "# ax3 = plt.plot(a, um_o, color = 'blue',linestyle='dashed', label = 'Original UMID', marker = 'o')\n",
    "# ax4 = plt.plot(a, um_a, color = 'red',linestyle='dashed', label = 'Approx. UMID', marker = 'o')\n",
    "\n",
    "plt.xlabel('Layer')\n",
    "plt.ylabel('Correlation (UMID)')\n",
    "plt.xticks(np.arange(0, 13, step=1))\n",
    "plt.ylim(0,0.4)\n",
    "# plt.title('Similarity vs annotation correlation across layers')\n",
    "plt.legend()\n",
    "plt.savefig(\"/makesense_dir_path/analysis/usim_analysis/umid_cos_layers.pdf\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "caceb630",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
