import os
import _init_paths
from pos_vis.vis_utils import visualizekpts

from pycocotools.coco import COCO as coco_17
from crowdposetools.coco import COCO as coco_14
from utils.rescore import COCORescoreEval 
from utils.rescore import CrowdRescoreEval

if __name__ == "__main__":
   visualizer = visualizekpts(dataset_name='coco',
                              subset_name='N.A.', 
                              dataset_type='val', 
                              gt_path='../datasets/coco/annotations/person_keypoints_val2017.json', 
                              img_dir='../datasets/coco/val2017', 
                              #dt_path='jsons/top_down/coco/val2017/vit_base.json',
                              #dt_path='output/vitbase_coco/rescored.json',
                              #dt_path='jsons/bottom_up/coco/val2017/dekr.json', 
                              #dt_path='jsons/one_stage/coco/val2017/edpose.json',
                              dt_path='output/coco/dekr_coco/rescored.json', 
                              method='dekr', 
                              dt_model_name='dekr')
   visualizer.evaluateDT()
   visualizer.analyze_one_image_DT(img_id=4134, outdir='test/dekr/4134/rescored')
   # #print(visualizer.evaluateDTScore())
   # visualizer.replaceWithRanks(outdir='test')

   # visualizer = visualizekpts(dataset_name='coco',
   #                            subset_name='N.A.', 
   #                            dataset_type='val', 
   #                            gt_path='../datasets/coco/annotations/person_keypoints_val2017.json', 
   #                            img_dir='../datasets/coco/val2017', 
   #                            #dt_path='jsons/top_down/coco/val2017/hrnet_w32.json',
   #                            #dt_path='test/new_dekr.json', 
   #                            #dt_path='jsons/one_stage/coco/val2017/edpose.json',
   #                            #dt_path='jsons/bottom_up/coco/val2017/dekr.json',
   #                            dt_path='output/hrnet_w32_coco/rescored.json',
   #                            #dt_path='output/vitbase_coco/rescored.json', 
   #                            #method='dekr', 
   #                            dt_model_name='dekr')
   # visualizer.evaluateDT()
   # print(visualizer.evaluateDTScoreV2())

   # visualizer = visualizekpts(dataset_name='coco',
   #                            subset_name='N.A.', 
   #                            dataset_type='val', 
   #                            gt_path='../datasets/coco/annotations/person_keypoints_train2017.json', 
   #                            img_dir='../datasets/coco/train2017', 
   #                            #dt_path='test/new_dekr.json', 
   #                            dt_path='jsons/bottom_up/coco/train2017/higherhrnet.json',
   #                            method='higherhrnet', 
   #                            dt_model_name='higherhrnet')
   # visualizer.evaluateDT()

   #coco
   # coco_gt = coco_17('../datasets/coco/annotations/person_keypoints_train2017.json')
   # coco_dt = coco_gt.loadRes('jsons/bottom_up/coco/train2017/higherhrnet.json')
   # coco_eval = COCORescoreEval(coco_gt, coco_dt, 'keypoints')
   # coco_eval.params.useSegm = None
   # coco_eval.evaluate()
   # coco_eval.dumpdataset('pkls/bottom_up/coco/train2017//higherhrnet.pkl')

   #exlpose-ocn
   # visualizer = visualizekpts(dataset_name='exlpose',
   #                            subset_name='N.A.', 
   #                            dataset_type='val', 
   #                            gt_path='../datasets/ExLPose/Annotations/ExLPose-OC_test_A7M3.json', 
   #                            img_dir='../datasets/ExLPose', 
   #                            dt_path='jsons/bottom_up/a7m3/swahr.json',
   #                            #dt_path='jsons/bottom_up/coco/val2017/swahr.json', 
   #                            #dt_path='jsons/one_stage/coco/val2017/edpose.json',
   #                            #dt_path='output/vitbase_coco/rescored.json', 
   #                            method='swahr', 
   #                            dt_model_name='swahr')
   # visualizer.evaluateDT()

   # coco_gt = coco_14('../datasets/ExLPose/Annotations/ExLPose-OC_test_A7M3.json')
   # coco_dt = coco_gt.loadRes('jsons/bottom_up/a7m3/swahr.json')
   # coco_eval = CrowdRescoreEval(coco_gt, coco_dt, 'keypoints')
   # coco_eval.params.useSegm = None
   # coco_eval.evaluate()
   # coco_eval.dumpdataset('pkls/bottom_up/a7m3/swahr.pkl')
   

   #visualizer = visualizekpts(dataset_name='crowdpose',
   #                            subset_name='N.A.', 
   #                            dataset_type='val', 
   #                            gt_path='../datasets/CrowdPose/annotations/crowdpose_trainval.json', 
   #                            img_dir='../datasets/images', 
   #                            #dt_path='jsons/top_down/coco/val2017/vit_base.json',
   #                            #dt_path='output/vitbase_coco/rescored.json',
   #                            dt_path='jsons/one_stage/crowdpose/trainval/edpose.json', 
   #                            #dt_path='jsons/one_stage/coco/val2017/edpose.json',
   #                            #dt_path='output/vitbase_coco/rescored.json', 
   #                            method='edpose', 
   #                            dt_model_name='edpose')
   # visualizer.evaluateDT()
   # # visualizer.analyze_one_image_DT(img_id=4134, outdir='test/dekr/4134/original')
   # #print(visualizer.evaluateDTScore())
   # visualizer.replaceWithRanks(outdir='test')

   # visualizer = visualizekpts(dataset_name='crowdpose',
   #                            subset_name='N.A.', 
   #                            dataset_type='val', 
   #                            gt_path='../datasets/CrowdPose/annotations/crowdpose_test.json', 
   #                            img_dir='../datasets/images', 
   #                            #dt_path='jsons/top_down/coco/val2017/vit_base.json',
   #                            #dt_path='output/vitbase_coco/rescored.json',
   #                            dt_path='test/new_pinet.json', 
   #                            #dt_path='jsons/one_stage/coco/val2017/edpose.json',
   #                            #dt_path='output/vitbase_coco/rescored.json', 
   #                            method='pinet', 
   #                            dt_model_name='pinet')
   # visualizer.evaluateDT()
   # coco_gt = coco_14('../datasets/CrowdPose/annotations/crowdpose_trainval.json')
   # coco_dt = coco_gt.loadRes('jsons/one_stage/crowdpose/trainval/edpose.json')
   # coco_eval = CrowdRescoreEval(coco_gt, coco_dt, 'keypoints')
   # coco_eval.params.useSegm = None
   # coco_eval.evaluate()
   # coco_eval.dumpdataset('pkls/one_stage/crowdpose/trainval/edpose.pkl')
