{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "7e9e3b05",
   "metadata": {},
   "source": [
    "## Rules and noisy data used for behaviour cloning teacher"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b376f5c2",
   "metadata": {},
   "source": [
    "## Use noisy states from buffer to BC teacher"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "id": "88ac6cce",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.optim as optim\n",
    "import gym\n",
    "import numpy as np\n",
    "import random\n",
    "import torch.nn.functional as F\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import seaborn as sns"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "id": "54ab0a89",
   "metadata": {},
   "outputs": [],
   "source": [
    "class Actor(nn.Module):\n",
    "\n",
    "    def __init__(self, num_state, num_actions, seed):\n",
    "        super(Actor, self).__init__()\n",
    "\n",
    "        # set seed\n",
    "        torch.manual_seed(seed)\n",
    "\n",
    "        num_hidden = 256\n",
    "\n",
    "        self.fnn = nn.Sequential(\n",
    "            nn.Linear(in_features=num_state, out_features=num_hidden),\n",
    "            nn.SELU(),\n",
    "            nn.Linear(in_features=num_hidden, out_features=num_hidden),\n",
    "            nn.SELU(),\n",
    "            nn.Linear(in_features=num_hidden, out_features=num_hidden),\n",
    "            nn.SELU(),\n",
    "            nn.Linear(in_features=num_hidden, out_features=num_actions)\n",
    "        )\n",
    "\n",
    "        for param in self.parameters():\n",
    "            if len(param.shape) == 1:\n",
    "                torch.nn.init.constant_(param, 0)\n",
    "            if len(param.shape) >= 2:\n",
    "                torch.nn.init.kaiming_normal_(param, mode='fan_in', nonlinearity='linear')\n",
    "\n",
    "    def forward(self, state):\n",
    "        if len(state.shape) == 1:\n",
    "            state = state.unsqueeze(dim=0)\n",
    "\n",
    "        return self.fnn(state)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "id": "98f305f8",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Function to collect expert demonstrations actions\n",
    "def collect_demonstrations(data):\n",
    "    observations = []\n",
    "    actions = []\n",
    "\n",
    "    for i in range(len(data)):\n",
    "        action = expert_policy(data[i])\n",
    "        if(action == None):\n",
    "            print(data[i])\n",
    "        observations.append(data[i])\n",
    "        actions.append(action)\n",
    "\n",
    "    return np.array(observations), np.array(actions)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "id": "10425ae6",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Training the behavior cloning model\n",
    "# 256 1e-3 for other environments\n",
    "def train_behavior_cloning(model, observations, actions, num_epochs=100, batch_size=128, learning_rate=1e-4):\n",
    "    optimizer = optim.Adam(model.parameters(), lr=learning_rate)\n",
    "    criterion = nn.CrossEntropyLoss()\n",
    "\n",
    "    for epoch in range(num_epochs):\n",
    "        # Shuffle data\n",
    "        indices = np.arange(len(observations))\n",
    "        np.random.shuffle(indices)\n",
    "\n",
    "        for start in range(0, len(observations), batch_size):\n",
    "            end = start + batch_size\n",
    "            batch_indices = indices[start:end]\n",
    "\n",
    "            # Convert data to PyTorch tensors\n",
    "            obs_batch = torch.FloatTensor(observations[batch_indices])\n",
    "            #print(observations[batch_indices])\n",
    "            #print(actions[batch_indices])\n",
    "            action_batch = torch.LongTensor(actions[batch_indices])\n",
    "\n",
    "            # Forward pass\n",
    "            logits = model(obs_batch)\n",
    "            #print(logits)\n",
    "            #print(action_batch)\n",
    "\n",
    "            # Compute loss\n",
    "            loss = criterion(logits, action_batch)\n",
    "\n",
    "            # Backward pass and optimization\n",
    "            optimizer.zero_grad()\n",
    "            loss.backward()\n",
    "            optimizer.step()\n",
    "\n",
    "        if epoch % 10 == 0:\n",
    "            evaluate()\n",
    "            print(f'Epoch {epoch}/{num_epochs}, Loss: {loss.item()}')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "6d6fa676",
   "metadata": {},
   "source": [
    "## BC Mountain car"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "df91db51",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 864x360 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 864x360 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Define the bounds for position and velocity\n",
    "df = pd.read_pickle('data/MountainCar-v0_run3_randomconv.pkl')\n",
    "\n",
    "# Define the bounds for position and velocity\n",
    "position_bounds = [0.6, -1.2]\n",
    "velocity_bounds = [0.07, -0.07]\n",
    "\n",
    "# Number of data points\n",
    "num_points = 1000\n",
    "\n",
    "# Generate random values within the specified bounds\n",
    "positions = np.random.uniform(position_bounds[1], position_bounds[0], num_points)\n",
    "velocities = np.random.uniform(velocity_bounds[1], velocity_bounds[0], num_points)\n",
    "data = []\n",
    "\n",
    "# Number of data points\n",
    "num_points = 10000\n",
    "\n",
    "# Generate random values within the specified bounds\n",
    "position = []\n",
    "velocity = []\n",
    "for ind in df.index:\n",
    "    position.append(df['state'][ind][0])\n",
    "    velocity.append(df['state'][ind][1])\n",
    "    data.append(df['state'][ind])\n",
    "    # action_full.append(df['action'][ind][0])\n",
    "\n",
    "# Create 2D histograms\n",
    "plt.figure(figsize=(12, 5))\n",
    "\n",
    "# Plotting position histogram\n",
    "plt.subplot(1, 2, 1)\n",
    "plt.hist(positions, bins=30, color='blue', alpha=0.7)\n",
    "plt.title('Position Distribution')\n",
    "plt.xlabel('Position')\n",
    "plt.ylabel('Frequency')\n",
    "\n",
    "# Plotting velocity histogram\n",
    "plt.subplot(1, 2, 2)\n",
    "plt.hist(velocities, bins=30, color='green', alpha=0.7)\n",
    "plt.title('Velocity Distribution')\n",
    "plt.xlabel('Velocity')\n",
    "plt.ylabel('Frequency')\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.show()\n",
    "\n",
    "# Create 2D kernel density plots\n",
    "plt.figure(figsize=(12, 5))\n",
    "\n",
    "# Plotting position kernel density\n",
    "plt.subplot(1, 2, 1)\n",
    "sns.kdeplot(positions, color='blue', fill=True)\n",
    "plt.title('Position Distribution (Kernel Density)')\n",
    "plt.xlabel('Position')\n",
    "plt.ylabel('Density')\n",
    "\n",
    "# Plotting velocity kernel density\n",
    "plt.subplot(1, 2, 2)\n",
    "sns.kdeplot(velocities, color='green', fill=True)\n",
    "plt.title('Velocity Distribution (Kernel Density)')\n",
    "plt.xlabel('Velocity')\n",
    "plt.ylabel('Density')\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "90e27226",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/ubuntu/anaconda3/envs/sonyenv/lib/python3.7/site-packages/ipykernel/ipkernel.py:283: DeprecationWarning: `should_run_async` will not call `transform_cell` automatically in the future. Please pass the result to `transformed_cell` argument and any exception that happen during thetransform in `preprocessing_exc_tuple` in IPython 7.17 and above.\n",
      "  and should_run_async(code)\n"
     ]
    }
   ],
   "source": [
    "class MActor(nn.Module):\n",
    "    def __init__(self,\n",
    "                 input_dim,\n",
    "                 output_dim,\n",
    "                 hidden_dims=(32, 32),\n",
    "                 activation_fc=F.relu):\n",
    "        super(MActor, self).__init__()\n",
    "        self.activation_fc = activation_fc\n",
    "        self.dropout = nn.Dropout(p=0.5)\n",
    "        self.input_layer = nn.Linear(input_dim, hidden_dims[0])\n",
    "        self.hidden_layers = nn.ModuleList()\n",
    "        for i in range(len(hidden_dims) - 1):\n",
    "            hidden_layer = nn.Linear(hidden_dims[i], hidden_dims[i + 1])\n",
    "            self.hidden_layers.append(hidden_layer)\n",
    "        self.output_layer = nn.Linear(hidden_dims[-1], output_dim)\n",
    "        self.device = torch.device(\"cuda:0\" if torch.cuda.is_available() else \"cpu\")\n",
    "        self.to(self.device)\n",
    "\n",
    "    def _format(self, state):\n",
    "        x = state\n",
    "        if not isinstance(x, torch.Tensor):\n",
    "            x = torch.tensor(x,\n",
    "                             device=self.device,\n",
    "                             dtype=torch.float32)\n",
    "            x = x.unsqueeze(0)\n",
    "        return x\n",
    "\n",
    "    def forward(self, state, training=True):\n",
    "        x = self._format(state)\n",
    "        x = self.activation_fc(self.input_layer(x))\n",
    "        for hidden_layer in self.hidden_layers:\n",
    "            x = self.activation_fc(hidden_layer(x))\n",
    "        if not training:\n",
    "            x = self.dropout(x)\n",
    "        x = self.output_layer(x)\n",
    "        return F.softmax(x)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "a3ddc1ca",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<All keys matched successfully>"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "anetwork_local = MActor(2, 3, hidden_dims=(128,128))\n",
    "anetwork_local.load_state_dict(torch.load('mountaincar.pth'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ed2e43f2",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_action_heur(observation):\n",
    "    state = torch.from_numpy(observation).float().unsqueeze(0).to(device)\n",
    "    qnetwork_local.eval()\n",
    "    with torch.no_grad():\n",
    "        action_values = qnetwork_local(state)\n",
    "    return np.argmax(action_values.cpu().data.numpy())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "017eb762",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Expert policy (target policy in this case)\n",
    "def expert_policy(observation):\n",
    "    # Replace this with your expert policy logic\n",
    "    action = random.randint(0, 2)\n",
    "    position = observation[0]\n",
    "    velocity = observation[1]\n",
    "    if position < -0.5:\n",
    "        if velocity < -0.01:\n",
    "            action = 0\n",
    "        else:\n",
    "            action = 2\n",
    "    else:\n",
    "        if velocity > 0.01:\n",
    "            action = 2\n",
    "    return action"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "ad928da3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0/100, Loss: 0.41382700204849243\n",
      "Epoch 10/100, Loss: 0.28489401936531067\n",
      "Epoch 20/100, Loss: 0.2801625430583954\n",
      "Epoch 30/100, Loss: 0.30062946677207947\n",
      "Epoch 40/100, Loss: 0.2627647817134857\n",
      "Epoch 50/100, Loss: 0.2962140142917633\n",
      "Epoch 60/100, Loss: 0.24094609916210175\n",
      "Epoch 70/100, Loss: 0.23463746905326843\n",
      "Epoch 80/100, Loss: 0.23508505523204803\n",
      "Epoch 90/100, Loss: 0.2575281262397766\n"
     ]
    }
   ],
   "source": [
    "if __name__ == \"__main__\":\n",
    "    \n",
    "    env = gym.make(\"MountainCar-v0\")\n",
    "\n",
    "    # Collect expert demonstrations\n",
    "    expert_observations, expert_actions = collect_demonstrations(data)\n",
    "\n",
    "    # Define the behavior cloning model\n",
    "    input_size = expert_observations.shape[1]\n",
    "    output_size = env.action_space.n  # Assuming discrete action space\n",
    "    model = Actor(input_size, output_size,0)\n",
    "\n",
    "    # Train the behavior cloning model\n",
    "    train_behavior_cloning(model, expert_observations, expert_actions)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "e4ff80b3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-91.0\n",
      "-200.0\n",
      "-119.0\n",
      "-200.0\n",
      "-200.0\n",
      "-200.0\n",
      "-200.0\n",
      "-100.0\n",
      "-145.0\n",
      "-200.0\n",
      "-157.0\n",
      "-121.0\n",
      "-200.0\n",
      "-120.0\n",
      "-116.0\n",
      "-200.0\n",
      "-200.0\n",
      "-149.0\n",
      "-200.0\n",
      "-124.0\n",
      "-200.0\n",
      "-200.0\n",
      "-119.0\n",
      "-174.0\n",
      "-124.0\n",
      "-176.0\n",
      "-120.0\n",
      "-149.0\n",
      "-125.0\n",
      "-200.0\n",
      "-200.0\n",
      "-200.0\n",
      "-200.0\n",
      "-108.0\n",
      "-200.0\n",
      "-121.0\n",
      "-146.0\n",
      "-169.0\n",
      "-113.0\n",
      "-200.0\n",
      "-200.0\n",
      "-121.0\n",
      "-122.0\n",
      "-186.0\n",
      "-118.0\n",
      "-119.0\n",
      "-200.0\n",
      "-123.0\n",
      "-104.0\n",
      "-200.0\n",
      "-124.0\n",
      "-106.0\n",
      "-121.0\n",
      "-137.0\n",
      "-118.0\n",
      "-200.0\n",
      "-200.0\n",
      "-118.0\n",
      "-119.0\n",
      "-104.0\n",
      "-119.0\n",
      "-200.0\n",
      "-200.0\n",
      "-119.0\n",
      "-124.0\n",
      "-200.0\n",
      "-193.0\n",
      "-120.0\n",
      "-200.0\n",
      "-200.0\n",
      "-200.0\n",
      "-200.0\n",
      "-200.0\n",
      "-200.0\n",
      "-122.0\n",
      "-200.0\n",
      "-200.0\n",
      "-119.0\n",
      "-122.0\n",
      "-200.0\n",
      "-122.0\n",
      "-120.0\n",
      "-99.0\n",
      "-200.0\n",
      "-119.0\n",
      "-200.0\n",
      "-123.0\n",
      "-200.0\n",
      "-200.0\n",
      "-200.0\n",
      "-200.0\n",
      "-118.0\n",
      "-132.0\n",
      "-102.0\n",
      "-118.0\n",
      "-200.0\n",
      "-200.0\n",
      "-120.0\n",
      "-133.0\n",
      "-97.0\n",
      "Average reward over 100 episodes: -157.67\n"
     ]
    }
   ],
   "source": [
    "# Evaluate the trained model\n",
    "env = gym.make(\"MountainCar-v0\")\n",
    "total_reward = 0\n",
    "num_episodes = 100\n",
    "buffer_heur = []\n",
    "buffer_other = []\n",
    "for _ in range(num_episodes):\n",
    "    obs = env.reset()\n",
    "    done = False\n",
    "    ep_rew = 0\n",
    "\n",
    "    while not done:\n",
    "        # action = model(torch.FloatTensor(obs)).argmax().item()\n",
    "        action = expert_policy(obs)\n",
    "        obs, reward, done, _ = env.step(action)\n",
    "        total_reward += reward\n",
    "        ep_rew += reward\n",
    "    print(ep_rew)\n",
    "\n",
    "avg_reward = total_reward / num_episodes\n",
    "print(f'Average reward over {num_episodes} episodes: {avg_reward}')\n",
    "\n",
    "env.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "id": "4cdb5e70",
   "metadata": {},
   "outputs": [],
   "source": [
    "torch.save(model.state_dict(), 'mountaincarabc.pt')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "id": "79d604eb",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<All keys matched successfully>"
      ]
     },
     "execution_count": 44,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "anetwork_local = Actor(2, 3, 0)\n",
    "anetwork_local.load_state_dict(torch.load('mountaincarabc.pt'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "3a541956",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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HiJijBAhQoQIEfIQEWOECBEiRIiQh/mo4UfprBEiRIgQ4UyiIrGCaiGyGCNEiBAhQoQ8RMQYIUKECBEi5CEixggRIkSIECEPETFGiBAhQoQIeZhP8k2ECBEinFVks1m6urqYnJw811OJUEUkk0k6OzuJxWLneirA/LRSo6zUCBEinFUcOnSIhoYG2traEDknCYsRqgxjDP39/YyMjLBq1arCt6Os1AgRIkSYCZOTkxEpXmQQEdra2s4rL0BEjBEiRLigEJHixYfz7TuNiDFChAgRKsCb3vQm2tvbufLK6X15BwYGuP3227n00ku5/fbbSaVSgHUVvuMd72DNmjVcddVVPPXUVNvRz3/+81x66aVceumlfP7zn8+9/uSTT7JhwwbWrFnDO97xDsKQV6l9nEvU19ef6ylUHRExRogQIUIFuPfee3nooYdOe/2DH/wgt912G/v27eO2227jgx/8IAAPPvgg+/btY9++fXzyk5/kbW97G2BJ7n3vex+//OUvefzxx3nf+96XI7q3ve1tfOpTn8p9LtxfqX1EqC4iYowQIcLFjTFsj/ux6gx3yy230Nraetrr3/rWt3jjG98IwBvf+Ea++c1v5l6/5557EBFuvPFGBgcHOX78ON/97ne5/fbbaW1tpaWlhdtvv52HHnqI48ePMzw8zI033oiIcM8990wbq9g+8rFjxw6uv/56rr76aq666ir27dsHwCtf+Uo2b97M+vXr+eQnP5nbvr6+nvvuu4/169fzohe9iMcff5wXvOAFrF69mvvvvx+Az33uc9x111284AUv4NJLL+V973tf0XPz4Q9/mOuuu46rrrqKv/iLvwBgbGyMl73sZWzcuJErr7ySr371q5Wf9LOMqFwjQoQIFy+2Ah8DskAM+J/AhjOzq97eXjo6OgBYvHgxvb29AHR3d7Ns2bLcdp2dnXR3d8/4emdn52mvz7SPfHziE5/gne98J69//evJZDL4vg/AZz/7WVpbW5mYmOC6667j7rvvpq2tjbGxMW699VY+/OEP86pXvYo///M/53vf+x47d+7kjW98I694xSsAePzxx9m+fTu1tbVcd911vOxlL+Paa6/N7ffhhx9m3759PP744xhjeMUrXsGPf/xj+vr6WLJkCf/93/8NwNDQ0PxP9hlGZDFGiBDh4sQYlhTrgWXB/x+lapbjTBCRM55QUmofN910Ex/4wAf40Ic+xJEjR6ipqQHgn/7pn9i4cSM33ngjx44dy1mS8Xicl7zkJQBs2LCB5z//+cRiMTZs2MDhw4dz495+++20tbVRU1PDq1/9an76059O2+/DDz/Mww8/zDXXXMOmTZvYvXs3+/btY8OGDXzve9/jj//4j/nJT35CU1PTGToj1UNEjBEiRLg4MYi1FMPckPrg78Ezs7tFixZx/PhxAI4fP057ezsAS5cu5dixY7nturq6WLp06Yyvd3V1nfb6TPvIx+te9zruv/9+ampquPPOO/nBD37Ao48+yiOPPMIvfvELtmzZwjXXXJMrj4jFYjmCVUqRSCRyv3uelxu3kIQL/zbG8Kd/+qc888wzPPPMM+zfv583v/nNXHbZZTz11FNs2LCBP//zP+f9739/Jaf1nCAixggRIlycaMa6T0eDv0eDv5vPzO5e8YpX5DJLP//5z3PXXXflXv/CF76AMYbHHnuMpqYmOjo6uOOOO3j44YdJpVKkUikefvhh7rjjDjo6OmhsbOSxxx7DGMMXvvCFaWMV20c+Dh48yOrVq3nHO97BXXfdxdatWxkaGqKlpYXa2lp2797NY489VvHxfe9732NgYICJiQm++c1vcvPNN097/4477uCzn/0so6P2hHd3d3Py5El6enqora3lDW94A/fdd9+0rNzzFVGMMUKECBcn6rAxxY8CKaZijHXzG/a1r30tjz76KKdOnaKzs5P3ve99vPnNb+ZP/uRPeM1rXsNnPvMZVqxYwde+9jUA7rzzTh544AHWrFlDbW0t//qv/wpAa2sr7373u7nuuusAeM973pNL6vnYxz7Gvffey8TEBC996Ut56UtfClByH/n42te+xhe/+EVisRiLFy/mz/7sz6irq+MTn/gE69at4/LLL+fGG2+s+Livv/567r77brq6unjDG94wLb4I8OIXv5hdu3Zx0003ATap50tf+hL79+/nvvvuQylFLBbj4x//eMX7PtuIJOEiRIhwwWDXrl2sW7eusg+NYd2nzcybFJ+t+NznPsevfvUrPvKRj5yxfZT4bs9J5X9kMUaIEOHiRh0RIUaoCJHFGCFChAsGc7IYI1wQOJ8sxij5JkKECBEiRMhDRIwRIkS4oDAPL1eE8xTn23caEWOECBEuGCSTSfr7+8+7B2mEuSPsx5hMJs/1VHKIYowRIkS4YJDN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",
      "text/plain": [
       "<Figure size 1296x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "from mpl_toolkits.mplot3d import Axes3D\n",
    "\n",
    "# Create 3D scatter plots for position and velocity for full dataset, first 10,000, and sampled data\n",
    "fig = plt.figure(figsize=(18, 6))\n",
    "\n",
    "# Plot for full dataset\n",
    "ax1 = fig.add_subplot(1, 3, 1, projection='3d')\n",
    "ax1.scatter(position, velocity, expert_actions, c='magenta', label='100000 samples', alpha=0.5)\n",
    "ax1.set_xlabel('Position')\n",
    "ax1.set_ylabel('Velocity')\n",
    "ax1.set_zlabel('Action')\n",
    "ax1.set_title('3D Scatter Plot - State action distribution for teacher Mountain-Car V0')\n",
    "ax1.legend()\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "810906ad",
   "metadata": {},
   "source": [
    "## Cartpole BC from random data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "9505b423",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/ubuntu/anaconda3/envs/sonyenv/lib/python3.7/site-packages/ipykernel/ipkernel.py:283: DeprecationWarning: `should_run_async` will not call `transform_cell` automatically in the future. Please pass the result to `transformed_cell` argument and any exception that happen during thetransform in `preprocessing_exc_tuple` in IPython 7.17 and above.\n",
      "  and should_run_async(code)\n"
     ]
    }
   ],
   "source": [
    "# Define the bounds for position and velocity\n",
    "df = pd.read_pickle('OfflineRL-OOD-Teacher-Student/Discrete/CQL-DQN/data/CartPole-v1_run3_randomconv.pkl')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "id": "862f7347",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Expert policy (target policy in this case)\n",
    "def expert_policy(observation):\n",
    "    action = random.choice([0, 1])\n",
    "    if observation[0] > -1:\n",
    "        if observation[0] < 1:\n",
    "            if observation[2] < 0:\n",
    "                action = 0\n",
    "            else:\n",
    "                action = 1\n",
    "        else:\n",
    "            if observation[2] < 0:\n",
    "                action = 0\n",
    "            else:\n",
    "                if observation[1] > 0:\n",
    "                    if observation[3] < 0:\n",
    "                        action = 0\n",
    "                    else:\n",
    "                        action = 1\n",
    "                else:\n",
    "                    if observation[2] < 0:\n",
    "                        action = 0\n",
    "                    else:\n",
    "                        action = 1\n",
    "    else:\n",
    "        if observation[2] < 0:\n",
    "            if observation[1] < 0:\n",
    "                if observation[3] > 0:\n",
    "                    action = 1\n",
    "                else:\n",
    "                    action = 0\n",
    "            else:\n",
    "                if observation[2] < 0:\n",
    "                    action = 0\n",
    "                else:\n",
    "                    action = 1\n",
    "    return action"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "id": "f40084d2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0/100, Loss: 0.008418798446655273\n",
      "Epoch 10/100, Loss: 0.004097086377441883\n",
      "Epoch 20/100, Loss: 0.0019288783660158515\n",
      "Epoch 30/100, Loss: 0.004586287774145603\n",
      "Epoch 40/100, Loss: 0.011334984563291073\n",
      "Epoch 50/100, Loss: 0.007198832929134369\n",
      "Epoch 60/100, Loss: 1.8051021470455453e-05\n",
      "Epoch 70/100, Loss: 2.0471006791922264e-05\n",
      "Epoch 80/100, Loss: 0.0023348848335444927\n",
      "Epoch 90/100, Loss: 4.999142788619793e-07\n"
     ]
    }
   ],
   "source": [
    "if __name__ == \"__main__\":\n",
    "    data = []\n",
    "    for ind in df.index:\n",
    "        data.append(df['state'][ind])\n",
    "    \n",
    "    env = gym.make(\"CartPole-v1\")\n",
    "\n",
    "    # Collect expert demonstrations\n",
    "    expert_observations, expert_actions = collect_demonstrations(data)\n",
    "\n",
    "    # Define the behavior cloning model\n",
    "    input_size = expert_observations.shape[1]\n",
    "    output_size = env.action_space.n  # Assuming discrete action space\n",
    "    model = Actor(input_size, output_size,0)\n",
    "\n",
    "    # Train the behavior cloning model\n",
    "    train_behavior_cloning(model, expert_observations, expert_actions)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "id": "145ebfc5",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "31.0\n",
      "46.0\n",
      "43.0\n",
      "38.0\n",
      "54.0\n",
      "36.0\n",
      "35.0\n",
      "41.0\n",
      "35.0\n",
      "50.0\n",
      "Average reward over 10 episodes: 40.9\n"
     ]
    }
   ],
   "source": [
    "# Evaluate the trained model\n",
    "env = gym.make(\"CartPole-v1\")\n",
    "total_reward = 0\n",
    "num_episodes = 10\n",
    "buffer_heur = []\n",
    "buffer_other = []\n",
    "for _ in range(num_episodes):\n",
    "    obs = env.reset()\n",
    "    done = False\n",
    "    ep_rew = 0\n",
    "\n",
    "    while not done:\n",
    "        action = model(torch.FloatTensor(obs)).argmax().item()\n",
    "        # action = expert_policy(obs)\n",
    "        obs, reward, done, _ = env.step(action)\n",
    "        total_reward += reward\n",
    "        ep_rew += reward\n",
    "    print(ep_rew)\n",
    "\n",
    "avg_reward = total_reward / num_episodes\n",
    "print(f'Average reward over {num_episodes} episodes: {avg_reward}')\n",
    "\n",
    "env.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 73,
   "id": "0e67dd3a",
   "metadata": {},
   "outputs": [],
   "source": [
    "torch.save(model.state_dict(), 'cartpoleabc44.pt')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "id": "a2643fab",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<All keys matched successfully>"
      ]
     },
     "execution_count": 48,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "anetwork_local = Actor(4, 2, 0)\n",
    "anetwork_local.load_state_dict(torch.load('cartpoleabc44.pt'))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "318b250a",
   "metadata": {},
   "source": [
    "## Lunar Lander"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "c01ebe64",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Define the bounds for position and velocity\n",
    "df = pd.read_pickle('data/LunarLander-v2_run3_randomconv.pkl')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 95,
   "id": "ae2b8c5e",
   "metadata": {},
   "outputs": [],
   "source": [
    "class QNetwork(nn.Module):\n",
    "    \"\"\"Actor (Policy) Model.\"\"\"\n",
    "\n",
    "    def __init__(self, state_size, action_size, seed):\n",
    "        \"\"\"Initialize parameters and build model.\n",
    "        Params\n",
    "        ======\n",
    "            state_size (int): Dimension of each state\n",
    "            action_size (int): Dimension of each action\n",
    "            seed (int): Random seed\n",
    "        \"\"\"\n",
    "        super(QNetwork, self).__init__()\n",
    "        # self.seed = torch.manual_seed(seed)\n",
    "        self.fc1 = nn.Linear(state_size, 64)\n",
    "        self.fc2 = nn.Linear(64, 64)\n",
    "        self.fc3 = nn.Linear(64, action_size)\n",
    "        \n",
    "    def forward(self, state):\n",
    "        \"\"\"Build a network that maps state -> action values.\"\"\"\n",
    "        x = self.fc1(state)\n",
    "        x = F.relu(x)\n",
    "        x = self.fc2(x)\n",
    "        x = F.relu(x)\n",
    "        return F.softmax(self.fc3(x))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 96,
   "id": "702924c9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<All keys matched successfully>"
      ]
     },
     "execution_count": 96,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "device = torch.device(\"cuda:0\" if torch.cuda.is_available() else \"cpu\")\n",
    "qnetwork_local = QNetwork(8, 4, 0).to(device)\n",
    "qnetwork_local.load_state_dict(torch.load('model/checkpoint30.pth'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 97,
   "id": "cbf26157",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_action_heur(observation):\n",
    "    state = torch.from_numpy(observation).float().unsqueeze(0).to(device)\n",
    "    qnetwork_local.eval()\n",
    "    with torch.no_grad():\n",
    "        action_values = qnetwork_local(state)\n",
    "    return np.argmax(action_values.cpu().data.numpy())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "id": "63e2b9b4",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Expert policy (target policy in this case)\n",
    "def expert_policy(obs):\n",
    "    # Replace this with your expert policy logic\n",
    "    action = random.randint(0, 3)\n",
    "    if obs[5]<0.04:\n",
    "        if obs[3]> -0.35:\n",
    "            action = get_action_heur(obs)\n",
    "        else:\n",
    "            if obs[5]>-0.22:\n",
    "                action = get_action_heur(obs)\n",
    "            else:\n",
    "                if obs[4]>-0.04:\n",
    "                    action = get_action_heur(obs)\n",
    "    return action"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 87,
   "id": "352da973",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/ubuntu/anaconda3/envs/sonyenv/lib/python3.7/site-packages/ipykernel_launcher.py:24: UserWarning: Implicit dimension choice for softmax has been deprecated. Change the call to include dim=X as an argument.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0/100, Loss: 0.5901600122451782\n",
      "Epoch 10/100, Loss: 0.44198083877563477\n",
      "Epoch 20/100, Loss: 0.47865375876426697\n",
      "Epoch 30/100, Loss: 0.48859214782714844\n",
      "Epoch 40/100, Loss: 0.3983001708984375\n",
      "Epoch 50/100, Loss: 0.45174941420555115\n",
      "Epoch 60/100, Loss: 0.4957652986049652\n",
      "Epoch 70/100, Loss: 0.50995272397995\n",
      "Epoch 80/100, Loss: 0.4589824676513672\n",
      "Epoch 90/100, Loss: 0.4217764437198639\n"
     ]
    }
   ],
   "source": [
    "if __name__ == \"__main__\":\n",
    "    data = []\n",
    "    for ind in df.index:\n",
    "        data.append(df['state'][ind])\n",
    "    \n",
    "    env = gym.make(\"LunarLander-v2\")\n",
    "\n",
    "    # Collect expert demonstrations\n",
    "    expert_observations, expert_actions = collect_demonstrations(data)\n",
    "    #print(expert_actions[0:100])\n",
    "\n",
    "    # Define the behavior cloning model\n",
    "    input_size = expert_observations.shape[1]\n",
    "    output_size = env.action_space.n  # Assuming discrete action space\n",
    "    model = Actor(input_size, output_size,0)\n",
    "\n",
    "    # Train the behavior cloning model\n",
    "    train_behavior_cloning(model, expert_observations, expert_actions)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 94,
   "id": "0c4a4b5a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "166.3451475411211\n",
      "292.31847446273827\n",
      "14.422953887745948\n",
      "65.36275026557651\n",
      "-70.23115241207947\n",
      "-118.42030809301681\n",
      "26.06097281708979\n",
      "-82.99129510246469\n",
      "22.638832535471273\n",
      "209.37634072630402\n",
      "Average reward over 10 episodes: 52.48827166284834\n"
     ]
    }
   ],
   "source": [
    "# Evaluate the trained model\n",
    "env = gym.make(\"LunarLander-v2\")\n",
    "total_reward = 0\n",
    "num_episodes = 10\n",
    "buffer_heur = []\n",
    "buffer_other = []\n",
    "for _ in range(num_episodes):\n",
    "    obs = env.reset()\n",
    "    done = False\n",
    "    ep_rew = 0\n",
    "\n",
    "    while not done:\n",
    "        action = model(torch.FloatTensor(obs)).argmax().item()\n",
    "        # action = expert_policy(obs)\n",
    "        obs, reward, done, _ = env.step(action)\n",
    "        total_reward += reward\n",
    "        ep_rew += reward\n",
    "    print(ep_rew)\n",
    "\n",
    "avg_reward = total_reward / num_episodes\n",
    "print(f'Average reward over {num_episodes} episodes: {avg_reward}')\n",
    "\n",
    "env.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "id": "f3c327d1",
   "metadata": {},
   "outputs": [],
   "source": [
    "torch.save(model.state_dict(), 'checkpoint30.pt')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2a3602ce",
   "metadata": {},
   "source": [
    "## Minigrid Lavagaps "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "d65c95f9",
   "metadata": {},
   "outputs": [],
   "source": [
    "from gym import spaces\n",
    "import random, numpy, argparse\n",
    "class FlatImgObsWrapper(gym.core.ObservationWrapper):\n",
    "    \"\"\"\n",
    "    Use the image as the only observation output, no language/mission and flatten it\n",
    "    Modified from https://github.com/maximecb/gym-minigrid/blob/master/gym_minigrid/wrappers.py\n",
    "    to not only remove mission string but also remove the third dimension(representing the door state that can be open,\n",
    "    closed or locked) which is unnecessary as I am not using doors and flatten from 7x7x2 to 98.\n",
    "    \"\"\"\n",
    "\n",
    "    def __init__(self, env):\n",
    "        super().__init__(env)\n",
    "        obs_shape = env.observation_space.spaces['image'].shape\n",
    "\n",
    "        self.observation_space = spaces.Box(\n",
    "            low=0,\n",
    "            high=255,\n",
    "            shape=(obs_shape[0] * obs_shape[1] * 2,),\n",
    "            dtype='uint8'\n",
    "        )\n",
    "\n",
    "    def observation(self, obs):\n",
    "        # division by 10 as the first dimension can hold up to 5 different colors\n",
    "        # and the second channel can hold up to 10 different objects\n",
    "        # return obs['image'][:, :, :1], obs['direction']\n",
    "        return obs['image'][:, :, :2].flatten() / 10, # obs['direction']\n",
    "\n",
    "\n",
    "class RestrictMiniGridActionWrapper(gym.core.ActionWrapper):\n",
    "    \"\"\"\n",
    "    restrict to the first three actions -> turn left, turn right and move forward.\n",
    "    This is sufficient for the used environments from MiniGrid\n",
    "    \"\"\"\n",
    "\n",
    "    def __init__(self, env):\n",
    "        super(RestrictMiniGridActionWrapper, self).__init__(env)\n",
    "        self.action_space = gym.spaces.Discrete(3)\n",
    "\n",
    "    def action(self, action):\n",
    "        return action\n",
    "class SymbolicObsWrapper(gym.core.ObservationWrapper):\n",
    "    \"\"\"\n",
    "    Use the image as the only observation output, no language/mission and flatten it\n",
    "    Modified from https://github.com/maximecb/gym-minigrid/blob/master/gym_minigrid/wrappers.py\n",
    "    to not only remove mission string but also remove the third dimension(representing the door state that can be open,\n",
    "    closed or locked) which is unnecessary as I am not using doors and flatten from 7x7x2 to 98.\n",
    "    \"\"\"\n",
    "    # Map of object type to integers\n",
    "    OBJECT_TO_IDX = {\n",
    "        \"unseen\": 0,\n",
    "        \"empty\": 1,\n",
    "        \"wall\": 2,\n",
    "        \"floor\": 3,\n",
    "        \"door\": 4,\n",
    "        \"key\": 5,\n",
    "        \"ball\": 6,\n",
    "        \"box\": 7,\n",
    "        \"goal\": 8,\n",
    "        \"lava\": 9,\n",
    "        \"agent\": 10,\n",
    "    }\n",
    "\n",
    "    def __init__(self, env):\n",
    "        super().__init__(env)\n",
    "        obs_shape = env.observation_space.spaces['image'].shape\n",
    "\n",
    "        self.observation_space = spaces.Box(\n",
    "            low=0,\n",
    "            high=255,\n",
    "            shape=(obs_shape[0] * obs_shape[1] * 2,),\n",
    "            dtype='uint8'\n",
    "        )\n",
    "\n",
    "    def observation(self, obs):\n",
    "        def observation(self, obs):\n",
    "            objects = np.array(\n",
    "                [OBJECT_TO_IDX[o.type] if o is not None else -1 for o in self.grid.grid]\n",
    "            )\n",
    "            print(objects)\n",
    "            agent_pos = self.env.agent_pos\n",
    "            ncol, nrow = self.width, self.height\n",
    "            grid = np.mgrid[:ncol, :nrow]\n",
    "            _objects = np.transpose(objects.reshape(1, nrow, ncol), (0, 2, 1))\n",
    "\n",
    "            grid = np.concatenate([grid, _objects])\n",
    "            grid = np.transpose(grid, (1, 2, 0))\n",
    "            grid[agent_pos[0], agent_pos[1], 2] = OBJECT_TO_IDX[\"agent\"]\n",
    "            obs[\"image\"] = grid\n",
    "            return obs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 114,
   "id": "d607c0b6",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Define the bounds for position and velocity\n",
    "df = pd.read_pickle('data/MiniGrid-LavaGapS7-v0_run3_randomconv.pkl')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 79,
   "id": "c1918fd5",
   "metadata": {},
   "outputs": [],
   "source": [
    "def expert_policy1(state):\n",
    "    obs = state\n",
    "    # choose one action at random \n",
    "    action = random.randint(0, 2)\n",
    "    # wall or lava in the left side \n",
    "    if(obs[40] == 0.2 or obs[40] == 0.9):\n",
    "        #print('-------left-------')\n",
    "        # do not choose turn left\n",
    "        action = random.choice([1, 2])\n",
    "    # wall or lava in the right side \n",
    "    if(obs[68] == 0.2 or obs[68] == 0.9):\n",
    "        # do not choose turn right\n",
    "        #print('-------right-------')\n",
    "        action = random.choice([0, 2])\n",
    "    # wall or lava in front\n",
    "    if(obs[52] == 0.2 or obs[52] == 0.9):\n",
    "        #print('-------forward-------')\n",
    "        # do not choose move forward\n",
    "        action = random.choice([1, 0])\n",
    "    # handling wall and lava on left and front\n",
    "    if(obs[40] == (0.2 or 0.9)  and obs[52] == (0.2 or 0.9)):\n",
    "        #print('-------left-------')\n",
    "        # choose turn right\n",
    "        action = 1\n",
    "    # handling wall and lava on left and right\n",
    "    '''if(obs[40] == (0.2 or 0.9)  and obs[68] == (0.2 or 0.9)):\n",
    "        #print('-------left-------')\n",
    "        # choose forward\n",
    "        action = 2\n",
    "    # handling wall and lava on right and forward\n",
    "    if(obs[68] == (0.2 or 0.9)  and obs[52] == (0.2 or 0.9)):\n",
    "        #print('-------left-------')\n",
    "        # choose left\n",
    "        action = 0'''\n",
    "    return action"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 115,
   "id": "8ab8b1f3",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/ubuntu/anaconda3/envs/sonyenv/lib/python3.7/site-packages/ipykernel/ipkernel.py:283: DeprecationWarning: `should_run_async` will not call `transform_cell` automatically in the future. Please pass the result to `transformed_cell` argument and any exception that happen during thetransform in `preprocessing_exc_tuple` in IPython 7.17 and above.\n",
      "  and should_run_async(code)\n"
     ]
    }
   ],
   "source": [
    "def expert_policy(state):\n",
    "    obs = state\n",
    "    action = 2\n",
    "    # Wall or lava in front\n",
    "    if obs[52] == 0.9 or obs [52] == [0.2]:\n",
    "        # Wall or lava not in left move left\n",
    "        if obs[40] not in [0.2, 0.9]:\n",
    "            action = 0\n",
    "        # Wall or lava not in right move right\n",
    "        elif obs[68] not in [0.2, 0.9]:\n",
    "            action = 1\n",
    "        else:\n",
    "            action = random.choice([0, 1])\n",
    "    return action"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 116,
   "id": "ac723a53",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "98\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0.9540816326530612\n",
      "0\n",
      "0\n",
      "0\n",
      "0.9540816326530612\n",
      "0\n",
      "Average reward over 10 episodes: 0.19081632653061226\n",
      "Epoch 0/100, Loss: 0.00010729704808909446\n",
      "0.9586734693877551\n",
      "0.9540816326530612\n",
      "0.9540816326530612\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0.9586734693877551\n",
      "0\n",
      "0\n",
      "Average reward over 10 episodes: 0.38255102040816324\n",
      "Epoch 10/100, Loss: 1.6018745441215287e-07\n",
      "0.9586734693877551\n",
      "0\n",
      "0\n",
      "0.9586734693877551\n",
      "0\n",
      "0\n",
      "0.9586734693877551\n",
      "0.9586734693877551\n",
      "0\n",
      "0.9540816326530612\n",
      "Average reward over 10 episodes: 0.4788775510204082\n",
      "Epoch 20/100, Loss: 0.0\n",
      "0.9586734693877551\n",
      "0\n",
      "0.9540816326530612\n",
      "0\n",
      "0.9540816326530612\n",
      "0.9540816326530612\n",
      "0.9540816326530612\n",
      "0\n",
      "0.9540816326530612\n",
      "0.9540816326530612\n",
      "Average reward over 10 episodes: 0.6683163265306121\n",
      "Epoch 30/100, Loss: 0.0\n",
      "0.9586734693877551\n",
      "0.9586734693877551\n",
      "0.9540816326530612\n",
      "0.9540816326530612\n",
      "0.9586734693877551\n",
      "0\n",
      "0.9586734693877551\n",
      "0\n",
      "0.9540816326530612\n",
      "0.9540816326530612\n",
      "Average reward over 10 episodes: 0.7651020408163266\n",
      "Epoch 40/100, Loss: 0.0\n",
      "0\n",
      "0\n",
      "0.9586734693877551\n",
      "0.9586734693877551\n",
      "0.9586734693877551\n",
      "0.9586734693877551\n",
      "0\n",
      "0\n",
      "0.9540816326530612\n",
      "0.9540816326530612\n",
      "Average reward over 10 episodes: 0.5742857142857143\n",
      "Epoch 50/100, Loss: 0.0\n",
      "0.9586734693877551\n",
      "0.9586734693877551\n",
      "0.9540816326530612\n",
      "0\n",
      "0\n",
      "0.9540816326530612\n",
      "0.9586734693877551\n",
      "0.9540816326530612\n",
      "0\n",
      "0\n",
      "Average reward over 10 episodes: 0.573826530612245\n",
      "Epoch 60/100, Loss: 0.0\n",
      "0\n",
      "0\n",
      "0\n",
      "0.9540816326530612\n",
      "0.9540816326530612\n",
      "0\n",
      "0\n",
      "0.9586734693877551\n",
      "0.9586734693877551\n",
      "0.9586734693877551\n",
      "Average reward over 10 episodes: 0.47841836734693877\n",
      "Epoch 70/100, Loss: 0.0\n",
      "0\n",
      "0.9586734693877551\n",
      "0.9586734693877551\n",
      "0.9586734693877551\n",
      "0\n",
      "0\n",
      "0\n",
      "0.9586734693877551\n",
      "0.9586734693877551\n",
      "0.9540816326530612\n",
      "Average reward over 10 episodes: 0.5747448979591836\n",
      "Epoch 80/100, Loss: 0.0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0.9586734693877551\n",
      "0.9586734693877551\n",
      "0\n",
      "0.9586734693877551\n",
      "Average reward over 10 episodes: 0.28760204081632657\n",
      "Epoch 90/100, Loss: 0.0\n"
     ]
    }
   ],
   "source": [
    "if __name__ == \"__main__\":\n",
    "    data = []\n",
    "    action = []\n",
    "    for ind in df.index:\n",
    "        data.append(df['state'][ind])\n",
    "        action.append(df['action'][ind][0])\n",
    "    \n",
    "    env = gym.make(\"MiniGrid-LavaGapS7-v0\")\n",
    "    env = FlatImgObsWrapper(RestrictMiniGridActionWrapper(env))\n",
    "\n",
    "    # Collect expert demonstrations\n",
    "    print(len(data[0]))\n",
    "    #expert_observations = np.array(data)\n",
    "    # print(expert_observations[0])\n",
    "    #expert_actions = np.array(action)\n",
    "    # print(expert_actions[0:100])\n",
    "    expert_observations, expert_actions = collect_demonstrations(data)\n",
    "    # print(type(expert_observations))\n",
    "    # print(expert_actions[0:100])\n",
    "\n",
    "    # Define the behavior cloning model\n",
    "    input_size = 98 #expert_observations.shape[1]\n",
    "    # print(input_size)\n",
    "    output_size = env.action_space.n  # Assuming discrete action space\n",
    "    model = Actor(input_size, output_size,0)\n",
    "\n",
    "    # Train the behavior cloning model\n",
    "    train_behavior_cloning(model, expert_observations, expert_actions)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 107,
   "id": "7aae869e",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Evaluate the trained model\n",
    "def evaluate():\n",
    "    env = gym.make(\"MiniGrid-LavaGapS7-v0\")\n",
    "    env = FlatImgObsWrapper(RestrictMiniGridActionWrapper(env))\n",
    "    total_reward = 0\n",
    "    num_episodes = 10\n",
    "    buffer_heur = []\n",
    "    buffer_other = []\n",
    "    for _ in range(num_episodes):\n",
    "        obs = env.reset()\n",
    "        done = False\n",
    "        ep_rew = 0\n",
    "\n",
    "        while not done:\n",
    "            action = model(torch.FloatTensor(obs[0])).argmax().item()\n",
    "            #action = expert_policy2(obs[0])\n",
    "            obs, reward, done, _ = env.step(action)\n",
    "            total_reward += reward\n",
    "            ep_rew += reward\n",
    "        print(ep_rew)\n",
    "\n",
    "    avg_reward = total_reward / num_episodes\n",
    "    print(f'Average reward over {num_episodes} episodes: {avg_reward}')\n",
    "\n",
    "    env.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 110,
   "id": "b28ec7f5",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.9540816326530612\n",
      "0\n",
      "0\n",
      "0\n",
      "0.9586734693877551\n",
      "0.9540816326530612\n",
      "0\n",
      "0.9540816326530612\n",
      "0\n",
      "0\n",
      "Average reward over 10 episodes: 0.3820918367346938\n"
     ]
    }
   ],
   "source": [
    "evaluate()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "33fc6c2e",
   "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.0"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
