import os

import numpy as np
from lib.test.evaluation.data import Sequence, BaseDataset, SequenceList
from lib.test.utils.load_text import load_text


class EOTBDataset(BaseDataset):
    """ OTB-2015 dataset

    Publication:
        Object Tracking Benchmark
        Wu, Yi, Jongwoo Lim, and Ming-hsuan Yan
        TPAMI, 2015
        http://faculty.ucmerced.edu/mhyang/papers/pami15_tracking_benchmark.pdf

    Download the dataset from http://cvlab.hanyang.ac.kr/tracker_benchmark/index.html
    """

    def __init__(self):
        super().__init__()
        self.base_path = self.env_settings.eotb_path
        self.sequence_info_list = self._get_sequence_info_list()

    def get_sequence_list(self):
        return SequenceList([self._construct_sequence(s) for s in self.sequence_info_list])

    def _construct_sequence(self, sequence_info):
        sequence_path = sequence_info['path']
        nz = sequence_info['nz']
        ext = sequence_info['ext']
        start_frame = sequence_info['startFrame']
        end_frame = sequence_info['endFrame']
        frames = []
        init_omit = 0
        if 'initOmit' in sequence_info:
            init_omit = sequence_info['initOmit']
        for frame_num in range(start_frame + init_omit, end_frame + 1):
            seq_path = '{base_path}/{sequence_path}/'.format(base_path=self.base_path,sequence_path=sequence_path)
            # frames.append(os.path.join(seq_path, 'frame{:04}.png'.format(frame_num)))
            frames.append(os.path.join(seq_path, '{:04}_1.png'.format(frame_num + 1)))
            # frames.append(os.path.join(seq_path, '{:04}_3.png'.format(frame_num + 1)))

        anno_path = '{}/{}'.format(self.base_path, sequence_info['anno_path'])

        # NOTE: OTB has some weird annos which panda cannot handle
        ground_truth_rect = load_text(str(anno_path), delimiter=(',', None), dtype=np.float64, backend='numpy')

        return Sequence(sequence_info['name'], frames, 'eotb', ground_truth_rect[init_omit:, :],
                        object_class=sequence_info['object_class'])

    def __len__(self):
        return len(self.sequence_info_list)

    def _get_sequence_info_list(self):
        sequence_info_list = [   {'anno_path': 'airplane_mul222/groundtruth_rect.txt',
'endFrame': 2050,
'ext': 'png',
'name': 'airplane_mul222',
'nz': 4,
'object_class': 'object',
'path': 'airplane_mul222/inter1_stack_3008',
'startFrame': 0},
{'anno_path': 'bike222/groundtruth_rect.txt',
'endFrame': 1898 ,
'ext': 'png',
'name': 'bike222',
'nz': 4,
'object_class': 'object',
'path': 'bike222/inter1_stack_3008',
'startFrame': 0},
{'anno_path': 'bike333/groundtruth_rect.txt',
'endFrame': 2000,
'ext': 'png',
'name': 'bike333',
'nz': 4,
'object_class': 'object',
'path': 'bike333/inter1_stack_3008',
'startFrame': 0},
{'anno_path': 'bike_low/groundtruth_rect.txt',
'endFrame': 1289,
'ext': 'png',
'name': 'bike_low',
'nz': 4,
'object_class': 'object',
'path': 'bike_low/inter1_stack_3008',
'startFrame': 0},
{'anno_path': 'bottle_mul222/groundtruth_rect.txt',
'endFrame': 1100,
'ext': 'png',
'name': 'bottle_mul222',
'nz': 4,
'object_class': 'object',
'path': 'bottle_mul222/inter1_stack_3008',
'startFrame': 0},
{'anno_path': 'box_hdr/groundtruth_rect.txt',
'endFrame': 1947,
'ext': 'png',
'name': 'box_hdr',
'nz': 4,
'object_class': 'object',
'path': 'box_hdr/inter1_stack_3008',
'startFrame': 0},
                                 {'anno_path': 'box_low/groundtruth_rect.txt',
                                  'endFrame': 2083,
                                  'ext': 'png',
                                  'name': 'box_low',
                                  'nz': 4,
                                  'object_class': 'object',
                                  'path': 'box_low/inter1_stack_3008',
                                  'startFrame': 0},
                                 {'anno_path': 'cow_mul222/groundtruth_rect.txt',
                                  'endFrame': 2230,
                                  'ext': 'png',
                                  'name': 'cow_mul222',
                                  'nz': 4,
                                  'object_class': 'object',
                                  'path': 'cow_mul222/inter1_stack_3008',
                                  'startFrame': 0},
                                 {'anno_path': 'cup222/groundtruth_rect.txt',
                                  'endFrame': 2009,
                                  'ext': 'png',
                                  'name': 'cup222',
                                  'nz': 4,
                                  'object_class': 'object',
                                  'path': 'cup222/inter1_stack_3008',
                                  'startFrame': 0},
                                 {'anno_path': 'cup_low/groundtruth_rect.txt',
                                  'endFrame': 1932,
                                  'ext': 'png',
                                  'name': 'cup_low',
                                  'nz': 4,
                                  'object_class': 'object',
                                  'path': 'cup_low/inter1_stack_3008',
                                  'startFrame': 0},
                                 {'anno_path': 'dog/groundtruth_rect.txt',
                                  'endFrame': 641,
                                  'ext': 'png',
                                  'name': 'dog',
                                  'nz': 4,
                                  'object_class': 'object',
                                  'path': 'dog/inter1_stack_3008',
                                  'startFrame': 0},
                                 {'anno_path': 'dog_motion/groundtruth_rect.txt',
                                  'endFrame': 2787,
                                  'ext': 'png',
                                  'name': 'dog_motion',
                                  'nz': 4,
                                  'object_class': 'object',
                                  'path': 'dog_motion/inter1_stack_3008',
                                  'startFrame': 0},
                                 {'anno_path': 'dove_motion/groundtruth_rect.txt',
                                  'endFrame': 2201,
                                  'ext': 'png',
                                  'name': 'dove_motion',
                                  'nz': 4,
                                  'object_class': 'object',
                                  'path': 'dove_motion/inter1_stack_3008',
                                  'startFrame': 0},
                                 {'anno_path': 'dove_mul/groundtruth_rect.txt',
                                  'endFrame': 1929,
                                  'ext': 'png',
                                  'name': 'dove_mul',
                                  'nz': 4,
                                  'object_class': 'object',
                                  'path': 'dove_mul/inter1_stack_3008',
                                  'startFrame': 0},
                                 {'anno_path': 'dove_mul222/groundtruth_rect.txt',
                                  'endFrame': 1296,
                                  'ext': 'png',
                                  'name': 'dove_mul222',
                                  'nz': 4,
                                  'object_class': 'object',
                                  'path': 'dove_mul222/inter1_stack_3008',
                                  'startFrame': 0},
                                 {'anno_path': 'elephant222/groundtruth_rect.txt',
                                  'endFrame': 2289,
                                  'ext': 'png',
                                  'name': 'elephant222',
                                  'nz': 4,
                                  'object_class': 'object',
                                  'path': 'elephant222/inter1_stack_3008',
                                  'startFrame': 0},
                                 {'anno_path': 'fighter_mul/groundtruth_rect.txt',
                                  'endFrame': 1999,
                                  'ext': 'png',
                                  'name': 'fighter_mul',
                                  'nz': 4,
                                  'object_class': 'object',
                                  'path': 'fighter_mul/inter1_stack_3008',
                                  'startFrame': 0},
                                 {'anno_path': 'giraffe222/groundtruth_rect.txt',
                                  'endFrame': 2389,
                                  'ext': 'png',
                                  'name': 'giraffe222',
                                  'nz': 4,
                                  'object_class': 'object',
                                  'path': 'giraffe222/inter1_stack_3008',
                                  'startFrame': 0},
                                 {'anno_path': 'giraffe_low/groundtruth_rect.txt',
                                  'endFrame': 2266,
                                  'ext': 'png',
                                  'name': 'giraffe_low',
                                  'nz': 4,
                                  'object_class': 'object',
                                  'path': 'giraffe_low/inter1_stack_3008',
                                  'startFrame': 0},
                                 {'anno_path': 'giraffe_motion/groundtruth_rect.txt',
                                  'endFrame': 1499,
                                  'ext': 'png',
                                  'name': 'giraffe_motion',
                                  'nz': 4,
                                  'object_class': 'object',
                                  'path': 'giraffe_motion/inter1_stack_3008',
                                  'startFrame': 0},
                                 {'anno_path': 'ship/groundtruth_rect.txt',
                                  'endFrame': 966,
                                  'ext': 'png',
                                  'name': 'ship',
                                  'nz': 4,
                                  'object_class': 'object',
                                  'path': 'ship/inter1_stack_3008',
                                  'startFrame': 0},
                                 {'anno_path': 'ship_motion/groundtruth_rect.txt',
                                  'endFrame': 2300,
                                  'ext': 'png',
                                  'name': 'ship_motion',
                                  'nz': 4,
                                  'object_class': 'object',
                                  'path': 'ship_motion/inter1_stack_3008',
                                  'startFrame': 0},
                                 {'anno_path': 'star/groundtruth_rect.txt',
                                  'endFrame': 1155,
                                  'ext': 'png',
                                  'name': 'star',
                                  'nz': 4,
                                  'object_class': 'object',
                                  'path': 'star/inter1_stack_3008',
                                  'startFrame': 0},
                                 {'anno_path': 'star_motion/groundtruth_rect.txt',
                                  'endFrame': 2121,
                                  'ext': 'png',
                                  'name': 'star_motion',
                                  'nz': 4,
                                  'object_class': 'object',
                                  'path': 'star_motion/inter1_stack_3008',
                                  'startFrame': 0},
                                 {'anno_path': 'star_mul/groundtruth_rect.txt',
                                  'endFrame': 2159,
                                  'ext': 'png',
                                  'name': 'star_mul',
                                  'nz': 4,
                                  'object_class': 'object',
                                  'path': 'star_mul/inter1_stack_3008',
                                  'startFrame': 0},
                                 {'anno_path': 'star_mul222/groundtruth_rect.txt',
                                  'endFrame': 2035,
                                  'ext': 'png',
                                  'name': 'star_mul222',
                                  'nz': 4,
                                  'object_class': 'object',
                                  'path': 'star_mul222/inter1_stack_3008',
                                  'startFrame': 0},
                                 {'anno_path': 'tank_low/groundtruth_rect.txt',
                                  'endFrame': 2275,
                                  'ext': 'png',
                                  'name': 'tank_low',
                                  'nz': 4,
                                  'object_class': 'object',
                                  'path': 'tank_low/inter1_stack_3008',
                                  'startFrame': 0},
                                 {'anno_path': 'tower/groundtruth_rect.txt',
                                  'endFrame': 1143,
                                  'ext': 'png',
                                  'name': 'tower',
                                  'nz': 4,
                                  'object_class': 'object',
                                  'path': 'tower/inter1_stack_3008',
                                  'startFrame': 0},
                                 {'anno_path': 'tower333/groundtruth_rect.txt',
                                  'endFrame': 2400,
                                  'ext': 'png',
                                  'name': 'tower333',
                                  'nz': 4,
                                  'object_class': 'object',
                                  'path': 'tower333/inter1_stack_3008',
                                  'startFrame': 0},
                                 {'anno_path': 'truck/groundtruth_rect.txt',
                                  'endFrame': 1130,
                                  'ext': 'png',
                                  'name': 'truck',
                                  'nz': 4,
                                  'object_class': 'object',
                                  'path': 'truck/inter1_stack_3008',
                                  'startFrame': 0},
                                 {'anno_path': 'truck_hdr/groundtruth_rect.txt',
                                  'endFrame': 1968,
                                  'ext': 'png',
                                  'name': 'truck_hdr',
                                  'nz': 4,
                                  'object_class': 'object',
                                  'path': 'truck_hdr/inter1_stack_3008',
                                  'startFrame': 0},
                                 {'anno_path': 'whale_mul222/groundtruth_rect.txt',
                                  'endFrame': 2170,
                                  'ext': 'png',
                                  'name': 'whale_mul222',
                                  'nz': 4,
                                  'object_class': 'object',
                                  'path': 'whale_mul222/inter1_stack_3008',
                                  'startFrame': 0}
        ]
        return sequence_info_list


