{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "7cebc479",
   "metadata": {},
   "outputs": [],
   "source": [
    "import warnings\n",
    "warnings.filterwarnings('ignore')\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import scipy\n",
    "from matplotlib import pyplot as plt\n",
    "plt.style.use('seaborn-paper')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7c098b17",
   "metadata": {},
   "source": [
    "### Preprocessing\n",
    "\n",
    "1. Read the data\n",
    "\n",
    "2. Calculate normalized qualification score: (math+reading+writng)/300"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "e7c17ede",
   "metadata": {},
   "outputs": [],
   "source": [
    "Exams = pd.read_csv('exams.csv')\n",
    "Exams = Exams[Exams['gender'] == 'female']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "bf511132",
   "metadata": {},
   "outputs": [],
   "source": [
    "Exams['Qscore'] = (Exams['math score'] + Exams['reading score'] + Exams['writing score'])/300"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "baa95ebf",
   "metadata": {},
   "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>gender</th>\n",
       "      <th>race/ethnicity</th>\n",
       "      <th>parental level of education</th>\n",
       "      <th>lunch</th>\n",
       "      <th>test preparation course</th>\n",
       "      <th>math score</th>\n",
       "      <th>reading score</th>\n",
       "      <th>writing score</th>\n",
       "      <th>Qscore</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>female</td>\n",
       "      <td>group D</td>\n",
       "      <td>some high school</td>\n",
       "      <td>free/reduced</td>\n",
       "      <td>none</td>\n",
       "      <td>40</td>\n",
       "      <td>59</td>\n",
       "      <td>55</td>\n",
       "      <td>0.513333</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>female</td>\n",
       "      <td>group D</td>\n",
       "      <td>high school</td>\n",
       "      <td>standard</td>\n",
       "      <td>none</td>\n",
       "      <td>63</td>\n",
       "      <td>77</td>\n",
       "      <td>76</td>\n",
       "      <td>0.720000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>female</td>\n",
       "      <td>group A</td>\n",
       "      <td>bachelor's degree</td>\n",
       "      <td>standard</td>\n",
       "      <td>none</td>\n",
       "      <td>62</td>\n",
       "      <td>59</td>\n",
       "      <td>63</td>\n",
       "      <td>0.613333</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>female</td>\n",
       "      <td>group D</td>\n",
       "      <td>high school</td>\n",
       "      <td>standard</td>\n",
       "      <td>completed</td>\n",
       "      <td>80</td>\n",
       "      <td>87</td>\n",
       "      <td>90</td>\n",
       "      <td>0.856667</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>female</td>\n",
       "      <td>group C</td>\n",
       "      <td>associate's degree</td>\n",
       "      <td>standard</td>\n",
       "      <td>completed</td>\n",
       "      <td>54</td>\n",
       "      <td>62</td>\n",
       "      <td>65</td>\n",
       "      <td>0.603333</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>988</th>\n",
       "      <td>female</td>\n",
       "      <td>group B</td>\n",
       "      <td>some college</td>\n",
       "      <td>standard</td>\n",
       "      <td>none</td>\n",
       "      <td>75</td>\n",
       "      <td>76</td>\n",
       "      <td>81</td>\n",
       "      <td>0.773333</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>991</th>\n",
       "      <td>female</td>\n",
       "      <td>group C</td>\n",
       "      <td>associate's degree</td>\n",
       "      <td>standard</td>\n",
       "      <td>none</td>\n",
       "      <td>87</td>\n",
       "      <td>93</td>\n",
       "      <td>88</td>\n",
       "      <td>0.893333</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>993</th>\n",
       "      <td>female</td>\n",
       "      <td>group A</td>\n",
       "      <td>associate's degree</td>\n",
       "      <td>standard</td>\n",
       "      <td>none</td>\n",
       "      <td>58</td>\n",
       "      <td>54</td>\n",
       "      <td>58</td>\n",
       "      <td>0.566667</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>997</th>\n",
       "      <td>female</td>\n",
       "      <td>group C</td>\n",
       "      <td>some high school</td>\n",
       "      <td>free/reduced</td>\n",
       "      <td>none</td>\n",
       "      <td>32</td>\n",
       "      <td>35</td>\n",
       "      <td>41</td>\n",
       "      <td>0.360000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>998</th>\n",
       "      <td>female</td>\n",
       "      <td>group C</td>\n",
       "      <td>some college</td>\n",
       "      <td>standard</td>\n",
       "      <td>none</td>\n",
       "      <td>73</td>\n",
       "      <td>74</td>\n",
       "      <td>82</td>\n",
       "      <td>0.763333</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>483 rows × 9 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "     gender race/ethnicity parental level of education         lunch  \\\n",
       "1    female        group D            some high school  free/reduced   \n",
       "5    female        group D                 high school      standard   \n",
       "6    female        group A           bachelor's degree      standard   \n",
       "11   female        group D                 high school      standard   \n",
       "17   female        group C          associate's degree      standard   \n",
       "..      ...            ...                         ...           ...   \n",
       "988  female        group B                some college      standard   \n",
       "991  female        group C          associate's degree      standard   \n",
       "993  female        group A          associate's degree      standard   \n",
       "997  female        group C            some high school  free/reduced   \n",
       "998  female        group C                some college      standard   \n",
       "\n",
       "    test preparation course  math score  reading score  writing score  \\\n",
       "1                      none          40             59             55   \n",
       "5                      none          63             77             76   \n",
       "6                      none          62             59             63   \n",
       "11                completed          80             87             90   \n",
       "17                completed          54             62             65   \n",
       "..                      ...         ...            ...            ...   \n",
       "988                    none          75             76             81   \n",
       "991                    none          87             93             88   \n",
       "993                    none          58             54             58   \n",
       "997                    none          32             35             41   \n",
       "998                    none          73             74             82   \n",
       "\n",
       "       Qscore  \n",
       "1    0.513333  \n",
       "5    0.720000  \n",
       "6    0.613333  \n",
       "11   0.856667  \n",
       "17   0.603333  \n",
       "..        ...  \n",
       "988  0.773333  \n",
       "991  0.893333  \n",
       "993  0.566667  \n",
       "997  0.360000  \n",
       "998  0.763333  \n",
       "\n",
       "[483 rows x 9 columns]"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "Exams"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7f2b95bd",
   "metadata": {},
   "source": [
    "### Fit the distribution\n",
    "\n",
    "We try to fit the qualification score by a beta distribution\n",
    "\n",
    "Because the maximum of Qscore is 1.0, we fix loc = 0 and scale = 1+1e-8 (slightly larger than 1.0) to avoid error"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "8c374975",
   "metadata": {},
   "outputs": [],
   "source": [
    "import scipy.integrate as integrate\n",
    "from scipy.stats import uniform, beta\n",
    "Qscore = Exams['Qscore']\n",
    "a, b, loc, scale = beta.fit(Qscore, floc = 0 ,fscale = 1+1e-8)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "b639b384",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(4.149196473806914, 1.7897438509912498, 0, 1.00000001)"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "a,b,loc,scale"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "144bc196",
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAlkAAAHYCAYAAAB+/P2nAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8qNh9FAAAACXBIWXMAAA9hAAAPYQGoP6dpAABg60lEQVR4nO3dd3hUVfoH8O+kTRoJJCFAConUBJIQOkEkdCMgRUVQXEHQXRVF97eKBUFYcEFXV3EtiEiRLiAiValK7yWhlyS0QCAhvc7M+f1xN0PuTAKZJDN3yvfzPPPAfe+9c9/JJcnLOeeeoxJCCBARERFRrXJSOgEiIiIie8Qii4iIiMgMWGQRERERmQGLLCIiIiIzYJFFREREZAYssoiIiIjMgEUWERERkRmwyCIiIiIyAxZZRERERGbAIovIzowePRrPPfecfjs8PBxz587Vb2/cuBHNmjWDs7MzpkyZgilTpqBbt25mzUmlUmHr1q1mvYatmTt3LsLDw/XbhvetNqSkpEClUuHixYsAgAULFiAkJKRWr1HRdYhI4qJ0AkRkXocOHYK3t7d++7XXXsPw4cPx+uuvw8fHBwAwfvz4WrnW1q1b0bdvXxiu1pWWlgY/P79auYa9mjVrVpWO02g0cHV1xY4dO9CjR4/7HhsaGoq0tDTUr1+/FjKUzJ07F9OnT0dKSopZr0NkD1hkEdm58r/4dDodUlJS0K9fPwQFBVksh4YNG1rsWuYkhNAXObXN19e3Vt+vpKQEbm5uFvnaOzs72809JqpN7C4ksqDs7Gw8+eST8PDwQIsWLbBhwwaoVCrs3LkTQMXdOYbdeT/88ANiY2Ph5eWFsLAwTJo0CRqNptJrlnUXpqSkwNnZGUII9OrVS39dw/fXaDSYPHkyGjduDHd3d0RGRmLdunUAgLNnz6J///4ICAhA3bp10b9/fyQnJwOQuoz69u0LQOoeVKlUWLBggX67fHfhpk2bEB0dDbVajWbNmuHHH3/U7yvrevrll1/QqVMneHl5oUePHrhy5Uqln/Hy5ctISEiAj48PfHx80LlzZ1nX1fLly/XXCwkJwfTp0/X7Dh48iLi4OKjVaoSGhuKTTz6RvbdKpcLcuXPRq1cveHh4YP369QCAL7/8Ek2aNIGnpyc6duyov4eV2blzJyIjI+Hh4YGBAwciIyNDtt+wu/CLL77AQw89pM95ypQpAIBmzZoBAHr27AmVSoXRo0cDAHr06IG33noLY8eOhY+PD95+++1Ku/EWLVqE0NBQeHt746WXXkJJSYns85a/V+XfY+fOnXjppZeQmpqqv8c7d+6s8Do//vgjmjVrBrVajejoaGzatEn2tVCpVNi2bRtatWqFOnXqYMiQIbh79+59v4ZEtoZFFpEFvfnmmzh16hS2b9+OhQsX6n9xmkKn0+HTTz9FUlISZs+ejblz52LOnDkPPC80NBTXrl0DAKxevRppaWno2rWr0XEffvghvv/+e3zxxRc4deoU/vOf/+hbbvLy8vDUU09h9+7d2L17N9zc3DBixAj9+//0008ApO7BtLQ0DB8+3Oj9U1JSMGTIEAwZMgQnT57Em2++iTFjxmDPnj2y46ZMmYKPP/4YBw8eREFBAf7+979X+tlee+01NGjQAIcOHcLhw4cxfvx4ODlJP95+//13PP/883jhhReQlJSElStXolGjRgCA3Nxc9O/fH61bt8bx48fxySefYOrUqVi6dKlRLq+++ipOnz6Nhx9+GPPmzcOsWbPwzTffICkpCc8//zz69+8v60IrLzs7G0OHDkXPnj1x7NgxDBw4EDNnzqz08xw6dAgffvghZs+ejQsXLuCnn37SF1f79+8HcO8elu9m/O6779C8eXMcPXoUb775ZoXvnZGRgR9++AHr16/HmjVrsGHDBvzrX/+qNJfyunbtis8++wwhISH6e1zRv6G9e/dizJgxGD9+PE6ePImhQ4diyJAhRl+f6dOnY8GCBdixYwcSExNlxS+RXRBEZBHZ2dnCxcVFbNq0SR/btGmTACB27NghhBBi/vz5Ijg4WHbehx9+KB5++OFK33fGjBmiZ8+e+u1Ro0aJkSNH6rfDwsLE999/L4QQorS0VHY9w/cvKCgQarVarFy5skqfKS0tTQAQqampQgghtmzZIir6sQJAbNmyRQghxDvvvCM6duwo2z98+HDx1FNPCSGESE5OFgDEihUr9PuXLl0q/P39K80jKipK/PjjjxXu6969uxg3blyF+7799lsRFBQkSktL9bF33nlHdOjQQZb7lClTZOc99NBDYt26dbJY3759xbRp0yq8zjfffCOCg4Nl1xk+fLgICwvTb5e/b6tWrRItWrSQHV+monsohBDx8fGiR48esljZ1/LChQtCCOnfFwBx5swZ/THff/+9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\n",
      "text/plain": [
       "<Figure size 700x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Visualize the distribution\n",
    "x = np.linspace(0,1,1000)\n",
    "plt.figure(figsize = (7,5))\n",
    "plt.plot(x, beta.pdf(x, a, b, loc, scale),\n",
    "       'r-', lw=3, alpha=0.6, label = 'fitted')\n",
    "plt.hist(Qscore, label = 'actual score',density=True)\n",
    "plt.title('qualification score distribution')\n",
    "plt.xlabel('Score', fontsize = 12)\n",
    "plt.xticks(fontsize = 12)\n",
    "plt.yticks(fontsize = 12)\n",
    "plt.legend()\n",
    "plt.savefig('score_exam_female.pdf')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d7d229fd",
   "metadata": {},
   "source": [
    "###  Decision Maker to incentivize improvement"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "f1052c41",
   "metadata": {},
   "outputs": [],
   "source": [
    "threshold = 0.316364\n",
    "def compute_decision_benefit_strategic(r, theta):\n",
    "    # lower bound for improvement to begin\n",
    "    if theta == 0 or theta == 1:\n",
    "        xstar = theta\n",
    "    else:\n",
    "        xstar = (1 + (1/theta**(2)-1) * np.exp(2*threshold/np.log(1+r)))**(-0.5)\n",
    "\n",
    "    result = integrate.quad(lambda x: (theta-x)*beta.pdf(x,a,b,loc,scale), xstar, theta)[0]\n",
    "    return result\n",
    "\n",
    "def maximize_one_decision_benefit_strategic(r):\n",
    "    theta = np.linspace(0.0001,1,10000)\n",
    "    myFn = np.vectorize(compute_decision_benefit_strategic, excluded=['r'])\n",
    "    benefit = myFn(r,theta)\n",
    "    df = pd.DataFrame({'theta':theta, 'benefit':benefit})\n",
    "    max_benefit = df.max()['benefit']\n",
    "    max_theta = df[df['benefit'] == max_benefit]['theta'].item()\n",
    "    min_improve = (1 + (1/max_theta**(2)-1) * np.exp(2*threshold/np.log(1+r)))**(-0.5)\n",
    "    max_percentage = 1-beta.cdf(min_improve,a,b,loc,scale)\n",
    "    print('Strategic threshold is %f and the max benefit is %f' %(max_theta, max_benefit))\n",
    "    print('Finally, qualified population percentage will be: %.2f%%' % (100*max_percentage))\n",
    "#     return max_theta, max_benefit"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "7460709a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Strategic threshold is 0.873600 and the max benefit is 0.141997\n",
      "Finally, qualified population percentage will be: 87.17%\n"
     ]
    }
   ],
   "source": [
    "maximize_one_decision_benefit_strategic(0.3)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d0b2863a",
   "metadata": {},
   "source": [
    "**This means when considering improvement, the decision maker can have both higher threshold and higher maximum utility**"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e0123c28",
   "metadata": {},
   "source": [
    "### Varying r and ploting:\n",
    "\n",
    "1. the optimal strategic threshold\n",
    "\n",
    "2. the total improvement amount\n",
    "\n",
    "It is reasonable to varying r from 0 to 0.3 to see the threshold change"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "d4426763",
   "metadata": {},
   "outputs": [],
   "source": [
    "def produce_threshold_dataframe(r_list, maximize_func):\n",
    "    best_threshold = {'r':[],'optimal theta':[],'qualified percentage':[],'optimal utility':[]}\n",
    "    for r in r_list:\n",
    "        theta = np.linspace(0.0001,1,10000)\n",
    "        benefit = maximize_func(r,theta)\n",
    "        df = pd.DataFrame({'theta':theta, 'benefit':benefit})\n",
    "        max_benefit = df.max()['benefit']\n",
    "        max_theta = df[df['benefit'] == max_benefit]['theta'].item()\n",
    "        min_improve = (1 + (1/max_theta**(2)-1) * np.exp(2*threshold/np.log(1+r)))**(-0.5)\n",
    "        max_percentage = 1-beta.cdf(min_improve,a,b,loc,scale)\n",
    "        best_threshold['r'].append(r)\n",
    "        best_threshold['optimal theta'].append(max_theta)\n",
    "        best_threshold['qualified percentage'].append(np.round(100*max_percentage, 4))\n",
    "        best_threshold['optimal utility'].append(max_benefit)\n",
    "    return pd.DataFrame(best_threshold)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "d7ca3552",
   "metadata": {},
   "outputs": [],
   "source": [
    "r_list = np.linspace(0,0.3,7)\n",
    "r_list = r_list[1:]\n",
    "maximize_func = np.vectorize(compute_decision_benefit_strategic, excluded=['r'])\n",
    "exam_res = produce_threshold_dataframe(r_list, maximize_func)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "9e262807",
   "metadata": {},
   "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>r</th>\n",
       "      <th>optimal theta</th>\n",
       "      <th>qualified percentage</th>\n",
       "      <th>optimal utility</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.05</td>\n",
       "      <td>0.9998</td>\n",
       "      <td>99.9916</td>\n",
       "      <td>0.301078</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.10</td>\n",
       "      <td>0.9887</td>\n",
       "      <td>99.2339</td>\n",
       "      <td>0.283918</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.15</td>\n",
       "      <td>0.9603</td>\n",
       "      <td>96.7004</td>\n",
       "      <td>0.239202</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.20</td>\n",
       "      <td>0.9292</td>\n",
       "      <td>93.3283</td>\n",
       "      <td>0.191821</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.25</td>\n",
       "      <td>0.9019</td>\n",
       "      <td>90.0360</td>\n",
       "      <td>0.153262</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>0.30</td>\n",
       "      <td>0.8795</td>\n",
       "      <td>87.1091</td>\n",
       "      <td>0.124109</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "      r  optimal theta  qualified percentage  optimal utility\n",
       "0  0.05         0.9998               99.9916         0.301078\n",
       "1  0.10         0.9887               99.2339         0.283918\n",
       "2  0.15         0.9603               96.7004         0.239202\n",
       "3  0.20         0.9292               93.3283         0.191821\n",
       "4  0.25         0.9019               90.0360         0.153262\n",
       "5  0.30         0.8795               87.1091         0.124109"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "exam_res.to_csv('exam_female.csv')\n",
    "exam_res"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "4a8e97f9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 300x250 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib\n",
    "matplotlib.rcParams.update({'font.size': 20.7})\n",
    "fig, axes = plt.subplots(1, 1, figsize = (3,2.5))\n",
    "plt.tight_layout\n",
    "plt.plot(exam_res['r'], exam_res['optimal theta'], marker='o', label = r'$\\theta^*$')\n",
    "plt.plot(exam_res['r'], exam_res['optimal utility'], marker = 's', label = 'total improvement')\n",
    "plt.xlabel('r')\n",
    "plt.ylabel('Threshold (or improvement)')\n",
    "plt.legend()\n",
    "plt.tight_layout()\n",
    "fig.savefig('threshold_exam_female.pdf')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2674bd55",
   "metadata": {},
   "source": [
    "### Plot the percentage of population who manipulates under the strategic optimal threshold"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "2f27c097",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_manipulation_percentage(theta_list, r_list, prob = [0.1,0.2,0.3,0.4,0.5]):\n",
    "    final_res = {}\n",
    "    violate = False\n",
    "    for p in prob:\n",
    "        manip_res = {'r':[],'optimal theta':[],'manipulation percentage':[]}\n",
    "        for i in range(len(theta_list)):\n",
    "            theta = theta_list[i]\n",
    "            r = r_list[i]\n",
    "            x = np.linspace(0,theta,1000)\n",
    "            A = -np.log(np.sqrt((1/theta**2-1)/(1/x**2-1)))*np.log(1+r)\n",
    "            T = -np.log(np.sqrt((1/theta**2-1)/(1/x**2-1)))/np.log(2)\n",
    "            manip_res['r'].append(np.round(r,2))\n",
    "            manip_res['optimal theta'].append(np.round(theta,2))\n",
    "            y1 = (1-p) * 1/(1+r)**T - (theta - x)\n",
    "            y2 = np.zeros(1000)\n",
    "            i = 0\n",
    "            for A_value in A:\n",
    "                func = lambda tau: -np.exp(-A_value/tau) + np.exp(tau) - 1\n",
    "                res = scipy.optimize.minimize_scalar(func, bounds= [0,1], method='bounded')\n",
    "                y2[i] = max(-func(res.x),0)\n",
    "                i += 1\n",
    "            df = pd.DataFrame({'x0': x, 'net': y1-y2})\n",
    "            if(len(df[df['net'] >= 0]) == 0):\n",
    "                manip_res['manipulation percentage'].append(0)\n",
    "            else:\n",
    "                target_df = df[df['net']>0]\n",
    "                i = 0\n",
    "                percentage = 0\n",
    "                left = target_df.iloc[0]['x0'] \n",
    "                while i < len(target_df):\n",
    "                    if i == len(target_df) - 1 or target_df.iloc[i+1]['x0'] - target_df.iloc[i]['x0'] > theta/900:\n",
    "                        right = target_df.iloc[i]['x0']\n",
    "                        percentage += (beta.cdf(right,a,b,loc,scale) - beta.cdf(left,a,b,loc,scale))/(beta.cdf(theta,a,b,loc,scale))\n",
    "                        if i != len(target_df) - 1:\n",
    "                            violate = True\n",
    "                            left = target_df.iloc[i+1]['x0']\n",
    "                    i += 1\n",
    "                manip_res['manipulation percentage'].append(np.round(100*percentage,4))\n",
    "        if p not in final_res.keys():\n",
    "            final_res[p] = manip_res\n",
    "        if violate == True:\n",
    "            print('theta = %f does not exceed theta bar' %(theta))\n",
    "    return final_res\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "08c278d2",
   "metadata": {},
   "outputs": [],
   "source": [
    "theta_list = exam_res['optimal theta']\n",
    "r_list = exam_res['r']\n",
    "manip_result = get_manipulation_percentage(theta_list, r_list, prob = [0.1,0.3,0.4,0.6])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "24645c51",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 300x250 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(3,2.5))\n",
    "plt.tight_layout()\n",
    "prob = [0.1,0.3,0.4,0.6]\n",
    "color = ['#1f77b4', '#ff7f0e', '#046a38', '#d62728', '#9467bd']\n",
    "i = 0\n",
    "for p in prob:\n",
    "    target1 = manip_result[p]\n",
    "    plt.plot(target1['r'], target1['manipulation percentage'], marker='o', label = 'p = %.2f'%p, color = color[i])\n",
    "    plt.xlabel(r'$r$')\n",
    "    plt.ylabel('Percentage(%)')\n",
    "    plt.legend()\n",
    "    i += 1\n",
    "plt.tight_layout()\n",
    "plt.savefig('manipulation_percent_exam_female.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "04073860",
   "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.9.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
