{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "13704296",
   "metadata": {},
   "outputs": [],
   "source": [
    "#For correct folder \n",
    "%cd /content/drive/MyDrive/Human-Path-Prediction-master/ynet"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "056715c1",
   "metadata": {},
   "outputs": [],
   "source": [
    "%ls"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "8de9a60b",
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "1120bbba",
   "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": "5c71c2e8",
   "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/zara2_train.pkl'#train pkl file path \n",
    "TRAIN_IMAGE_PATH = '/content/drive/MyDrive/Human-Path-Prediction-master/ynet/data/eth_ucy/train/zara2/oracle.png'#Train_image_file_path we are not giving train folder path beacuse there is only one scene image\n",
    "VAL_DATA_PATH = '/content/drive/MyDrive/Human-Path-Prediction-master/ynet/data/eth_ucy/zara2_test.pkl'#Test_pkl_file_path\n",
    "VAL_IMAGE_PATH = '/content/drive/MyDrive/Human-Path-Prediction-master/ynet/data/eth_ucy/test'#path to test folder of dataset\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  \n",
    "scene_name = \"zara2\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "4ac187ba",
   "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/zara2_train.pkl'#train pkl file path \n",
    "TRAIN_IMAGE_PATH = '/content/drive/MyDrive/Human-Path-Prediction-master/ynet/data/eth_ucy/train/zara2/oracle.png'#Train_image_file_path we are not giving train folder path beacuse there is only one scene image\n",
    "VAL_DATA_PATH = '/content/drive/MyDrive/Human-Path-Prediction-master/ynet/data/eth_ucy/zara2_test.pkl'#Test_pkl_file_path\n",
    "VAL_IMAGE_PATH = '/content/drive/MyDrive/Human-Path-Prediction-master/ynet/data/eth_ucy/test'#path to test folder of dataset\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  \n",
    "scene_name = \"zara2\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "58ec28ff",
   "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": 8,
   "id": "bc455bcb",
   "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/zara2_train.pkl'#train pkl file path \n",
    "TRAIN_IMAGE_PATH = '/content/drive/MyDrive/Human-Path-Prediction-master/ynet/data/eth_ucy/train/zara2/oracle.png'#Train_image_file_path we are not giving train folder path beacuse there is only one scene image\n",
    "VAL_DATA_PATH = '/content/drive/MyDrive/Human-Path-Prediction-master/ynet/data/eth_ucy/zara2_test.pkl'#Test_pkl_file_path\n",
    "VAL_IMAGE_PATH = '/content/drive/MyDrive/Human-Path-Prediction-master/ynet/data/eth_ucy/test'#path to test folder of dataset\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  \n",
    "scene_name = \"zara2\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "b1975809",
   "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": 10,
   "id": "d96cc57b",
   "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": 11,
   "id": "3763cf21",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "       frame  trackId    x    y sceneId  metaId\n",
      "0        7.0      1.0  403  718   zara2       0\n",
      "1       17.0      1.0  402  697   zara2       0\n",
      "2       27.0      1.0  401  676   zara2       0\n",
      "3       37.0      1.0  400  655   zara2       0\n",
      "4       47.0      1.0  399  634   zara2       0\n",
      "...      ...      ...  ...  ...     ...     ...\n",
      "7781  8057.0    159.0  368  347   zara2     158\n",
      "7782  8067.0    159.0  368  325   zara2     158\n",
      "7783  8077.0    159.0  369  303   zara2     158\n",
      "7784  8087.0    159.0  371  281   zara2     158\n",
      "7785  8097.0    159.0  372  259   zara2     158\n",
      "\n",
      "[6240 rows x 6 columns]"
     ]
    }
   ],
   "source": [
    "#df_train we are changing sceneid to dataset name baecuse there is only one scene in dataset \n",
    "df_train['sceneId'] = \"zara2\"\n",
    "df_train = df_train.iloc[: , 1:]\n",
    "df_train"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "c9d89bbc",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "        frame  trackId    x    y sceneId  metaId\n",
      "7797   7997.0    160.0  419  690   zara2     159\n",
      "7798   8007.0    160.0  416  659   zara2     159\n",
      "7799   8017.0    160.0  413  629   zara2     159\n",
      "7800   8027.0    160.0  410  600   zara2     159\n",
      "7801   8037.0    160.0  407  572   zara2     159\n",
      "...       ...      ...  ...  ...     ...     ...\n",
      "9500  10397.0    202.0  353  361   zara2     201\n",
      "9501  10407.0    202.0  355  387   zara2     201\n",
      "9502  10417.0    202.0  356  413   zara2     201\n",
      "9503  10427.0    202.0  357  438   zara2     201\n",
      "9504  10437.0    202.0  358  463   zara2     201\n",
      "\n",
      "[1240 rows x 6 columns]"
     ]
    }
   ],
   "source": [
    "#we are changing sceneid to dataset name baecuse there is only one scene in dataset\n",
    "df_val['sceneId'] = \"zara2\"\n",
    "df_val = df_val.iloc[: , 1:]\n",
    "df_val"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "81e19c4b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "'1.10.2+cu102'"
     ]
    }
   ],
   "source": [
    "torch.__version__"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "ceb3fa07",
   "metadata": {},
   "outputs": [],
   "source": [
    "model = YNet(obs_len=OBS_LEN, pred_len=PRED_LEN, params=params)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "6ec2e8e8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "\n",
       "                    Syncing run <strong><a href=\"https://wandb.ai/agv/ynet/runs/117jynuk\" target=\"_blank\">cosmic-dawn-58</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": 16,
   "id": "90156551",
   "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,scene_name=scene_name)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "09822bfb",
   "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/zara2_train.pkl'#train pkl file path \n",
    "TRAIN_IMAGE_PATH = '/content/drive/MyDrive/Human-Path-Prediction-master/ynet/data/eth_ucy/train/zara2/oracle.png'#Train_image_file_path we are not giving train folder path beacuse there is only one scene image\n",
    "VAL_DATA_PATH = '/content/drive/MyDrive/Human-Path-Prediction-master/ynet/data/eth_ucy/zara2_test.pkl'#Test_pkl_file_path\n",
    "VAL_IMAGE_PATH = '/content/drive/MyDrive/Human-Path-Prediction-master/ynet/data/eth_ucy/test'#path to test folder of dataset\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  \n",
    "scene_name = \"zara2\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "74ddb94b",
   "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": "1269a8d3",
   "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": "a2bc29dd",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "       frame  trackId    x    y sceneId  metaId\n",
      "0        7.0      1.0  403  718   zara2       0\n",
      "1       17.0      1.0  402  697   zara2       0\n",
      "2       27.0      1.0  401  676   zara2       0\n",
      "3       37.0      1.0  400  655   zara2       0\n",
      "4       47.0      1.0  399  634   zara2       0\n",
      "...      ...      ...  ...  ...     ...     ...\n",
      "7781  8057.0    159.0  368  347   zara2     158\n",
      "7782  8067.0    159.0  368  325   zara2     158\n",
      "7783  8077.0    159.0  369  303   zara2     158\n",
      "7784  8087.0    159.0  371  281   zara2     158\n",
      "7785  8097.0    159.0  372  259   zara2     158\n",
      "\n",
      "[6240 rows x 6 columns]"
     ]
    }
   ],
   "source": [
    "#df_train we are changing sceneid to dataset name baecuse there is only one scene in dataset \n",
    "#df_train['sceneId'] = \"zara2\"\n",
    "#df_train = df_train.iloc[: , 1:]\n",
    "df_train"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "b536cd74",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "        frame  trackId    x    y sceneId  metaId\n",
      "7797   7997.0    160.0  419  690   zara2     159\n",
      "7798   8007.0    160.0  416  659   zara2     159\n",
      "7799   8017.0    160.0  413  629   zara2     159\n",
      "7800   8027.0    160.0  410  600   zara2     159\n",
      "7801   8037.0    160.0  407  572   zara2     159\n",
      "...       ...      ...  ...  ...     ...     ...\n",
      "9500  10397.0    202.0  353  361   zara2     201\n",
      "9501  10407.0    202.0  355  387   zara2     201\n",
      "9502  10417.0    202.0  356  413   zara2     201\n",
      "9503  10427.0    202.0  357  438   zara2     201\n",
      "9504  10437.0    202.0  358  463   zara2     201\n",
      "\n",
      "[1240 rows x 6 columns]"
     ]
    }
   ],
   "source": [
    "#we are changing sceneid to dataset name baecuse there is only one scene in dataset\n",
    "#df_val['sceneId'] = \"zara2\"\n",
    "#df_val = df_val.iloc[: , 1:]\n",
    "df_val"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "607aa4a4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "'1.10.2+cu102'"
     ]
    }
   ],
   "source": [
    "torch.__version__"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "4bd86b8a",
   "metadata": {},
   "outputs": [],
   "source": [
    "model = YNet(obs_len=OBS_LEN, pred_len=PRED_LEN, params=params)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "c51b3f79",
   "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
}
