{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-01-20T20:33:41.350Z",
     "iopub.status.busy": "2022-01-20T20:33:41.342Z",
     "iopub.status.idle": "2022-01-20T20:33:43.053Z",
     "shell.execute_reply": "2022-01-20T20:33:43.101Z"
    },
    "jupyter": {
     "outputs_hidden": false,
     "source_hidden": false
    },
    "nteract": {
     "transient": {
      "deleting": false
     }
    }
   },
   "outputs": [
    {
     "ename": "ModuleNotFoundError",
     "evalue": "No module named 'mallows_kendall'",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mModuleNotFoundError\u001b[0m                       Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-1-cf886e8151e8>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m     11\u001b[0m \u001b[0;32mimport\u001b[0m \u001b[0msys\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     12\u001b[0m \u001b[0msys\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mpath\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0minsert\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m'../top-k-mallows'\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 13\u001b[0;31m \u001b[0;32mimport\u001b[0m \u001b[0mmallows_kendall\u001b[0m \u001b[0;32mas\u001b[0m \u001b[0mmk\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     14\u001b[0m \u001b[0;32mimport\u001b[0m \u001b[0mpermutil\u001b[0m \u001b[0;32mas\u001b[0m \u001b[0mpu\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     15\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mModuleNotFoundError\u001b[0m: No module named 'mallows_kendall'"
     ]
    }
   ],
   "source": [
    "from scipy.spatial.distance import pdist\n",
    "import collections\n",
    "import seaborn as sns\n",
    "import subprocess\n",
    "import numpy as np\n",
    "import itertools as it\n",
    "import scipy as sp\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "from  imp import reload\n",
    "import sys\n",
    "sys.path.insert(1, '../top-k-mallows')\n",
    "import mallows_kendall as mk\n",
    "import permutil as pu\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "nteract": {
     "transient": {
      "deleting": false
     }
    }
   },
   "source": [
    "# what happens as more and more metrics are corrpted?\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-01-20T21:25:54.236Z",
     "iopub.status.busy": "2022-01-20T21:25:54.231Z",
     "iopub.status.idle": "2022-01-20T21:25:54.243Z",
     "shell.execute_reply": "2022-01-20T21:25:54.246Z"
    },
    "jupyter": {
     "outputs_hidden": false,
     "source_hidden": false
    },
    "nteract": {
     "transient": {
      "deleting": false
     }
    }
   },
   "outputs": [],
   "source": [
    "def phi_to_w(phi):\n",
    "    return np.exp([n-phi*i for i in range(n)])\n",
    "\n",
    "def Borda_u_m(data):\n",
    "    return data.sum(axis=1).argsort().argsort().sum(axis=0).argsort().argsort()\n",
    "def Borda_m_u(data):\n",
    "    return data.sum(axis=0).argsort().argsort().sum(axis=0).argsort().argsort()\n",
    "def Borda(data):\n",
    "    return data.reshape(m*p,-1).sum(axis=0).argsort().argsort()\n",
    "\n",
    "def Mean_u_m(data):\n",
    "    return data.mean(axis=1).mean(axis=0).argsort().argsort()[::-1]\n",
    "def Mean_m_u(data):\n",
    "    return data.mean(axis=0).mean(axis=0).argsort().argsort()[::-1]\n",
    "def Mean(data):\n",
    "    return data.reshape(m*p,-1).mean(axis=0).argsort().argsort()[::-1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-01-20T21:45:20.235Z",
     "iopub.status.busy": "2022-01-20T21:45:20.230Z",
     "iopub.status.idle": "2022-01-20T21:45:23.419Z",
     "shell.execute_reply": "2022-01-20T21:45:23.444Z"
    },
    "jupyter": {
     "outputs_hidden": false,
     "source_hidden": false
    },
    "nteract": {
     "transient": {
      "deleting": false
     }
    }
   },
   "outputs": [],
   "source": [
    "\n",
    "n = 10 # numer of systems\n",
    "m = 11 # numner of metrics\n",
    "p = 12 # number of utterances\n",
    "repes = 10\n",
    "N = n*(n-1)/2\n",
    "phis_honest = [.01, .1,.5] \n",
    "\n",
    "res, sol=[] , []\n",
    "for repe in range(repes):\n",
    "    for phi_honest in phis_honest : #np.linspace(0,.1, 2):\n",
    "        honest_full = pu.plackett_luce_sample(m*p,n,w=phi_to_w(phi_honest))\n",
    "        honest_full= honest_full.reshape(m,p,n)\n",
    "\n",
    "    for num_corrupted_metrics in range(m):\n",
    "        bum, bmu, b = Borda_u_m(honest_full),Borda_m_u(honest_full),Borda(honest_full)\n",
    "        dum, dmu, db = mk.distance(bum), mk.distance(bmu), mk.distance(b)\n",
    "        res.append([repe,phi_honest,num_corrupted_metrics,dum, dmu, db])\n",
    "        # now, at the end of the iter , we corrupt . \n",
    "        manip = np.tile(np.arange(n)[::-1], (p, 1))  \n",
    "        honest_full[num_corrupted_metrics,:,:] = manip\n",
    "\n",
    "df = pd.DataFrame(res,columns=['repe','Dispersion','# Corrupted Metrics','Uter>Metric', 'Metric>Uter', 'BordaAll'])\n",
    "df = df.melt(id_vars=['repe','Dispersion','# Corrupted Metrics'],var_name='Agg_type',value_name='Error')\n",
    "df['Error'] = df['Error']/N\n",
    "sns.lineplot(data=df,x='# Corrupted Metrics',y='Error', style='Dispersion',hue='Agg_type')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 95,
   "metadata": {
    "collapsed": true,
    "execution": {
     "iopub.execute_input": "2022-01-20T21:49:32.383Z",
     "iopub.status.busy": "2022-01-20T21:49:32.378Z",
     "iopub.status.idle": "2022-01-20T21:49:32.642Z",
     "shell.execute_reply": "2022-01-20T21:49:32.649Z"
    },
    "jupyter": {
     "outputs_hidden": false,
     "source_hidden": false
    },
    "nteract": {
     "transient": {
      "deleting": false
     }
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<AxesSubplot:xlabel='# Corrupted Metrics', ylabel='Error'>"
      ]
     },
     "execution_count": 95,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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UkpditOnTxMZGUlmZiaHDh1i2bJlAMydOze3p3D06FHat29Pt27dAHdZ561btxIWFsbcuXPZuXMnsbGxHD58mObNmzNy5EgAxo8fzzPPuJ+LHT58ON988w19+/YlMzOTpUuX8v7775OamkpMTIwmgrLsUGYCVewu1v7xDTdGDrv4BkqpAl3KL/fidPbSEMDq1au5++672bp1K6tWrWLIkCHY7XZq1qzJX/7yF9atW8c111xDhw4dCAsLA2DlypW57erUqZM71wDA8uXLefXVVzl16hQpKSlERETQt29fvvnmG7p370758uUZMGAAL7zwAm+88Qb2MjCHiY4RFCCRVDJs8HnOen7aOtfqcJRSV6BTp04cPXqU5OTkC7YrSlnnzMxMHnjgAebMmcOWLVu4//77ycx0z6kVExPD0qVLadCgAe3atePYsWO5PZHSThPBeXJysknwc5Fls3GPfxfu7K53DClVlu3YsQOn00m1atW4/vrrmTVrFk6nk+TkZFauXEmHDh3ybdOtW7fcdocOHcqtLHr2S7969eqkp6fn3kl04sQJfvrpJ/bv3098fDzx8fG8++67+WY1K6300tB5Nu5cSbbNnR/POE8TUqOBtQEppS7Z2TECcA8Qf/zxx9jtdm6//XZWr15N69atERFeffVVatWqxY4d5w5o33777SxbtozmzZtTr149OnXqBEDlypW5//77adGiBbVq1aJ9+/YAfPXVV/To0YNy5f4cT7ztttt49NFHOXPmTMl86Cvg1TLU3uDtMtTTFjzLm8fnYjOGhlk2vhq92WvHUupqpGWorXepZaj10tB59qXEAnBtlvBKz08sjkYppbxPE8F5Es8cAGNwAemnizZlnVJKlWWaCM5z2JZB2Blhr78h+fgBq8NRSimv08HiPE5lZnDQz3Cjsx7T+39EYIUqVoeklFJepz2CPDbE/kCOCL+ZfXy25FV9olgp5RM0EeSxdd9qAFIcws7UDRZHo5RSJUMTQR77U2PBGFqfqcBrwxdaHY5SPuNs2eiIiAhat27Nv/71L1wuFwDr169n4sSJJR7TggULePnll0v8uFbQMYI8DmYdhAAhTTJJTjlI/TpNrA5JKZ+QtzbQkSNHGDp0KCdOnOD5558nKiqKqKgCb38vFk6ns8B6QP369aNfv35eO25poj2CPBLspwFI9HNS+ZrqFkejlG+qUaMGU6dO5Z133sEYw4oVK+jTpw8AP/74I5GRkURGRtKmTRtOnjzJihUr6NatG7feeivh4eGMHTs2tzexePFiOnXqRNu2bbnjjjtIT08H3JPDPPbYY7Rt25bZs2fz1ltv0bx5c1q1asXgwYMBmDFjBuPHjwcgPj6eHj160KpVK2644Qb2798PuCesmThxIp07d6Zhw4ZFmrymNNIegUdaegpHHe6a4lM7TSWoUlWLI1LKdzVs2BCn08mRI0fOWT5lyhTeffddunTpQnp6OgEBAQCsXbuW2NhY6tevT69evZg7dy7R0dH885//ZOnSpVSsWJFXXnmF119/PbeEdLVq1fjtt98AqFOnDnv37qVcuXKkpqbmi2fChAncc8893HPPPXz00UdMnDiRefPmAXDo0CFWrVrFjh076NevHwMHDvTeifES7RF4rN26BCNC3SzD6u3fWB2OUqoAXbp0YdKkSbz11lukpqbicLh/y3bo0IGGDRtit9sZMmQIq1at4tdffyU2NpYuXboQGRnJxx9/zL59+3L3NWjQoNzXrVq14q677uLTTz/N3Wdeq1evZujQoYB7DoJVq1blruvfvz82m43mzZtz+PBhb310r9JE4LH9gPuOIRtwIvOYtcEo5eP27NmD3W6nRo0a5yx//PHHmTZtGqdPn6ZLly65xeLOzhB2lohgjOGmm25i06ZNbNq0idjYWD788MPcNnnLTn/77beMGzeO3377jfbt21/SdJV5C82VtdptZ2ki8NiXtgMxhuH1RvDokKlWh6OUz0pOTmbs2LGMHz8+3xf87t27admyJY899hjt27fPTQRr165l7969uFwuZs2aRdeuXenYsSM///wzcXFxAGRkZLBr1658x3O5XBw4cIDu3bvzyiuvkJaWljuWcFbnzp2ZOXMmAJ999hnXX3+9Nz66ZXSMwOOAMwnjJ3yx72MGOf+GrQzMKqTU1eJs2ejs7GwcDgfDhw9n0qRJ+dq98cYbLF++HJvNRkREBLfccgurV6+mffv2jB8/nri4OLp3787tt9+OzWZjxowZDBkyJLcU9D//+U+aNDn3bkCn08mwYcNIS0vDGMPEiROpXLnyOW3efvttRowYwWuvvUZwcDDTp0/32rmwgpah9rj+w+akOuyEn7ExZ/Tvxb5/pXxFSZehXrFiBVOmTOGbb3Rs7ywtQ30ZDh87SKrD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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "manip_factor = 1000\n",
    "repes = 1\n",
    "res, sol=[] , []\n",
    "for repe in range(repes):\n",
    "    for phi_honest in phis_honest : \n",
    "        honest_full = np.array([np.random.gumbel(phi_to_w(phi_honest), 1) for i in range(m*p)])\n",
    "        honest_full= honest_full.reshape(m,p,n)\n",
    "    for num_corrupted_metrics in range(m):\n",
    "        bum, bmu, b = Mean_u_m(honest_full),Mean_m_u(honest_full),Mean(honest_full)\n",
    "        dum, dmu, db = mk.distance(bum), mk.distance(bmu), mk.distance(b)\n",
    "        res.append([repe,phi_honest,num_corrupted_metrics,dum, dmu, db])\n",
    "        manip = np.tile(np.random.gumbel(manip_factor*phi_to_w(1), 1)[::-1], (p, 1))  \n",
    "        honest_full[num_corrupted_metrics,:,:] = manip\n",
    "\n",
    "\n",
    "df = pd.DataFrame(res,columns=['repe','Dispersion','# Corrupted Metrics','Uter>Metric', 'Metric>Uter', 'BordaAll'])\n",
    "df = df.melt(id_vars=['repe','Dispersion','# Corrupted Metrics'],var_name='Agg_type',value_name='Error')\n",
    "df['Error'] = df['Error']/N\n",
    "sns.lineplot(data=df,x='# Corrupted Metrics',y='Error', style='Dispersion',hue='Agg_type')"
   ]
  }
 ],
 "metadata": {
  "kernel_info": {
   "name": "python3"
  },
  "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.9.7"
  },
  "nteract": {
   "version": "0.28.0"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 1
}
