{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "2990da4f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The autoreload extension is already loaded. To reload it, use:\n",
      "  %reload_ext autoreload\n"
     ]
    }
   ],
   "source": [
    "%load_ext autoreload\n",
    "\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "49a6cc43",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import matplotlib.pyplot as plt\n",
    "frames = torch.load(\"../video.pt\")\n",
    "w = 10\n",
    "h = 10\n",
    "fig = plt.figure(figsize=(8, 8))\n",
    "columns = 4\n",
    "rows = 4\n",
    "for i in range(1, 16):\n",
    "    img = frames[i,:,:,:]\n",
    "    fig.add_subplot(rows, columns, i)\n",
    "    plt.imshow(img.transpose((1,2,0)))\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "98da0d0b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([18, 3, 224, 224])"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "frames.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "b416bfbb",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from torch.utils.data import DataLoader\n",
    "from torch.utils.data.dataloader import default_collate\n",
    "from torch.utils.data.sampler import SubsetRandomSampler\n",
    "from torch.utils.data.distributed import DistributedSampler\n",
    "\n",
    "class BaseDataLoader(DataLoader):\n",
    "    \"\"\"\n",
    "    Base class for all data loaders\n",
    "    \"\"\"\n",
    "    def __init__(self, dataset, batch_size, shuffle, validation_split, num_workers, collate_fn=default_collate):\n",
    "        self.validation_split = validation_split\n",
    "        self.shuffle = shuffle\n",
    "\n",
    "        self.batch_idx = 0\n",
    "        self.n_samples = len(dataset)\n",
    "\n",
    "        self.sampler, self.valid_sampler = self._split_sampler(self.validation_split)\n",
    "\n",
    "        self.init_kwargs = {\n",
    "            'dataset': dataset,\n",
    "            'batch_size': batch_size,\n",
    "            'shuffle': self.shuffle,\n",
    "            'collate_fn': collate_fn,\n",
    "            'num_workers': num_workers\n",
    "        }\n",
    "        super().__init__(sampler=self.sampler, **self.init_kwargs)\n",
    "\n",
    "    def _split_sampler(self, split):\n",
    "        if split == 0.0:\n",
    "            return None, None\n",
    "\n",
    "        idx_full = np.arange(self.n_samples)\n",
    "\n",
    "        np.random.seed(0)\n",
    "        np.random.shuffle(idx_full)\n",
    "\n",
    "        if isinstance(split, int):\n",
    "            assert split > 0\n",
    "            assert split < self.n_samples, \"validation set size is configured to be larger than entire dataset.\"\n",
    "            len_valid = split\n",
    "        else:\n",
    "            len_valid = int(self.n_samples * split)\n",
    "\n",
    "        valid_idx = idx_full[0:len_valid]\n",
    "        train_idx = np.delete(idx_full, np.arange(0, len_valid))\n",
    "\n",
    "        train_sampler = SubsetRandomSampler(train_idx)\n",
    "        valid_sampler = SubsetRandomSampler(valid_idx)\n",
    "        # turn off shuffle option which is mutually exclusive with sampler\n",
    "        self.shuffle = False\n",
    "        self.n_samples = len(train_idx)\n",
    "\n",
    "        return train_sampler, valid_sampler\n",
    "\n",
    "    def split_validation(self, diff_kwargs=None):\n",
    "        init_kwargs = self.init_kwargs\n",
    "        if diff_kwargs is not None:\n",
    "            init_kwargs.update(diff_kwargs)\n",
    "        if self.valid_sampler is None:\n",
    "            return None\n",
    "        else:\n",
    "            return DataLoader(sampler=self.valid_sampler, **self.init_kwargs)\n",
    "\n",
    "    def num_samples(self):\n",
    "        return len(self.sampler)\n",
    "\n",
    "\n",
    "class BaseDataLoaderExplicitSplit(DataLoader):\n",
    "    \"\"\"\n",
    "    Base class for all data loaders\n",
    "    \"\"\"\n",
    "    def __init__(self, dataset, batch_size, shuffle, num_workers, collate_fn=default_collate):\n",
    "        self.shuffle = shuffle\n",
    "\n",
    "        self.batch_idx = 0\n",
    "        self.n_samples = len(dataset)\n",
    "\n",
    "        self.init_kwargs = {\n",
    "            'dataset': dataset,\n",
    "            'batch_size': batch_size,\n",
    "            'shuffle': self.shuffle,\n",
    "            'collate_fn': collate_fn,\n",
    "            'num_workers': num_workers,\n",
    "            'pin_memory': True\n",
    "        }\n",
    "        super().__init__(**self.init_kwargs)\n",
    "\n",
    "\n",
    "class DistBaseDataLoaderExplicitSplit(DataLoader):\n",
    "    \"\"\"\n",
    "    Base class for all data loaders\n",
    "    \"\"\"\n",
    "    def __init__(self, dataset, batch_size, shuffle, num_workers, collate_fn=default_collate):\n",
    "        self.shuffle = shuffle\n",
    "\n",
    "        self.batch_idx = 0\n",
    "        self.n_samples = len(dataset)\n",
    "        self.train_sampler = DistributedSampler(dataset)\n",
    "        self.init_kwargs = {\n",
    "            'dataset': dataset,\n",
    "            'batch_size': batch_size,\n",
    "            'shuffle': False,\n",
    "            'collate_fn': collate_fn,\n",
    "            'num_workers': num_workers,\n",
    "            'pin_memory': True,\n",
    "            'sampler': self.train_sampler\n",
    "        }\n",
    "        super().__init__(**self.init_kwargs)\n",
    "\n",
    "\n",
    "class MultiDistBaseDataLoaderExplicitSplit(DataLoader):\n",
    "    \"\"\"\n",
    "    Base class for all data loaders\n",
    "    \"\"\"\n",
    "    def __init__(self, args, dataset, batch_size, shuffle, num_workers, collate_fn=default_collate):\n",
    "        self.shuffle = shuffle\n",
    "\n",
    "        self.batch_idx = 0\n",
    "        self.n_samples = len(dataset)\n",
    "        self.args = args\n",
    "        self.train_sampler = DistributedSampler(dataset, num_replicas=self.args.world_size, rank=self.args.rank, drop_last=False)\n",
    "        self.init_kwargs = {\n",
    "            'dataset': dataset,\n",
    "            'batch_size': batch_size,\n",
    "            'shuffle': False,\n",
    "            'collate_fn': collate_fn,\n",
    "            'num_workers': num_workers,\n",
    "            'pin_memory': True,\n",
    "            'sampler': self.train_sampler\n",
    "        }\n",
    "        super().__init__(**self.init_kwargs)\n",
    "\n",
    "class BaseMultiDataLoader:\n",
    "    \"\"\"\n",
    "    Currently implemented as undersample the bigger dataloaders...\n",
    "    \"\"\"\n",
    "    def __init__(self, dataloaders):\n",
    "        self.dataloaders = dataloaders\n",
    "        self.batch_size = self.dataloaders[0].batch_size\n",
    "\n",
    "    def __getitem__(self, item):\n",
    "        dl_idx = item % len(self.dataloaders)\n",
    "        return next(iter(self.dataloaders[dl_idx]))\n",
    "\n",
    "    def __len__(self):\n",
    "        return min(len(x) for x in self.dataloaders) * len(self.dataloaders)\n",
    "\n",
    "    def num_samples(self):\n",
    "        return sum(len(x.sampler) for x in self.dataloaders)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "4201d594",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import pdb\n",
    "\n",
    "import tqdm\n",
    "import random\n",
    "from abc import abstractmethod\n",
    "\n",
    "import av\n",
    "import cv2\n",
    "import decord\n",
    "import ffmpeg\n",
    "import numpy as np\n",
    "import torch\n",
    "from PIL import Image\n",
    "from torch.utils.data import Dataset, get_worker_info\n",
    "from torchvision import transforms\n",
    "\n",
    "\n",
    "class TextVideoDataset(Dataset):\n",
    "    def __init__(self,\n",
    "                 dataset_name,\n",
    "                 text_params,\n",
    "                 video_params,\n",
    "                 data_dir,\n",
    "                 meta_dir=None,\n",
    "                 split='train',\n",
    "                 tsfms=None,\n",
    "                 cut=None,\n",
    "                 subsample=1,\n",
    "                 sliding_window_stride=-1,\n",
    "                 reader='decord',\n",
    "                 neg_param=None,\n",
    "                 data_source=\"clip\",\n",
    "                 ):\n",
    "        self.dataset_name = dataset_name\n",
    "        self.text_params = text_params\n",
    "        self.video_params = video_params\n",
    "        self.data_source = data_source\n",
    "        # check for environment variables\n",
    "        self.data_dir = os.path.expandvars(data_dir)\n",
    "        if meta_dir is not None:\n",
    "            self.meta_dir = os.path.expandvars(meta_dir)\n",
    "        else:\n",
    "            self.meta_dir = self.data_dir\n",
    "        self.split = split\n",
    "        self.transforms = tsfms\n",
    "        self.cut = cut\n",
    "        self.subsample = subsample\n",
    "        self.sliding_window_stride = sliding_window_stride\n",
    "        self.video_reader = video_reader[reader]\n",
    "        self.label_type = 'caption'\n",
    "        self.neg_param = neg_param\n",
    "        self._load_metadata()\n",
    "        if self.sliding_window_stride != -1:\n",
    "            if self.split != 'test':\n",
    "                raise ValueError('Fixing frame sampling is for test time only. can remove but...')\n",
    "            self._fix_temporal_samples()\n",
    "\n",
    "    @abstractmethod\n",
    "    def _load_metadata(self):\n",
    "        raise NotImplementedError(\"Metadata loading must be implemented by subclass\")\n",
    "\n",
    "    @abstractmethod\n",
    "    def _get_video_path(self, sample):\n",
    "        raise NotImplementedError(\"Get video path function must be implemented by subclass\")\n",
    "\n",
    "    def _get_caption(self, sample):\n",
    "        raise NotImplementedError(\"Get caption function must be implemented by subclass\")\n",
    "\n",
    "    def _get_video_lens(self):\n",
    "        vlen_li = []\n",
    "        for idx, row in self.metadata.iterrows():\n",
    "            video_path = self._get_video_path(row)[0]\n",
    "            vlen_li.append(get_video_len(video_path))\n",
    "\n",
    "        return vlen_li\n",
    "\n",
    "    def _fix_temporal_samples(self):\n",
    "        self.metadata['vlen'] = self._get_video_lens()\n",
    "        self.metadata['frame_intervals'] = self.metadata['vlen'].apply(\n",
    "            lambda x: np.linspace(start=0, stop=x, num=min(x, self.video_params['num_frames']) + 1).astype(int))\n",
    "        self.metadata['fix_start'] = self.metadata['frame_intervals'].apply(\n",
    "            lambda x: np.arange(0, int(x[-1] / len(x - 1)), self.sliding_window_stride)\n",
    "        )\n",
    "        self.metadata = self.metadata.explode('fix_start')\n",
    "\n",
    "    def __len__(self):\n",
    "        return len(self.metadata)\n",
    "\n",
    "    def __getitem__(self, item):\n",
    "        item = item % len(self.metadata)\n",
    "        sample = self.metadata.iloc[item]\n",
    "        video_fp, rel_fp = self._get_video_path(sample)\n",
    "        caption = self._get_caption(sample)\n",
    "\n",
    "        video_loading = self.video_params.get('loading', 'strict')\n",
    "        frame_sample = 'rand'\n",
    "        fix_start = None\n",
    "        if self.split == 'test':\n",
    "            frame_sample = 'uniform'\n",
    "        if self.sliding_window_stride != -1:\n",
    "            fix_start = sample['fix_start']\n",
    "\n",
    "        try:\n",
    "            if os.path.isfile(video_fp):\n",
    "                imgs, idxs = self.video_reader(video_fp, self.video_params['num_frames'], frame_sample,\n",
    "                                               fix_start=fix_start)\n",
    "            else:\n",
    "                print(f\"Warning: missing video file {video_fp}.\")\n",
    "                assert False\n",
    "        except Exception as e:\n",
    "            if video_loading == 'strict':\n",
    "                raise ValueError(\n",
    "                    f'Video loading failed for {video_fp}, video loading for this dataset is strict.') from e\n",
    "            else:\n",
    "                imgs = Image.new('RGB', (self.video_params['input_res'], self.video_params['input_res']), (0, 0, 0))\n",
    "                imgs = transforms.ToTensor()(imgs).unsqueeze(0)\n",
    "\n",
    "        # if self.transforms is not None:\n",
    "        #     imgs = self.transforms(imgs)\n",
    "\n",
    "        if self.transforms is not None:\n",
    "            if self.video_params['num_frames'] > 1:\n",
    "                imgs = imgs.transpose(0, 1)  # [T, C, H, W] ---> [C, T, H, W]\n",
    "                imgs = self.transforms(imgs)\n",
    "                imgs = imgs.transpose(0, 1)  # recover\n",
    "            else:\n",
    "                imgs = self.transforms(imgs)\n",
    "\n",
    "        # if self.transforms is not None:\n",
    "        #     # for video aug if T>1 else just do image aug\n",
    "        #     if imgs.size(0) > 1:\n",
    "        #         # added by Mr. YAN\n",
    "        #         imgs = imgs.transpose(0, 1) # [T, C, H, W] ---> [C, T, H, W]\n",
    "        #         imgs = self.transforms(imgs)\n",
    "        #         imgs = imgs.transpose(0, 1) # recover\n",
    "        #     else:\n",
    "        #         imgs = self.transforms(imgs)    # t\n",
    "\n",
    "        final = torch.zeros([self.video_params['num_frames'], 3, self.video_params['input_res'],\n",
    "                             self.video_params['input_res']])\n",
    "        final[:imgs.shape[0]] = imgs\n",
    "\n",
    "        meta_arr = {'raw_captions': caption, 'paths': rel_fp, 'dataset': self.dataset_name}\n",
    "        data = {'video': final, 'text': caption, 'meta': meta_arr}\n",
    "        return data\n",
    "\n",
    "\n",
    "def sample_frames(num_frames, vlen, sample='rand', fix_start=None):\n",
    "    acc_samples = min(num_frames, vlen)\n",
    "    intervals = np.linspace(start=0, stop=vlen, num=acc_samples + 1).astype(int)\n",
    "    ranges = []\n",
    "    for idx, interv in enumerate(intervals[:-1]):\n",
    "        ranges.append((interv, intervals[idx + 1] - 1))\n",
    "    if sample == 'rand':\n",
    "        frame_idxs = [random.choice(range(x[0], x[1])) for x in ranges]\n",
    "    elif fix_start is not None:\n",
    "        frame_idxs = [x[0] + fix_start for x in ranges]\n",
    "    elif sample == 'uniform':                                             \n",
    "        frame_idxs = [(x[0] + x[1]) // 2 for x in ranges]\n",
    "    else:\n",
    "        raise NotImplementedError\n",
    "\n",
    "    return frame_idxs\n",
    "\n",
    "def sample_frames_clips(start, end, vlen, acc_samples):\n",
    "    start = max(0, start)\n",
    "    end = min(vlen, end)\n",
    "\n",
    "    intervals = np.linspace(start=start, stop=end, num=int(acc_samples) + 1).astype(int)\n",
    "    ranges = []\n",
    "    for idx, interv in enumerate(intervals[:-1]):\n",
    "        ranges.append((interv, intervals[idx + 1] - 1))\n",
    "        frame_idxs = [(x[0] + x[1]) // 2 for x in ranges\n",
    "                      ]\n",
    "    return frame_idxs\n",
    "\n",
    "def sample_frames_start_end(num_frames, start, end, sample='rand', fix_start=None):\n",
    "    acc_samples = min(num_frames, end)\n",
    "    intervals = np.linspace(start=start, stop=end, num=acc_samples + 1).astype(int)\n",
    "    ranges = []\n",
    "    for idx, interv in enumerate(intervals[:-1]):\n",
    "        ranges.append((interv, intervals[idx + 1] - 1))\n",
    "    if sample == 'rand':\n",
    "        frame_idxs = [random.choice(range(x[0], x[1])) for x in ranges]\n",
    "    elif fix_start is not None:\n",
    "        frame_idxs = [x[0] + fix_start for x in ranges]\n",
    "    elif sample == 'uniform':\n",
    "        frame_idxs = [(x[0] + x[1]) // 2 for x in ranges]\n",
    "    else:\n",
    "        raise NotImplementedError\n",
    "\n",
    "    return frame_idxs\n",
    "\n",
    "decord.bridge.set_bridge(\"torch\")\n",
    "\n",
    "def read_frames_decord(video_path, num_frames, sample='rand', fix_start=None):\n",
    "    video_reader = decord.VideoReader(video_path, num_threads=1)\n",
    "    vlen = len(video_reader)\n",
    "    frame_idxs = sample_frames(num_frames, vlen, sample=sample, fix_start=fix_start)\n",
    "    video_reader.skip_frames(1)\n",
    "    frames = video_reader.get_batch(frame_idxs)\n",
    "\n",
    "    frames = frames.float() / 255\n",
    "    frames = frames.permute(0, 3, 1, 2)\n",
    "    return frames, frame_idxs\n",
    "\n",
    "def read_frames_decord_start_end(video_path, start, end, num_frames):\n",
    "    video_reader = decord.VideoReader(video_path, num_threads=1)\n",
    "    vlen = len(video_reader)\n",
    "    frame_idxs = sample_frames_clips(start, end, vlen, num_frames + 1)\n",
    "    video_reader.skip_frames(1)\n",
    "    frames = video_reader.get_batch(frame_idxs)\n",
    "\n",
    "    frames = frames.float() / 255\n",
    "    frames = frames.permute(0, 3, 1, 2)\n",
    "    return frames, frame_idxs\n",
    "\n",
    "def get_video_len(video_path):\n",
    "    cap = cv2.VideoCapture(video_path)\n",
    "    if not (cap.isOpened()):\n",
    "        return False\n",
    "    vlen = int(cap.get(cv2.CAP_PROP_FRAME_COUNT))\n",
    "    cap.release()\n",
    "    return vlen\n",
    "\n",
    "video_reader = {\n",
    "#     'av': read_frames_av,\n",
    "#     'cv2': read_frames_cv2,\n",
    "#     'cv2_epic': read_frames_cv2_epic,\n",
    "#     'cv2_charades': read_frames_cv2_charades,\n",
    "#     'cv2_egoclip': read_frames_cv2_egoclip,\n",
    "    'decord': read_frames_decord,\n",
    "    'decord_start_end': read_frames_decord_start_end,\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "88322195",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Video Transform is used!\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "Video Transform is used!\n",
      "278\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/4057194060.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import pdb\n",
    "import sys\n",
    "import json\n",
    "import pandas as pd\n",
    "\n",
    "from transforms import init_transform_dict, init_video_transform_dict\n",
    "\n",
    "class SQDES(TextVideoDataset):\n",
    "    def _load_metadata(self):\n",
    "        split_files = {\n",
    "            'train': 'train_v1.json',\n",
    "#             'val': 'nlq_val.json',            # there is no test\n",
    "#             'test': 'nlq_test_unannotated.json'\n",
    "        }\n",
    "        # target_split_fp = split_files[self.split]\n",
    "        assert self.subsample in ['video', 'text',]\n",
    "\n",
    "        self.metadata = pd.DataFrame(columns=['video_uid', 'clip_uid',\n",
    "                                              'video_start_time', 'video_end_time',\n",
    "                                              'query'])\n",
    "\n",
    "        # for split in ['train', 'val']:\n",
    "        target_split_fp = split_files[split]\n",
    "        ann_file = os.path.join(self.meta_dir, target_split_fp)\n",
    "        with open(ann_file) as f:\n",
    "            anno_json = json.load(f)\n",
    "\n",
    "        # forward clip features\n",
    "        if self.subsample == 'video':\n",
    "            for anno_video in anno_json[\"videos\"]:\n",
    "                for anno_clip in anno_video[\"clips\"]:\n",
    "                    for annotator in anno_clip[\"annotations\"]:\n",
    "                        for label in annotator[\"labels\"]:\n",
    "                            times = float(label[\"video_start_time\"]), float(label[\"video_end_time\"])\n",
    "                            label_duration = times[1] - times[0]\n",
    "                            query = None\n",
    "                            if 'query' in label:\n",
    "                                query = label['query']['query']\n",
    "                                print(\"here\")\n",
    "                            new = pd.DataFrame({\n",
    "                                'video_uid': anno_video['video_uid'],\n",
    "                                'clip_uid': anno_clip['clip_uid'],\n",
    "                                'video_start_time': times[0],\n",
    "                                'video_end_time': times[1],\n",
    "                                'query': query}, index=[1])\n",
    "                            self.metadata = self.metadata.append(new, ignore_index=True)\n",
    "\n",
    "        self.transforms = init_video_transform_dict()['test']\n",
    "\n",
    "    def _get_video_path(self, sample):\n",
    "        if self.data_source == \"clip\":\n",
    "            rel_video_fp = sample[\"clip_uid\"]\n",
    "        else:\n",
    "            rel_video_fp = sample[\"video_uid\"]\n",
    "        full_video_fp = os.path.join(self.data_dir, rel_video_fp + '.mp4')\n",
    "        return full_video_fp, rel_video_fp\n",
    "    \n",
    "    def _get_caption(self, sample):\n",
    "        caption = sample['query']\n",
    "        return caption\n",
    "\n",
    "    def _get_video_feats(self, item):\n",
    "        sample = self.metadata.iloc [item]\n",
    "        print(sample)\n",
    "        video_fp, rel_fp = self._get_video_path(sample)\n",
    "\n",
    "        fps = 1.87\n",
    "        try:\n",
    "            print(sample[2], sample[3])\n",
    "            imgs, idxs = self.video_reader(video_fp, sample[2]*30, sample[3]*30,\n",
    "                                               (sample[3]-sample[2]) * fps * self.video_params['num_frames'])\n",
    "        except:\n",
    "            print(f\"Warning: missing video file {video_fp}.\")\n",
    "\n",
    "        if self.transforms is not None:\n",
    "            imgs = imgs.transpose(0, 1)  # [T, C, H, W] ---> [C, T, H, W]\n",
    "            imgs = self.transforms(imgs)\n",
    "            imgs = imgs.transpose(0, 1)  # recover\n",
    "\n",
    "        meta_arr = {'video_uid': sample[0], 'clip_uid': sample[1], 'data': video_fp}\n",
    "        data = {'video': imgs, 'meta' : meta_arr}\n",
    "        return data\n",
    "\n",
    "    def _get_text_feats(self, item):\n",
    "        sample = self.metadata.iloc [item]\n",
    "        text = self._get_caption(sample)\n",
    "        meta_arr = {'video_uid': sample[0], 'clip_uid': sample[1], 'dataset': self.dataset_name}\n",
    "        data = {'text': text, 'meta' : meta_arr}\n",
    "        return data\n",
    "\n",
    "    def __getitem__(self, item):\n",
    "        if self.subsample == 'video':\n",
    "            return self._get_video_feats(item)\n",
    "        if self.subsample == 'text':\n",
    "            return self._get_text_feats(item)\n",
    "\n",
    "split = 'train'\n",
    "kwargs = dict(\n",
    "    dataset_name=\"Ego4d_NLQ\",\n",
    "    text_params={\n",
    "        \"input\": \"text\"\n",
    "    },\n",
    "    video_params={\n",
    "        \"input_res\": 224,\n",
    "        \"num_frames\": 4,\n",
    "        \"loading\": \"lax\"\n",
    "    },\n",
    "    data_dir=\"/vision/group/ego4d/v1/clips/\",\n",
    "    meta_dir=\"/vision/u/eatang/sdas/datasets/\",\n",
    "    tsfms=init_video_transform_dict()['train'],\n",
    "    reader='decord_start_end',\n",
    "    subsample='video',\n",
    "    split=split,\n",
    ")\n",
    "dataset = SQDES(**kwargs)\n",
    "print(len(dataset))\n",
    "# for i in range(1000):\n",
    "#     item = dataset[i]\n",
    "#     # print(item.keys())\n",
    "#     print(item)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "26b17118",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0      Next time I use my phone after arranging the d...\n",
       "1      Next time I'm watering the flowers, please rem...\n",
       "2      Next time I'm cleaning or wiping a table or ki...\n",
       "3      Next time I'm walking up the stairs, please re...\n",
       "4      Next time I'm arranging and organizing items, ...\n",
       "                             ...                        \n",
       "273    Next time I'm about to request and eat a food ...\n",
       "274    Next time I'm conversing or interacting with s...\n",
       "275    Next time I see someone serving food onto a pl...\n",
       "276    Next time I see person Y drinking from a cup, ...\n",
       "277    Next time I'm conversing with someone, after I...\n",
       "Name: query, Length: 278, dtype: object"
      ]
     },
     "execution_count": 35,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dataset.metadata['query']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "id": "12b88e5c",
   "metadata": {},
   "outputs": [],
   "source": [
    "def dataset_loader(dataset_name,\n",
    "                   text_params,\n",
    "                   video_params,\n",
    "                   data_dir,\n",
    "                   meta_dir=None,\n",
    "                   split='train',\n",
    "                   tsfms=None,\n",
    "                   cut=None,\n",
    "                   subsample=1,\n",
    "                   sliding_window_stride=-1,\n",
    "                   reader='decord',\n",
    "                   neg_param=None):\n",
    "    kwargs = dict(\n",
    "        dataset_name=dataset_name,\n",
    "        text_params=text_params,\n",
    "        video_params=video_params,\n",
    "        data_dir=data_dir,\n",
    "        meta_dir=meta_dir,\n",
    "        split=split,\n",
    "        tsfms=tsfms,\n",
    "        cut=cut,\n",
    "        subsample=subsample,\n",
    "        sliding_window_stride=sliding_window_stride,\n",
    "        reader=reader,\n",
    "        neg_param=neg_param,\n",
    "    )\n",
    "\n",
    "    dataset = SQDES(**kwargs)\n",
    "\n",
    "    return dataset\n",
    "\n",
    "class TextVideoDataLoader(BaseDataLoaderExplicitSplit):\n",
    "    def __init__(self,\n",
    "                 dataset_name,\n",
    "                 text_params,\n",
    "                 video_params,\n",
    "                 data_dir,\n",
    "                 meta_dir=None,\n",
    "                 split='train',\n",
    "                 tsfm_params=None,\n",
    "                 tsfm_split=None,\n",
    "                 cut=None,\n",
    "                 subsample=1,\n",
    "                 sliding_window_stride=-1,\n",
    "                 reader='decord',\n",
    "                 neg_param=None,\n",
    "                 batch_size=1,\n",
    "                 num_workers=1,\n",
    "                 shuffle=True):\n",
    "        if tsfm_params is None:\n",
    "            tsfm_params = {}\n",
    "        if video_params['num_frames'] > 1:\n",
    "            # video data can not do flip, crop aug\n",
    "            tsfm_dict = init_video_transform_dict(**tsfm_params)\n",
    "        else:\n",
    "            tsfm_dict = init_transform_dict(**tsfm_params)\n",
    "        if tsfm_split is None:\n",
    "            tsfm_split = split\n",
    "        tsfm = tsfm_dict[tsfm_split]\n",
    "        dataset = dataset_loader(dataset_name, text_params, video_params, data_dir, meta_dir, split, tsfm, cut,\n",
    "                                 subsample, sliding_window_stride, reader, neg_param)\n",
    "\n",
    "        super().__init__(dataset, batch_size, shuffle, num_workers)\n",
    "        self.dataset_name = dataset_name"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "b099d863",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Video Transform is used!\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "Video Transform is used!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n",
      "/tmp/eatang/ipykernel_474965/3532354571.py:47: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  self.metadata = self.metadata.append(new, ignore_index=True)\n"
     ]
    }
   ],
   "source": [
    "loader = TextVideoDataLoader(\n",
    "    dataset_name=\"Ego4D_NLQ\",\n",
    "    text_params={\"input\": \"text\"},\n",
    "    video_params={\"input_res\": 224, \"num_frames\": 4, \"loading\": \"lax\"},\n",
    "    data_dir=\"/vision/group/ego4d/v1/clips\",\n",
    "    meta_dir=\"/vision/u/eatang/sdas/datasets/\",\n",
    "    split=\"train\",\n",
    "    subsample=\"video\",\n",
    "    reader=\"decord_start_end\",\n",
    "    batch_size=32,\n",
    "    num_workers=16,\n",
    "    shuffle=True\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "a31425f5",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "video_uid                        dd08bc58-b614-4ba7-b883-a213560621dd\n",
      "clip_uid                         9df49083-577b-43f9-9874-6e4b21f104b4\n",
      "video_start_time                                            347.62496\n",
      "video_end_time                                                  349.0\n",
      "query               Next time I use my phone after arranging the d...\n",
      "Name: 0, dtype: object\n",
      "347.62496 349.0\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "torch.Size([11, 3, 224, 224])"
      ]
     },
     "execution_count": 38,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dataset.__getitem__(0)[\"video\"].shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "9c7aed45",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n",
      "here\n"
     ]
    }
   ],
   "source": [
    "missing_clips = set()\n",
    "here_count = 0\n",
    "for clip_uid in dataset.metadata[\"clip_uid\"]:\n",
    "    if os.path.exists(os.path.join(\"/vision/group/ego4d/v1/clips/\", clip_uid + \".mp4\")):\n",
    "        here_count += 1\n",
    "        print(\"here\")\n",
    "    else:\n",
    "        missing_clips.add(clip_uid)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "a677876f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "True"
      ]
     },
     "execution_count": 31,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "\"77be1058-8ecb-49b0-97ce-5acac6fd5a43\" in list(dataset.metadata[\"clip_uid\"])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "30c07382",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "True"
      ]
     },
     "execution_count": 33,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    " os.path.exists(os.path.join(\"/vision/group/ego4d/v1/clips/\", \"77be1058-8ecb-49b0-97ce-5acac6fd5a43\" + \".mp4\"))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "c945ae98",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "video_uid                        dddce8ac-09b0-4b13-b0fa-eb18e1f27b21\n",
      "clip_uid                         77be1058-8ecb-49b0-97ce-5acac6fd5a43\n",
      "video_start_time                                          1709.082923\n",
      "video_end_time                                            1710.714333\n",
      "query               Next time I use my phone, please remind me to ...\n",
      "Name: 181, dtype: objectvideo_uid                        2c54abd0-aa4f-4b0a-9e78-c45aca156af0\n",
      "clip_uid                         94bf098c-6430-438c-9c71-6fd4f02153c4\n",
      "video_start_time                                           178.890215\n",
      "video_end_time                                             183.194185\n",
      "query               Next time I'm taking a photo or recording a vi...\n",
      "Name: 90, dtype: objectvideo_uid           59dac266-4b43-43b1-9fe3-6013ade33eb6\n",
      "clip_uid            fbafc354-121f-40f1-a553-bbae0d2f66ed\n",
      "video_start_time                              724.469249\n",
      "video_end_time                                728.469029\n",
      "query                                               None\n",
      "Name: 27, dtype: objectvideo_uid                        65d56a26-3556-491a-880a-c0fbb581f1bf\n",
      "clip_uid                         b2dd4ae0-c0e6-4670-991d-9082ea5620f9\n",
      "video_start_time                                           835.548491\n",
      "video_end_time                                             857.601631\n",
      "query               Next time I'm playing with the cat, please rem...\n",
      "Name: 220, dtype: objectvideo_uid                        c980a9d2-3fbc-4305-a8ff-ab6522f8320a\n",
      "clip_uid                         d862277d-cad2-4d81-8590-da0280773e00\n",
      "video_start_time                                            258.64859\n",
      "video_end_time                                                261.954\n",
      "query               Next time I'm using a hammer or nail gun to fi...\n",
      "Name: 151, dtype: objectvideo_uid           59dac266-4b43-43b1-9fe3-6013ade33eb6\n",
      "clip_uid            3ab53ed1-2f79-4672-b46e-d6eaa233ce5c\n",
      "video_start_time                             1467.521499\n",
      "video_end_time                               1470.043029\n",
      "query                                               None\n",
      "Name: 49, dtype: objectvideo_uid                        c980a9d2-3fbc-4305-a8ff-ab6522f8320a\n",
      "clip_uid                         d862277d-cad2-4d81-8590-da0280773e00\n",
      "video_start_time                                            308.10448\n",
      "video_end_time                                                310.574\n",
      "query               Next time I'm using a hammer to fix a nail, pl...\n",
      "Name: 156, dtype: object\n",
      "video_uid                        c980a9d2-3fbc-4305-a8ff-ab6522f8320a\n",
      "clip_uid                         d862277d-cad2-4d81-8590-da0280773e00\n",
      "video_start_time                                            117.48765\n",
      "video_end_time                                                120.097\n",
      "query               Next time I'm using a hammer or nail gun to fi...\n",
      "Name: 136, dtype: object\n",
      "\n",
      "video_uid                        c980a9d2-3fbc-4305-a8ff-ab6522f8320a\n",
      "clip_uid                         d862277d-cad2-4d81-8590-da0280773e00\n",
      "video_start_time                                            479.84376\n",
      "video_end_time                                                  480.0\n",
      "query               Next time I'm using a hammer or nail gun to fi...\n",
      "Name: 170, dtype: object\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "Warning: missing video file /vision/group/ego4d/v1/clips/77be1058-8ecb-49b0-97ce-5acac6fd5a43.mp4.\n",
      "Warning: missing video file /vision/group/ego4d/v1/clips/3ab53ed1-2f79-4672-b46e-d6eaa233ce5c.mp4.\n",
      "Warning: missing video file /vision/group/ego4d/v1/clips/fbafc354-121f-40f1-a553-bbae0d2f66ed.mp4.\n",
      "Warning: missing video file /vision/group/ego4d/v1/clips/b2dd4ae0-c0e6-4670-991d-9082ea5620f9.mp4.\n"
     ]
    },
    {
     "ename": "UnboundLocalError",
     "evalue": "Caught UnboundLocalError in DataLoader worker process 0.\nOriginal Traceback (most recent call last):\n  File \"/viscam/u/eatang/miniconda3/lib/python3.10/site-packages/torch/utils/data/_utils/worker.py\", line 302, in _worker_loop\n    data = fetcher.fetch(index)\n  File \"/viscam/u/eatang/miniconda3/lib/python3.10/site-packages/torch/utils/data/_utils/fetch.py\", line 58, in fetch\n    data = [self.dataset[idx] for idx in possibly_batched_index]\n  File \"/viscam/u/eatang/miniconda3/lib/python3.10/site-packages/torch/utils/data/_utils/fetch.py\", line 58, in <listcomp>\n    data = [self.dataset[idx] for idx in possibly_batched_index]\n  File \"/tmp/eatang/ipykernel_466762/3532354571.py\", line 93, in __getitem__\n    return self._get_video_feats(item)\n  File \"/tmp/eatang/ipykernel_466762/3532354571.py\", line 76, in _get_video_feats\n    imgs = imgs.transpose(0, 1)  # [T, C, H, W] ---> [C, T, H, W]\nUnboundLocalError: local variable 'imgs' referenced before assignment\n",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mUnboundLocalError\u001b[0m                         Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[21], line 1\u001b[0m\n\u001b[0;32m----> 1\u001b[0m \u001b[38;5;28;01mfor\u001b[39;00m idx, batch \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28menumerate\u001b[39m(loader):\n\u001b[1;32m      2\u001b[0m     \u001b[38;5;28;01mbreak\u001b[39;00m\n",
      "File \u001b[0;32m/viscam/u/eatang/miniconda3/lib/python3.10/site-packages/torch/utils/data/dataloader.py:628\u001b[0m, in \u001b[0;36m_BaseDataLoaderIter.__next__\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    625\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_sampler_iter \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m:\n\u001b[1;32m    626\u001b[0m     \u001b[38;5;66;03m# TODO(https://github.com/pytorch/pytorch/issues/76750)\u001b[39;00m\n\u001b[1;32m    627\u001b[0m     \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_reset()  \u001b[38;5;66;03m# type: ignore[call-arg]\u001b[39;00m\n\u001b[0;32m--> 628\u001b[0m data \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_next_data\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    629\u001b[0m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_num_yielded \u001b[38;5;241m+\u001b[39m\u001b[38;5;241m=\u001b[39m \u001b[38;5;241m1\u001b[39m\n\u001b[1;32m    630\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_dataset_kind \u001b[38;5;241m==\u001b[39m _DatasetKind\u001b[38;5;241m.\u001b[39mIterable \u001b[38;5;129;01mand\u001b[39;00m \\\n\u001b[1;32m    631\u001b[0m         \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_IterableDataset_len_called \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m \u001b[38;5;129;01mand\u001b[39;00m \\\n\u001b[1;32m    632\u001b[0m         \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_num_yielded \u001b[38;5;241m>\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_IterableDataset_len_called:\n",
      "File \u001b[0;32m/viscam/u/eatang/miniconda3/lib/python3.10/site-packages/torch/utils/data/dataloader.py:1333\u001b[0m, in \u001b[0;36m_MultiProcessingDataLoaderIter._next_data\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m   1331\u001b[0m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[1;32m   1332\u001b[0m     \u001b[38;5;28;01mdel\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_task_info[idx]\n\u001b[0;32m-> 1333\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_process_data\u001b[49m\u001b[43m(\u001b[49m\u001b[43mdata\u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m/viscam/u/eatang/miniconda3/lib/python3.10/site-packages/torch/utils/data/dataloader.py:1359\u001b[0m, in \u001b[0;36m_MultiProcessingDataLoaderIter._process_data\u001b[0;34m(self, data)\u001b[0m\n\u001b[1;32m   1357\u001b[0m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_try_put_index()\n\u001b[1;32m   1358\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28misinstance\u001b[39m(data, ExceptionWrapper):\n\u001b[0;32m-> 1359\u001b[0m     \u001b[43mdata\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mreraise\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m   1360\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m data\n",
      "File \u001b[0;32m/viscam/u/eatang/miniconda3/lib/python3.10/site-packages/torch/_utils.py:543\u001b[0m, in \u001b[0;36mExceptionWrapper.reraise\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    539\u001b[0m \u001b[38;5;28;01mexcept\u001b[39;00m \u001b[38;5;167;01mTypeError\u001b[39;00m:\n\u001b[1;32m    540\u001b[0m     \u001b[38;5;66;03m# If the exception takes multiple arguments, don't try to\u001b[39;00m\n\u001b[1;32m    541\u001b[0m     \u001b[38;5;66;03m# instantiate since we don't know how to\u001b[39;00m\n\u001b[1;32m    542\u001b[0m     \u001b[38;5;28;01mraise\u001b[39;00m \u001b[38;5;167;01mRuntimeError\u001b[39;00m(msg) \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;28mNone\u001b[39m\n\u001b[0;32m--> 543\u001b[0m \u001b[38;5;28;01mraise\u001b[39;00m exception\n",
      "\u001b[0;31mUnboundLocalError\u001b[0m: Caught UnboundLocalError in DataLoader worker process 0.\nOriginal Traceback (most recent call last):\n  File \"/viscam/u/eatang/miniconda3/lib/python3.10/site-packages/torch/utils/data/_utils/worker.py\", line 302, in _worker_loop\n    data = fetcher.fetch(index)\n  File \"/viscam/u/eatang/miniconda3/lib/python3.10/site-packages/torch/utils/data/_utils/fetch.py\", line 58, in fetch\n    data = [self.dataset[idx] for idx in possibly_batched_index]\n  File \"/viscam/u/eatang/miniconda3/lib/python3.10/site-packages/torch/utils/data/_utils/fetch.py\", line 58, in <listcomp>\n    data = [self.dataset[idx] for idx in possibly_batched_index]\n  File \"/tmp/eatang/ipykernel_466762/3532354571.py\", line 93, in __getitem__\n    return self._get_video_feats(item)\n  File \"/tmp/eatang/ipykernel_466762/3532354571.py\", line 76, in _get_video_feats\n    imgs = imgs.transpose(0, 1)  # [T, C, H, W] ---> [C, T, H, W]\nUnboundLocalError: local variable 'imgs' referenced before assignment\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "video_uid           65d56a26-3556-491a-880a-c0fbb581f1bf\n",
      "clip_uid            135c81f0-56cc-4195-844a-af3a562f3307\n",
      "video_start_time                             1729.271021\n",
      "video_end_time                               1735.295031\n",
      "query                                               None\n",
      "Name: 236, dtype: object\n",
      "Warning: missing video file /vision/group/ego4d/v1/clips/135c81f0-56cc-4195-844a-af3a562f3307.mp4.\n",
      "video_uid                        9d43acb7-9a94-4a80-a461-63f074c6f865\n",
      "clip_uid                         77e05256-299f-4703-81f9-d3c1da63c70e\n",
      "video_start_time                                           303.849385\n",
      "video_end_time                                             348.225695\n",
      "query               Next time I'm operating an ATM machine, please...\n",
      "Name: 203, dtype: object\n",
      "video_uid                        59dac266-4b43-43b1-9fe3-6013ade33eb6\n",
      "clip_uid                         1c861004-cfd1-4497-8e32-5cb4ad1ff276\n",
      "video_start_time                                           337.614499\n",
      "video_end_time                                             393.924029\n",
      "query               Next time I'm frying dough, please remind me t...\n",
      "Name: 63, dtype: object\n",
      "video_uid           65d56a26-3556-491a-880a-c0fbb581f1bf\n",
      "clip_uid            135c81f0-56cc-4195-844a-af3a562f3307\n",
      "video_start_time                             1731.546801\n",
      "video_end_time                               1735.196711\n",
      "query                                               None\n",
      "Name: 237, dtype: object\n",
      "Warning: missing video file /vision/group/ego4d/v1/clips/135c81f0-56cc-4195-844a-af3a562f3307.mp4.\n",
      "video_uid                        65d56a26-3556-491a-880a-c0fbb581f1bf\n",
      "clip_uid                         4518c357-edf0-404a-a1f4-172ac16731f8\n",
      "video_start_time                                           437.235741\n",
      "video_end_time                                             460.362031\n",
      "query               Next time I'm feeding the cat, please remind m...\n",
      "Name: 215, dtype: object\n",
      "video_uid                        dd08bc58-b614-4ba7-b883-a213560621dd\n",
      "clip_uid                         9df49083-577b-43f9-9874-6e4b21f104b4\n",
      "video_start_time                                            287.47733\n",
      "video_end_time                                               302.6363\n",
      "query               Next time I'm walking up the stairs, please re...\n",
      "Name: 3, dtype: object\n",
      "video_uid           59dac266-4b43-43b1-9fe3-6013ade33eb6\n",
      "clip_uid            3ab53ed1-2f79-4672-b46e-d6eaa233ce5c\n",
      "video_start_time                              993.820869\n",
      "video_end_time                               1017.283029\n",
      "query                                               None\n",
      "Name: 33, dtype: object\n",
      "Warning: missing video file /vision/group/ego4d/v1/clips/3ab53ed1-2f79-4672-b46e-d6eaa233ce5c.mp4.\n",
      "video_uid                        8db05748-e83e-4422-ac45-de586be75f70\n",
      "clip_uid                         86c26ddf-8179-4058-98d1-f77ff5d5175b\n",
      "video_start_time                                           1020.66501\n",
      "video_end_time                                             1058.96891\n",
      "query               Next time I'm about to converse or interact wi...\n",
      "Name: 117, dtype: object\n",
      "Warning: missing video file /vision/group/ego4d/v1/clips/86c26ddf-8179-4058-98d1-f77ff5d5175b.mp4.\n",
      "video_uid                        c980a9d2-3fbc-4305-a8ff-ab6522f8320a\n",
      "clip_uid                         d862277d-cad2-4d81-8590-da0280773e00\n",
      "video_start_time                                             32.35464\n",
      "video_end_time                                                 45.933\n",
      "query               Next time I'm using my phone, please remind me...\n",
      "Name: 129, dtype: object\n",
      "video_uid                        c980a9d2-3fbc-4305-a8ff-ab6522f8320a\n",
      "clip_uid                         d862277d-cad2-4d81-8590-da0280773e00\n",
      "video_start_time                                            459.98862\n",
      "video_end_time                                                468.249\n",
      "query               Next time I'm using a hammer or nail gun to fi...\n",
      "Name: 168, dtype: object\n",
      "video_uid                        1246d6ec-5620-4f71-8b4b-d823775f58c2\n",
      "clip_uid                         be7661cc-9528-4c31-9954-abc648a96dda\n",
      "video_start_time                                            14.021029\n",
      "video_end_time                                             480.021029\n",
      "query               Next time I'm conversing or interacting with s...\n",
      "Name: 274, dtype: object\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Traceback (most recent call last):\n",
      "  File \"/viscam/u/eatang/miniconda3/lib/python3.10/runpy.py\", line 196, in _run_module_as_main\n",
      "    return _run_code(code, main_globals, None,\n",
      "  File \"/viscam/u/eatang/miniconda3/lib/python3.10/runpy.py\", line 86, in _run_code\n",
      "    exec(code, run_globals)\n",
      "  File \"/viscam/u/eatang/miniconda3/lib/python3.10/site-packages/ipykernel_launcher.py\", line 17, in <module>\n",
      "    app.launch_new_instance()\n",
      "  File \"/viscam/u/eatang/miniconda3/lib/python3.10/site-packages/traitlets/config/application.py\", line 992, in launch_instance\n",
      "    app.start()\n",
      "  File \"/viscam/u/eatang/miniconda3/lib/python3.10/site-packages/ipykernel/kernelapp.py\", line 711, in start\n",
      "    self.io_loop.start()\n",
      "  File \"/viscam/u/eatang/miniconda3/lib/python3.10/site-packages/tornado/platform/asyncio.py\", line 215, in start\n",
      "    self.asyncio_loop.run_forever()\n",
      "  File \"/viscam/u/eatang/miniconda3/lib/python3.10/asyncio/base_events.py\", line 603, in run_forever\n",
      "    self._run_once()\n",
      "  File \"/viscam/u/eatang/miniconda3/lib/python3.10/asyncio/base_events.py\", line 1863, in _run_once\n",
      "    event_list = self._selector.select(timeout)\n",
      "  File \"/viscam/u/eatang/miniconda3/lib/python3.10/selectors.py\", line 469, in select\n",
      "    fd_event_list = self._selector.poll(timeout, max_ev)\n",
      "  File \"/viscam/u/eatang/miniconda3/lib/python3.10/site-packages/torch/utils/data/_utils/signal_handling.py\", line 66, in handler\n",
      "    _error_if_any_worker_fails()\n",
      "RuntimeError: DataLoader worker (pid 473277) is killed by signal: Killed. \n"
     ]
    }
   ],
   "source": [
    "for idx, batch in enumerate(loader):\n",
    "    break\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "id": "8b9b70a3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<__main__.NaturalLanguageQueries at 0x7f7a90f6e440>"
      ]
     },
     "execution_count": 51,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dataset."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "e1b1816a",
   "metadata": {},
   "outputs": [],
   "source": [
    "import json"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "ec2caa71",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open('/vision/u/eatang/sdas/datasets/train_v1.json', \"r\") as f:\n",
    "    train_v1 = json.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "fb6ec165",
   "metadata": {},
   "outputs": [],
   "source": [
    "for video in train_v1[\"videos\"]:\n",
    "    clip_idx = 0\n",
    "    annotator_idx = 0\n",
    "    label_idx = 0\n",
    "    \n",
    "    clip_uid = video[\"clips\"][clip_idx]['clip_uid']\n",
    "    start = video[\"clips\"][clip_idx]['annotations'][annotator_idx]['labels'][0]['start_time']\n",
    "    end = video[\"clips\"][clip_idx]['annotations'][annotator_idx]['labels'][0]['end_time']\n",
    "    query = video[\"clips\"][clip_idx]['annotations'][annotator_idx]['labels'][0]['query']\n",
    "    break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "e463bd25",
   "metadata": {},
   "outputs": [],
   "source": [
    "x = read_frames_decord_start_end(os.path.join('/vision/group/ego4d/v1/clips/', clip_uid + '.mp4'), start, end, 4)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "id": "74cf924c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'event_has_occurred_before': True,\n",
       " 'event': 'use_phone',\n",
       " 'event_readable': '#c uses the phone.',\n",
       " 'request': 'reminder to check emails.',\n",
       " 'query': 'Next time I use my phone after arranging the documents and cleaning my work station, please remind me to check my emails.',\n",
       " 'ans': 'Remember to check your emails.'}"
      ]
     },
     "execution_count": 48,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "query"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "id": "f8d01f89",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[346, 347, 347, 347, 348]"
      ]
     },
     "execution_count": 49,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x[1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "id": "e2b9b0a6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[[0.2863, 0.2863, 0.2863,  ..., 0.3490, 0.3490, 0.3490],\n",
       "         [0.2863, 0.2863, 0.2863,  ..., 0.3490, 0.3490, 0.3490],\n",
       "         [0.2863, 0.2863, 0.2863,  ..., 0.3490, 0.3490, 0.3490],\n",
       "         ...,\n",
       "         [0.1922, 0.1922, 0.1922,  ..., 0.0706, 0.0706, 0.0706],\n",
       "         [0.1922, 0.1922, 0.1922,  ..., 0.0745, 0.0706, 0.0706],\n",
       "         [0.1922, 0.1922, 0.1922,  ..., 0.0784, 0.0784, 0.0745]],\n",
       "\n",
       "        [[0.2510, 0.2510, 0.2510,  ..., 0.3529, 0.3529, 0.3529],\n",
       "         [0.2510, 0.2510, 0.2510,  ..., 0.3529, 0.3529, 0.3529],\n",
       "         [0.2510, 0.2510, 0.2510,  ..., 0.3529, 0.3529, 0.3529],\n",
       "         ...,\n",
       "         [0.1765, 0.1765, 0.1765,  ..., 0.0627, 0.0627, 0.0627],\n",
       "         [0.1765, 0.1765, 0.1765,  ..., 0.0667, 0.0627, 0.0627],\n",
       "         [0.1765, 0.1765, 0.1765,  ..., 0.0706, 0.0706, 0.0667]],\n",
       "\n",
       "        [[0.2275, 0.2275, 0.2275,  ..., 0.3216, 0.3216, 0.3216],\n",
       "         [0.2275, 0.2275, 0.2275,  ..., 0.3216, 0.3216, 0.3216],\n",
       "         [0.2275, 0.2275, 0.2275,  ..., 0.3216, 0.3216, 0.3216],\n",
       "         ...,\n",
       "         [0.1529, 0.1529, 0.1529,  ..., 0.0549, 0.0667, 0.0667],\n",
       "         [0.1529, 0.1529, 0.1529,  ..., 0.0588, 0.0549, 0.0549],\n",
       "         [0.1529, 0.1529, 0.1529,  ..., 0.0627, 0.0627, 0.0588]]])"
      ]
     },
     "execution_count": 50,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x[0][2]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "051e5739",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python [conda env:root] *",
   "language": "python",
   "name": "conda-root-py"
  },
  "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.10.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
