{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-10-02T04:46:40.553795Z",
     "start_time": "2020-10-02T04:46:38.733942Z"
    }
   },
   "outputs": [],
   "source": [
    "import os\n",
    "import sys\n",
    "sys.path.append('~/particle/TrafficFluidsPt/TrafficFluids')\n",
    "sys.path.append('../datasets')\n",
    "import numpy as np\n",
    "from glob import glob\n",
    "from tensorpack import dataflow\n",
    "import pandas as pd\n",
    "import helper\n",
    "import tqdm\n",
    "import pickle\n",
    "from collections import defaultdict\n",
    "from typing import Dict, Optional\n",
    "from datasets.argoverse_lane_loader import read_pkl_data\n",
    "from argoverse.data_loading.argoverse_forecasting_loader import ArgoverseForecastingLoader\n",
    "from argoverse.map_representation.map_api import ArgoverseMap\n",
    "\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.optim as optim\n",
    "import torch.nn.functional as F\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.lines as mlines\n",
    "%matplotlib inline\n",
    "device = torch.device('cuda:2')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-10-02T04:47:15.400874Z",
     "start_time": "2020-10-02T04:47:15.318426Z"
    }
   },
   "outputs": [],
   "source": [
    "model_unequi = torch.load('./weights/pedestrian_ctsconv_rel_pos.pth').to(device)\n",
    "model_equi = torch.load('./weights/pedestrain_ctsconv_rel_pos.pth').to(device)\n",
    "model_reg = torch.load('./weights/pedestrain_ctsconv_reg_rel_pos.pth').to(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-10-02T04:46:47.475462Z",
     "start_time": "2020-10-02T04:46:44.019418Z"
    }
   },
   "outputs": [],
   "source": [
    "with open('./results/pedestrian_ctsconv_rel_pos_val_metrics.pickle', 'rb') as f:\n",
    "    unequi_pred = pickle.load(f)[-1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-10-02T04:46:47.510639Z",
     "start_time": "2020-10-02T04:46:47.477025Z"
    }
   },
   "outputs": [],
   "source": [
    "unequi_result = {}\n",
    "unequi_de = {}\n",
    "\n",
    "for k, v in unequi_pred.items():\n",
    "    unequi_de[k] = torch.sqrt((v[0][:,0] - v[1][:,0])**2 + \n",
    "                    (v[0][:,1] - v[1][:,1])**2)\n",
    "    \n",
    "unequi_ade = []\n",
    "unequi_fde = []\n",
    "for k, v in unequi_de.items():\n",
    "    unequi_ade.append((k, np.mean(v.numpy())))\n",
    "    unequi_fde.append((k, v.numpy()[-1]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-10-02T04:46:49.297970Z",
     "start_time": "2020-10-02T04:46:47.511991Z"
    }
   },
   "outputs": [],
   "source": [
    "with open('./results/pedestrain_ctsconv_rho1_rel_pos_val_metrics.pickle', 'rb') as f:\n",
    "    equi_pred = pickle.load(f)[-1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-10-02T04:46:49.333239Z",
     "start_time": "2020-10-02T04:46:49.299945Z"
    }
   },
   "outputs": [],
   "source": [
    "equi_result = {}\n",
    "equi_de = {}\n",
    "\n",
    "for k, v in equi_pred.items():\n",
    "    equi_de[k] = torch.sqrt((v[0][:,0] - v[1][:,0])**2 + \n",
    "                    (v[0][:,1] - v[1][:,1])**2)\n",
    "    \n",
    "equi_ade = []\n",
    "equi_fde = []\n",
    "for k, v in equi_de.items():\n",
    "    equi_ade.append((k, np.mean(v.numpy())))\n",
    "    equi_fde.append((k, v.numpy()[-1]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-10-02T04:46:49.446680Z",
     "start_time": "2020-10-02T04:46:49.334352Z"
    }
   },
   "outputs": [],
   "source": [
    "with open('./results/pedestrain_ctsconv_reg_rel_pos_val_metrics.pickle', 'rb') as f:\n",
    "    reg_pred = pickle.load(f)[-1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-10-02T04:46:49.466775Z",
     "start_time": "2020-10-02T04:46:49.448149Z"
    }
   },
   "outputs": [],
   "source": [
    "reg_result = {}\n",
    "reg_de = {}\n",
    "\n",
    "for k, v in reg_pred.items():\n",
    "    reg_de[k] = torch.sqrt((v[0][:,0] - v[1][:,0])**2 + \n",
    "                    (v[0][:,1] - v[1][:,1])**2)\n",
    "    \n",
    "reg_ade = []\n",
    "reg_fde = []\n",
    "for k, v in reg_de.items():\n",
    "    reg_ade.append((k, np.mean(v.numpy())))\n",
    "    reg_fde.append((k, v.numpy()[-1]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-10-02T04:46:49.473609Z",
     "start_time": "2020-10-02T04:46:49.467970Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.001392364501953125"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "fde = pd.DataFrame(reg_fde, columns=['index', 'fde']).fde.min()\n",
    "fde"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-10-02T05:06:38.476779Z",
     "start_time": "2020-10-02T05:06:38.463692Z"
    }
   },
   "outputs": [],
   "source": [
    "better_list = []\n",
    "unequi_dict = {k: v for k,v in unequi_fde}\n",
    "reg_dict = {k: v for k,v in reg_fde}\n",
    "for k, v in equi_fde:\n",
    "    if (k in unequi_dict.keys()) & (k in reg_dict.keys()):\n",
    "        pass\n",
    "    else:\n",
    "        continue\n",
    "    if (unequi_dict[k] > v) & (reg_dict[k]<1) & (reg_dict[k]<unequi_dict[k]):\n",
    "        better_list.append(k)\n",
    "better_311 = better_list"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 73,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-10-02T05:06:39.156270Z",
     "start_time": "2020-10-02T05:06:39.149699Z"
    },
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['biwi_hotel_136',\n",
       " 'biwi_hotel_150',\n",
       " 'biwi_hotel_176',\n",
       " 'biwi_hotel_8',\n",
       " 'cff_06_10634',\n",
       " 'cff_06_10716',\n",
       " 'cff_06_10792',\n",
       " 'cff_06_10951',\n",
       " 'cff_06_11126',\n",
       " 'cff_06_11259',\n",
       " 'cff_06_11441',\n",
       " 'cff_06_11671',\n",
       " 'cff_06_11731',\n",
       " 'cff_06_11964',\n",
       " 'cff_06_11986',\n",
       " 'cff_06_12047',\n",
       " 'cff_06_12120',\n",
       " 'cff_06_12387',\n",
       " 'cff_06_12415',\n",
       " 'cff_06_12417',\n",
       " 'cff_06_12627',\n",
       " 'cff_06_1268',\n",
       " 'cff_06_12718',\n",
       " 'cff_06_13083',\n",
       " 'cff_06_13136',\n",
       " 'cff_06_13320',\n",
       " 'cff_06_13486',\n",
       " 'cff_06_13527',\n",
       " 'cff_06_13763',\n",
       " 'cff_06_13818',\n",
       " 'cff_06_14343',\n",
       " 'cff_06_14605']"
      ]
     },
     "execution_count": 73,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "better_311"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 124,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-10-02T05:11:48.462191Z",
     "start_time": "2020-10-02T05:11:48.454476Z"
    }
   },
   "outputs": [],
   "source": [
    "# Good: cff_06_10716\n",
    "dataset_path = '~/particle/trajnetplusplus_dataset/'\n",
    "pkl_path = os.path.join(dataset_path, 'val', '{}.pkl'.format('cff_06_10716'))\n",
    "with open(pkl_path, 'rb') as f:\n",
    "    data = pickle.load(f)\n",
    "    data_true = {k:[v] for k,v in data.items()}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 125,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-10-02T05:11:48.673413Z",
     "start_time": "2020-10-02T05:11:48.658349Z"
    },
    "code_folding": [
     0
    ]
   },
   "outputs": [],
   "source": [
    "def visualize_trajectory(array, gt=False) -> None:\n",
    "    \n",
    "    _ZORDER = {\"AGENT\": 15, \"OTHERS\": 5}\n",
    "    \n",
    "    plt.figure(0, figsize=(8, 7))\n",
    "\n",
    "    x_min = np.min(array[...,0])\n",
    "    x_max = np.max(array[...,0])\n",
    "    y_min = np.min(array[...,1])\n",
    "    y_max = np.max(array[...,1])\n",
    "    \n",
    "    plt.xlim(x_min-1, x_max+1)\n",
    "    plt.ylim(y_min-1, y_max+1)\n",
    "\n",
    "    # plt.xlabel(\"Map X\")\n",
    "    # plt.ylabel(\"Map Y\")\n",
    "\n",
    "    color_dict = {\"AGENT\": \"#d33e4c\", \"OTHERS\": \"deepskyblue\"}\n",
    "\n",
    "    for i, path in enumerate(array):\n",
    "\n",
    "        object_type = 'AGENT' if i == 0 else 'OTHERS'\n",
    "        cor_x = path[...,0]\n",
    "        cor_y = path[...,1]\n",
    "\n",
    "        plt.plot(\n",
    "            cor_x[:8],\n",
    "            cor_y[:8],\n",
    "            \"--\",\n",
    "            color=color_dict[object_type],\n",
    "            label=\"History\",\n",
    "            alpha=1,\n",
    "            linewidth=1,\n",
    "            zorder=_ZORDER[object_type],\n",
    "        )\n",
    "        plt.plot(\n",
    "            cor_x[8:],\n",
    "            cor_y[8:],\n",
    "            \"-\",\n",
    "            color=color_dict[object_type],\n",
    "            label=\"Ground Truth\" if gt else \"Prediction\",\n",
    "            alpha=1,\n",
    "            linewidth=1,\n",
    "            zorder=_ZORDER[object_type],\n",
    "        )\n",
    "\n",
    "        final_x = cor_x[-1]\n",
    "        final_y = cor_y[-1]\n",
    "\n",
    "        if object_type == \"AGENT\":\n",
    "            marker_type = \"o\"\n",
    "            marker_size = 7\n",
    "        elif object_type == \"OTHERS\":\n",
    "            marker_type = \"o\"\n",
    "            marker_size = 7\n",
    "\n",
    "        plt.plot(\n",
    "            final_x,\n",
    "            final_y,\n",
    "            marker_type,\n",
    "            color=color_dict[object_type],\n",
    "            label='Agent' if object_type == \"AGENT\" else 'Others',\n",
    "            alpha=1,\n",
    "            markersize=marker_size,\n",
    "            zorder=_ZORDER[object_type],\n",
    "        )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 134,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-10-02T05:13:19.043583Z",
     "start_time": "2020-10-02T05:13:19.034281Z"
    },
    "code_folding": []
   },
   "outputs": [],
   "source": [
    "def get_gt(sample):\n",
    "    mask = sample['man_mask'][0] == 1\n",
    "    pred = []\n",
    "    pred.append(sample['pos_enc'][0][mask,...,:2])\n",
    "    data = {}\n",
    "    keys = ['pos' + str(i) for i in range(13)]\n",
    "    for k in keys:\n",
    "        pred.append(sample[k][0][mask,np.newaxis,:2])\n",
    "    return np.concatenate(pred, axis=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 156,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-10-02T05:35:43.114387Z",
     "start_time": "2020-10-02T05:35:42.931521Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x504 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "gt = get_gt(data_true)\n",
    "visualize_trajectory(gt, True)\n",
    "plt.savefig('figs/ped_gt_norm.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 157,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-10-02T05:35:43.842471Z",
     "start_time": "2020-10-02T05:35:43.826159Z"
    },
    "code_folding": [
     0
    ]
   },
   "outputs": [],
   "source": [
    "def unequi_pred(sample):\n",
    "    model_unequi.eval()\n",
    "    with torch.no_grad():\n",
    "        mask = sample['man_mask'][0] == 1\n",
    "        pred = []\n",
    "        pred.append(sample['pos_enc'][0][mask,...,:2])\n",
    "        pred.append(sample['pos0'][0][mask,np.newaxis,:2])\n",
    "        data = {}\n",
    "        convert_keys = (['pos' + str(i) for i in range(13)] + \n",
    "                        ['vel' + str(i) for i in range(13)] + \n",
    "                        ['pos_enc', 'vel_enc', 'man_mask'])\n",
    "\n",
    "        for k in convert_keys:\n",
    "            data[k] = torch.tensor(np.stack(sample[k]), dtype=torch.float32, device=device)\n",
    "\n",
    "        data['scene_idx'] = np.stack(sample['scene_idx'])\n",
    "        scenes = data['scene_idx'].tolist()\n",
    "\n",
    "        data['man_mask'] = data['man_mask'].squeeze(-1)\n",
    "        # accel = torch.zeros(1, 1, 3).to(device)\n",
    "        accel = data['vel0'] - data['vel_enc'][...,-1,:]\n",
    "        data['accel'] = accel\n",
    "\n",
    "        inputs = ([\n",
    "            data['pos_enc'], data['vel_enc'], \n",
    "            data['pos0'], data['vel0'], \n",
    "            data['accel'], None, \n",
    "            data['man_mask']\n",
    "        ])\n",
    "        pr_pos1, pr_vel1, states = model_unequi(inputs)\n",
    "\n",
    "        pred.append(pr_pos1.detach().cpu().numpy()[0,mask,np.newaxis,:2])\n",
    "\n",
    "        # pr_direction = get_lane_direction(\n",
    "        #     pr_pos1, batch['city'][batch_i], am\n",
    "        # )\n",
    "        pos_2s = data['pos_enc']\n",
    "        vel_2s = data['vel_enc']\n",
    "        pos0 = data['pos0']\n",
    "        vel0 = data['vel0']\n",
    "        for i in range(11):\n",
    "            pos_enc = torch.unsqueeze(pos0, 2)\n",
    "            # pos_2s = torch.cat([pos_2s[:,:,1:,:], pos_enc], axis=2)\n",
    "            vel_enc = torch.unsqueeze(vel0, 2)\n",
    "            # vel_2s = torch.cat([vel_2s[:,:,1:,:], vel_enc], axis=2)\n",
    "            accel = pr_vel1 - vel_enc[...,-1,:]\n",
    "            inputs = (pos_enc, vel_enc, pr_pos1, pr_vel1, accel, None, \n",
    "                      data['man_mask'])\n",
    "            pos0, vel0 = pr_pos1, pr_vel1\n",
    "            pr_pos1, pr_vel1, states = model_unequi(inputs, states)\n",
    "\n",
    "            pred.append(pr_pos1.detach().cpu().numpy()[0,mask,np.newaxis,:2])\n",
    "    return np.concatenate(pred, axis=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 158,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-10-02T05:35:44.628393Z",
     "start_time": "2020-10-02T05:35:44.244782Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x504 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "prediction = unequi_pred(data_true)\n",
    "visualize_trajectory(prediction, False)\n",
    "plt.savefig('figs/ped_unequi_norm.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 159,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-10-02T05:35:44.662314Z",
     "start_time": "2020-10-02T05:35:44.648894Z"
    },
    "code_folding": [
     0
    ]
   },
   "outputs": [],
   "source": [
    "def equi_pred(sample):\n",
    "    model_equi.eval()\n",
    "    with torch.no_grad():\n",
    "        mask = sample['man_mask'][0] == 1\n",
    "        pred = []\n",
    "        pred.append(sample['pos_enc'][0][mask,...,:2])\n",
    "        pred.append(sample['pos0'][0][mask,np.newaxis,:2])\n",
    "        data = {}\n",
    "        convert_keys = (['pos' + str(i) for i in range(13)] + \n",
    "                        ['vel' + str(i) for i in range(13)] + \n",
    "                        ['pos_enc', 'vel_enc'])\n",
    "\n",
    "        for k in convert_keys:\n",
    "            data[k] = torch.tensor(np.stack(sample[k])[...,:2], dtype=torch.float32, device=device)\n",
    "        \n",
    "        for k in ['man_mask']:\n",
    "            data[k] = torch.tensor(np.stack(sample[k]), dtype=torch.float32, device=device).unsqueeze(-1)\n",
    "\n",
    "        data['scene_idx'] = np.stack(sample['scene_idx'])\n",
    "        scenes = data['scene_idx'].tolist()\n",
    "\n",
    "        data['man_mask'] = data['man_mask']\n",
    "        # accel = torch.zeros(1, 1, 3).to(device)\n",
    "        accel = data['vel0'] - data['vel_enc'][...,-1,:]\n",
    "        data['accel'] = accel\n",
    "\n",
    "        inputs = ([\n",
    "            data['pos_enc'], data['vel_enc'], \n",
    "            data['pos0'], data['vel0'], \n",
    "            data['accel'], None, \n",
    "            data['man_mask']\n",
    "        ])\n",
    "        pr_pos1, pr_vel1, states = model_equi(inputs)\n",
    "\n",
    "        pred.append(pr_pos1.detach().cpu().numpy()[0,mask,np.newaxis])\n",
    "\n",
    "        # pr_direction = get_lane_direction(\n",
    "        #     pr_pos1, batch['city'][batch_i], am\n",
    "        # )\n",
    "        pos_2s = data['pos_enc']\n",
    "        vel_2s = data['vel_enc']\n",
    "        pos0 = data['pos0']\n",
    "        vel0 = data['vel0']\n",
    "        for i in range(11):\n",
    "            pos_enc = torch.unsqueeze(pos0, 2)\n",
    "            # pos_2s = torch.cat([pos_2s[:,:,1:,:], pos_enc], axis=2)\n",
    "            vel_enc = torch.unsqueeze(vel0, 2)\n",
    "            # vel_2s = torch.cat([vel_2s[:,:,1:,:], vel_enc], axis=2)\n",
    "            accel = pr_vel1 - vel_enc[...,-1,:]\n",
    "            inputs = (pos_enc, vel_enc, pr_pos1, pr_vel1, accel, None, \n",
    "                      data['man_mask'])\n",
    "            pos0, vel0 = pr_pos1, pr_vel1\n",
    "            pr_pos1, pr_vel1, states = model_equi(inputs, states)\n",
    "\n",
    "            pred.append(pr_pos1.detach().cpu().numpy()[0,mask,np.newaxis])\n",
    "    return np.concatenate(pred, axis=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 160,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-10-02T05:35:45.434499Z",
     "start_time": "2020-10-02T05:35:45.003311Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x504 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "prediction1 = equi_pred(data_true)\n",
    "visualize_trajectory(prediction1, False)\n",
    "plt.savefig('figs/ped_rho1_norm.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 161,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-10-02T05:35:45.445139Z",
     "start_time": "2020-10-02T05:35:45.435759Z"
    },
    "code_folding": [
     0
    ]
   },
   "outputs": [],
   "source": [
    "def reg_pred(sample):\n",
    "    model_reg.eval()\n",
    "    with torch.no_grad():\n",
    "        mask = sample['man_mask'][0] == 1\n",
    "        pred = []\n",
    "        pred.append(sample['pos_enc'][0][mask,...,:2])\n",
    "        pred.append(sample['pos0'][0][mask,np.newaxis,:2])\n",
    "        data = {}\n",
    "        convert_keys = (['pos' + str(i) for i in range(13)] + \n",
    "                        ['vel' + str(i) for i in range(13)] + \n",
    "                        ['pos_enc', 'vel_enc'])\n",
    "\n",
    "        for k in convert_keys:\n",
    "            data[k] = torch.tensor(np.stack(sample[k])[...,:2], dtype=torch.float32, device=device)\n",
    "        \n",
    "        for k in ['man_mask']:\n",
    "            data[k] = torch.tensor(np.stack(sample[k]), dtype=torch.float32, device=device).unsqueeze(-1)\n",
    "\n",
    "        data['scene_idx'] = np.stack(sample['scene_idx'])\n",
    "        scenes = data['scene_idx'].tolist()\n",
    "\n",
    "        data['man_mask'] = data['man_mask']\n",
    "        # accel = torch.zeros(1, 1, 3).to(device)\n",
    "        accel = data['vel0'] - data['vel_enc'][...,-1,:]\n",
    "        data['accel'] = accel\n",
    "\n",
    "        inputs = ([\n",
    "            data['pos_enc'], data['vel_enc'], \n",
    "            data['pos0'], data['vel0'], \n",
    "            data['accel'], None, \n",
    "            data['man_mask']\n",
    "        ])\n",
    "        pr_pos1, pr_vel1, states = model_reg(inputs)\n",
    "\n",
    "        pred.append(pr_pos1.detach().cpu().numpy()[0,mask,np.newaxis])\n",
    "\n",
    "        # pr_direction = get_lane_direction(\n",
    "        #     pr_pos1, batch['city'][batch_i], am\n",
    "        # )\n",
    "        pos_2s = data['pos_enc']\n",
    "        vel_2s = data['vel_enc']\n",
    "        pos0 = data['pos0']\n",
    "        vel0 = data['vel0']\n",
    "        for i in range(11):\n",
    "            pos_enc = torch.unsqueeze(pos0, 2)\n",
    "            # pos_2s = torch.cat([pos_2s[:,:,1:,:], pos_enc], axis=2)\n",
    "            vel_enc = torch.unsqueeze(vel0, 2)\n",
    "            # vel_2s = torch.cat([vel_2s[:,:,1:,:], vel_enc], axis=2)\n",
    "            accel = pr_vel1 - vel_enc[...,-1,:]\n",
    "            inputs = (pos_enc, vel_enc, pr_pos1, pr_vel1, accel, None, \n",
    "                      data['man_mask'])\n",
    "            pos0, vel0 = pr_pos1, pr_vel1\n",
    "            pr_pos1, pr_vel1, states = model_reg(inputs, states)\n",
    "\n",
    "            pred.append(pr_pos1.detach().cpu().numpy()[0,mask,np.newaxis])\n",
    "    return np.concatenate(pred, axis=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 162,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-10-02T05:35:46.170806Z",
     "start_time": "2020-10-02T05:35:45.601367Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x504 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "prediction2 = reg_pred(data_true)\n",
    "visualize_trajectory(prediction2, False)\n",
    "plt.savefig('figs/ped_reg_norm.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 163,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-10-02T05:35:46.175892Z",
     "start_time": "2020-10-02T05:35:46.172104Z"
    }
   },
   "outputs": [],
   "source": [
    "def RotMat(theta):\n",
    "    m = np.array([\n",
    "            [np.cos(theta), -np.sin(theta)], \n",
    "            [np.sin(theta), np.cos(theta)]\n",
    "        ])\n",
    "    return m\n",
    "\n",
    "def rotation(theta, field):\n",
    "    rotmat = RotMat(theta)\n",
    "    rot_field = np.zeros(field.shape)\n",
    "    rot_field[...,:2] =  np.einsum('ij,...j->...i', rotmat, field[...,:2])\n",
    "    if field.shape[-1] > 2:\n",
    "        rot_field[...,2] = 0\n",
    "    return rot_field"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 164,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-10-02T05:35:46.316914Z",
     "start_time": "2020-10-02T05:35:46.308545Z"
    }
   },
   "outputs": [],
   "source": [
    "theta = 7*np.pi/8\n",
    "convert_keys = (['pos' + str(i) for i in range(13)] + \n",
    "                ['vel' + str(i) for i in range(13)] + \n",
    "                ['pos_enc', 'vel_enc'])\n",
    "rotate_data = data_true.copy()\n",
    "for k in convert_keys:\n",
    "    rotate_data[k] = [rotation(theta, rotate_data[k][0])]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 165,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-10-02T05:35:46.876023Z",
     "start_time": "2020-10-02T05:35:46.695839Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x504 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "gt_rot = get_gt(rotate_data)\n",
    "visualize_trajectory(gt_rot, True)\n",
    "plt.savefig('figs/ped_gt_rot.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 166,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-10-02T05:35:47.499955Z",
     "start_time": "2020-10-02T05:35:47.158313Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x504 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "rot_prediction = unequi_pred(rotate_data)\n",
    "visualize_trajectory(rot_prediction, False)\n",
    "plt.savefig('figs/ped_unequi_rot.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 167,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-10-02T05:35:48.231198Z",
     "start_time": "2020-10-02T05:35:47.792048Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x504 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "rot_prediction0 = equi_pred(rotate_data)\n",
    "visualize_trajectory(rot_prediction0, False)\n",
    "plt.savefig('figs/ped_rho1_rot.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 168,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-10-02T05:35:50.271626Z",
     "start_time": "2020-10-02T05:35:49.694985Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAegAAAGbCAYAAAAP5gNjAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjMsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+AADFEAAAgAElEQVR4nO3deXicZb3G8e+Tmex7973pBoVCoTQttGzKJoqKsriggoAWpSx6VEBwA5cjgspRQEVA4ShyROhxAQHRIxRapGmBQoXuTbe0TZfs68w8549nQqbJpE2bzLzvzNyf65oryTtJ5jekzD3Pbqy1iIiIiL9keV2AiIiI9KaAFhER8SEFtIiIiA8poEVERHxIAS0iIuJDQa8LiDVs2DBbUVHhdRkiIiJJs3z58t3W2uE9r/sqoCsqKqiqqvK6DBERkaQxxlTHu64ubhERER9SQIuIiPiQAlpERMSHFNAiIiI+pIAWERHxIQW0iIiIDymgRUREfEgBLSIi4kMKaBERER9SQIuIiPiQAlpERMSHFNAiIiI+pIAWERHxIQW0iIiIDymgRUREfEgBLSIi4kMJD2hjzLnGmNXGmHXGmJsS/XgiIiLpIKEBbYwJAPcA7wWOBj5ujDk6kY8pIiKSDhLdgp4LrLPWbrDWdgCPAucn+DFFRERSXqIDeiywJebrrdFr7zDGLDDGVBljqmpraxNcjoiISGpIdECbONfsfl9Ye5+1ttJaWzl8+PAElyMiIpIaEh3QW4HxMV+PA7Yn+DFFRERSXjDBv38ZMM0YMwnYBnwMuCTBjykiIgPUGoZFu2F9K0zJhwuGQV7A66oyS0ID2lobMsZcAzwDBIAHrbWrEvmYIiIyMMsa4JyVELLQHIbCACxcC8/OhDklXleXORLdgsZa+xTwVKIfR0REBq417MK5LtR9rSnsPp6zEmrmqSWdLNpJTERE3rFot2s5xxOy8MTu5NaTyRTQIiLyjvWtrls7nuYwbGhNbj2ZTAEtIiLvmJLvxpzjKQzA5Pzk1pPJFNAiIvKOC4ZBMN4OFrjrFwxLbj2ZTAEtIiLvyAu42dr5WZBt3G5TRQEoC7rrmiCWPAmfxS0iIqllTgmcWQYV+TAy23Vrax108imgRURkP9bC0gb42REwLs/rajKXurhFRGQ/q1ugOKhw9poCWkRE9vNiPZxS6nUVooAWEZH9LFZA+4ICWkRE9vNiPZyqgPacAlpERN6xvd3twz29wOtKRAEtIiLveLEeTi6FrD42K5HkUUCLiMg71L3tHwpoERF5h2Zw+4cCWkREAGgIwZoWmF3sdSUCCmgREYla2gCVxZCjZPAF/RlERARQ97bfKKBFRATonsEt/qCAFhEROiKwrAHmK6B9QwEtIiKsaIRpBVCqMw59QwEtIiIaf/YhBbSIiCigfUgBLSKS4SI2OkGsxOtKJJYCWkQkw61ugeIgjMvzuhKJpYAWEclw2n/bnxTQIiIZbrHWP/uSAlpEJMOpBe1PCmgRkQy2rR3qQzC9wOtKpCcFtIhIBnspurwqy3hdifSkgBYRyWBa/+xfCmgRkQymgPYvBbSISIZqCMGaFphd7HUlEo8CWkQkQy1tgMpiyFES+JL+LCIiGUrd2/6mgBYRyVAKaH9TQIuIZKCOCFQ1wnwFtG8poEVEMtCKRpiaDyVBryuRviigRUQykLq3/U8BLSKSgRTQ/qeAFhHJMBGrgE4FCmgRkQyzusWNPY/N9boSORAFtIhIhlHrOTUooEVEMsxiBXRKUECLiGSYF+vhVAW07ymgRUQyyLZ2d0jG9AKvK5GDSVhAG2PuMMa8bYxZaYxZZIwpS9RjiYhI/7xYDyeXgjFeVyIHk8gW9N+AY6y1M4E1wFcT+FgiItIP6t5OHQkLaGvts9baUPTLl4FxiXosERHpH83gTh3JGoO+AvhrvDuMMQuMMVXGmKra2toklSMiknnqQ7CuFU4o9roS6Y8BbZNujHkOGBXnrlustX+Mfs8tQAj4bbzfYa29D7gPoLKy0g6kHhER6dvSeqgshhxND04JAwpoa+1ZB7rfGHMZ8H7gTGutwldExEPq3k4tiZzFfS5wI/BBa21Loh5HRET658V6OLnE6yqkvxLZ0XE3UAz8zRjzmjHm5wl8LBEROYD2CFQ1wny1oFNGwo7qttZOTdTvFhGRQ7OiEY4ocIdkSGrQVAERkQyg/bdTjwJaRCQDaIJY6lFAi4ikuYiFlxTQKUcBLSKS5t5qgbIgjMn1uhI5FApoEZE0p+7t1KSAFhFJc4vrFNCpSAEtIpLm1IJOTQpoEZE0tqUNmiMwvcDrSuRQKaBFRNJYV+vZGK8rkUOlgBYRSWPq3k5dCmgRkTS2uB5OVUCnJAW0iEia2tcJG1phVpHXlcjhUECLiKSpJQ0wtwSy9UqfkvRnExFJUy+qezulKaBFRNKUJoilNgW0iEgaagu7M6BPKvG6EjlcCmgRkTS0rBGOKoDioNeVyOFSQIuIpKEX6+HUMq+rkIFQQIuIpCGtf059CmgRkTQTtrCkHk5WQKc0BbSISJp5sxlG5ribpC5NHxARSTMHWv/cGoZFu2F9K0zJhwuGQV4gufVJ/yigRUTSzOI6OHdI7+vLGuCclRCy0ByGwgAsXAvPzoQ5Wo7lO+riFhFJI9ZGJ4j1mMHdGnbhXBeCpjBY3Me6kLveFvakXDkABbSISBrZ2ObCd3Le/tcX7XYt53hCFp7YnfDS5BApoEVE0kjX8ipj9r++vtV1a8fTHHanXom/KKBFRNLI4rr4E8Sm5EN+H6/4hQGYnJ/YuuTQKaBFRNJIvPHniIXqVmiNxP+ZoHGzucVfFNAiImliZwfs6oRjCruvbW+H96yEJ/fCohlQFoSiABjcx7Kgm8WtpVb+o2VWIiJp4sV6mF8Cgej48x93w1Wr4eqxcPMECGbB9iFuwtiGVtetrXXQ/qWAFhFJE13jzy1h+I918Ow+eOIYmB8zJp0fgEtGelej9J+6uEVE0sTiere95+zlbo3zq5X7h7OkFrWgRUTSQF2n24P7hg1w11T4hFrJKU8BLSKS4mra4bw3IC8L/nWClkylC3Vxi4iksD/vhllVUJgF145VOKcTBbSISApqCcPVa+DatfCHGYCB08sO+mOSQhTQIiIp5vUmqFwO+0LwWiVUFsOrjTBPJ1KllYwdg9aZqCKSaiIW/msrfG8z/HAKfGqk23P7hTqYUQhFGfuKnp4y8s+pM1FFJNXsaIdPv+2Oh3z5BNew6PJCH/tvS2rLuC5unYkqIqnmyT0wa7lrQCyetX84A7xQD6dp/DntZFxA60xUEUkVrWG4Zo2bDPb7o+HbkyC7x6t2KAIvN8ApakGnnYwL6AOdidoUhvu3wzN73aJ/ERGvvNEEc5bD7k54vbL3CVVdAsbdPyQ7ufVJ4mXcGPSUfDfm3BQnpPOy3CSL/6yG5U0wIdfNipxX6j5OL4As0/vnREQGi7Xw023w7Wq4cwpcGp0I1hdjYJLWPqeljAvoC4a5CWHx5GW5bqS8gOs2WtkMSxvg//bB96rdkoYTS6KhXeI+L8m4/4Iikig7O+Dyt12reeksmFrgdUXipYyLl7yAm63dcxZ30Ox/JmowC04odreFY921nR1urGdpvXt3u6LRvXOdX9Ld0j4i/8DvdkVE4nlqD1y5Gi4fBbdW9B5rlsxjrO1jxtRgPYAxXwbuAIZbaw84BauystJWVVUltJ4uXeugB3ImamfEbRiwtKH71hCCk2ICe24xFGfc2yAR6a+2MNy4wb0ePTwd3lXudUWSbMaY5dbayp7XExodxpjxwNnA5kQ+zuEYjDNRs7OgssTdro1eq2nvDutvboTXmmBqfvc49rwS97Va2SLyZhNc8hYcWeB2BNNEL4mV6Lbdj4EbgD8m+HF8Y3QuXDDc3QA6Ii6klza4LqyvbYTWSHdYzytxaxsLtYuZSMawFu7ZBrdWww8mw6dH6U279JawgDbGfBDYZq193RzgX54xZgGwAGDChAmJKsczOVkwt8Tdrh/nrm1rd+PYSxvg5o2wsgmOKOgO7PmlMClP/8OKpKNdHXDF27CzE5bMgmmaCCZ9GNAYtDHmOWBUnLtuAW4GzrHW1htjNgGVfhqD9pP2iNvofknXWHY9dNr9l3hVFkOBWtkiKe3pPXDFargsOhEsZwATwTa1wtpWOHvIYFUnXknIGLS19qw+HuxYYBLQ1XoeB6wwxsy11u4YyGOmo9wsOKnU3bpsaesey/7KenizGY4u3L9rfKJa2SIpoS0MN21wOxU+ctTgTAR7PHrYjwI6fSWki9ta+wYwouvr/ragpdv4PHf7SPS/YlvYbZ6ytB7+UAtfWu/2EY/tFp9dpBO5RPxmVTNc8m+Ylj+4E8H+sc8tyZL0pQVAKSIvACeXuhu4SSab22FJdCz7C+vg381wTGF31/j8EhfyIpJ81sK92+Fbm+D7k+GKQZwI1hmBF+vhoemD8/vEn5IS0NbaimQ8TiYxxnVxT8yDj0eXi7WEYXmjC+zf7YTr1kK22X+J1wnFrktdRBKntsONNde0w0uz3CTQwZRl4O/HwbCcwf294i9qQaeRgoDbUL9rU31rYWNb98Sz3+6Et1tgZlG0Wzza0h6b623dIunkmb1ulvanRsLjMwY2Eawv/252b84lvSmg05gxbpe0yfnwiWgruzkMy6KTzx7eCZ9b44J9XszuZ7OKEvOiIpLO2sLw1Y1ujshvjoJ3J3BHsC+sgy+Og/cPS9xjiPcU0BmmMOBmkHbNIrUW1rV2zxj/9Q63dGNW0f5d46PVyhbpU9dEsKnRiWBDE7gjWFsYXmmE0/o4flLShwI6wxnjNkqYVgCXRmeENobcC8DSenigBj67GooD3RPP5pXAcUXazF8kkRPB+rKkAWYU6CS9TKA/sfRSHIQzy90N3IvQmtbuGeP31cDGVjfhLLZrfKQmrEgG6doRbEcHvDjL7aedDNPy4Y4pyXks8ZYCWg7KGPfic2QBXD7aXasPwSvRbvGfb4fLV8OQ4P67n80sdMd2iqSb2B3BnqhI7pyNDgunlB78+yT1KaDlsJQG3Q5GXbsYRaybId41Y/yebbCl3W1RGrv7mZaFSCqLPRpysHYEOxQbW2H+CqiZD9pEMP0poGVQZBm3FenRhXBltJW9rxP+FW1l/3QbfPIt1w0e2y1+TCEE9EojKeCN6NGQ0z08GvLJPfDeIe7/N0l/CmhJmPJsOHeouwGErVu/2TVj/K6tsL0D5hS7rUrnlcBJJToTV/zFWvcG89vVcMdk163t1R74T+11R1NKZlBAS9IEDBxb5G4Lxrhrezrh5Wi3+A+3wLJGt3FKbLf40YVqMYg3drS7+RV7O2HpLJjq8dGQFw2Hc5LcrS7eUUCLp4Zmw3lD3Q0gFHEndy1tgMX1cPtm2N0JJ8YcCnJiiRsDF0mkP+2GBavdm8mvT/R+WWFDyLXeNSSUOfQyJ74SzILji93t82PdtV0drpW9pB6+W+32G6/I6+4Wn1fiZpjr6E0ZDC1hd1rc03vhDzPgFJ9sCHLjBjgyH74w3utKJFkU0OJ7I3Lgg8PcDdxJPq83uVb23/bBbdWudXFSTCt7bjEU6V+3HKIVjW5HsMpiNxHMLz011sJTe+C6mV5XIsnkk39+Iv2XnQWVJe52bfRaTXv35LOvb4TXmtwJQvNjQntSnlrZEl/YujkQd26Bu6bCJSO9rmh/bza7ru3pHo+BS3IpoCUtjM6FC4a7G0B7BF6NHr35xz2uezBku7vF55fA7GLID3hbt3hvcxtc+hZYYNlsf54SFTDwrQq9wcw0xlrrdQ3vqKystFVVVV6XIWnIWrdxytKG7i1LVzW7ddhdLez5JTDOhy/OkjiP7HQnQ31pPHx5vH8nYHVGvJ+kJoljjFlura3seV0taMkIxsCEPHf76Ah3rSXsJpwtbXAv1Neshbys7nOy55fA8ToUJC3VdcLCtbCiCZ6e6faV96u9nTBjGWw5SVvnZhoFtGSsggCcWuZu4FrZ61vdaUFL6uHBGvf1CcUurLu6x4dru9KU9nwdXPYWfGAYLJ/t/h342bN73WY+CufMo4AWiTLGbUQxNebozYaQ2650SYPbX/zSt1xAz4/pFp+hjVRSQlsYvr7J9ZbcfyS8d6jXFfXPk3u79wmQzKKAFjmAkh6HgoQtvNXsAvulejfrt7bDLfE6uTS6kYqWePnO601uL/gj8+H1ytQ6tGVSHrxviNdViBc0SUxkgHZ1uC7xrq7xV5vcxinzY0J7Qq5m4HohbOGOzfCjrfDDKfDJkfo7iP9okphIgozIgQ8NdzdwS7xWNLoW9mO1bpZwtunuEj+5FGYVaUwx0Ta0uiGJnCyomu0mCKaa71e7MfLrxnldiXhBAS0yyHKz3CzweaXua2thQ5sL7CX18OAO+POx/lxvmy5ea4SzV8LNE+D6cak7R+CZfXCDtvbMWApokQQzBqbku9ulOiowKY4tgpdmud3kUlVrGJY1wCmlXlciXlEnm4iknYBJ7XAGd1b6x0dCsZpRGUsBLZIi9nXC+1fCDza7pV+dEa8rkkSakg+/PNLrKsRLCmiRFJGbBZePhq3tcNVquL8GIhb+s9ptvtEW9rrC5LIWmkJeV5E4n37LbZQjmUsBLZIiCgJw4XD4yTR4bQ58bgy0RmBvCL6yHoa9BN/Z5L53eWN6hxfA5nb47mavq0iM+hA8vhvGptB6bRl8Gt0QSVHGQGEA7pjivm4MQWO0Ff21jfBCnTsM5GMj4IvjXWs7VWczd+mIwB1bYGeHe6PyvUleV5QYi+vchjd5Pt+GVBJLAS2SJoqD3ROK/jrTzQL+VwM0RUP7fSvd52eWw9nlcEqZd7UejiX1sGC1W552zzR3LV03Haluh/do97CMp4AWSVP5AXhXeffXTxzj1mI/tw9+vt0F9K9qXBf5mWUws8ifLey2sGtJLm+Eb1TAxcPTN5jBTf5bONb1eEhmU0CLJMHrTW729ZximFPidhJL9ilKBYH99xUH1xpdVgu/2A7NYdh0kpuEZoHJ+cmtL9b2dnhqD/yjzr2heHEWXJsBu2k1hWDOCnhmZmrufCaDS5PERJJgTA6cVQ5rWt3Wn3/e41qGn13twnFFozfLps4oh3uPgDUnwquV7uzr5+vg5Fdh0stw5duwuyPxrbmtbfDwDvjM226ceWkD/LPOdce/ckLqr2nur29scm/iFM4COixDxDPNYXhoByxrdDtGvWcI/HCq2395dK57oZ5e4E23s7XwVgv8Yx8sGOP2FL95A5xWBqeXwoeGDexEqJ0d8EYTnDUEvrbBdbm/uxzeXQafHuX/M5oTYVkDfOANeHNOap22JQPX12EZCmgRn7DWja3+ZKubELWs0R01+Nzx8HitO5lpTjFU5CV/DNZa1/p/oQ5eqHf7Q+dludnip5XBaaX9Oxf7h1vcuPfWdtej8NgMN3GtMODP8e9k2tUBq1vg1BSbvCcDp4AWSUHtEbdBya9q4I+7XWgHDFSfBCuaYFu7C+3Rucmvra4T/rSnO7S/Mh6uGA0/3er2j55V7Gp9qd61kH893X1vUUCnefX02K7omy8Px/3FOzpuUiQF5UZD7PLR7gawp9O1oLe2w73bXGgXZMFLJ0COgbdbYG6Ja5UmUlm2O/yj6wCQiHWt4bWt8Msat5f0kfmuzlsmgrGuG1v2t64FPr8Gls32uhLxGwW0SIoZmu0+nj/M3bqOsxybA1WNcMtGN2v8qAK3mceJJW5W9PgETzzKMlASdI8J8JsdsLjezUieuwK+W+0mfV00HD4wLLG1pIrVLXDhm3DzRJik1rP0oIAWSXFdx1kCnFQKS05wM8SXN7nrm9vgxBWuNX5yiZv0dUZ5YnYWq2qAz6+FL46Dy0a7G8Dbc13L+u/73AQxcHtNlwRdaL+rDEoz7NXIWtjR4ZaPLRjtdTXiRxqDFskA1sK6VljSANPyYW4xjFnqtgKdX+JmkA9kclIoAtetgydq4fuTXbf3wcL/1Ub42z63zrk9As/Pgr/ucePW80ugKE0DuyUM1651PRxfnuB1NeIHGoMWyWDGwLQCd+uyeq7bCnRJA6xsdgF90ZvuvrklMK/k4KFtrRvzPqoQjiuC706C8uz+1TSr2N1umOB+D0B1Gzyyy60Ln1UMzx/vWpn5Wf3/vX62sRUm/8vtj/65MV5XI36nFrSIvGNdC/yrEV6J7uH9wHS3A9rbLa7VPbfEBXHAuHXMV6+FbAN/P25wl361hd067FnFcNcW+PommJLnlnTdWgFlwdTc7nNrG/y+1g0BpGL9khhaZiUih+WtZre72CuN8GoTvHyC24bzqjVwWwV8dowL7ETqiLhW9Qv1Ltwe2QXf3+w2TTmtDN43xM0qF0lFCmgRGTTrWtykruEe7XgVtrCyyQX283XujUJOFvx4qzv4493l3bPdRfyur4DWVgEicsimFngXzuBa7LOK4fpx7pSuY4rcG4Zp+fDgDreP+O93uSB/dq+bmCWSajRJTETSwsgc+I/x7tYRceFc2wHfrobXmqCyGL40Dt4/LDFLzEQGW0ID2hhzLXANEAKetNbekMjHExEB190N7kzsxbPcMY6L62FEjgvvipddYJ9ZDucNcT0CIn6TsIA2xrwbOB+Yaa1tN8aMSNRjiYgcSFEQ3ju0++vXKuH/omdNN4Tg6xVu29Tji9zOa4me9CbSH4lsQX8e+L61th3AWrsrgY8lItJvI3LgoyPcDdw67F0dbk/sHR1w3Ti3f3gmdoVHrLvpMBPvJWwWtzHmNeCPwLlAG/Bla+2yON+3AFgAMGHChNnV1dUJqUdEpD82tsKuTteSnrcChme7Pc/fP9SNc6ea9gjs7oTOiDst6/k6t1f77k53++k0t2zupg1Q2wl7O93Eu23t7nzu6YVeP4P0l5CdxIwxzwGj4tx1S/R3lwMnAXOA3xtjJtse7wistfcB94FbZjWQekREBmpSfvfBFU8eC3/d6476/MseWHSMt7V1aQ27lv6ODphZBPs63QliOzqgpgMuGQEfGwljl7jQHZYNZ5fDQ0fBm82wpsXNwp9R6CbTnVQCjx7t3owMzYbsLDj9VbcdqQLaOwMKaGvtWX3dZ4z5PPBENJBfMcZEgGFA7UAeU0QkWYZkwydGuluihSKwJ+RCNte4YHywBt5ohpp2CFn4wzHwnU3wnWoYleNuDx/ltkI1uHO235vjlqABvDUXigP771q2cGzvxx6e03vZXGvETbIT7yRyDPp/gTOAfxpjjgBygN0JfDwREV/Z2QFb2lxXcm2n24P7jWb42fbotQ431n1yKQx50e03Pjo6Pn5LoQvlCbnRw01y3e+8cUL0fO0eY+PfmtT78UsG8ArfGnHBL95JZEA/CDxojHkT6AAu69m9LSKSLj66yp0YtrsTJufD/x0PP9riTuwant09ll0cgDnFrtt5eDYcXeiutZ/ee/b4gjgHamQnKTSfPDY1x9zTScIC2lrbAXwyUb9fRORQdURgX8hNhNob/ZifBWcNGfjvvnosFGS50B0W3Wb09ilwe4/vKwnuf6pYF7/1Jm9qc13o4h3tJCYiKac94iZG7Y0J2z09vt7b2ftaawTKgzAk6CZDDcl23ceDEdCnD+A8bT86/01YfyIMUTe3ZxTQIuIJa92RlntDvcN2b2e0pRvvWie0Wxe0Q7NhaNAF7ZCYjzML97/W9T09J0xJ31rDGoP2mgJaRAakM9ptvK9HiO4N9fg8TvjmGjcxakickC0PwpT8+PcVKmgTKmKhw0KeAtpTCmgRwVpoCHeH6L7Q/p/HBm9sy3ZfyJ0UVZ7d3XUcG7jlQZiUByfEhG7X9SHZkKsA8KWIhf+aqjdBXlNAi6SRtvCBQ7Wv0K0LuTWv8UK0K3in5LvPy2NbudFu40zbDjPdBbPceunOSPJmjUtvCmgRnwlFXGAeLFR7dSuHXMunr4Atz4YjC+LfXx7UC7Hs7xNvwflD3Y5k4g0FtEgCWAuN4b5brwcK3eYwlPYIz9hW69hcOKZw/+7krvvzs9QtKYPj2EKoalRAe0kBLXIArTGzjA8laOtCUBDo3UqNbdFOyu8O19igLQmqy1i8V1kM39PZRZ5SQEvaC8WbZdzPoIW+u4vLgzC9YP9w7fq8TF3GkuIqi+HYIq+ryGwK6AzXGoZFu2F9q5sEdMEwyPPblka4sdWG0IEDta/PW8IuMOONuw7JhvG5cFxh76AtD7pWsEgmGpLtjqIU7yigM9iyBjhnpduQvzns1pYuXAvPzoQ5JYP/eNZCS+TgE53idSc3hFx9fU1wGpoNU/P3b912LfXR5hQih+e2Te7IyYtHeF1JZlJAZ6jWsAvnulD3taaw+3jOSqiZ13dLOnY/44MFbc8Wb9D0PS5bHoQZBfsv4elq0ZYF3dIPEUmegix4sV4B7RUFdIZatNu1nONpCcOFq9xJNvECuMPuPxbbc/x1Uh7M7iOA/dh9LiLxVRbDEzok2DMK6Ay1vtV1a8fTYSFsYX5J/AlS2mZRJDOcUOzeyFur/+e9oIDOUFPyXdA2xQnpogBcOgou0fpHkYxWEoRXZntdRebSqF6GumCYGw+OJ2jc/SIi/7ML/rrH6yoykwI6Q+UF3GztsqBrMRvcx7Kgu66xYhEBqGmHPyugPaEu7gw2pwS2z3MTxja0wmQfr4MWEW906thJzyigM1x+QGPNItK3da1wvHYU84QCWkRE+nTPtL6XZEpiqeNCRET69MguHd7iFQW0iIjE1RiCz63pe8WHJJYCWkRE4lrX6va4VwvaGwpoERGJa00rHJHvdRWZS5PEREQkrlNK3Znn4g21oEVEJK6IVUB7SQEtIiJxXbwKljd6XUXmUkCLiEgv1sLqVpimMWjPKKBFRKSXPZ3u47Bsb+vIZApoERHpJQJ8faLOgfaSAlpERHoZkQP/Md7rKjKbAlpERHoJW5j0MnREvK4kcymgRUSkl4Bx58RXt3ldSeZSQIuISFxT8912n+INBbSIiMR1WqmOmvSStvoUEZG4vlbhdQWZTS1oERGJa1UzfGeT11VkLgW0iIjEZS38dpfXVWQuBbSIiMQ1OR82tbklV5J8CmgREYmrIABDgrC93etKMpMmiYmISJ/WnQj5Aa+ryExqQbEFKgkAABk4SURBVIuISJ8Uzt5RQIuIiPiQAlpERMSHFNAiIiI+pIAWERHxoYQFtDHmeGPMy8aY14wxVcaYuYl6LBERkXSTyBb0D4BbrbXHA9+Ifi0iIiL9kMiAtkBJ9PNSYHsCH0tERCStJHKjki8Azxhj7sS9EZgf75uMMQuABQATJkxIYDkiIiKpY0ABbYx5DhgV565bgDOBL1prHzfGfAR4ADir5zdaa+8D7gOorKzUjq8iIiIMMKCttb0Ct4sx5mHg+uiXjwH3D+SxREREMkkix6C3A6dHPz8DWJvAxxIREUkriRyD/izwX8aYINBGdJxZREREDi5hAW2tfRGYnajfLyIiks503KRIBoq0t9PwwlI6tu8gZ8woSk6bT1ZujtdliUgMBXQKaA3Dot2wvhWm5MMFwyBPR8DJYWp5aw2bvvwNbDiMbWvD5OWx/a6fU3HnbRQcdYTX5YlIlLHWPyubKisrbVVVlddl+MqyBjhnJYQsNIehMABBA8/OhDklB/95kViR9nbevuAyIk3Nve7LKipk+hMPqyUtkmTGmOXW2sqe13VYho+1hl0414WgKey2ZmsKu6/PWQltYa8rlFTT8MJSbLiPfzjhMA0vLEluQSLSJwW0jy3a7VrO8XRG4Pe1ya1HUl/H9h3Ytra490Xa2umo2ZnkikSkLxqD9rH1ra5bO57mCFzxNty0ASbmwcRcmJDX+/NS/YUlRs6YUZi8PGxrnJDOyiJQXJT8okQkLr18+9iUfDfm3BQnpIsC8LNpcHoZbG6H6jZ3e7MZntzT/XXQxA/uibnu48gcyDLJf27ijZLT5rP9rp8Tr2PGZGWx88HfEGltZeiFH9RYtIjHNEnMx9rCMHqpG3PuqSwINfMOPJvbWtgXckEdG+Kxn9eHYFw0rCfEBHfX5+PzIFcDIWmlaxY34TCRtnay8nIhEKDiztsIFBex42cP0rahmlGfv5ySU+dhjN7BiSRSX5PEFNA+l+hZ3K1h2NJHeFe3w/Z2GJoNE6LBPTGv9+dl2QOvQ5LrnXXQNTvJGT2y1zropqrXqLn7foKlJYy65jPkT5vsYbUi6U0BncK61kFvaIXJSV4HHbZQ0953C7y63c00jBfcXZ+PUjd6SrKhMHv/8gy7fv07Sk4+kZGf+STB8jKvyxJJOwpoSQhrXRd8V1hvbuv9+b5oN3q8LvSJeTA+Vxuv+Fm4sYldDz1K3bP/YPglFzHkgg+QlaNuE5HBooAWz7TFdqNHP26O+XxbO5QH+57MNiHP3a+hUG+1b9nGjnseoH3zVkZdfQXFJ5+o8WmRQaCAFt8KW9jR0Tu4Yz+3xG99d30+OhcCyoqkaFy2gh13309w6BBGL/wMeVMqvC5JJKUpoCVlWetmm1f3NQ4e7UYfk9sd3PHGxNWNPnhsKMzePz/NrocepfTUeYy48hMEy0q9LkskJSmgJa11daP3NZlta5xu9J6t8TJ1ox+yUEMjtb/+HXXPPc/wT17MkA+fR1a2xqdFDoUCWjJaJKYbva914REO3AJXN3rf2jZtYce9D9CxfYcbn543R+PTIv2kgBY5iLrO3kvIYmel7+2Esbn7B3dskKsbHRpfrmLHPQ+QPXI4oxZeSd6kiV6XJOJ7CmiRAWqPwJY+JrHFdqPHC++ubvVM2NTFhkLs/d+n2PXfv6f03acw4vJLCJbqbFSRviigRRKsazZ6bKs7diJbX5u6pOve6KH6Bnb96hHq/+9Fhn/qIwz90PswQW3/L9KTAlrEYz03dekZ3tVt0BCzN3rP8J6Y5+7LSbG90ds2VrPjngfo2LmL0Qs/Q/FJvV6HRAZVZwQ6LRQcZMhpTQt8ab17c31yKXx4GBxdmJwaYymgRVJAS7i76zxeS7ymA0ZkQ0Ve7xCviM5KP9iLkhestTS9XEXNPQ+QM3okoxZ+hryK8V6XJWlqcR3csAGWnhD//uYwPLwDPjoCXqhz+yz8da/7f+hmD6ZN9BXQ6m8S8ZGCAEwvdLd4OiNu57XY0F7WAI9Fg3xLG5REx8ErYoL7na/z3P3JZoyheN4cCiuPZ++iJ9l43U2UnnmaG58uKU5+QZLWXmmEygP8s7p7G6xohM+PheOK4N7t8HgtLBybvBr7Qy1okTQSsbCzo7vlvSka4rEfc7N6hHaPEE/GevBQXT27Hvwt9c8vYcSlH2XI+e/V+LQMmgvfdD1NY3JhSo8DhupDMPVl11J+ei+saIJLR8J149z/A15QF7eIYC3s7uwO6009gnxjm5vIdt5QeOToxNfTtqGamrvvJ7R7D6MWXknxibMT/6CS1pY1wOmvgQFaI91H9D5zLASz4Kb18EK9G3O+YjRcmMTTAfuigBaRg7LWbZvaEIKK/EP/+bA99M1crLU0LnmFHfc8QM64MYxeeCW5EzU+LYeuNQxjlrrJmD0FcPsYXD4KLhkBR3gwGawvfQV0is0HFZFEMgaGZB9eOANcvArGLIFTX4VXGtykt9/sgCX1rus9XnvAGEPJyScy9aF7KJp9HBuuvZGan9xHqKFxYE9GMs6i3RDqo82ZkwVzi93YtJ/C+UAU0CIyaP4wA145Ab4zCSblQWMYntwLX1wHM16Bmza477tmDXxpHdy7zc2iBcjKzmbYRz/MtId/RqSzk7Wf+jx7nvgLNhT27glJSlnf6mZox9MWcf8Wjy9Kbk0DoVkZIjJosgyMy3O3Lr+LGcsOR1s3Zw+B1S3wehOsbYXTyuCq1bC4HqYXlHLkhxdy4wfeR+2991P7v08x9prPUDy3jzUzIlFT8t2Yc1OckA4aOK10/3+bfqcxaBHxhdawC+vVLe5280R4bJfloT/+i+uefpB9I8dy5HVXMv2IcfyzDo4scLPOdYCJdGkLw+g+xqBzDKyee/jDN4mkSWIikpKshW1NnWz5w18oWfQHss94Fzec+HFeo4gdHfCtCrhpInxzo1vjPSXPhfdRKTLOKINrWQOcs9KNRTeHu2dxPzsT5vh0S3gFtIikvNC+OnY++FsaFr/MiMs+RsF559KRFaA0CD/fBm+3wIY2GJYND06H69ZCVSNMznPdnzdPdBPX2iNu33OdiJmeWsNuwtiGVpjcYx20HymgRSRttK3f6NZP793HqIV9j0/v7HD7LW9og42t8M0KeKwWrl7jWlhHFsC9R8CR+fDMPpheAFPz3WYuIsmigBaRtLLf+unxYxl99RWHtH56dwesboWjClxX6DVr3dj3pja4bRLcMAG+Ww3Ds6Nd5gUwIieBT0gylgJaRNJSpLOTvU88Se1vH6PsrNMZ/umPD2h/746I6wIvDsIPt8CqZhfcY3Ph9zPcWHd1mwvtIwvg/GGaqCYDo4AWkbSWrP29X210+ze/3eKC+n+Ohp9uc7fpBa67/Lpxboy7IeTGwzXWLQeigBaRjNC2oZqae+4ntGs3o66+gqKTKjEJTsiOiNskY3WLC+5PjYLaDnj3625P6Kn5cMN4uGgEPLoTRue62eZjct3acclsCmgRyRjvnD997wPkjBzBqKuvJG9y8g/6tRZqO114j8xxu6tdsRrWRieuzS6GPx8L36+G7R3ds83fP9T9vFremUEBLSIZx4ZC7P3jX9n18P9Qetp8Rlz5CYJlpV6X9Y6uw0VeqHPnE69vgx0d8NgMN/5919bubvOvTICR2S7wx6rlnVYU0CKSsUINjdQ+9Ch1f/snwz5+IUMv/ABZOdlel3VAYQub27q7zT8+Emra4X1vuLHtIwrglolw4XBYVOt2VTuiwG3MIalFAS0iGa9981Z2/PzXtG3YxKirPk3Ju05O+Ph0ItSH3Pru4dkwPg8+9m8X4uta4SPD4aGjvK5QDoUCWkQkqmnF6+y450Gy8nIZtfBKCo4+0uuSBkXYutZ1ub87B6QHnQctIhJVdMJxTLnvR5Sfdw6bv/49tnz7Tjp27vK6rAELGIVzOlFAi0hGMoEA5e87i2n//XNyxo5m/We+wI5f/JpwU7PXpYkACmgRyXCBgnxGXvEJpj74U0L76lnzyc+x5/E/Y0NxziwUSSIFtIgIkD18KONuup6KO2+jceky1l62kPoXluCneTqSWQYU0MaYi40xq4wxEWNMZY/7vmqMWWeMWW2Mec/AyhQRSY78qZOouPM2Rn/hKmp//Ts2XnsjLave9rosyUADbUG/CVwAvBB70RhzNPAxYAZwLnCvMUar80QkZRTPOYEpv7yL8vPOYfuPf0akvcPrkiTDDGgneWvtW0C8dYTnA49aa9uBjcaYdcBcYOlAHk9EJJlMIED5e8+i7NwzU3K9tKS2RI1BjwW2xHy9NXqtF2PMAmNMlTGmqra2NkHliIgcPoWzeOGgAW2Mec4Y82ac2/kH+rE41+LOtLDW3metrbTWVg4fPry/dYuI+IK1lkhrm9dlSBo6aBe3tfasw/i9W4HxMV+PA7Yfxu8REfG1trXrCZSWkNXejsnJIVCQ73VJkiYS1cX9J+BjxphcY8wkYBrwSoIeS0TEM/lHTCVn5Aganl/CmksWUPvI44RbWr0uS9LAQJdZfdgYsxWYBzxpjHkGwFq7Cvg98G/gaWChtTY80GJFRPxqyPnvZdKPv0Pb2vWs/8z12JBe8mRgdFiGiMggCzU0EiwpZuvtPyF3/BiGfOg8dX1Ln3RYhohIkgRLigEY9pHzaV2znjUf/yx7Fj3pcVWSaga0DlpERPqWN2kiE751I22bttC5YyfWWvb9+RlK330KgeIir8sTn1MLWkQkwfIqxlN8UiW2o4OWVW+z5pIF7HzgN4TqG7wuTXxMAS0ikiRZubmM++oXmPKLHxHaW0fTKyuw4TChunqvSxMfUkCLiCRZzphRjP3KNZSd/S7a1m1k7Sc/R829D9C5Z5/XpYmPKKBFRDyUf+RUpv7qbgiFWXfZ1bRt2ux1SeITWmYlIuIToX11BMpK2feXZ2lbt4Fhn7iInBHaAjndaZmViIjPBcvLMMZQcsqJZOXns+Gq/6CjZofXZYlHFNAiIj4TLC9j1Oc+zbBPXMzePz/jdTniEa2DFhHxqaEXfgCAzj37CA4p07GXGUYtaBERnzLGYIxh6213sPd/n/K6HEkyBbSIiM+NueFadj30KM1v/NvrUiSJFNAiIj6XO3Y04266nu0/vBcbiXhdjiSJxqBFRFJA8UmVFBx7NAA2FMYEAx5XJImmFrSISIoIFBaw+9FF1Nx9v9elSBIooEVEUsiQD55L07IV7Hv6H16XIgmmgBYRSSGBokImfPtmdtz7AO3barwuRxJIAS0ikmLyJk9k8t23kzNmlNelSAIpoEVEUlDuhHG0b9jE5m98HxsOe12OJIACWkQkReVOnEC4oZFdD/7W61IkARTQIiIpygQDjP/WDdT97Z80LF7qdTkyyLQOWkQkhQXLSpnw3a8RKC4i0t6OycnRnt1pQgEtIpLi8qdNBqDm7l/SuWsPY79yDYHiIo+rkoFSF7eISJoY+dnLCA4tZ92V19H8+iqvy5EBUgtaRCRNZOXmMOb6q2iYM4uOrdspPG4GNhLBZKktlor0VxMRSTMl8+dSft7ZNK1YycZrb6KjZqfXJclhUECLiKSpwuOPoeS0eaz/3Jeo+/sLXpcjh0gBLSKSpkxWFsM++mEqfvAtGpcu04YmKUYBLSKS5vKPnMr4r30J29HJpi9/Q13eKUIBLSKSIbLy8yg6qZIN19xA65p1XpcjB6GAFhHJIMMu+iCjr1vA5lu+S7il1ety5AC0zEpEJMOUnn4yRbOPJ1CQT8tbayg46givS5I41IIWEclAgaJCwo1NbLntDnb+6hGstV6XJD0ooEVEMlSguIgp9/yAxqXL2Hb7T7ChkNclSQwFtIhIBgsOKWfSXd8jZ9QIr0uRHhTQIiIZLlCQz4hPf5xwUzPVN91K5569XpckKKBFRCQqUFpC/tHT2XD1V2jbtMXrcjKeAlpERAAwxjDi0o8y4vJLqL7pViLtHV6XlNG0zEpERPZTfu6ZlJx8IiYnm8ZXVlA0ZxbGGK/LyjhqQYuISC+B4iIiLa3s/MVDbPvPu9Sa9oACWkRE4goUFjD57tuJdHSw8fqvEmpo9LqkjKIubhER6VNWfh7jv3kD9f9YTKCwgEh7B1m5OV6XlRHUghYRkQMyxlB25mlgYf1VX2Tf03/3uqSMoIAWEZF+McEA4791I7UP/w81d/8SG9L50omkgBYRkX7Lq5jAlF/8iNCefXRs2+51OWlNY9AiInJIAsVFjP/mDdhQmM49e8keOsTrktLSgFrQxpiLjTGrjDERY0xlzPWzjTHLjTFvRD+eMfBSRUTETxqXvEL1jbfqkI0EGWgX95vABcALPa7vBj5grT0WuAz47wE+joiI+EzxqScRLC+j9nePe11KWhpQQFtr37LWro5z/VVrbdfgxCogzxiTO5DHEhERfzHGMOYr17DnsT/RsavW63LSTjImiV0IvGqtbY93pzFmgTGmyhhTVVurP7CISCrJGTGcKb/8MTkjhntdSto5aEAbY54zxrwZ53Z+P352BnA7cFVf32Otvc9aW2mtrRw+XH9gEZFUkzNyBA2Ll7LnD3/yupS0ctBZ3Nbasw7nFxtjxgGLgEuttesP53eIiEhqyJs6iW13/JSiObPInTje63LSQkK6uI0xZcCTwFettS8l4jFERMQ/ckaPYsSnL2Hr7T/BhrWByWAY6DKrDxtjtgLzgCeNMc9E77oGmAp83RjzWvQ2YoC1ioiIjw350Psomn0ckba4U47kEBlrrdc1vKOystJWVVV5XYaIiEjSGGOWW2sre17XVp8iIiI+pIAWERHxIQW0iIiIDymgRUREfEgBLSIi4kMKaBERER9SQIuIiPiQAlpERMSHFNAiIiI+pIAWERHxIQW0iIiIDymgRUREfEgBLSIi4kMKaBERER9SQIuIiPiQAlpERMSHFNAiIiI+pIAWERHxIQW0iIiIDymgRUREfEgBLSIi4kMKaBERER9SQIuIiPiQAlpERMSHFNAiIiI+pIAWERHxIWOt9bqGdxhjaoFqDx56GLDbg8dNNj3P9JMpz1XPM73oee5vorV2eM+Lvgporxhjqqy1lV7XkWh6nuknU56rnmd60fPsH3Vxi4iI+JACWkRExIcU0M59XheQJHqe6SdTnqueZ3rR8+wHjUGLiIj4kFrQIiIiPqSAFhER8aGMDWhjzB3GmLeNMSuNMYuMMWXR62cbY5YbY96IfjzD61oHqq/nGr3vq8aYdcaY1caY93hZ50AZYy42xqwyxkSMMZUx17ONMQ9F/6ZvGWO+6mWdA9XX84zeN9MYszR6/xvGmDyv6hyoAz3P6P0TjDFNxpgve1HfYDnAv9t0fC060L/dtHktimWMOd4Y87Ix5jVjTJUxZm5/fzZjAxr4G3CMtXYmsAboetHeDXzAWnsscBnw3x7VN5jiPldjzNHAx4AZwLnAvcaYgGdVDtybwAXACz2uXwzkRv+ms4GrjDEVyS1tUMV9nsaYIPAb4HPW2hnAu4DOpFc3ePr6e3b5MfDX5JWTMH09z3R8Lerr3266vRbF+gFwq7X2eOAb0a/7JZiwknzOWvtszJcvAxdFr78ac30VkGeMybXWtiezvsHU13MFzgcejT63jcaYdcBcYGmSSxwU1tq3AIwxve4CCqMBlg90AA3JrW7wHOB5ngOstNa+Hv2+PUkubVAd4HlijPkQsAFoTnJZg66v55mmr0V9/U3T6rWoBwuURD8vBbb39wczuQUd6wrivxO/EHg1lf+HiCP2uY4FtsTctzV6Ld38AfdCXgNsBu601u71tqSEOAKwxphnjDErjDE3eF1QIhhjCoEbgVu9riWJ0vG1KFY6vxZ9AbjDGLMFuJPu3tqDSusWtDHmOWBUnLtusdb+Mfo9twAh4Lc9fnYGcDuuVeJ7h/lcezdN3Ls93+rP84xjLhAGxgDlwGJjzHPW2g0JKnPADvN5BoFTgDlAC/B3Y8xya+3fE1TmgB3m87wV+LG1tile69qPDvN5dv1s2r0WxfuxONd8/VoU60DPGTgT+KK19nFjzEeAB4Cz+vN70zqgrbUH/I9gjLkMeD9wpo1ZEG6MGQcsAi611q5PbJWD4zCf61ZgfMy3jeMQul+8cLDn2YdLgKettZ3ALmPMS0AlrovUlw7zeW4FnrfW7gYwxjwFnAD4NqAP83meCFxkjPkBUAZEjDFt1tq7B7e6wXOYzzMtX4v6kHKvRbEO9JyNMQ8D10e/fAy4v7+/N2O7uI0x5+K6yT5orW2JuV4GPAl81Vr7klf1Daa+nivwJ+BjxphcY8wkYBrwihc1Jthm4AzjFAInAW97XFMiPAPMNMYURMfbTwf+7XFNg85ae6q1tsJaWwHcBXzPz+F8uNLxtegA0vm1aDvu/0WAM4C1/f3BjA1o4G6gGPhbdPr7z6PXrwGmAl+PXn/NGDPCsyoHR9znaq1dBfwe9yL+NLDQWhv2rsyBMcZ82BizFZgHPGmMeSZ61z1AEW4G6TLgV9balR6VOWB9PU9r7T7gR7jn+Bqwwlr7pHeVDswB/p5p5QDPM+1eiw7wbzetXot6+CzwQ2PM68D3gAX9/UFt9SkiIuJDmdyCFhER8S0FtIiIiA8poEVERHxIAS0iIuJDCmgREREfUkCLiIj4kAJaRETEh/4figqOnB4T56EAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 576x504 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "rot_prediction1 = reg_pred(rotate_data)\n",
    "visualize_trajectory(rot_prediction1, False)\n",
    "plt.savefig('figs/ped_reg_rot.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 169,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-10-02T05:35:55.274987Z",
     "start_time": "2020-10-02T05:35:55.054053Z"
    }
   },
   "outputs": [],
   "source": [
    "!zip -q -r figs.zip figs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.6.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
