{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "98624d45",
   "metadata": {},
   "outputs": [],
   "source": [
    "%cd /content/drive/MyDrive/Human-Path-Prediction-master/ynet"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "02f74606",
   "metadata": {},
   "outputs": [],
   "source": [
    "%ls"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "f935555c",
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "034859e7",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import yaml\n",
    "import argparse\n",
    "import torch\n",
    "from model import YNet\n",
    "import pytorch_lightning as pl\n",
    "import pickle5 as pickle\n",
    "import weights_and_biases as wandb\n",
    "import utils\n",
    "import cv2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "5b0f860a",
   "metadata": {},
   "outputs": [],
   "source": [
    "CONFIG_FILE_PATH = 'config/eth_trajnet.yaml'  # yaml config file containing all the hyperparameters\n",
    "EXPERIMENT_NAME = 'eth_ucy'  # arbitrary name for this experiment\n",
    "DATASET_NAME = 'eth'\n",
    "\n",
    "TRAIN_DATA_PATH = '/content/drive/MyDrive/Human-Path-Prediction-master/ynet/data/eth_ucy/hotel_train.pkl'\n",
    "TRAIN_IMAGE_PATH = '/content/drive/MyDrive/Human-Path-Prediction-master/ynet/data/eth_ucy/train/hotel'\n",
    "VAL_DATA_PATH = '/content/drive/MyDrive/Human-Path-Prediction-master/ynet/data/eth_ucy/hotel_test.pkl'\n",
    "VAL_IMAGE_PATH = '/content/drive/MyDrive/Human-Path-Prediction-master/ynet/data/eth_ucy/test/hotel'\n",
    "OBS_LEN = 8  # in timesteps\n",
    "PRED_LEN = 12  # in timesteps\n",
    "NUM_GOALS = 20  # K_e\n",
    "NUM_TRAJ = 1  # K_a\n",
    "\n",
    "BATCH_SIZE = 4  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "2e1f5196",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(CONFIG_FILE_PATH) as file:\n",
    "    params = yaml.load(file, Loader=yaml.FullLoader)\n",
    "experiment_name = CONFIG_FILE_PATH.split('.yaml')[0].split('config/')[1]\n",
    "params['resize'] = 0.67\n",
    "params"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "6a3c23bd",
   "metadata": {},
   "outputs": [],
   "source": [
    "CONFIG_FILE_PATH = '/content/drive/MyDrive/Human-Path-Prediction-master/ynet/config/eth_longterm.yaml'  # yaml config file containing all the hyperparameters\n",
    "EXPERIMENT_NAME = 'eth_ucy'  # arbitrary name for this experiment\n",
    "DATASET_NAME = 'eth'\n",
    "\n",
    "TRAIN_DATA_PATH = '/content/drive/MyDrive/Human-Path-Prediction-master/ynet/data/eth_ucy/hotel_train.pkl'\n",
    "TRAIN_IMAGE_PATH = '/content/drive/MyDrive/Human-Path-Prediction-master/ynet/data/eth_ucy/train/hotel'\n",
    "VAL_DATA_PATH = '/content/drive/MyDrive/Human-Path-Prediction-master/ynet/data/eth_ucy/hotel_test.pkl'\n",
    "VAL_IMAGE_PATH = '/content/drive/MyDrive/Human-Path-Prediction-master/ynet/data/eth_ucy/test/hotel'\n",
    "OBS_LEN = 8  # in timesteps\n",
    "PRED_LEN = 12  # in timesteps\n",
    "NUM_GOALS = 20  # K_e\n",
    "NUM_TRAJ = 1  # K_a\n",
    "\n",
    "BATCH_SIZE = 4  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "d94e97d4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'CWS_params': {'ratio': 2, 'rot': True, 'sigma_factor': 6},\n",
      " 'batch_size': 8,\n",
      " 'decoder_channels': [64, 64, 64, 32, 32],\n",
      " 'encoder_channels': [32, 32, 64, 64, 64],\n",
      " 'kernlen': 31,\n",
      " 'learning_rate': 0.0001,\n",
      " 'loss_scale': 1000,\n",
      " 'nsig': 4,\n",
      " 'num_epochs': 300,\n",
      " 'rel_threshold': 0.002,\n",
      " 'resize': 0.67,\n",
      " 'segmentation_model_fp': 'segmentation_models/SDD_segmentation.pth',\n",
      " 'semantic_classes': 6,\n",
      " 'temperature': 1.8,\n",
      " 'unfreeze': 100,\n",
      " 'use_CWS': True,\n",
      " 'use_TTST': True,\n",
      " 'use_features_only': False,\n",
      " 'viz_epoch': 10,\n",
      " 'waypoints': [11]}"
     ]
    }
   ],
   "source": [
    "with open(CONFIG_FILE_PATH) as file:\n",
    "    params = yaml.load(file, Loader=yaml.FullLoader)\n",
    "experiment_name = CONFIG_FILE_PATH.split('.yaml')[0].split('config/')[1]\n",
    "params['resize'] = 0.67\n",
    "params"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "805835ed",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(TRAIN_DATA_PATH, \"rb\") as fh:\n",
    "\tdf_train = pickle.load(fh)\n",
    "with open(VAL_DATA_PATH, \"rb\") as fh:\n",
    "\tdf_val = pickle.load(fh)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "fb390521",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "        frame  trackId    x    y sceneId  metaId\n",
      "4         1.0      5.0  187  535   hotel       4\n",
      "14       11.0      5.0  187  535   hotel       4\n",
      "22       21.0      5.0  187  535   hotel       4\n",
      "28       31.0      5.0  187  535   hotel       4\n",
      "34       41.0      5.0  187  535   hotel       4\n",
      "...       ...      ...  ...  ...     ...     ...\n",
      "4692  13281.0    311.0  209  361   hotel     287\n",
      "4702  13291.0    311.0  209  361   hotel     287\n",
      "4712  13301.0    311.0  209  361   hotel     287\n",
      "4722  13311.0    311.0  209  361   hotel     287\n",
      "4732  13321.0    311.0  209  361   hotel     287\n",
      "\n",
      "[2040 rows x 6 columns]"
     ]
    }
   ],
   "source": [
    "#df_train\n",
    "df_train['sceneId'] = \"hotel\"\n",
    "df_train = df_train.iloc[: , 1:]\n",
    "df_train"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "1aed71a0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "        frame  trackId    x    y sceneId  metaId\n",
      "4536  13131.0    313.0  233  665   hotel     289\n",
      "4546  13141.0    313.0  233  665   hotel     289\n",
      "4556  13151.0    313.0  233  665   hotel     289\n",
      "4565  13161.0    313.0  233  665   hotel     289\n",
      "4575  13171.0    313.0  233  665   hotel     289\n",
      "...       ...      ...  ...  ...     ...     ...\n",
      "6473  17921.0    414.0  420  472   hotel     383\n",
      "6478  17931.0    414.0  418  504   hotel     383\n",
      "6484  17941.0    414.0  418  535   hotel     383\n",
      "6491  17951.0    414.0  416  568   hotel     383\n",
      "6497  17961.0    414.0  417  598   hotel     383\n",
      "\n",
      "[860 rows x 6 columns]"
     ]
    }
   ],
   "source": [
    "df_val['sceneId'] = \"hotel\"\n",
    "df_val = df_val.iloc[: , 1:]\n",
    "df_val"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "64bcaaea",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "'1.10.2+cu102'"
     ]
    }
   ],
   "source": [
    "torch.__version__"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "6d2deca6",
   "metadata": {},
   "outputs": [],
   "source": [
    "model = YNet(obs_len=OBS_LEN, pred_len=PRED_LEN, params=params)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "a295c6d4",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "\n",
       "                    Syncing run <strong><a href=\"https://wandb.ai/agv/ynet/runs/17nwrq64\" target=\"_blank\">blooming-frost-52</a></strong> to <a href=\"https://wandb.ai/agv/ynet\" target=\"_blank\">Weights & Biases</a> (<a href=\"https://docs.wandb.com/integrations/jupyter.html\" target=\"_blank\">docs</a>).<br/>\n",
       "\n",
       "                "
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "!wandb login --relogin\n",
    "wandb.init_wandb(params.copy(), model.model)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "15044870",
   "metadata": {},
   "outputs": [],
   "source": [
    "model.train(df_train, df_val, params, train_image_path=TRAIN_IMAGE_PATH, val_image_path=VAL_IMAGE_PATH,\n",
    "            experiment_name=EXPERIMENT_NAME, batch_size=BATCH_SIZE, num_goals=NUM_GOALS, num_traj=NUM_TRAJ, \n",
    "            device=None, dataset_name=DATASET_NAME)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "cf14679c",
   "metadata": {},
   "outputs": [],
   "source": [
    "model.train(df_train, df_val, params, train_image_path=TRAIN_IMAGE_PATH, val_image_path=VAL_IMAGE_PATH,\n",
    "            experiment_name=EXPERIMENT_NAME, batch_size=BATCH_SIZE, num_goals=NUM_GOALS, num_traj=NUM_TRAJ, \n",
    "            device=None, dataset_name=DATASET_NAME)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "416c5824",
   "metadata": {},
   "outputs": [],
   "source": [
    "CONFIG_FILE_PATH = '/content/drive/MyDrive/Human-Path-Prediction-master/ynet/config/eth_longterm.yaml'  # yaml config file containing all the hyperparameters\n",
    "EXPERIMENT_NAME = 'eth_ucy'  # arbitrary name for this experiment\n",
    "DATASET_NAME = 'eth'\n",
    "\n",
    "TRAIN_DATA_PATH = '/content/drive/MyDrive/Human-Path-Prediction-master/ynet/data/eth_ucy/hotel_train.pkl'\n",
    "TRAIN_IMAGE_PATH = '/content/drive/MyDrive/Human-Path-Prediction-master/ynet/data/eth_ucy/train/hotel/oracle.png'\n",
    "VAL_DATA_PATH = '/content/drive/MyDrive/Human-Path-Prediction-master/ynet/data/eth_ucy/hotel_test.pkl'\n",
    "VAL_IMAGE_PATH = '/content/drive/MyDrive/Human-Path-Prediction-master/ynet/data/eth_ucy/test/hotel'\n",
    "OBS_LEN = 8  # in timesteps\n",
    "PRED_LEN = 12  # in timesteps\n",
    "NUM_GOALS = 20  # K_e\n",
    "NUM_TRAJ = 1  # K_a\n",
    "\n",
    "BATCH_SIZE = 4  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "6ed0a328",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'CWS_params': {'ratio': 2, 'rot': True, 'sigma_factor': 6},\n",
      " 'batch_size': 8,\n",
      " 'decoder_channels': [64, 64, 64, 32, 32],\n",
      " 'encoder_channels': [32, 32, 64, 64, 64],\n",
      " 'kernlen': 31,\n",
      " 'learning_rate': 0.0001,\n",
      " 'loss_scale': 1000,\n",
      " 'nsig': 4,\n",
      " 'num_epochs': 300,\n",
      " 'rel_threshold': 0.002,\n",
      " 'resize': 0.67,\n",
      " 'segmentation_model_fp': 'segmentation_models/SDD_segmentation.pth',\n",
      " 'semantic_classes': 6,\n",
      " 'temperature': 1.8,\n",
      " 'unfreeze': 100,\n",
      " 'use_CWS': True,\n",
      " 'use_TTST': True,\n",
      " 'use_features_only': False,\n",
      " 'viz_epoch': 10,\n",
      " 'waypoints': [11]}"
     ]
    }
   ],
   "source": [
    "with open(CONFIG_FILE_PATH) as file:\n",
    "    params = yaml.load(file, Loader=yaml.FullLoader)\n",
    "experiment_name = CONFIG_FILE_PATH.split('.yaml')[0].split('config/')[1]\n",
    "params['resize'] = 0.67\n",
    "params"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "26b9af57",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(TRAIN_DATA_PATH, \"rb\") as fh:\n",
    "\tdf_train = pickle.load(fh)\n",
    "with open(VAL_DATA_PATH, \"rb\") as fh:\n",
    "\tdf_val = pickle.load(fh)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "eab55918",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "        frame  trackId    x    y sceneId  metaId\n",
      "4         1.0      5.0  187  535   hotel       4\n",
      "14       11.0      5.0  187  535   hotel       4\n",
      "22       21.0      5.0  187  535   hotel       4\n",
      "28       31.0      5.0  187  535   hotel       4\n",
      "34       41.0      5.0  187  535   hotel       4\n",
      "...       ...      ...  ...  ...     ...     ...\n",
      "4692  13281.0    311.0  209  361   hotel     287\n",
      "4702  13291.0    311.0  209  361   hotel     287\n",
      "4712  13301.0    311.0  209  361   hotel     287\n",
      "4722  13311.0    311.0  209  361   hotel     287\n",
      "4732  13321.0    311.0  209  361   hotel     287\n",
      "\n",
      "[2040 rows x 6 columns]"
     ]
    }
   ],
   "source": [
    "#df_train\n",
    "df_train['sceneId'] = \"hotel\"\n",
    "df_train = df_train.iloc[: , 1:]\n",
    "df_train"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "36db85f4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "        frame  trackId    x    y sceneId  metaId\n",
      "4536  13131.0    313.0  233  665   hotel     289\n",
      "4546  13141.0    313.0  233  665   hotel     289\n",
      "4556  13151.0    313.0  233  665   hotel     289\n",
      "4565  13161.0    313.0  233  665   hotel     289\n",
      "4575  13171.0    313.0  233  665   hotel     289\n",
      "...       ...      ...  ...  ...     ...     ...\n",
      "6473  17921.0    414.0  420  472   hotel     383\n",
      "6478  17931.0    414.0  418  504   hotel     383\n",
      "6484  17941.0    414.0  418  535   hotel     383\n",
      "6491  17951.0    414.0  416  568   hotel     383\n",
      "6497  17961.0    414.0  417  598   hotel     383\n",
      "\n",
      "[860 rows x 6 columns]"
     ]
    }
   ],
   "source": [
    "df_val['sceneId'] = \"hotel\"\n",
    "df_val = df_val.iloc[: , 1:]\n",
    "df_val"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "75eff932",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "'1.10.2+cu102'"
     ]
    }
   ],
   "source": [
    "torch.__version__"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "2566ecca",
   "metadata": {},
   "outputs": [],
   "source": [
    "model = YNet(obs_len=OBS_LEN, pred_len=PRED_LEN, params=params)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "f980feee",
   "metadata": {},
   "outputs": [],
   "source": [
    "!wandb login --relogin\n",
    "wandb.init_wandb(params.copy(), model.model)"
   ]
  }
 ],
 "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.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
