# Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved
import torch.utils.data
import torchvision

from .coco import build as build_coco


def get_coco_api_from_dataset(dataset):
    for _ in range(10):
        # if isinstance(dataset, torchvision.datasets.CocoDetection):
        #     break
        if isinstance(dataset, torch.utils.data.Subset):
            dataset = dataset.dataset
    if isinstance(dataset, torchvision.datasets.CocoDetection):
        return dataset.coco


def build_dataset(image_set, args):
    if args.dataset_file == 'coco':
        return build_coco(image_set, args)
    if args.dataset_file == 'coco_panoptic':
        # to avoid making panopticapi required for coco
        from .coco_panoptic import build as build_coco_panoptic
        return build_coco_panoptic(image_set, args)
    if args.dataset_file == 'o365':
        from .o365 import build_o365_combine
        return build_o365_combine(image_set, args)
    if args.dataset_file == 'vanke':
        from .vanke import build_vanke
        return build_vanke(image_set, args)
    
    if args.dataset_file == 'measurement':
        from .villi_measurement import build_measurement
        return build_measurement(image_set, args)
    
    if args.dataset_file == 'measurement_start_end':
        from .villi_measurement_start_end import build_measurement
        return build_measurement(image_set, args)

    if args.dataset_file == 'measurement_polynomial':
        from .villi_measurement_polynomical import build_measurement
        return build_measurement(image_set, args)

    if args.dataset_file == 'measurement_augment':
        from .villi_measurement_augmentation import build_measurement
        return build_measurement(image_set, args)

    if args.dataset_file == 'measurement_augment_mask':
        from .villi_measurement_augmentation_mask import build_measurement
        return build_measurement(image_set, args)
    
    if args.dataset_file == 'measurement_augment_drop_mask':
        from .villi_measurement_augmentation_villi_drop_mask import build_measurement
        return build_measurement(image_set, args)

    if args.dataset_file == 'measurement_augment_mask_mixup':
        from .villi_measurement_augmentation_mask_mixup import build_measurement
        return build_measurement(image_set, args)

    if args.dataset_file == 'measurement_augment_mask_mixup_mid_point':
        from .villi_measurement_augmentation_mask_mixup_mid_point import build_measurement
        return build_measurement(image_set, args)

    if args.dataset_file == 'measurement_augment_rotate_mask_mixup_mid_point':
        from .villi_measurement_augmentation_rotate_mask_mixup_mid_point import build_measurement
        return build_measurement(image_set, args)
    
    raise ValueError(f'dataset {args.dataset_file} not supported')
