{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Some Statistics to Gain Some Insights"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "from collections import namedtuple\n",
    "\n",
    "def smooth(y, radius=200, mode='two_sided'):\n",
    "    if len(y) < 2*radius+1:\n",
    "        return np.ones_like(y) * y.mean()\n",
    "    elif mode == 'two_sided':\n",
    "        convkernel = np.ones(2 * radius+1)\n",
    "        return np.convolve(y, convkernel, mode='same') / \\\n",
    "               np.convolve(np.ones_like(y), convkernel, mode='same')\n",
    "    elif mode == 'causal':\n",
    "        convkernel = np.ones(radius)\n",
    "        out = np.convolve(y, convkernel,mode='full') / \\\n",
    "              np.convolve(np.ones_like(y), convkernel, mode='full')\n",
    "        return out[:-radius+1]\n",
    "\n",
    "def plot(rewards):\n",
    "    # clear_output(True)\n",
    "    x=np.arange(rewards.shape[0])\n",
    "    plt.figure(figsize=(10,5))\n",
    "    plt.grid()\n",
    "    plt.plot(x, smooth(rewards))\n",
    "    plt.plot(x, rewards, alpha=0.7)\n",
    "    plt.show()\n",
    "    plt.clf()  \n",
    "    plt.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "import json\n",
    "filename = \"./rl.json\"\n",
    "with open(filename, \"r\") as read_file:\n",
    "        general_rl_confs = json.load(read_file)  # hyperparameters for rl training\n",
    "\n",
    "filename = \"../mlp/mlp_rl_train.json\"\n",
    "with open(filename, \"r\") as read_file:\n",
    "        rl_confs = json.load(read_file)  # hyperparameters for rl training\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## CartPole-v1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "metadata": {},
   "outputs": [],
   "source": [
    "EnvName = 'CartPole-v1' "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x360 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# learning curve\n",
    "log_path = '../'+rl_confs[EnvName][\"train_confs\"][\"log_path\"]\n",
    "rewards = np.load(log_path+'.npy')\n",
    "plot(rewards)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 79,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[-0.01169291 -0.00718749 -0.01653909  0.00497331]\n",
      " [-0.01183666 -0.20206839 -0.01643963  0.2923924 ]\n",
      " [-0.01587803 -0.39695213 -0.01059178  0.57984548]\n",
      " [-0.02381707 -0.59192407  0.00100513  0.86917306]\n",
      " [-0.03565556 -0.39681581  0.01838859  0.57680632]\n",
      " [-0.04359187 -0.59219062  0.02992472  0.87522493]\n",
      " [-0.05543568 -0.39748797  0.04742922  0.59209826]\n",
      " [-0.06338544 -0.20306096  0.05927118  0.31472468]\n",
      " [-0.06744666 -0.39897493  0.06556567  0.62549512]\n",
      " [-0.07542616 -0.20482657  0.07807558  0.35416082]]\n",
      "state data shape:  (1450500, 4)\n",
      "state data mean: [ 6.86851844e-01  8.76015026e-02  2.45632109e-06 -5.83751407e-06] and std: [0.26297849 0.18775287 0.01788451 0.20956907]\n"
     ]
    }
   ],
   "source": [
    "# state statistics: mean and std for states encountered\n",
    "data_path_prefix = '../'+general_rl_confs[\"data_collect_confs\"][\"data_path\"]+EnvName.split(\"-\")[0].lower()\n",
    "states = np.load(data_path_prefix+'/greedy_state.npy')\n",
    "print(states[1000:1010])\n",
    "print('state data shape: ', states.shape)\n",
    "mean = np.mean(states, axis=0)\n",
    "std = np.std(states, axis=0)\n",
    "print('state data mean: {} and std: {}'.format(mean, std))\n",
    "state_info = {'env_name': EnvName,\n",
    "             'mean': mean,\n",
    "             'std': std}\n",
    "with open(data_path_prefix+'/state_info.pkl', 'wb') as f:\n",
    "    pickle.dump(state_info, f)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## LunarLander-v2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 81,
   "metadata": {},
   "outputs": [],
   "source": [
    "EnvName = 'LunarLander-v2'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x360 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# learning curve\n",
    "log_path = '../'+rl_confs[EnvName][\"train_confs\"][\"log_path\"]\n",
    "rewards = np.load(log_path+'.npy')\n",
    "plot(rewards)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 82,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "state data shape:  (2048608, 8)\n",
      "state data mean: [-0.10747622  0.20303167 -0.03579763 -0.08802626  0.00266608  0.0007375\n",
      "  0.38794148  0.29506376] and std: [0.31191328 0.3447302  0.17022705 0.16021654 0.06994157 0.05709264\n",
      " 0.4899489  0.46029896]\n"
     ]
    }
   ],
   "source": [
    "# state statistics: mean and std for states encountered\n",
    "import pickle\n",
    "data_path_prefix = '../'+general_rl_confs[\"data_collect_confs\"][\"data_path\"]+EnvName.split(\"-\")[0].lower()\n",
    "states = np.load(data_path_prefix+'/greedy_state.npy')\n",
    "print('state data shape: ', states.shape)\n",
    "mean = np.mean(states, axis=0)\n",
    "std = np.std(states, axis=0)\n",
    "print('state data mean: {} and std: {}'.format(mean, std))\n",
    "state_info = {'env_name': EnvName,\n",
    "             'mean': mean,\n",
    "             'std': std}\n",
    "with open(data_path_prefix+'/state_info.pkl', 'wb') as f:\n",
    "    pickle.dump(state_info, f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 83,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[-0.10747622  0.20303167 -0.03579763 -0.08802626  0.00266608  0.0007375\n",
      "  0.38794148  0.29506376]\n"
     ]
    }
   ],
   "source": [
    "with open(data_path_prefix+'/state_info.pkl', 'rb') as f:\n",
    "    s=pickle.load(f)\n",
    "print(s.get('mean'))\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## MountainCar-v0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "EnvName = 'MountainCar-v0'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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/nmGTwfnXH4ikajoMSlLo3KpTgstlytOnaJpPM7RJ55gvPls5TO2zFaff5HV8TgDB19kYKiv4usrPc/NpRqOl3IFY28CngXuBrYBDxljvluOBVtr7wfuB9i3b5/t7e0tx2Ln9sIggwPfIdbdXbl1yJIMxuMqlyWI3XYbDP3d1PsrroSjp4lduxe29UL/5wDo7Z16XXz/2CE37969cGXvnMvv6+ujosekLInKpTotuFxSD0F8ktjNN8OqnRXP17J7/gLkXiS2axe79/ZWfn2l57k5VMPxsuRmSmPMR4wxzxpjnsX1GfuKdY4Ax4CrgDPAxpKPbfDSznivZ6aLiIgIULPNeLpfb5YlB2PW2s9aa6+z1l4HHAJeD2CM6QF2AkeBbwL3GGM6vY779wDftNaeBUaNMbd6/cw+AHz1MrdFREREqp068M9SrmbKTwCfN8a8gAvlP2atHQQwxnwCeNKb7zettUPe6w8DnwcagW94fyIiIgLU/hAXqiErKEswZq3tx9V6zTXtAeCBOdKfAvaUY/0iIiI1Q814dUcj8IvUtBlX1moeEKl+Ok7rjoIxkbq0iCtvXaWL+KRWjz0FmzMpGBMREZHlpwu9IgVjIiIiIj5SMCYiIiLiIwVjIiIisvx0o0KRgjEREZFqpD5VdUPBmIiISDWq9ZojBZtFCsZEREREfKRgTERERMRHCsZEZB413kQiIlIlFIyVUvu11At910Wqn47TuqFgTERERMRHCsZEREREfKRgTETmVuu31YuIVAkFYyIiIiI+UjAmInNT52ERkWWhYExERETERwrGRERERHykYEykls3qhL+ITvnqwC8isiwUjInIJajvmIiUkS70ZlEwNo1+dERERGR5KRgTERER8ZGCMREREREfKRgTERGpJupTVXcUjImIiIj4SMGYiIhINdHTL+qOgjERERERHykYExEREfGRgjGRmjajI7A6BotUv5o/Tmt9+xZPwZhIXVpEnxT1XxHxSY0fezq3FCkYExEREfGRgjERERERHykYExERkeVX833jFk7BmIiIiIiPFIyJiIjI8lMH/iIFYyIiIiI+UjAmIiIi4iMFYyK17LI6yKpzrYjIclAwVkrt11Iv9F0XqX41f5zW+vYt3KKCMWPMVcaYR40xKWPML86Ydq8x5rAx5ogx5uMl6VuNMY976V8yxkS89Abv/RFv+pZy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\n",
      "text/plain": [
       "<Figure size 720x360 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# learning curve\n",
    "log_path = '../'+rl_confs[EnvName][\"train_confs\"][\"log_path\"]\n",
    "rewards = np.load(log_path+'.npy')\n",
    "plot(rewards)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "state data shape:  (487168, 2)\n",
      "state data mean: [-0.40410234  0.00295303] and std: [0.21420211 0.01521328]\n"
     ]
    }
   ],
   "source": [
    "# state statistics: mean and std for states encountered\n",
    "import pickle\n",
    "data_path_prefix = '../'+general_rl_confs[\"data_collect_confs\"][\"data_path\"]+EnvName.split(\"-\")[0].lower()\n",
    "states = np.load(data_path_prefix+'/greedy_state.npy')\n",
    "print('state data shape: ', states.shape)\n",
    "mean = np.mean(states, axis=0)\n",
    "std = np.std(states, axis=0)\n",
    "print('state data mean: {} and std: {}'.format(mean, std))\n",
    "state_info = {'env_name': EnvName,\n",
    "             'mean': mean,\n",
    "             'std': std}\n",
    "with open(data_path_prefix+'/state_info.pkl', 'wb') as f:\n",
    "    pickle.dump(state_info, f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[-0.40410234  0.00295303]\n"
     ]
    }
   ],
   "source": [
    "with open(data_path_prefix+'/state_info.pkl', 'rb') as f:\n",
    "    s=pickle.load(f)\n",
    "print(s.get('mean'))"
   ]
  },
  {
   "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.6.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
