{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "collapsed": true,
    "execution": {
     "iopub.execute_input": "2022-01-12T21:56:58.801Z",
     "iopub.status.busy": "2022-01-12T21:56:58.797Z",
     "iopub.status.idle": "2022-01-12T21:57:00.061Z",
     "shell.execute_reply": "2022-01-12T21:57:00.067Z"
    },
    "jupyter": {
     "outputs_hidden": false,
     "source_hidden": false
    },
    "nteract": {
     "transient": {
      "deleting": false
     }
    }
   },
   "outputs": [],
   "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"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "nteract": {
     "transient": {
      "deleting": false
     }
    }
   },
   "source": [
    "# Plackett-Luce PL distributions\n",
    "\n",
    "we use a parameter `phi` to generate  PL distributions. It controls both the location (the mode) and the variance. we could give concentration measures such as expected distance form the mode\n",
    "\n",
    "- phi = -1 -> mode in the reverse of identity permutaion (5,4,3,2,1), small variance\n",
    "- phi =  -> uniform distribution over all the permus, high variance\n",
    "- phi = 1 -> mode in the idemtity permutation (1, 2, 3, ..., n ) , large variance\n",
    "\n",
    "\n",
    "The following is some illlustration on the different settings of phi ( on the reultsing PL distribution, you can see this as a"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "collapsed": true,
    "execution": {
     "iopub.execute_input": "2022-01-12T21:57:00.084Z",
     "iopub.status.busy": "2022-01-12T21:57:00.080Z",
     "iopub.status.idle": "2022-01-12T21:57:00.657Z",
     "shell.execute_reply": "2022-01-12T21:57:00.724Z"
    },
    "jupyter": {
     "outputs_hidden": false,
     "source_hidden": false
    },
    "nteract": {
     "transient": {
      "deleting": false
     }
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-1.0  , the probability of e is: 5.780111869675654e-22 , rev(e): 0.020192399479783622\n",
      "-0.75  , the probability of e is: 1.1042126951732606e-17 , rev(e): 0.005017547588027264\n",
      "-0.5  , the probability of e is: 1.1042957974974056e-13 , rev(e): 0.0006526964675212318\n",
      "-0.25  , the probability of e is: 3.864368496619603e-10 , rev(e): 2.9709233996126372e-05\n",
      "0.0  , the probability of e is: 2.755731922398589e-07 , rev(e): 2.755731922398589e-07\n",
      "0.25  , the probability of e is: 2.970923399612637e-05 , rev(e): 3.864368496619605e-10\n",
      "0.5  , the probability of e is: 0.0006526964675212315 , rev(e): 1.1042957974974048e-13\n",
      "0.75  , the probability of e is: 0.0050175475880272664 , rev(e): 1.1042126951732606e-17\n",
      "1.0  , the probability of e is: 0.020192399479783626 , rev(e): 5.780111869675648e-22\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1080x216 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "n = 10 # numer of systems\n",
    "m = 8 # numner of metrics\n",
    "p = 10# number of utterances\n",
    "def phi_to_w(phi):\n",
    "    return np.exp([n-phi*i for i in range(n)])\n",
    "\n",
    "df = pd.DataFrame()\n",
    "res = []\n",
    "for phi in np.linspace(-1,1,9):\n",
    "    w = phi_to_w(phi)\n",
    "    print(phi, \" , the probability of e is:\",pu.pl_proba(list(range(n)), w),\", rev(e):\", pu.pl_proba(list(range(n))[::-1], w))\n",
    "for phi in np.linspace(0,1,9):\n",
    "    w = phi_to_w(phi)\n",
    "    for inde,myw in enumerate(w):\n",
    "        res.append([phi,inde,myw])\n",
    "df = pd.DataFrame(res,columns=['phi','item','w'])\n",
    "f, ax = plt.subplots(1, figsize=(15,3))\n",
    "sns.barplot(hue=\"item\", y=\"w\", x=\"phi\", data=df,ax=ax)\n",
    "w = df[df.phi==1].w.values"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "collapsed": true,
    "execution": {
     "iopub.execute_input": "2022-01-12T21:57:00.669Z",
     "iopub.status.busy": "2022-01-12T21:57:00.665Z",
     "iopub.status.idle": "2022-01-12T21:57:00.678Z",
     "shell.execute_reply": "2022-01-12T21:57:00.727Z"
    },
    "jupyter": {
     "outputs_hidden": false,
     "source_hidden": false
    },
    "nteract": {
     "transient": {
      "deleting": false
     }
    }
   },
   "outputs": [],
   "source": [
    "\n",
    "n = 10 # numer of systems\n",
    "m = 7 # numner of metrics\n",
    "p = 5 # number of utterances\n",
    "repes = 20\n",
    "\n",
    "\n",
    "def borda(rankings):\n",
    "    return np.argsort(np.argsort(rankings.sum(axis=0)))\n",
    "\n",
    "def borda_u_m(df):\n",
    "    res = []\n",
    "    for i in df.Uterance.drop_duplicates().values:\n",
    "        rans = df[(df.Uterance==i)].ran.values\n",
    "        res.append(borda(rans))\n",
    "    \n",
    "    return borda(np.array(res))\n",
    "  \n",
    "def borda_m_u(df):\n",
    "    res = []\n",
    "    for i in df.Metric.drop_duplicates().values:\n",
    "        rans = df[(df.Metric==i)].ran.values\n",
    "        res.append(borda(rans))\n",
    "    return borda(np.array(res))\n",
    "\n",
    "\n",
    "def create_df_honest(m,n,p,phi):#all are sampled from the same distri\n",
    "    res = []\n",
    "    w = phi_to_w(phi)\n",
    "    for m_i in range(m):\n",
    "        ranks = pu.plackett_luce_sample(p,n,w=w)\n",
    "        for inde,ran in enumerate(ranks):\n",
    "            res.append([m_i,inde,ran])\n",
    "            \n",
    "    dfhonest = pd.DataFrame(res,columns = ['Metric', 'Uterance', 'ran'])\n",
    "    return dfhonest\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "collapsed": true,
    "execution": {
     "iopub.execute_input": "2022-01-12T21:57:00.689Z",
     "iopub.status.busy": "2022-01-12T21:57:00.683Z",
     "iopub.status.idle": "2022-01-12T21:57:00.700Z",
     "shell.execute_reply": "2022-01-12T21:57:00.731Z"
    },
    "jupyter": {
     "outputs_hidden": false,
     "source_hidden": false
    },
    "nteract": {
     "transient": {
      "deleting": false
     }
    }
   },
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Metric</th>\n",
       "      <th>Uterance</th>\n",
       "      <th>ran</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>[3.0, 1.0, 2.0, 0.0]</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>[2.0, 0.0, 3.0, 1.0]</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0</td>\n",
       "      <td>2</td>\n",
       "      <td>[2.0, 0.0, 3.0, 1.0]</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0</td>\n",
       "      <td>3</td>\n",
       "      <td>[2.0, 3.0, 0.0, 1.0]</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0</td>\n",
       "      <td>4</td>\n",
       "      <td>[2.0, 3.0, 1.0, 0.0]</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   Metric  Uterance                   ran\n",
       "0       0         0  [3.0, 1.0, 2.0, 0.0]\n",
       "1       0         1  [2.0, 0.0, 3.0, 1.0]\n",
       "2       0         2  [2.0, 0.0, 3.0, 1.0]\n",
       "3       0         3  [2.0, 3.0, 0.0, 1.0]\n",
       "4       0         4  [2.0, 3.0, 1.0, 0.0]"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "create_df_honest(3,4,5,0).head()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "nteract": {
     "transient": {
      "deleting": false
     }
    }
   },
   "source": [
    "## toy synthetic example\n",
    "\n",
    "There is a honeset sample:\n",
    "    $n$ systems, $m$ metrics and $p$ uterances :  sample from a PL the rankings of the $n$ systems\n",
    "    \n",
    "there is a manipulator (a metric) who ranks \n",
    "phi manipu and phi honest range"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "collapsed": true,
    "execution": {
     "iopub.execute_input": "2022-01-12T21:57:00.712Z",
     "iopub.status.busy": "2022-01-12T21:57:00.708Z",
     "iopub.status.idle": "2022-01-12T21:57:04.669Z",
     "shell.execute_reply": "2022-01-12T21:57:04.694Z"
    },
    "jupyter": {
     "outputs_hidden": false,
     "source_hidden": false
    },
    "nteract": {
     "transient": {
      "deleting": false
     }
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([ 9.95,  9.55, 10.55]), array([6.40683229, 6.88095197, 8.00921344]))"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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Bnnl6BCK+CHQFL0g1KdwPpchpaQ939LPWj/CKfgCigBLV7H6GcS+hIzt0V0Qdh8wRzGG3VANjIiBL3329u5ld2o3ZVYZdfE6kubBHf1CQkJC9qev7GckEmHt2rVs2bKFT33qU6TTaSorK7n77ruZMGECK1asYNGiRcXiJrNnz+brX/86tm1TUVHBf//3f1NTU8Odd97Jrl272L59O7t27eL222/ntttuA+AXv/gF3/3udxFCsHDhQn75y1/S2trKRz/6UXbt2gXA//t//4/zzjuPZ555httvv50bbriBm2++mSlTphzQ92g0yqmnnsq6detYunQp999/P+9///uLtcgHu/akSZP48Y9/jKqq3HPPPfzgBz/grrvuwrIsNmzYwHnnncfChQtZt24d//7v/05zczMf/ehH2b59OwA/+tGPhrTgh8tJLeKeXyx1OmyEEFRaNVRaNZxReR7QNwX/dtFaP+Ip+AKDCbvnS9I5j860MyCGPWHts9itEXrEK0IhaSaD9+JkeK31NUzNZHJyMpVWJboaTrWHhBxr/J/fb2ZLY8+oXnPexCRfufLQ1udQLF26lO9+97ssXboUx3H4xCc+wUMPPURVVRX3338/d9xxBz/96U8BsG2bvpwfnZ2dPP/88wgh+K//+i++/e1vF5OxbN26lSeeeIJUKsWcOXP42Mc+xptvvsnXv/51nnvuOSorK+no6ADgH/7hH/jkJz/J+eefz65du7jssst4/fXXefe7381ZZ53FL3/5S1atWkVtbS1/8zd/w3ve8x4MY1+SrA984APcd9991NTUoKoqEydOLIr4UNf+6Ec/Sjwe5x//8R8BuOuuu2hoaOC5555DVVXuvvvu4vVvu+02li9fzm9/+1s8zxuVDHEntYj/ZUszn//NHqZW+Syemmf2BJ2YOXLrM5iCP525pacDQbz23sxOdo7iFHwfQ8Ww92Rd2tJ20EYI4hGNUksnaqpYujbs+PWoHiWqR3E8h+1d29nOdmpjtdREa4rT8CEhIScvQznD7n/8jTfeYNOmTVx66aUAeJ7HhAkTiuf7yn4CNDQ0cN1117F3715s2y6WQQV497vfjWmamKZJdXU1zc3NrF69mmuvvZbKykoAysvLgaFLo/at13/yk5/kk5/8JGvXruXmm2/ma1/7Gq+++mqx/eWXX86XvvQlampqBvTvYNcejGuv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\n",
      "text/plain": [
       "<Figure size 576x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "#   borda_u_m_true = borda_u_m(dfhonest)\n",
    "#   borda_m_u_true = borda_m_u(dfhonest)\n",
    "#   borda_true = borda(dfhonest.ran.values)\n",
    "# the corrruption is in the metric, therefore a nmew metric , just one phi (w)\n",
    "\n",
    "\n",
    "n = 10 # numer of systems\n",
    "m = 10 # numner of metrics\n",
    "p = 10 # number of utterances\n",
    "repes = 10\n",
    "N = n*(n-1)/2\n",
    "\n",
    "reshonest, sol=[] , []\n",
    "for rep in range(repes):\n",
    "  for phi_honest in [.01, .1] : #np.linspace(0,.1, 2):\n",
    "    dfhonest = create_df_honest(m,n,p, phi_honest)\n",
    "    reshonest.append([mk.distance(borda_u_m(dfhonest)), \n",
    "                      mk.distance(borda_m_u(dfhonest)),\n",
    "                      mk.distance(borda(dfhonest.ran.values))])\n",
    "    for phi_manip in np.linspace(-0.5,.5,9):\n",
    "      res =[]\n",
    "      w = phi_to_w(phi_manip)\n",
    "      ranks = pu.plackett_luce_sample(p,n,w=w)\n",
    "#       print(ranks)\n",
    "      for inde,ran in enumerate(ranks):\n",
    "        res.append([-1,inde,ran])\n",
    "      df = pd.DataFrame(res,columns = ['Metric', 'Uterance', 'ran'])\n",
    "      df = pd.concat([dfhonest,df])\n",
    "#       print(borda_m_u(df), borda_u_m(df), borda(df.ran.values))\n",
    "      error_um = mk.distance(borda_u_m(df))/N # assuming e is the groupnd truth\n",
    "      error_mu = mk.distance(borda_m_u(df))/N\n",
    "      error_bo = mk.distance(borda(df.ran.values))/N\n",
    "      sol.append([phi_honest,phi_manip,rep,error_um, error_mu, error_bo])\n",
    "  #     print(phi_manip, error_um, error_mu, error_bo)\n",
    "  \n",
    "df = pd.DataFrame(sol,columns=['phi_honest','phi_manip','rep', 'error_um', 'error_mu', 'error_bo'])\n",
    "df = df.melt(id_vars=['phi_honest','phi_manip'], value_vars=['error_um', 'error_mu', 'error_bo'],\n",
    "             value_name='Error', var_name='Aggregation type')\n",
    "df['Aggregation type'] = df['Aggregation type'].str.replace('error_um','Uterance>Metric')\n",
    "df['Aggregation type'] = df['Aggregation type'].str.replace('error_mu','Metric>Uterance')\n",
    "df['Aggregation type'] = df['Aggregation type'].str.replace('error_bo','One level Borda')\n",
    "f, ax = plt.subplots(1, figsize=(8,4))\n",
    "# ax.set_yscale('log')\n",
    "sns.lineplot(data=df, style=\"phi_honest\", x=\"phi_manip\", hue=\"Aggregation type\", y=\"Error\")\n",
    "np.array(reshonest).mean(axis=0),np.array(reshonest).std(axis=0)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "nteract": {
     "transient": {
      "deleting": false
     }
    }
   },
   "source": [
    "# Scores\n",
    "\n",
    "For the same data generation process we use scores instead of rankings: \n",
    "\n",
    "Instead of sampling rankings, we sample the scores form the gumbels. \n",
    "Then aggregate them (with the mean)\n",
    "\n",
    "    - (a) only the honest samples\n",
    "    - (b) both honest and manipulators\n",
    "    \n",
    "We give the results as the kendall correlation between (a) and (b)\n",
    "\n",
    "We can extend to other correlation measures, and will have the same resutls"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "collapsed": true,
    "execution": {
     "iopub.execute_input": "2022-01-12T21:57:04.679Z",
     "iopub.status.busy": "2022-01-12T21:57:04.675Z",
     "iopub.status.idle": "2022-01-12T21:57:04.917Z",
     "shell.execute_reply": "2022-01-12T21:57:04.924Z"
    },
    "jupyter": {
     "outputs_hidden": false,
     "source_hidden": false
    },
    "nteract": {
     "transient": {
      "deleting": false
     }
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<AxesSubplot:xlabel='phi_manip', ylabel='Error'>"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import scipy\n",
    "repes = 4\n",
    "for repe in range(repes):\n",
    "    res = []\n",
    "    scores_honest = np.array([np.random.gumbel(phi_to_w(phi_honest), 1) for i in range(m*p)])\n",
    "    mean_honest = scores_honest.mean(axis=0)\n",
    "    for phi_manip in np.linspace(-1,1,9):\n",
    "        w = phi_to_w(phi_manip)\n",
    "        scores_manip = np.array([np.random.gumbel(w, 1) for i in range(m*p)])\n",
    "        mean_all = np.concatenate([scores_honest,scores_manip]).mean(axis=0)\n",
    "        ken = scipy.stats.kendalltau(mean_all,mean_honest)[0]\n",
    "        res.append([phi_honest, phi_manip, ken, repe])\n",
    "df = pd.DataFrame(res,columns=['phi_honest', 'phi_manip', 'Error', 'repe'])\n",
    "sns.lineplot(data=df, style=\"phi_honest\", x=\"phi_manip\", y=\"Error\") # more correlations  as hue=\"Aggregation type\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": false,
     "source_hidden": false
    },
    "nteract": {
     "transient": {
      "deleting": false
     }
    }
   },
   "outputs": [],
   "source": []
  }
 ],
 "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
}
