# Copyright (c) Meta Platforms, Inc. and affiliates.

# link to the dataset folder, model weights and the config file.
export DETECTRON2_DATASETS=/data/xxx/datasets
# model_weights="http://dl.fbaipublicfiles.com/cutler/checkpoints/cutler_cascade_final.pth"
# model_weights="output/model_final.pth"
model_weights="../checkpoints/cutler_cascade_final.pth"
config_file="model_zoo/configs/CutLER-ImageNet/cascade_mask_rcnn_R_50_FPN.yaml"
num_gpus=1
export CUDA_VISIBLE_DEVICES=0
# ------
python cutler/train_net.py \
    --config-file cutler/model_zoo/configs/CutLER-ImageNet/cascade_mask_rcnn_R_50_FPN.yaml \
    --num-gpus 1 \
    --eval-only \
    --test-dataset cls_agnostic_coco \
    MODEL.WEIGHTS output/cutler-official/model_0099999.pth \
    OUTPUT_DIR output/cutler-official
# ------
python cutler/train_net.py \
    --config-file cutler/model_zoo/configs/CutOnce-ImageNet/cascade_mask_rcnn_R_50_FPN.yaml \
    --num-gpus 1 \
    --eval-only \
    --test-dataset cls_agnostic_clipart \
    MODEL.WEIGHTS output/cutonce_imagenet_val/model_0004999.pth \
    OUTPUT_DIR output/output_coco_val_2017

python cutler/train_net.py \
    --config-file cutler/model_zoo/configs/CutLER-ImageNet/cascade_mask_rcnn_R_50_FPN.yaml \
    --num-gpus 1 \

nohup  python cutler/train_net.py \
    --config-file cutler/model_zoo/configs/CutLER-ImageNet/cascade_mask_rcnn_R_50_FPN.yaml \
    --num-gpus 1 --resume &

python cutler/train_net.py \
    --config-file cutler/model_zoo/configs/CutOnce-ImageNet/cascade_mask_rcnn_R_50_FPN.yaml \
    --num-gpus 1 \
    --eval-only \
    MODEL.WEIGHTS output/cutonce_imagenet_val/model_final.pth
# test_dataset='cls_agnostic_coco'
# echo "========== evaluating ${test_dataset} =========="
# python train_net.py --num-gpus ${num_gpus} \
#   --config-file ${config_file} \
#   --test-dataset ${test_dataset} \
#   --eval-only MODEL.WEIGHTS ${model_weights}

# test_dataset='cls_agnostic_voc'
# echo "========== evaluating ${test_dataset} =========="
# python train_net.py --num-gpus ${num_gpus} \
#   --config-file ${config_file} \
#   --test-dataset ${test_dataset} --no-segm \
#   --eval-only MODEL.WEIGHTS ${model_weights}

# test_dataset='cls_agnostic_lvis'
# echo "========== evaluating ${test_dataset} =========="
# # LVIS should set TEST.DETECTIONS_PER_IMAGE=300
# python train_net.py --num-gpus ${num_gpus} \
#   --config-file ${config_file} \
#   --test-dataset ${test_dataset} \
#   --eval-only MODEL.WEIGHTS ${model_weights} TEST.DETECTIONS_PER_IMAGE 300

# Available datasets are: coco_2014_train, coco_2014_val, coco_2014_minival, coco_2014_valminusminival, coco_2017_train, coco_2017_val, coco_2017_test, coco_2017_test-dev, coco_2017_val_100, keypoints_coco_2014_train, keypoints_coco_2014_val, keypoints_coco_2014_minival, keypoints_coco_2014_valminusminival, keypoints_coco_2017_train, keypoints_coco_2017_val, keypoints_coco_2017_val_100, coco_2017_train_panoptic_separated, coco_2017_train_panoptic_stuffonly, coco_2017_train_panoptic, coco_2017_val_panoptic_separated, coco_2017_val_panoptic_stuffonly, coco_2017_val_panoptic, coco_2017_val_100_panoptic_separated, coco_2017_val_100_panoptic_stuffonly, coco_2017_val_100_panoptic, lvis_v1_train, lvis_v1_val, lvis_v1_test_dev, lvis_v1_test_challenge, lvis_v0.5_train, lvis_v0.5_val, lvis_v0.5_val_rand_100, lvis_v0.5_test, lvis_v0.5_train_cocofied, lvis_v0.5_val_cocofied, cityscapes_fine_instance_seg_train, cityscapes_fine_sem_seg_train, cityscapes_fine_instance_seg_val, cityscapes_fine_sem_seg_val, cityscapes_fine_instance_seg_test, cityscapes_fine_sem_seg_test, cityscapes_fine_panoptic_train, cityscapes_fine_panoptic_val, voc_2007_trainval, voc_2007_train, voc_2007_val, voc_2007_test, voc_2012_trainval, voc_2012_train, voc_2012_val, ade20k_sem_seg_train, ade20k_sem_seg_val, coco_semi_1perc, coco_semi_2perc, coco_semi_5perc, coco_semi_10perc, coco_semi_20perc, coco_semi_30perc, coco_semi_40perc, coco_semi_50perc, coco_semi_60perc, coco_semi_80perc, cls_agnostic_coco, cls_agnostic_coco20k, imagenet_train, imagenet_train_r1, imagenet_train_r2, imagenet_train_r3, cls_agnostic_uvo, cls_agnostic_voc, cls_agnostic_clipart, cls_agnostic_watercolor, cls_agnostic_comic, cls_agnostic_kitti, cls_agnostic_openimages, cls_agnostic_objects365, cls_agnostic_lvis"

exit 0
echo "========== start evaluating the model on all 11 datasets =========="

test_dataset='cls_agnostic_clipart'
echo "========== evaluating ${test_dataset} =========="
python train_net.py --num-gpus ${num_gpus} \
  --config-file ${config_file} \
  --test-dataset ${test_dataset} --no-segm \
  --eval-only MODEL.WEIGHTS ${model_weights}

test_dataset='cls_agnostic_watercolor'
echo "========== evaluating ${test_dataset} =========="
python train_net.py --num-gpus ${num_gpus} \
  --config-file ${config_file} \
  --test-dataset ${test_dataset} --no-segm \
  --eval-only MODEL.WEIGHTS ${model_weights}

test_dataset='cls_agnostic_comic'
echo "========== evaluating ${test_dataset} =========="
python train_net.py --num-gpus ${num_gpus} \
  --config-file ${config_file} \
  --test-dataset ${test_dataset} --no-segm \
  --eval-only MODEL.WEIGHTS ${model_weights}

test_dataset='cls_agnostic_voc'
echo "========== evaluating ${test_dataset} =========="
python train_net.py --num-gpus ${num_gpus} \
  --config-file ${config_file} \
  --test-dataset ${test_dataset} --no-segm \
  --eval-only MODEL.WEIGHTS ${model_weights}

test_dataset='cls_agnostic_objects365'
echo "========== evaluating ${test_dataset} =========="
python train_net.py --num-gpus ${num_gpus} \
  --config-file ${config_file} \
  --test-dataset ${test_dataset} --no-segm \
  --eval-only MODEL.WEIGHTS ${model_weights}

test_dataset='cls_agnostic_openimages'
echo "========== evaluating ${test_dataset} =========="
python train_net.py --num-gpus ${num_gpus} \
  --config-file ${config_file} \
  --test-dataset ${test_dataset} --no-segm \
  --eval-only MODEL.WEIGHTS ${model_weights}

test_dataset='cls_agnostic_kitti'
echo "========== evaluating ${test_dataset} =========="
python train_net.py --num-gpus ${num_gpus} \
  --config-file ${config_file} \
  --test-dataset ${test_dataset} --no-segm \
  --eval-only MODEL.WEIGHTS ${model_weights}

test_dataset='cls_agnostic_coco'
echo "========== evaluating ${test_dataset} =========="
python train_net.py --num-gpus ${num_gpus} \
  --config-file ${config_file} \
  --test-dataset ${test_dataset} \
  --eval-only MODEL.WEIGHTS ${model_weights}

test_dataset='cls_agnostic_coco20k'
echo "========== evaluating ${test_dataset} =========="
python train_net.py --num-gpus ${num_gpus} \
  --config-file ${config_file} \
  --test-dataset ${test_dataset} \
  --eval-only MODEL.WEIGHTS ${model_weights}

test_dataset='cls_agnostic_lvis'
echo "========== evaluating ${test_dataset} =========="
# LVIS should set TEST.DETECTIONS_PER_IMAGE=300
python train_net.py --num-gpus ${num_gpus} \
  --config-file ${config_file} \
  --test-dataset ${test_dataset} \
  --eval-only MODEL.WEIGHTS ${model_weights} TEST.DETECTIONS_PER_IMAGE 300

test_dataset='cls_agnostic_uvo'
echo "========== evaluating ${test_dataset} =========="
python train_net.py --num-gpus ${num_gpus} \
  --config-file ${config_file} \
  --test-dataset ${test_dataset} \
  --eval-only MODEL.WEIGHTS ${model_weights}

echo "========== evaluation is completed =========="