{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 99,
   "metadata": {},
   "outputs": [],
   "source": [
    "#import dependencies\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "from sklearn.linear_model import LinearRegression\n",
    "from sklearn.preprocessing import PolynomialFeatures\n",
    "import datetime\n",
    "from datetime import date\n",
    "import math\n",
    "import random\n",
    "from rdd import rdd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 100,
   "metadata": {},
   "outputs": [],
   "source": [
    "#Load data set here\n",
    "data = pd.read_csv('../dataset_numeric.csv') "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 101,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Filter by year (int) and paper category (Accept/Reject)\n",
    "\n",
    "year = 2020\n",
    "decision = 'all'\n",
    "decision_to_numeric = {'all': [-1,3], 'accept':[1,3], 'reject':[-1,0], 'poster':[1,1], 'oral':[2,2], 'spotlight':[3,3]\n",
    "                      , 'workshop':[0,0]}\n",
    "\n",
    "if isinstance(year, int):\n",
    "    data = data[data['year'] == year]\n",
    "data = data[(decision_to_numeric[decision][0] <= data['decision']) & (data['decision'] <= decision_to_numeric[decision][1])]\n",
    "\n",
    "# Average score\n",
    "x = data.iloc[:, 3:4].values\n",
    "for i in range (len(x)):\n",
    "    arr = str(x[i][0]).split(\";\")\n",
    "    for j in range (len(arr)):\n",
    "        arr[j] = float(arr[j])\n",
    "    if len(arr) != 0:\n",
    "        val = sum(arr)/len(arr)\n",
    "    x[i] = val\n",
    "    \n",
    "# Citation rate \n",
    "citations = data.iloc[:, 10:11].values\n",
    "citations = [citation[0] for citation in citations]\n",
    "dates = data.iloc[:, 2:3].values\n",
    "now = datetime.datetime.now();\n",
    "for i in range(len(dates)):\n",
    "    arr = dates[i][0].split(\"/\")\n",
    "    d0 = date(int(arr[2]), int(arr[0]), int(arr[1]))\n",
    "    d1 = date(now.year, now.month, now.day)\n",
    "    delta = d1 - d0\n",
    "    # Can either log transform or leave as-is\n",
    "    citations[i] = float(citations[i]/delta.days)**(1/5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 102,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Convert x, citations to np arrays and make new dataframe\n",
    "x = np.array([i[0] for i in x], dtype=float)\n",
    "citations = np.array(citations, dtype=float)\n",
    "data = pd.DataFrame({'x':x, 'citations':citations})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 103,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Optimal bandwidth: 1.6570316979623803\n"
     ]
    }
   ],
   "source": [
    "# Regression dicsontinuity design\n",
    "# Set threshold and find optimal bandwidth\n",
    "threshold = 6.4\n",
    "bandwidth_opt = rdd.optimal_bandwidth(data['citations'], data['x'], cut=threshold)\n",
    "print(\"Optimal bandwidth:\", bandwidth_opt)\n",
    "# Truncate data\n",
    "data_rdd = rdd.truncated_data(data, 'x', bandwidth_opt, cut=threshold)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 104,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.collections.PathCollection at 0x157d7126e88>"
      ]
     },
     "execution_count": 104,
     "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": [
    "plt.scatter(data_rdd['x'], data_rdd['citations'], facecolors='none', edgecolors='r')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 105,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.collections.PathCollection at 0x157d3b2e088>"
      ]
     },
     "execution_count": 105,
     "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": [
    "data_binned = rdd.bin_data(data_rdd, 'citations', 'x', 100)\n",
    "plt.scatter(data_binned['x'], data_binned['citations'], facecolors='none', edgecolors='r')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 106,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Estimation Equation:\t citations ~ TREATED + x\n",
      "                            WLS Regression Results                            \n",
      "==============================================================================\n",
      "Dep. Variable:              citations   R-squared:                       0.094\n",
      "Model:                            WLS   Adj. R-squared:                  0.092\n",
      "Method:                 Least Squares   F-statistic:                     50.29\n",
      "Date:                Mon, 03 Aug 2020   Prob (F-statistic):           1.65e-21\n",
      "Time:                        23:57:39   Log-Likelihood:                 236.39\n",
      "No. Observations:                 973   AIC:                            -466.8\n",
      "Df Residuals:                     970   BIC:                            -452.1\n",
      "Df Model:                           2                                         \n",
      "Covariance Type:            nonrobust                                         \n",
      "==============================================================================\n",
      "                 coef    std err          t      P>|t|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "Intercept     -0.1297      0.072     -1.793      0.073      -0.272       0.012\n",
      "TREATED       -0.0156      0.023     -0.669      0.504      -0.061       0.030\n",
      "x              0.0802      0.013      6.167      0.000       0.055       0.106\n",
      "==============================================================================\n",
      "Omnibus:                       31.318   Durbin-Watson:                   1.975\n",
      "Prob(Omnibus):                  0.000   Jarque-Bera (JB):               33.778\n",
      "Skew:                          -0.456   Prob(JB):                     4.63e-08\n",
      "Kurtosis:                       3.017   Cond. No.                         76.6\n",
      "==============================================================================\n",
      "\n",
      "Warnings:\n",
      "[1] Standard Errors assume that the covariance matrix of the errors is correctly specified.\n"
     ]
    }
   ],
   "source": [
    "model = rdd.rdd(data_rdd, 'x', 'citations', cut=threshold)\n",
    "print(model.fit().summary())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 112,
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "data_placebo = rdd.truncated_data(data, 'x', yname='citations', cut=1.01)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 114,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Estimation Equation:\t citations ~ TREATED + x\n",
      "                            WLS Regression Results                            \n",
      "==============================================================================\n",
      "Dep. Variable:              citations   R-squared:                       0.037\n",
      "Model:                            WLS   Adj. R-squared:                  0.031\n",
      "Method:                 Least Squares   F-statistic:                     6.315\n",
      "Date:                Tue, 04 Aug 2020   Prob (F-statistic):            0.00203\n",
      "Time:                        00:03:46   Log-Likelihood:                 125.88\n",
      "No. Observations:                 336   AIC:                            -245.8\n",
      "Df Residuals:                     333   BIC:                            -234.3\n",
      "Df Model:                           2                                         \n",
      "Covariance Type:            nonrobust                                         \n",
      "==============================================================================\n",
      "                 coef    std err          t      P>|t|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "Intercept     -0.0076      0.038     -0.199      0.843      -0.082       0.067\n",
      "TREATED        0.0155      0.042      0.368      0.713      -0.067       0.098\n",
      "x              0.0534      0.031      1.708      0.088      -0.008       0.115\n",
      "==============================================================================\n",
      "Omnibus:                       47.411   Durbin-Watson:                   1.962\n",
      "Prob(Omnibus):                  0.000   Jarque-Bera (JB):               60.160\n",
      "Skew:                           1.009   Prob(JB):                     8.64e-14\n",
      "Kurtosis:                       2.528   Cond. No.                         14.7\n",
      "==============================================================================\n",
      "\n",
      "Warnings:\n",
      "[1] Standard Errors assume that the covariance matrix of the errors is correctly specified.\n"
     ]
    }
   ],
   "source": [
    "model = rdd.rdd(data_placebo, 'x', 'citations', cut=1.01)\n",
    "print(model.fit().summary())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "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.7.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
