{
 "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'] == 'male']"
   ]
  },
  {
   "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": "e16ba925",
   "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>0</th>\n",
       "      <td>male</td>\n",
       "      <td>group A</td>\n",
       "      <td>high school</td>\n",
       "      <td>standard</td>\n",
       "      <td>completed</td>\n",
       "      <td>67</td>\n",
       "      <td>67</td>\n",
       "      <td>63</td>\n",
       "      <td>0.656667</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>male</td>\n",
       "      <td>group E</td>\n",
       "      <td>some college</td>\n",
       "      <td>free/reduced</td>\n",
       "      <td>none</td>\n",
       "      <td>59</td>\n",
       "      <td>60</td>\n",
       "      <td>50</td>\n",
       "      <td>0.563333</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>male</td>\n",
       "      <td>group B</td>\n",
       "      <td>high school</td>\n",
       "      <td>standard</td>\n",
       "      <td>none</td>\n",
       "      <td>77</td>\n",
       "      <td>78</td>\n",
       "      <td>68</td>\n",
       "      <td>0.743333</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>male</td>\n",
       "      <td>group E</td>\n",
       "      <td>associate's degree</td>\n",
       "      <td>standard</td>\n",
       "      <td>completed</td>\n",
       "      <td>78</td>\n",
       "      <td>73</td>\n",
       "      <td>68</td>\n",
       "      <td>0.730000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>male</td>\n",
       "      <td>group E</td>\n",
       "      <td>some college</td>\n",
       "      <td>standard</td>\n",
       "      <td>completed</td>\n",
       "      <td>93</td>\n",
       "      <td>88</td>\n",
       "      <td>84</td>\n",
       "      <td>0.883333</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>992</th>\n",
       "      <td>male</td>\n",
       "      <td>group C</td>\n",
       "      <td>some college</td>\n",
       "      <td>standard</td>\n",
       "      <td>none</td>\n",
       "      <td>69</td>\n",
       "      <td>63</td>\n",
       "      <td>66</td>\n",
       "      <td>0.660000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>994</th>\n",
       "      <td>male</td>\n",
       "      <td>group E</td>\n",
       "      <td>high school</td>\n",
       "      <td>free/reduced</td>\n",
       "      <td>completed</td>\n",
       "      <td>86</td>\n",
       "      <td>82</td>\n",
       "      <td>75</td>\n",
       "      <td>0.810000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>995</th>\n",
       "      <td>male</td>\n",
       "      <td>group C</td>\n",
       "      <td>high school</td>\n",
       "      <td>standard</td>\n",
       "      <td>none</td>\n",
       "      <td>73</td>\n",
       "      <td>70</td>\n",
       "      <td>65</td>\n",
       "      <td>0.693333</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>996</th>\n",
       "      <td>male</td>\n",
       "      <td>group D</td>\n",
       "      <td>associate's degree</td>\n",
       "      <td>free/reduced</td>\n",
       "      <td>completed</td>\n",
       "      <td>85</td>\n",
       "      <td>91</td>\n",
       "      <td>92</td>\n",
       "      <td>0.893333</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>999</th>\n",
       "      <td>male</td>\n",
       "      <td>group A</td>\n",
       "      <td>some college</td>\n",
       "      <td>standard</td>\n",
       "      <td>completed</td>\n",
       "      <td>65</td>\n",
       "      <td>60</td>\n",
       "      <td>62</td>\n",
       "      <td>0.623333</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>517 rows × 9 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "    gender race/ethnicity parental level of education         lunch  \\\n",
       "0     male        group A                 high school      standard   \n",
       "2     male        group E                some college  free/reduced   \n",
       "3     male        group B                 high school      standard   \n",
       "4     male        group E          associate's degree      standard   \n",
       "7     male        group E                some college      standard   \n",
       "..     ...            ...                         ...           ...   \n",
       "992   male        group C                some college      standard   \n",
       "994   male        group E                 high school  free/reduced   \n",
       "995   male        group C                 high school      standard   \n",
       "996   male        group D          associate's degree  free/reduced   \n",
       "999   male        group A                some college      standard   \n",
       "\n",
       "    test preparation course  math score  reading score  writing score  \\\n",
       "0                 completed          67             67             63   \n",
       "2                      none          59             60             50   \n",
       "3                      none          77             78             68   \n",
       "4                 completed          78             73             68   \n",
       "7                 completed          93             88             84   \n",
       "..                      ...         ...            ...            ...   \n",
       "992                    none          69             63             66   \n",
       "994               completed          86             82             75   \n",
       "995                    none          73             70             65   \n",
       "996               completed          85             91             92   \n",
       "999               completed          65             60             62   \n",
       "\n",
       "       Qscore  \n",
       "0    0.656667  \n",
       "2    0.563333  \n",
       "3    0.743333  \n",
       "4    0.730000  \n",
       "7    0.883333  \n",
       "..        ...  \n",
       "992  0.660000  \n",
       "994  0.810000  \n",
       "995  0.693333  \n",
       "996  0.893333  \n",
       "999  0.623333  \n",
       "\n",
       "[517 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.864021228209696, 2.365628260721473, 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+/P2nAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8qNh9FAAAACXBIWXMAAA9hAAAPYQGoP6dpAABjnElEQVR4nO3deVxUZd8/8M8wwLA5qCgii6AigoCSG2LmmkpqmpVZ2V0u9Tx1W1a/yhbL5dbSeuouu1tsVdO0csvbNffc91RQRJRFXBGQXZaZuX5/TIwcBpRlZs4sn/frNS+d75wz8x2OwMdzXXMdhRBCgIiIiIhMyknuBoiIiIjsEUMWERERkRkwZBERERGZAUMWERERkRkwZBERERGZAUMWERERkRkwZBERERGZAUMWERERkRkwZBERERGZAUMWkZ0ZP348nnrqKcP9kJAQfP/994b7GzduRGhoKJRKJWbOnImZM2eiT58+Zu1JoVBg27ZtZn0NW/P9998jJCTEcL/6cTOF9PR0KBQKnD9/HgCwaNEiBAYGmvQ1anodItJzlrsBIjKvI0eOwMvLy3D/xRdfxNixY/HSSy9BrVYDAKZMmWKS19q2bRsGDx6M6lfrunr1Kpo3b26S17BX8+fPr9N2Go0GLi4u2LlzJ/r373/HbYOCgnD16lW0bNnSBB3qff/995gzZw7S09PN+jpE9oAhi8jOVf3Fp9PpkJ6ejiFDhsDf399iPfj5+VnstcxJCGEIOabm7e1t0ucrLy+Hq6urRb72SqXSbo4xkSlxuJDIgvLz8/HII4/A3d0dYWFh2LBhAxQKBXbt2gWg5uGc6sN5P/zwA2JiYuDp6Yng4GC899570Gg0tb5m5XBheno6lEolhBAYOHCg4XWrP79Go8H06dPRpk0buLm5ISIiAuvWrQMAnD17FsOGDUOLFi3QtGlTDBs2DGlpaQD0Q0aDBw8GoB8eVCgUWLRokeF+1eHCTZs2ITo6GiqVCqGhofjpp58Mj1UOPf3+++/o2bMnPD090b9/f1y8eLHW95iamor4+Hio1Wqo1WrExsZKhq5++eUXw+sFBgZizpw5hscOHz6MuLg4qFQqBAUF4aOPPpI8t0KhwPfff4+BAwfC3d0d69evBwB8/vnnaNeuHTw8PNCjRw/DMazNrl27EBERAXd3d4wYMQI5OTmSx6sPF3722Wdo27atoeeZM2cCAEJDQwEAAwYMgEKhwPjx4wEA/fv3x+uvv45JkyZBrVbjjTfeqHUYb8mSJQgKCoKXlxeee+45lJeXS95v1WNV9Tl27dqF5557DhkZGYZjvGvXrhpf56effkJoaChUKhWio6OxadMmyddCoVBg+/bt6NSpE5o0aYKHHnoIN2/evOPXkMjWMGQRWdArr7yC06dPY8eOHVi8eLHhF2d96HQ6fPzxx0hMTMSCBQvw/fff49tvv73rfkFBQbh06RIAYNWqVbh69Sp69+5ttN2MGTPw3Xff4bPPPsPp06fx73//23DmpqioCI8++ij27t2LvXv3wtXVFY8//rjh+X/77TcA+uHBq1evYuzYsUbPn56ejoceeggPPfQQTp06hVdeeQUTJ07Evn37JNvNnDkTH374IQ4fPoySkhK8+uqrtb63F198Ea1atcKRI0dw9OhRTJkyBU5O+h9vW7ZswdNPP40JEyYgMTERK1asQOvWrQEAhYWFGDZsGCIjI3HixAl89NFHmDVrFpYtW2bUyz//+U+cOXMG9957L3788UfMnz8fX331FRITE/H0009j2LBhkiG0qvLz8zF69GgMGDAAf/31F0aMGIF58+bV+n6OHDmCGTNmYMGCBUhJScFvv/1mCFcHDx4EcPsYVh1m/Oabb9ChQwccP34cr7zySo3PnZOTgx9++AHr16/HmjVrsGHDBnzwwQe19lJV79698cknnyAwMNBwjGv6N7R//35MnDgRU6ZMwalTpzB69Gg89NBDRl+fOXPmYNGiRdi5cycSEhIk4ZfILggisoj8/Hzh7OwsNm3aZKht2rRJABA7d+4UQgixcOFCERAQINlvxowZ4t577631eefOnSsGDBhguP/MM8+IcePGGe4HBweL7777TgghREVFheT1qj9/SUmJUKlUYsWKFXV6T1evXhUAREZGhhBCiK1bt4qafqwAEFu3bhVCCPHmm2+KHj16SB4fO3asePTRR4UQQqSlpQkA4tdffzU8vmzZMuHj41NrH1FRUeKnn36q8bG+ffuKyZMn1/jY119/Lfz9/UVFRYWh9uabb4ru3btLep85c6Zkv7Zt24p169ZJaoMHDxazZ8+u8XW++uorERAQIHmdsWPHiuDgYMP9qsdt5cqVIiwsTLJ9pZqOoRBC9OvXT/Tv319Sq/xapqSkCCH0/74AiKSkJMM2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I0YgKyvL8NjChQsRExODLl26oHv37khPT8fzzz+PvLw8xMTEoHv37gCA/v37Y/369Yb9Hn30UcP1CpctW4bY2Fjcc889iImJwcaNG+/aU0pKCu6991506dIF0dHRePfddwEA5eXleOONNxAdHY0uXbogPj4eAKDVavH6668jKioKUVFReOmll1BeXg4AGD9+PKZMmYL4+Hh06dIFALBkyRLExsaia9eu6NevHxITExv/hayGw4VEREQO7rPPPkOLFi0AAPPmzcO//vUvfPHFF9i1axfef/997NmzB61bt0ZJSQkAYMGCBejevTtOnDhRp+cfOnQonnjiCSgUCqSnp6N3797IyMiAi4tLrft88cUXGD58ON555x0AQG5uLgBg7ty5uHDhAo4ePQqVSoUbN24AAL799lscO3YMx44dg1KpxMiRIzF//ny88cYbAIC9e/di9+7d8PLywr59+/DLL79g9+7dUKlU2LNnD8aNG4eTJ0826OtXG4YsIiIiB/fzzz9jyZIlKCsrw61bt+Dn5wcA2LBhA55++mm0bt0aAODh4dGg509LS8O4ceNw6dIlODs7Izs7GxkZGQgNDa11n759++KNN95AcXEx+vXrh/vvvx8AsH79enzyySeG6wm2bNkSALBt2zZMmjTJUH/uueewYMECQ8h67LHH4OXlBQBYu3YtTp48idjYWMPr3bhxA+Xl5XB1dW3Qe6wJhwuJiIgc2N69e/HFF19g06ZNSEhIwL///W+UlpbW+3mcnZ2h1WoN96s+x+OPP47nn38eiYmJOHHiBLy8vO76Go888gj27duHjh074osvvsCIESPuuL0QAgqFQlKrer8yYFVuO3HiRJw4ccJwu3LlikkDFsCQRURE5NBu3rwJtVqN5s2bo7y8HN98843hsQcffBA//fQTrl27BgAoKSlBSUkJ1Go1SkpKJJPI27dvj0OHDgHQn7nau3ev5DVCQkIAAEuXLsXNmzfv2ldKSgp8fX3x9NNP46OPPsLBgwcBACNHjsRnn32GsrIyADAMFw4ePBiLFi1CeXk5NBoNfvjhB8PZr+oq31dmZiYAQKfT4ejRo3X6etUHhwuJiIhkZq6lFurigQcewNKlSxEeHo7AwED07t0bf/zxBwD9kN27776LIUOGQKFQwNXVFStXrkRwcDDGjRuH6OhoeHp64ujRo3jzzTcxduxY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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_male.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": "379c1310",
   "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.9968</td>\n",
       "      <td>0.326982</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.10</td>\n",
       "      <td>0.9892</td>\n",
       "      <td>99.3501</td>\n",
       "      <td>0.311250</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.15</td>\n",
       "      <td>0.9598</td>\n",
       "      <td>96.9846</td>\n",
       "      <td>0.266424</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.20</td>\n",
       "      <td>0.9267</td>\n",
       "      <td>93.6491</td>\n",
       "      <td>0.216396</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.25</td>\n",
       "      <td>0.8976</td>\n",
       "      <td>90.2447</td>\n",
       "      <td>0.174383</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>0.30</td>\n",
       "      <td>0.8736</td>\n",
       "      <td>87.1685</td>\n",
       "      <td>0.141997</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.9968         0.326982\n",
       "1  0.10         0.9892               99.3501         0.311250\n",
       "2  0.15         0.9598               96.9846         0.266424\n",
       "3  0.20         0.9267               93.6491         0.216396\n",
       "4  0.25         0.8976               90.2447         0.174383\n",
       "5  0.30         0.8736               87.1685         0.141997"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "exam_res.to_csv('exam_male.csv')\n",
    "exam_res"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "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_male.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": 14,
   "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": 34,
   "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": 36,
   "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",
    "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_male.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
}
