{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "from torchvision import transforms\n",
    "from torch.utils.data import Dataset, DataLoader, random_split\n",
    "import torch\n",
    "from torch.utils.data import Dataset\n",
    "import os\n",
    "import json\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import cv2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['../data/record\\\\Town01_100npcs_1', '../data/record\\\\Town01_200npcs_1', '../data/record\\\\Town02_100npcs_1', '../data/record\\\\Town02_200npcs_1', '../data/record\\\\Town03_100npcs_1', '../data/record\\\\Town03_200npcs_1', '../data/record\\\\Town04_100npcs_1', '../data/record\\\\Town04_200npcs_1', '../data/record\\\\Town05_100npcs_1', '../data/record\\\\Town05_200npcs_1', '../data/record\\\\Town06_100npcs_1', '../data/record\\\\Town06_100npcs_2', '../data/record\\\\Town06_200npcs_1', '../data/record\\\\Town06_200npcs_2', '../data/record\\\\Town12_2000npcs_1', '../data/record\\\\Town12_200npcs_2', '../data/record\\\\Town12_200npcs_3', '../data/record\\\\Town15_500npcs']\n"
     ]
    }
   ],
   "source": [
    "dataset_paths = []\n",
    "records_folder = \"../data/reasoning_nuscenes\"\n",
    "for name in os.listdir(records_folder):\n",
    "   dir = os.path.join(records_folder, name)\n",
    "   if os.path.isdir(dir):\n",
    "      dataset_paths.append(dir)\n",
    "\n",
    "print(dataset_paths)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "14248\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Clipping input data to the valid range for imshow with RGB data ([0..1] for floats or [0..255] for integers).\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "11398 2850\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "class RedLightPredictionDataset(Dataset):\n",
    "    def __init__(self, dataset_paths, return_metadata=False, transform=None, sensor_range=50.0, bev_range=50.0):\n",
    "        super().__init__()\n",
    "        self.records = []\n",
    "        self.return_metadata = return_metadata\n",
    "        self.transform = transform\n",
    "        self.sensor_range = sensor_range\n",
    "        self.bev_range = bev_range\n",
    "\n",
    "        for path in dataset_paths:\n",
    "            self.read_data_folder(path)\n",
    "    \n",
    "    def read_data_folder(self, path):\n",
    "        for agent in os.listdir(os.path.join(path, 'agents')):\n",
    "            agent_folder = os.path.join(path, 'agents', agent)\n",
    "\n",
    "            rec = {}\n",
    "            for line in open(os.path.join(agent_folder, 'gt_location', 'data.jsonl'), 'r'):\n",
    "                record = json.loads(line)\n",
    "                rec[record['frame']] = {\n",
    "                    'location': record['location'],\n",
    "                    'rotation': record['rotation'],\n",
    "                }\n",
    "            \n",
    "            for line in open(os.path.join(agent_folder, 'gt_traffic_light', 'data.jsonl'), 'r'):\n",
    "                record = json.loads(line)\n",
    "                rec[record['frame']]['is_red_light'] = 0\n",
    "                if record['current_traffic_light'] is not None:\n",
    "                    if record['current_traffic_light']['state'] == 'Red':\n",
    "                        rec[record['frame']]['is_red_light'] = 1\n",
    "\n",
    "            for filename in os.listdir(os.path.join(agent_folder, 'front_camera')):\n",
    "                frame = int(filename.split('.')[0])\n",
    "                rec[frame]['image_path'] = os.path.join(agent_folder, 'front_camera', filename)\n",
    "                rec[frame]['output_path'] = os.path.join(agent_folder, 'pred_traffic_light', 'data.jsonl'),\n",
    "\n",
    "            for frame, r in rec.items():\n",
    "                r['frame'] = frame\n",
    "                self.records.append(r)\n",
    "    \n",
    "    def __len__(self):\n",
    "        return len(self.records)\n",
    "    \n",
    "    def __getitem__(self, index):\n",
    "        record = self.records[index]\n",
    "        agent_image = cv2.imread(record['image_path'])\n",
    "        agent_image = cv2.cvtColor(agent_image, cv2.COLOR_BGR2RGB)\n",
    "        y = record['is_red_light']\n",
    "\n",
    "        image = agent_image\n",
    "\n",
    "        if self.transform is not None:\n",
    "            image = self.transform(image)\n",
    "\n",
    "        if self.return_metadata:\n",
    "            return image, y, self.records[index]\n",
    "        return image, y\n",
    "\n",
    "preprocess = transforms.Compose([\n",
    "    transforms.ToPILImage(),\n",
    "    transforms.Resize(size=(224, 224)),\n",
    "    transforms.ToTensor(),\n",
    "    transforms.Normalize(mean=[0.485, 0.456, 0.406], std=[0.229, 0.224, 0.225]),\n",
    "])\n",
    "\n",
    "dataset = RedLightPredictionDataset(dataset_paths, transform=preprocess)\n",
    "\n",
    "print(len(dataset))\n",
    "img, label = dataset[0]\n",
    "plt.imshow(np.array(img).transpose(1, 2, 0))\n",
    "print(label)\n",
    "\n",
    "train_size = int(len(dataset) * 0.8)\n",
    "test_size = len(dataset) - train_size\n",
    "print(train_size, test_size)\n",
    "train_dataset, test_dataset = random_split(dataset, [train_size, test_size], generator=torch.Generator().manual_seed(233))\n",
    "\n",
    "train_loader = DataLoader(\n",
    "    train_dataset,\n",
    "    batch_size=64,\n",
    "    shuffle=True,\n",
    "    num_workers=0,\n",
    ")\n",
    "\n",
    "test_loader = DataLoader(\n",
    "    test_dataset,\n",
    "    batch_size=64,\n",
    "    shuffle=False,\n",
    ")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{0: 9567, 1: 4681}\n"
     ]
    }
   ],
   "source": [
    "label_counts = {}\n",
    "for i in range(len(dataset)):\n",
    "    _, label = dataset[i]\n",
    "    if label not in label_counts:\n",
    "        label_counts[label] = 0\n",
    "    label_counts[label] += 1\n",
    "\n",
    "print(label_counts)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cuda:0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Using cache found in C:\\Users\\IX/.cache\\torch\\hub\\pytorch_vision_v0.10.0\n",
      "d:\\Workspace\\Autopilot\\venv\\lib\\site-packages\\torchvision\\models\\_utils.py:208: UserWarning: The parameter 'pretrained' is deprecated since 0.13 and may be removed in the future, please use 'weights' instead.\n",
      "  warnings.warn(\n",
      "d:\\Workspace\\Autopilot\\venv\\lib\\site-packages\\torchvision\\models\\_utils.py:223: UserWarning: Arguments other than a weight enum or `None` for 'weights' are deprecated since 0.13 and may be removed in the future. The current behavior is equivalent to passing `weights=ResNeXt50_32X4D_Weights.IMAGENET1K_V1`. You can also use `weights=ResNeXt50_32X4D_Weights.DEFAULT` to get the most up-to-date weights.\n",
      "  warnings.warn(msg)\n"
     ]
    }
   ],
   "source": [
    "from torch import nn\n",
    "import torch.optim as optim\n",
    "\n",
    "device = torch.device('cuda:0' if torch.cuda.is_available() else 'cpu')\n",
    "print(device)\n",
    "\n",
    "class RedLightModel(nn.Module):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.backbone = torch.hub.load('pytorch/vision:v0.10.0', 'resnext50_32x4d', pretrained=True)\n",
    "        self.linear = nn.Linear(1000, 2)\n",
    "\n",
    "    def forward(self, x):\n",
    "        x = self.backbone(x)\n",
    "        x = self.linear(x)\n",
    "        return x\n",
    "\n",
    "model = RedLightModel()\n",
    "model.to(device)\n",
    "\n",
    "criterion = nn.CrossEntropyLoss()\n",
    "optimizer = optim.Adam(model.parameters(), lr=0.001, weight_decay=0)\n",
    "\n",
    "save_dir = '../tmp/RedLightPrediction/'\n",
    "os.makedirs(save_dir, exist_ok=True)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "try:\n",
    "    model.load_state_dict(torch.load(os.path.join(save_dir, 'model.pth')))\n",
    "    optimizer.load_state_dict(torch.load(os.path.join(save_dir, 'optimizer.pth')))\n",
    "except Exception as e:\n",
    "    print(e)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 training loss: 0.6387748258269351 accuracy: 0.6629948616027832\n",
      "Epoch 0 testing loss: 0.38466648509105045 accuracy: 0.8335626125335693\n",
      "Epoch 1 training loss: 0.32544944143813587 accuracy: 0.8702237606048584\n",
      "Epoch 1 testing loss: 0.2729297950863838 accuracy: 0.888583242893219\n",
      "Epoch 2 training loss: 0.20904150791466236 accuracy: 0.9239242672920227\n",
      "Epoch 2 testing loss: 0.2001373159388701 accuracy: 0.9270976781845093\n",
      "Epoch 3 training loss: 0.15392140452952488 accuracy: 0.9462994933128357\n",
      "Epoch 3 testing loss: 0.1929991419116656 accuracy: 0.9325997233390808\n",
      "Epoch 4 training loss: 0.17057809687179068 accuracy: 0.9376936554908752\n",
      "Epoch 4 testing loss: 0.18277834355831146 accuracy: 0.9408528208732605\n",
      "Epoch 5 training loss: 0.11686621901943632 accuracy: 0.9593803882598877\n",
      "Epoch 5 testing loss: 0.21792371633152166 accuracy: 0.928473174571991\n",
      "Epoch 6 training loss: 0.08611932093196589 accuracy: 0.9710843563079834\n",
      "Epoch 6 testing loss: 0.19733712015052637 accuracy: 0.9394773244857788\n",
      "Epoch 7 training loss: 0.07263173745013773 accuracy: 0.9759036302566528\n",
      "Epoch 7 testing loss: 0.18880217522382736 accuracy: 0.9381017684936523\n",
      "Epoch 8 training loss: 0.07693479766907252 accuracy: 0.9765920639038086\n",
      "Epoch 8 testing loss: 0.2148726380740603 accuracy: 0.9408528208732605\n",
      "Epoch 9 training loss: 0.08079165625183479 accuracy: 0.975559413433075\n",
      "Epoch 9 testing loss: 0.1713266378889481 accuracy: 0.9449793696403503\n",
      "Epoch 10 training loss: 0.05049430991968383 accuracy: 0.986919105052948\n",
      "Epoch 10 testing loss: 0.5673555408914884 accuracy: 0.888583242893219\n",
      "Epoch 11 training loss: 0.09347421496742121 accuracy: 0.9721170663833618\n",
      "Epoch 11 testing loss: 0.20659300529708466 accuracy: 0.9518569707870483\n",
      "Epoch 12 training loss: 0.04413345819541618 accuracy: 0.9855421781539917\n",
      "Epoch 12 testing loss: 0.19684692937880754 accuracy: 0.935350775718689\n",
      "Epoch 13 training loss: 0.055024589189206774 accuracy: 0.9865748882293701\n",
      "Epoch 13 testing loss: 0.2102230442687869 accuracy: 0.9449793696403503\n",
      "Epoch 14 training loss: 0.05540685593049326 accuracy: 0.9900172352790833\n",
      "Epoch 14 testing loss: 0.2620183990026514 accuracy: 0.9394773244857788\n",
      "Epoch 15 training loss: 0.16469122416785228 accuracy: 0.9418244361877441\n",
      "Epoch 15 testing loss: 0.18998785503208637 accuracy: 0.9449793696403503\n",
      "Epoch 16 training loss: 0.09953945549204946 accuracy: 0.9693631529808044\n",
      "Epoch 16 testing loss: 0.18012504590054354 accuracy: 0.9394773244857788\n",
      "Epoch 17 training loss: 0.06446899944389968 accuracy: 0.9783132672309875\n",
      "Epoch 17 testing loss: 0.19070640982439122 accuracy: 0.9449793696403503\n",
      "Epoch 18 training loss: 0.04574806797925545 accuracy: 0.9855421781539917\n",
      "Epoch 18 testing loss: 0.1880992582688729 accuracy: 0.9518569707870483\n",
      "Epoch 19 training loss: 0.05919705216934824 accuracy: 0.9848536849021912\n",
      "Epoch 19 testing loss: 0.1518800787938138 accuracy: 0.9504814147949219\n"
     ]
    }
   ],
   "source": [
    "num_epochs = 20\n",
    "for epoch in range(num_epochs):\n",
    "    train_loss = 0.0\n",
    "    train_correct = 0.0\n",
    "    for i, data in enumerate(train_loader):\n",
    "        x, y = data\n",
    "        x = x.to(device)\n",
    "        y = y.to(device)\n",
    "        optimizer.zero_grad()\n",
    "        y_pred = model(x)\n",
    "        loss = criterion(y_pred, y)\n",
    "\n",
    "        with torch.no_grad():\n",
    "            _, predictions = torch.max(y_pred, 1)\n",
    "            train_correct = train_correct + (predictions == y).float().sum()\n",
    "\n",
    "        loss.backward()\n",
    "        optimizer.step()\n",
    "\n",
    "        train_loss += loss.item()\n",
    "    train_loss = train_loss / len(train_loader)\n",
    "    train_acc = train_correct / len(train_dataset)\n",
    "    print(f'Epoch {epoch} training loss: {train_loss} accuracy: {train_acc}')\n",
    "\n",
    "    with torch.no_grad():\n",
    "        test_loss = 0.0\n",
    "        test_correct = 0.0\n",
    "        for i, data in enumerate(test_loader):\n",
    "            x, y = data\n",
    "            x = x.to(device)\n",
    "            y = y.to(device)\n",
    "            y_pred = model(x)\n",
    "            loss = criterion(y_pred, y)\n",
    "            _, predictions = torch.max(y_pred, 1)\n",
    "            test_correct = test_correct + (predictions == y).float().sum()\n",
    "            test_loss += loss.item()\n",
    "        test_loss = test_loss / len(test_loader)\n",
    "        test_acc = test_correct / len(test_dataset)\n",
    "        print(f'Epoch {epoch} testing loss: {test_loss} accuracy: {test_acc}')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "torch.save(model.state_dict(), os.path.join(save_dir, 'model.pth'))\n",
    "torch.save(optimizer.state_dict(), os.path.join(save_dir, 'optimizer.pth'))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average loss: 1.3882878296760186 accuracy: 0.6075238585472107\n"
     ]
    }
   ],
   "source": [
    "def write_pred():\n",
    "    dataset = RedLightPredictionDataset(dataset_paths, return_metadata=True, transform=preprocess)\n",
    "    dataloader = DataLoader(\n",
    "        dataset,\n",
    "        batch_size=8,\n",
    "        shuffle=False,\n",
    "    )\n",
    "\n",
    "    save_objs = {}\n",
    "\n",
    "    total_loss = 0.0\n",
    "    total_samples = 0.0\n",
    "    total_correct = 0.0\n",
    "    for i, data in enumerate(dataloader):\n",
    "        x, y, meta = data\n",
    "        x = x.to(device)\n",
    "        y = y.to(device)\n",
    "\n",
    "        y_pred = model(x)\n",
    "        loss = criterion(y_pred, y)\n",
    "\n",
    "        with torch.no_grad():\n",
    "            _, predictions = torch.max(y_pred, 1)\n",
    "            total_samples += y.shape[0]\n",
    "            total_correct += (predictions == y).float().sum()\n",
    "\n",
    "        for i in range(y.shape[0]):\n",
    "            output_path = meta['output_path'][0][i]\n",
    "            if output_path not in save_objs:\n",
    "                save_objs[output_path] = {}\n",
    "            frame = int(meta['frame'][i])\n",
    "            if frame not in save_objs[output_path]:\n",
    "                save_objs[output_path][frame] = {}\n",
    "            save_objs[output_path][frame] = {\n",
    "                'frame': int(meta['frame'][i]),\n",
    "                'is_under_red_traffic_light': int(predictions[i]),\n",
    "                'is_under_red_traffic_light_gt': int(y[i]),\n",
    "            }\n",
    "\n",
    "        total_loss += loss.item()\n",
    "    total_loss = total_loss / len(dataloader)\n",
    "    total_acc = total_correct / total_samples\n",
    "    print(f'Average loss: {total_loss} accuracy: {total_acc}')\n",
    "\n",
    "    for filepath, frames in save_objs.items():\n",
    "        os.makedirs(os.path.dirname(filepath), exist_ok=True)\n",
    "        with open(filepath, 'w') as file:\n",
    "            for frame in sorted(list(frames.keys())):\n",
    "                line = json.dumps(save_objs[filepath][frame])\n",
    "                file.write(line+\"\\n\")\n",
    "\n",
    "write_pred()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3.9.13 ('venv': venv)",
   "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"
  },
  "orig_nbformat": 4,
  "vscode": {
   "interpreter": {
    "hash": "da7e20478b5a775c0656e92accb7702d4567ea1fb2ed254df86c89875ad00a36"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
