import numpy as np
import os
import torch

##### 1) claculate the inst type to optimized res ######
##### 2) calcualte the object type to optimized res ######


@torch.jit.script
def quat_mul(a, b):
    assert a.shape == b.shape
    shape = a.shape
    a = a.reshape(-1, 4)
    b = b.reshape(-1, 4)

    x1, y1, z1, w1 = a[:, 0], a[:, 1], a[:, 2], a[:, 3]
    x2, y2, z2, w2 = b[:, 0], b[:, 1], b[:, 2], b[:, 3]
    ww = (z1 + x1) * (x2 + y2)
    yy = (w1 - y1) * (w2 + z2)
    zz = (w1 + y1) * (w2 - z2)
    xx = ww + yy + zz
    qq = 0.5 * (xx + (z1 - x1) * (x2 - y2))
    w = qq - ww + (z1 - y1) * (y2 - z2)
    x = qq - xx + (x1 + w1) * (x2 + w2)
    y = qq - yy + (w1 - x1) * (y2 + z2)
    z = qq - zz + (z1 + y1) * (w2 - x2)

    quat = torch.stack([x, y, z, w], dim=-1).view(shape)

    return quat


@torch.jit.script
def quat_conjugate(a):
    shape = a.shape
    a = a.reshape(-1, 4)
    return torch.cat((-a[:, :3], a[:, -1:]), dim=-1).view(shape)


def parse_obj_type_fr_folder_name(folder_nm):
    # /root/diffsim/IsaacGymEnvs2/isaacgymenvs/runs/tracking_ori_grab_s2_hammer_use_1_obs_pure_state_wref_density_500.0_trans_1.0_rot_1.0_goalcond_False_kinebias_t1r1_rewfingerdist_0.5_rewdeltahandpose_0.0_10-17-19-17
    folder_st_tag = "tracking_"
    remains_folder_nm = folder_nm.split("/")[-1][len(folder_st_tag): ]
    
    folder_nm_segs = remains_folder_nm.split("_")
    st_idx = 0
    for ed_idx in range(st_idx, len(folder_nm_segs)):
        cur_seg = folder_nm_segs[ed_idx]
        if cur_seg == 'obs' or cur_seg == 'leap':
            break
    obj_type = folder_nm_segs[st_idx: ed_idx]
    obj_type = "_".join(obj_type)
    return obj_type

def find_best_rew(folder_nm):
    nn_folder = os.path.join(folder_nm, "nn")
    if not os.path.exists(nn_folder):
        return -9999.9, None
    tot_ckpts = os.listdir(nn_folder)
    tot_ckpts = [
        fn for fn in tot_ckpts if fn.endswith(".pth")
    ]
    tot_rews = []
    cur_best_rew = -9999.9
    best_ckpt_fn = None
    for cur_ckpt_fn in tot_ckpts:
        # cur_full_ckpt_fn = os.path.join(nn_folder, cur_ckpt_fn)
        cur_ckpt_pure_fn = cur_ckpt_fn.split(".pth")[0]
        cur_ckpt_pure_fn_segs = cur_ckpt_pure_fn.split("_")
        try:
            if len(cur_ckpt_pure_fn_segs[-1]) == 0:
                cur_rew = float(cur_ckpt_pure_fn_segs[-2])
            else:
                cur_rew = float(cur_ckpt_pure_fn_segs[-1])
        except:
            print(cur_ckpt_pure_fn_segs)
            continue
        tot_rews.append(cur_rew)
        if cur_rew > cur_best_rew:
            cur_best_rew = cur_rew
            best_ckpt_fn = os.path.join(nn_folder, cur_ckpt_fn)
    # maxx_rew = max(tot_rews)
    # 
    return cur_best_rew, best_ckpt_fn
    


def get_obj_type_to_optimized_res(optimized_root_folder):
    tot_folders = os.listdir(optimized_root_folder)
    tracking_st_tag = 'tracking_'
    tot_folders = [
        fn for fn in tot_folders if fn[: len(tracking_st_tag)] == tracking_st_tag
    ]
    obj_type_to_optimized_res = {}
    for i_exp, cur_folder in enumerate(tot_folders):
        print(f"[{i_exp}/{len(tot_folders)}] cur_folder: {cur_folder}")
        cur_full_folder = os.path.join(optimized_root_folder, cur_folder)
        cur_obj_type = parse_obj_type_fr_folder_name(cur_full_folder)
        
        cur_best_rew, best_ckpt_fn = find_best_rew(cur_full_folder)
        if best_ckpt_fn is None:
            continue
        obj_type_to_optimized_res[cur_obj_type] = (cur_best_rew, best_ckpt_fn)
    return obj_type_to_optimized_res

def calculate_optimized_res(optimized_data_sv_root):
    # optimized_data_sv_root = './uni_manip/isaacgym_rl_exp_grab' # args.optimized_data_sv_root

    ## get hte optimized res ##
    tracking_data_statistics_folder = os.path.join(optimized_data_sv_root, "statistics")
    os.makedirs(tracking_data_statistics_folder, exist_ok=True)
    obj_type_to_optimized_res_sv_fn = "obj_type_to_optimized_res.npy"
    obj_type_to_optimized_res_sv_fn = os.path.join(tracking_data_statistics_folder, obj_type_to_optimized_res_sv_fn) 
    # if not os.path.exists(obj_type_to_optimized_res_sv_fn):
    obj_type_to_optimized_res = get_obj_type_to_optimized_res(optimized_data_sv_root) # get the tracking data sv root #
    print(f"obj_type_to_optimized_res: {obj_type_to_optimized_res}")
    np.save(obj_type_to_optimized_res_sv_fn, obj_type_to_optimized_res) # save the optimized res
    print(f"obj_type_to_optimized_res saved to {obj_type_to_optimized_res_sv_fn}")


def inspect_optimized_res(grab_inst_tag):
    tracking_data_statistics_folder = os.path.join(optimized_data_sv_root, "statistics")
    obj_type_to_optimized_res_sv_fn = "obj_type_to_optimized_res.npy"
    obj_type_to_optimized_res_sv_fn = os.path.join(tracking_data_statistics_folder, obj_type_to_optimized_res_sv_fn) 
    obj_type_to_optimized_res = np.load(obj_type_to_optimized_res_sv_fn, allow_pickle=True).item()
    cur_inst_optimized_res = obj_type_to_optimized_res[grab_inst_tag]
    print(cur_inst_optimized_res)
    
def mv_eval_data_to_eval_folder(eval_folder, forbid_tag=None):
    # 
    # 
    tracking_folder_st_tag = "tracking_"
    local_runs_folder = './runs'
    tot_runs_subfolder = os.listdir(local_runs_folder)
    tot_runs_subfolder = [
        fn for fn in tot_runs_subfolder if fn[: len(tracking_folder_st_tag)] == tracking_folder_st_tag
    ]
    for cur_run_subfolder in tot_runs_subfolder:
        cur_full_run_subfolder = os.path.join(local_runs_folder, cur_run_subfolder)
        run_subfolder_nn_folder = os.path.join(cur_full_run_subfolder, "nn")
        if forbid_tag is not None and forbid_tag in cur_run_subfolder:
            continue
        if not os.path.exists(run_subfolder_nn_folder): # 
            print(f"mv {cur_full_run_subfolder} {eval_folder}/")
            os.system(f"mv {cur_full_run_subfolder} {eval_folder}/")
    pass

def mv_training_data_to_folder(training_data_target_folder, nf=150):
    tracking_folder_st_tag = "tracking_"
    local_runs_folder = './runs'
    tot_runs_subfolder = os.listdir(local_runs_folder)
    tot_runs_subfolder = [
        fn for fn in tot_runs_subfolder if fn[: len(tracking_folder_st_tag)] == tracking_folder_st_tag
    ]
    for cur_run_subfolder in tot_runs_subfolder:
        cur_full_run_subfolder = os.path.join(local_runs_folder, cur_run_subfolder)
        run_subfolder_nn_folder = os.path.join(cur_full_run_subfolder, "nn")
        if not os.path.exists(run_subfolder_nn_folder):
            continue
        if nf == 150:
            if '_nf_' in cur_run_subfolder:
                continue
        else:
            nf_tag = f'_nf_{nf}_'
            if nf_tag not in cur_run_subfolder:
                continue
        print(f"mv {cur_full_run_subfolder} {training_data_target_folder}/")
        os.system(f"mv {cur_full_run_subfolder} {training_data_target_folder}/")
    pass

def get_data_inst_tag_to_optimized_res(eval_data_folder):
    tot_runs_subfolder = os.listdir(eval_data_folder)
    # ./uni_manip/isaacgym_rl_exp_grab_eval/tracking_ori_grab_s2_duck_inspect_1_obs_pure_state_wref_wdelta_density_500.0_trans_0.5_rot_0.5_goalcond_False_kinebias_t0.5r0.5f20_rfd_0.3_rh_0.5_12-23-05-11
    tracking_folder_st_tag = 'tracking_'
    obs_tag = 'obs_pure_state_wref_wdelta'
    tot_runs_subfolder = [
        fn for fn in tot_runs_subfolder if fn[: len(tracking_folder_st_tag)] == tracking_folder_st_tag
    ]
    tot_runs_subfolder = [
        fn for fn in tot_runs_subfolder if obs_tag in fn
    ]
    tot_runs_subfolder = [
        fn for fn in tot_runs_subfolder if (not os.path.exists(os.path.join(eval_data_folder, fn, "nn")) )
    ]
    traj_sv_fn = "ts_to_hand_obj_obs_reset_1.npy"
    tot_runs_subfolder = [
        fn for fn in tot_runs_subfolder if os.path.exists(os.path.join(eval_data_folder, fn, traj_sv_fn))
    ]
    data_inst_tag_to_optimized_res = {}
    for i_test, cur_run_subfolder in enumerate(tot_runs_subfolder):
        cur_full_run_subfolder = os.path.join(eval_data_folder, cur_run_subfolder)
        cur_obj_type = parse_obj_type_fr_folder_name(cur_full_run_subfolder)
        
        # ./uni_manip/isaacgym_rl_exp_grab_eval/tracking_ori_grab_s2_duck_inspect_1_obs_pure_state_wref_wdelta_density_500.0_trans_0.5_rot_0.5_goalcond_False_kinebias_t0.5r0.5f20_rfd_0.3_rh_0.5_12-23-05-11/ts_to_hand_obj_obs_reset_1.npy
        cur_run_traj_sv_fn = os.path.join(cur_full_run_subfolder, traj_sv_fn)
        
        print(f"[{i_test}/{len(tot_runs_subfolder)}] cur_run_subfolder: {cur_run_subfolder}")
        
        # try:
        #     cur_cur_traj_sv_info = np.load(cur_run_traj_sv_fn, allow_pickle=True).item()
        # except:
        #     continue
        
        # if 0 not in cur_cur_traj_sv_info:
        #     continue
        # first_fr_sv_res = cur_cur_traj_sv_info[0]
        # if 'shadow_hand_dof_tars' not in first_fr_sv_res:
        #     continue
        
        # if 'optimized_hand_qtars' not in cur_cur_traj_sv_info:
        #     continue
        
        cur_grab_exp_tag = (cur_obj_type, cur_obj_type)
        if cur_grab_exp_tag not in data_inst_tag_to_optimized_res:
            data_inst_tag_to_optimized_res[cur_grab_exp_tag] = [cur_run_traj_sv_fn]
        else:
            data_inst_tag_to_optimized_res[cur_grab_exp_tag].append(cur_run_traj_sv_fn) # get the run traj sv fn #
        print(f"len(data_inst_tag_to_optimized_res): {len(data_inst_tag_to_optimized_res)}")
        # 
    
    data_inst_tag_to_optimized_res_sv_statistics_folder = "statistics"
    data_inst_tag_to_optimized_res_sv_statistics_folder = os.path.join(eval_data_folder, data_inst_tag_to_optimized_res_sv_statistics_folder)
    os.makedirs(data_inst_tag_to_optimized_res_sv_statistics_folder, exist_ok=True)
    data_inst_tag_to_optimized_res_sv_statistics_fn = "data_inst_tag_to_optimized_res.npy"
    data_inst_tag_to_optimized_res_sv_statistics_fn = os.path.join(data_inst_tag_to_optimized_res_sv_statistics_folder, data_inst_tag_to_optimized_res_sv_statistics_fn)
    np.save(data_inst_tag_to_optimized_res_sv_statistics_fn, data_inst_tag_to_optimized_res)
    print(f"data_inst_tag_to_optimized_res saved to {data_inst_tag_to_optimized_res_sv_statistics_fn}")
    return data_inst_tag_to_optimized_res
        
    #     cur_best_rew, best_ckpt_fn = find_best_rew(cur_full_run_subfolder)
        
    #     if best_ckpt_fn is None:
    #         continue
    #     data_inst_tag_to_optimized_res[cur_obj_type] = (cur_best_rew, best_ckpt_fn)
    # return data_inst_tag_to_optimized_res



# parse_obj_type_traj_type_fr_folder_name

def get_data_inst_tag_to_optimized_res_obj_traj(eval_data_folder):
    tot_runs_subfolder = os.listdir(eval_data_folder)
    # ./uni_manip/isaacgym_rl_exp_grab_eval/tracking_ori_grab_s2_duck_inspect_1_obs_pure_state_wref_wdelta_density_500.0_trans_0.5_rot_0.5_goalcond_False_kinebias_t0.5r0.5f20_rfd_0.3_rh_0.5_12-23-05-11
    tracking_folder_st_tag = 'tracking_'
    obs_tag = 'obs_pure_state_wref_wdelta'
    tot_runs_subfolder = [
        fn for fn in tot_runs_subfolder if fn[: len(tracking_folder_st_tag)] == tracking_folder_st_tag
    ]
    tot_runs_subfolder = [
        fn for fn in tot_runs_subfolder if obs_tag in fn
    ]
    tot_runs_subfolder = [
        fn for fn in tot_runs_subfolder if (not os.path.exists(os.path.join(eval_data_folder, fn, "nn")) )
    ]
    traj_sv_fn = "ts_to_hand_obj_obs_reset_1.npy"
    tot_runs_subfolder = [
        fn for fn in tot_runs_subfolder if os.path.exists(os.path.join(eval_data_folder, fn, traj_sv_fn))
    ]
    data_inst_tag_to_optimized_res = {}
    for i_test, cur_run_subfolder in enumerate(tot_runs_subfolder):
        cur_full_run_subfolder = os.path.join(eval_data_folder, cur_run_subfolder)
        cur_obj_type, cur_traj_type = parse_obj_type_traj_type_fr_folder_name(cur_full_run_subfolder)
        
        # ./uni_manip/isaacgym_rl_exp_grab_eval/tracking_ori_grab_s2_duck_inspect_1_obs_pure_state_wref_wdelta_density_500.0_trans_0.5_rot_0.5_goalcond_False_kinebias_t0.5r0.5f20_rfd_0.3_rh_0.5_12-23-05-11/ts_to_hand_obj_obs_reset_1.npy
        cur_run_traj_sv_fn = os.path.join(cur_full_run_subfolder, traj_sv_fn)
        
        print(f"[{i_test}/{len(tot_runs_subfolder)}] cur_run_subfolder: {cur_run_subfolder}")
        
        
        
        cur_grab_exp_tag = (cur_obj_type, cur_traj_type)
        if cur_grab_exp_tag not in data_inst_tag_to_optimized_res:
            data_inst_tag_to_optimized_res[cur_grab_exp_tag] = [cur_run_traj_sv_fn]
        else:
            data_inst_tag_to_optimized_res[cur_grab_exp_tag].append(cur_run_traj_sv_fn) # get the run traj sv fn #
        print(f"len(data_inst_tag_to_optimized_res): {len(data_inst_tag_to_optimized_res)}")
        # 
    
    data_inst_tag_to_optimized_res_sv_statistics_folder = "statistics"
    data_inst_tag_to_optimized_res_sv_statistics_folder = os.path.join(eval_data_folder, data_inst_tag_to_optimized_res_sv_statistics_folder)
    os.makedirs(data_inst_tag_to_optimized_res_sv_statistics_folder, exist_ok=True)
    data_inst_tag_to_optimized_res_sv_statistics_fn = "data_inst_tag_to_optimized_res.npy"
    data_inst_tag_to_optimized_res_sv_statistics_fn = os.path.join(data_inst_tag_to_optimized_res_sv_statistics_folder, data_inst_tag_to_optimized_res_sv_statistics_fn)
    np.save(data_inst_tag_to_optimized_res_sv_statistics_fn, data_inst_tag_to_optimized_res)
    print(f"data_inst_tag_to_optimized_res saved to {data_inst_tag_to_optimized_res_sv_statistics_fn}")
    return data_inst_tag_to_optimized_res
        


def inspect_data_inst_tag_to_optimized_res(data_inst_tag_to_optimized_res_fn):
    data_inst_tag_to_res = np.load(data_inst_tag_to_optimized_res_fn, allow_pickle=True).item()
    res_nn_to_exp_nn = {}
    for inst_tag in data_inst_tag_to_res:
        cur_inst_tag_optimized_res = data_inst_tag_to_res[inst_tag]
        print(inst_tag, len(cur_inst_tag_optimized_res))
        cur_nn_res = len(cur_inst_tag_optimized_res)
        if cur_nn_res not in res_nn_to_exp_nn:
            res_nn_to_exp_nn[cur_nn_res] = 1
        else:
            res_nn_to_exp_nn[cur_nn_res] += 1
    print(res_nn_to_exp_nn)




def calculate_obj_traj_diffs(opt_obj_pose, kine_obj_pose):
    # nn_frames x 7 --- for opt obj pose and the kine obj pose # 
    tot_frame_diffs = []
    tot_data_nn_frs = min(opt_obj_pose.shape[0], kine_obj_pose.shape[0])
    
    opt_obj_pose = opt_obj_pose[:tot_data_nn_frs]
    kine_obj_pose = kine_obj_pose[:tot_data_nn_frs]
    opt_obj_pos = opt_obj_pose[:, :3]
    kine_obj_pos = kine_obj_pose[:, :3]
    opt_obj_ornt = opt_obj_pose[:, 3: ]
    kine_obj_ornt = kine_obj_pose[:, 3: ]
    # diff_obj_pos = np.linalg.norm(opt_obj_pos - kine_obj_pos, p= axis=-1)
    opt_obj_pos = torch.from_numpy(opt_obj_pos).float()
    kine_obj_pos = torch.from_numpy(kine_obj_pos).float()
    diff_obj_pos = torch.norm(opt_obj_pos - kine_obj_pos, p=2, dim=-1)
    diff_obj_pos = diff_obj_pos.mean().item()
    
    object_rot = torch.from_numpy(opt_obj_ornt).float()
    target_rot = torch.from_numpy(kine_obj_ornt).float()
    
    quat_diff = quat_mul(object_rot, quat_conjugate(target_rot))
    rot_dist = 2.0 * torch.asin(torch.clamp(torch.norm(quat_diff[:, 0:3], p=2, dim=-1), max=1.0))
    
    # # to the rotation angle in arc # # ./uni_manip/isaacgym_rl_exp_taco_400_train_wstatebased_wcustomidamping_realleap/statistics/obj_type_to_optimized_res.npy #
    rot_dist = rot_dist.mean().item() # averge rotation angle differences # []
    
    return diff_obj_pos, rot_dist
    
    # for i_fr in range(tot_data_nn_frs):
    #     cur_fr_opt_obj_pose = opt_obj_pose[i_fr]
    #     cur_fr_kine_obj_pose = kine_obj_pose[i_fr]
    #     cur_fr_opt_obj_pos, cur_fr_opt_obj_ornt = cur_fr_opt_obj_pose[:3], cur_fr_opt_obj_pose[3: ]
    #     cur_fr_kine_obj_pos, cur_fr_kine_obj_ornt = cur_fr_kine_obj_pose[:3], cur_fr_kine_obj_pose[3: ] # kine obj pose # 
    #     cur_fr_diff_pos = np.linalg.norm(cur_fr_opt_obj_pos - cur_fr_kine_obj_pos)
        
    #     quat_diff = quat_mul(object_rot, quat_conjugate(target_rot))
    #     rot_dist = 2.0 * torch.asin(torch.clamp(torch.norm(quat_diff[:, 0:3], p=2, dim=-1), max=1.0))
    
        
        
    #     cur_fr_diff_ornt = np.linalg.norm(cur_fr_opt_obj_ornt - cur_fr_kine_obj_ornt)
    

def best_optimized_res(data_optimized_res_nn, data_inst_tag, index=None):
    optimized_res = np.load(data_optimized_res_nn, allow_pickle=True).item()
    
    if '_nf_300' in data_inst_tag:
        kinematics_data_root = "./data/GRAB_Tracking_PK/data"
    
    else:
        kinematics_data_root = "./data/GRAB_Tracking_PK_reduced/data"
    
    
    
    if data_inst_tag.endswith(".npy"):
        cur_inst_kine_data_fn = data_inst_tag
    else:
        cur_inst_kine_data_fn = f"passive_active_info_{data_inst_tag}.npy"
        cur_inst_kine_data_fn = os.path.join(kinematics_data_root, cur_inst_kine_data_fn)
    
    save_info = np.load(cur_inst_kine_data_fn, allow_pickle=True).item()
        
        
    # hand_qs = save_info['robot_delta_states_weights_np'][ : ]
    # hand_qs = hand_qs[: , : ]
    
    goal_obj_trans = save_info['object_transl']
    goal_obj_rot_quat = save_info['object_rot_quat']

    goal_obj_pose = np.concatenate(
        [goal_obj_trans, goal_obj_rot_quat],  axis=-1
    )
    
    tot_optimized_obj_pose = []
    tot_optimized_hand_qs = []
    tot_optimized_hand_qtars = []
    # object_pose
    tot_ts = list(optimized_res.keys())
    tot_ts = [ cur_ts for cur_ts in tot_ts if isinstance(cur_ts, int) ]
    tot_ts = sorted(tot_ts)
    
    tot_obs_buf = []
    
    for ts in tot_ts:
        cur_optimized_obj_pose = optimized_res[ts]['object_pose']
        tot_optimized_obj_pose.append(cur_optimized_obj_pose)
        
        cur_optimized_hand_qs = optimized_res[ts]['shadow_hand_dof_pos']
        cur_optimized_hand_qtars = optimized_res[ts]['shadow_hand_dof_tars']
        tot_optimized_hand_qs.append(cur_optimized_hand_qs)
        tot_optimized_hand_qtars.append(cur_optimized_hand_qtars)
        tot_obs_buf.append(optimized_res[ts]['observations'])
        
    tot_optimized_obj_pose = np.stack(tot_optimized_obj_pose, axis=1) # nn_envs x nn_ts x 7 #
    tot_optimized_hand_qs = np.stack(tot_optimized_hand_qs, axis=1)
    tot_optimized_hand_qtars = np.stack(tot_optimized_hand_qtars, axis=1)
    tot_obs_buf = np.stack(tot_obs_buf, axis=1)
    
    if index is not None:
        tot_optimized_obj_pose = tot_optimized_obj_pose[index: index + 1]
        tot_optimized_hand_qs = tot_optimized_hand_qs[index: index + 1]
        tot_optimized_hand_qtars = tot_optimized_hand_qtars[index: index + 1]
    
    tot_env_diff_obj_pos, tot_env_diff_obj_rot = [], []
    tot_env_weighted_obj_pose_diff = []
    w_pos, w_ornt = 1.0, 0.33
    for i_env in range(tot_optimized_obj_pose.shape[0]):
        cur_optimized_obj_pose = tot_optimized_obj_pose[i_env]
        cur_diff_obj_pos, cur_diff_obj_rot = calculate_obj_traj_diffs(cur_optimized_obj_pose, goal_obj_pose)
        tot_env_diff_obj_pos.append(cur_diff_obj_pos)
        tot_env_diff_obj_rot.append(cur_diff_obj_rot)
        weighted_diff_obj_pose = w_pos * cur_diff_obj_pos + w_ornt * cur_diff_obj_rot
        tot_env_weighted_obj_pose_diff.append(weighted_diff_obj_pose)
    
    tot_env_weighted_obj_pose_diff = np.array(tot_env_weighted_obj_pose_diff)
    sorted_envs_idxes = np.argsort(tot_env_weighted_obj_pose_diff)
    tot_env_diff_obj_pos = np.array(tot_env_diff_obj_pos)
    tot_env_diff_obj_rot = np.array(tot_env_diff_obj_rot)
    
    
    
    # top
    # obj_pos_diff of the object position errors #
    new_optimized_info = {
        'optimized_obj_pose': tot_optimized_obj_pose[sorted_envs_idxes],
        'optimized_hand_qs': tot_optimized_hand_qs[sorted_envs_idxes],
        'optimized_hand_qtars': tot_optimized_hand_qtars[sorted_envs_idxes],
        'obj_pose_diff': tot_env_weighted_obj_pose_diff[sorted_envs_idxes],
        'obj_pos_diff': tot_env_diff_obj_pos[sorted_envs_idxes],
        'obj_rot_diff': tot_env_diff_obj_rot[sorted_envs_idxes],
        'obs_buf': tot_obs_buf
    }
    return new_optimized_info
    
    
# runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__01-23-35-23/ts_to_hand_obj_obs_reset_1.npy
# obj_code_to_best_opt_res = inspect_optimized_res_nn_w_object_codes(data_optimized_res_nn)
def inspect_optimized_res_nn_w_object_codes(data_optimized_res_nn):
    optimized_res = np.load(data_optimized_res_nn, allow_pickle=True).item()
    env_object_codes = optimized_res['env_object_codes'] # 
    obj_codes_to_tot_optimized_res = {}
    # object_code_list, env_object_codes
    for i_env, env_obj_code in enumerate(env_object_codes):
        ## ge tthe env object poses #
        cur_env_obj_pose = []
        cur_env_hand_qs = []
        cur_env_hand_qtars = []
        tot_ts = list(optimized_res.keys())
        tot_ts = [ key for key in tot_ts if key != 'env_object_codes' and key != 'object_code_list' ]
        tot_ts = [ int(key)  for key in tot_ts ]
        tot_ts = sorted(tot_ts)
        for i_ts in tot_ts:
            cur_ts_res = optimized_res[i_ts] # optimized_res
            cur_ts_object_pose = cur_ts_res['object_pose']
            cur_ts_hand_dof_pos = cur_ts_res['shadow_hand_dof_pos']
            cur_ts_hand_dof_tars = cur_ts_res['shadow_hand_dof_tars']
            cur_env_obj_pose.append(cur_ts_object_pose[i_env])
            cur_env_hand_qs.append(cur_ts_hand_dof_pos[i_env])
            cur_env_hand_qtars.append(cur_ts_hand_dof_tars[i_env])
        cur_env_obj_pose = np.array(cur_env_obj_pose)
        cur_env_hand_qs = np.array(cur_env_hand_qs)
        cur_env_hand_qtars = np.array(cur_env_hand_qtars)
        if env_obj_code not in obj_codes_to_tot_optimized_res:
            obj_codes_to_tot_optimized_res[env_obj_code] = {
                'optimized_obj_pose': [cur_env_obj_pose],
                'optimized_hand_qs': [cur_env_hand_qs],
                'optimized_hand_qtars': [cur_env_hand_qtars]
            }
        else:
            obj_codes_to_tot_optimized_res[env_obj_code]['optimized_obj_pose'].append(cur_env_obj_pose)
            obj_codes_to_tot_optimized_res[env_obj_code]['optimized_hand_qs'].append(cur_env_hand_qs)
            obj_codes_to_tot_optimized_res[env_obj_code]['optimized_hand_qtars'].append(cur_env_hand_qtars)
    
    obj_code_to_best_opt_res = {}
    for obj_code in obj_codes_to_tot_optimized_res:
        kinematics_data_root = "./data/GRAB_Tracking_PK/data"
        cur_inst_kine_data_fn = f"passive_active_info_{obj_code}.npy"
        cur_inst_kine_data_fn = os.path.join(kinematics_data_root, cur_inst_kine_data_fn)
        save_info = np.load(cur_inst_kine_data_fn, allow_pickle=True).item()
        goal_obj_trans = save_info['object_transl']
        goal_obj_rot_quat = save_info['object_rot_quat']
        goal_obj_pose = np.concatenate(
            [goal_obj_trans, goal_obj_rot_quat],  axis=-1
        )
        
        
        cur_obj_optimized_obj_pose = np.stack(obj_codes_to_tot_optimized_res[obj_code]['optimized_obj_pose'], axis=0)
        cur_obj_optimized_hand_qs = np.stack(obj_codes_to_tot_optimized_res[obj_code]['optimized_hand_qs'], axis=0)
        cur_obj_optimized_hand_qtars = np.stack(obj_codes_to_tot_optimized_res[obj_code]['optimized_hand_qtars'], axis=0)
        
        tot_env_diff_obj_pos, tot_env_diff_obj_rot = [], []
        tot_env_weighted_obj_pose_diff = []
        # w_pos, w_ornt = 1.0, 0.33
        w_pos, w_ornt = 1.0, 0.0
        for i_env in range(cur_obj_optimized_obj_pose.shape[0]):
            cur_optimized_obj_pose = cur_obj_optimized_obj_pose[i_env]
            cur_diff_obj_pos, cur_diff_obj_rot = calculate_obj_traj_diffs(cur_optimized_obj_pose, goal_obj_pose)
            tot_env_diff_obj_pos.append(cur_diff_obj_pos)
            tot_env_diff_obj_rot.append(cur_diff_obj_rot)
            weighted_diff_obj_pose = w_pos * cur_diff_obj_pos + w_ornt * cur_diff_obj_rot
            tot_env_weighted_obj_pose_diff.append(weighted_diff_obj_pose)
        tot_env_weighted_obj_pose_diff = np.array(tot_env_weighted_obj_pose_diff)
        sorted_envs_idxes = np.argsort(tot_env_weighted_obj_pose_diff)
        tot_env_diff_obj_pos = np.array(tot_env_diff_obj_pos)
        tot_env_diff_obj_rot = np.array(tot_env_diff_obj_rot)
        
        best_env_idx = sorted_envs_idxes[0].item()
        best_obj_pos_diff = tot_env_diff_obj_pos[best_env_idx].item()
        best_obj_rot_diff = tot_env_diff_obj_rot[best_env_idx].item()
        best_obj_pose_diff = tot_env_weighted_obj_pose_diff[best_env_idx].item()
        
        obj_code_to_best_opt_res[obj_code] = {
            'obj_pos_diff': best_obj_pos_diff,
            'obj_rot_diff': best_obj_rot_diff,
            'obj_pose_diff': best_obj_pose_diff,
        }
    return obj_code_to_best_opt_res

    
        
        
        

def inspect_optimized_res_nn(data_optimized_res_nn, data_inst_tag):
    
    sorted_optimized_res_fn = data_optimized_res_nn.replace(".npy", "_sorted.npy")
    if os.path.exists(sorted_optimized_res_fn):
        return
    
    optimized_res = np.load(data_optimized_res_nn, allow_pickle=True).item()
    print(optimized_res.keys())
    
    # kinematics_data_root = "./data/GRAB_Tracking_PK/data"
    # passive_active_info_ori_grab_s1_alarmclock_lift.npy
    # from the data
    
    new_optimized_info = best_optimized_res(data_optimized_res_nn, data_inst_tag[0])
    optimized_res.update(new_optimized_info)
    print(optimized_res.keys())
    ## save to a separte file ##
    sorted_optimized_res_fn = data_optimized_res_nn.replace(".npy", "_sorted.npy")
    
    np.save(sorted_optimized_res_fn, optimized_res)
    print(f"sorted_optimized_res_fn: {sorted_optimized_res_fn}")
    
    optimized_obj_pose = optimized_res['optimized_obj_pose']
    optimized_hand_qtars = optimized_res['optimized_hand_qtars']
    optimized_hand_qs = optimized_res['optimized_hand_qs']
    best_obj_pose = optimized_obj_pose[0:1]
    best_hand_qtars = optimized_hand_qtars[0:1]
    best_hand_qs = optimized_hand_qs[0:1]
    # best obj pos diff #
    # best_obj_pose_diff = optimized_res['tot_env_weighted_obj_pose_diff'][0:1]
    # best_obj_pos_diff = optimized_res['']
    
    best_obj_pose_diff_new = optimized_res['obj_pose_diff'][0:1]
    best_obj_pose_diff = best_obj_pose_diff_new
    best_obj_pos_diff_new = optimized_res['obj_pos_diff'][0:1]
    best_obj_rot_diff_new = optimized_res['obj_rot_diff'][0:1] 
    first_obs_buf = optimized_res['obs_buf'][0:1]
    
    
    best_ts_to_opt_res_fn = sorted_optimized_res_fn.replace(".npy", "_best.npy")
    best_ts_to_opt_res = {
        'optimized_obj_pose': best_obj_pose,
        'optimized_hand_qtars': best_hand_qtars,
        'optimized_hand_qs': best_hand_qs,
        'obj_pose_diff': best_obj_pose_diff,
        'best_obj_pose_diff': best_obj_pose_diff_new,
        'best_obj_pos_diff': best_obj_pos_diff_new,
        'best_obj_rot_diff': best_obj_rot_diff_new,
        'obs_buf': first_obs_buf
    }
    np.save(best_ts_to_opt_res_fn, best_ts_to_opt_res)
    print(f"Saved best ts_to_opt_res to {best_ts_to_opt_res_fn}")

    
    # for key in optimized_res:
    #     # cur_grab_inst_tag = key
    #     # cur_grab_
    #     print(optimized_res[key].keys())
    #     break
    #     # val = optimized_res[key]
        # print(f"key: {key}, val: {val.shape}")



def resave_optimized_res(data_inst_tag_to_optimized_res_fn, target_sub_tag=None):
    data_inst_tag_to_res = np.load(data_inst_tag_to_optimized_res_fn, allow_pickle=True).item()
    print(data_inst_tag_to_res.keys())
    
    if target_sub_tag is not None:
        data_inst_tag_to_res = {
            key: data_inst_tag_to_res[key] for key in data_inst_tag_to_res if target_sub_tag in key[0]
        }
    
    cur_nn = 0
    for inst_tag in data_inst_tag_to_res:
        print(f"[{cur_nn}/{len(data_inst_tag_to_res)}] {inst_tag}")
        cur_inst_tag_optimized_res = data_inst_tag_to_res[inst_tag]
        for cur_inst_tag_optimized_res_fn in cur_inst_tag_optimized_res:
            if not os.path.exists(cur_inst_tag_optimized_res_fn):
                changed_root_folder = "./uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_v2"
                pure_fn = "/".join(cur_inst_tag_optimized_res_fn.split("/")[-2:])
                actual_res_fn = os.path.join(changed_root_folder, pure_fn)
            else: #
                actual_res_fn = cur_inst_tag_optimized_res_fn
                # cur_inst_tag_optimized_res_fn = cur_inst_tag_optimized_res_fn.replace(changed_root_folder, "./uni_manip/isaacgym_rl_exp_grab")
            try:
                inspect_optimized_res_nn(actual_res_fn, inst_tag)
            except:
                pass
        cur_nn = cur_nn + 1


def inspect_new_eval_res(new_eval_res_sv_dict_fn):
    sv_dict = np.load( new_eval_res_sv_dict_fn, allow_pickle=True).item()
    print(sv_dict.keys())
    
    for cur_ts in sv_dict:
        cur_ts_dict = sv_dict[cur_ts]
        print(cur_ts_dict.keys())
        
def mv_evaled_data_to_eval_folder(target_eval_folder, forbid_subj_idx=None):
    local_eval_folder = "./runs"
    tot_eval_fns = os.listdir(local_eval_folder)
    tracking_fn_tag = "tracking_"
    tot_eval_fns = [
        fn for fn in tot_eval_fns if fn[: len(tracking_fn_tag)] == tracking_fn_tag
    ]
    if forbid_subj_idx is not None:
        forbid_subj_tag = f"_s{forbid_subj_idx}_"
        tot_eval_fns = [ fn for fn in tot_eval_fns if forbid_subj_tag not in fn]
    # /root/diffsim/IsaacGymEnvs2/isaacgymenvs/runs/tracking_ori_grab_s1_alarmclock_pass_1_obs_pure_state_wref_wdelta_density_500.0_trans_0.5_rot_0.5_goalcond_False_kinebias_t0.5r0.5f20_rfd_0.3_rh_0.5_20-00-11-57/ts_to_hand_obj_obs_reset_1.npy
    for cur_eval_fn in tot_eval_fns:
        cur_full_eval_fn = os.path.join(local_eval_folder, cur_eval_fn)
        
        print(f"mv {cur_full_eval_fn} {target_eval_folder}/")
        os.system(f"mv {cur_full_eval_fn} {target_eval_folder}/")
        
        # cur_eval_dict_fn = "ts_to_hand_obj_obs_reset_1.npy"
        # cur_eval_dict_fn = os.path.join(cur_full_eval_fn, cur_eval_dict_fn)
        # 

# ./uni_manip/isaacgym_rl_exp_grab_eval/statistics/data_inst_tag_to_optimized_res.npy
def inspect_inst_tag_to_optimized_res(inst_tag_to_optimized_res_fn):
    inst_tag_to_res = np.load(inst_tag_to_optimized_res_fn, allow_pickle=True).item()
    for cur_inst_tag in inst_tag_to_res:
        print(cur_inst_tag)



def inspect_data_statistics(data_statistics_fn):
    data_statistics = np.load(data_statistics_fn, allow_pickle=True).item()
    print(data_statistics.keys())




def inspect_data_instance_to_optimized_res(data_inst_to_opt_res_fn, target_grab_inst_tag=None):
    data_inst_to_opt_res = np.load(data_inst_to_opt_res_fn, allow_pickle=True).item()
    for key in data_inst_to_opt_res:
        
        if target_grab_inst_tag is not None:
            if key[0] == target_grab_inst_tag:
                cur_val = data_inst_to_opt_res[key]
                print(f"key: {key}, cur_val: {cur_val}")
        
        # if "s2" in key[0]:
        #     cur_val = data_inst_to_opt_res[key]
        #     print(f"key: {key}, cur_val: {cur_val}")


def parse_obj_type_traj_type_fr_folder_name(folder_nm):
    exp_folder_st_tag = 'tracking_'
    remains_folder_nm = folder_nm[len(exp_folder_st_tag): ] ## get the remainng folder name ##
    folder_nm_segs = remains_folder_nm.split("_")
    obj_type_st_idx  = 0
    obj_type_ed_idx = 0
    for obj_type_ed_idx in range(0, len(folder_nm_segs)):
        if folder_nm_segs[obj_type_ed_idx] == 'OPTFR':
            break
    obj_type_segs = folder_nm_segs[obj_type_st_idx: obj_type_ed_idx]
    obj_type = "_".join(obj_type_segs)
    traj_type_st_idx = obj_type_ed_idx + 1
    traj_type_ed_idx = traj_type_st_idx
    for traj_type_ed_idx in range(traj_type_ed_idx, len(folder_nm_segs)):
        if folder_nm_segs[traj_type_ed_idx] == 'obs':
            break
    traj_type = folder_nm_segs[traj_type_st_idx: traj_type_ed_idx]
    traj_type = "_".join(traj_type)
    return obj_type, traj_type

# ./uni_manip/isaacgym_rl_exp_grab_OPTFR/tracking_ori_grab_s2_airplane_fly_1_OPTFR_ori_grab_s2_elephant_inspect_1_obs_pure_state_wref_wdelta_density_500.0_trans_0.5_rot_0.5_goalcond_False_kinebias_t0.5r0.5f20_rfd_0.3_rh_0.5_18-18-56-44
def calculate_OPTFR_exp_to_optimized_res(exp_root_folder):
    tot_exp_folders = os.listdir(exp_root_folder)
    exp_folder_st_tag = "tracking_"
    tot_exp_folders = [
        fn for fn in tot_exp_folders if fn[: len(exp_folder_st_tag)] == exp_folder_st_tag
    ]
    
    exp_config_to_tracking_ckpt = {}
    for i_exp, cur_exp_folder in enumerate(tot_exp_folders):
        obj_type, traj_type = parse_obj_type_traj_type_fr_folder_name(cur_exp_folder)
        print(f"[{i_exp}/{len(tot_exp_folders)}] obj_type: {obj_type}, traj_type: {traj_type}")
        
        cur_exp_full_folder = os.path.join(exp_root_folder,cur_exp_folder)
        cur_exp_full_nn_folder = os.path.join(cur_exp_full_folder, "nn")
        if not os.path.exists(cur_exp_full_nn_folder):
            print(f"cur_exp_full_nn_folder: {cur_exp_full_nn_folder} not exists")
            continue
        # ./uni_manip/isaacgym_rl_exp_grab_OPTFR/tracking_ori_grab_s2_airplane_fly_1_OPTFR_ori_grab_s2_elephant_inspect_1_obs_pure_state_wref_wdelta_density_500.0_trans_0.5_rot_0.5_goalcond_False_kinebias_t0.5r0.5f20_rfd_0.3_rh_0.5_18-18-56-44/nn/tracking_ori_grab_s2_airplane_fly_1_OPTFR_ori_grab_s2_elephant_inspect_1_obs_pure_state_wref_wdelta_density_500.0_trans_0.5_rot_0.5_goalcond_False_kinebias_t0.5r0.5f20_rfd_0.3_rh_0.5.pth
        tot_tracking_ckpts = os.listdir(cur_exp_full_nn_folder)
        tot_tracking_ckpts = [ fn for fn in tot_tracking_ckpts if fn.endswith(".pth") ]
        tot_tracking_ckpts = [ fn for fn in tot_tracking_ckpts if fn[: len(exp_folder_st_tag)] == exp_folder_st_tag ]
        if len(tot_tracking_ckpts) != 1:
            continue
        assert len(tot_tracking_ckpts) == 1
        cur_exp_tracking_ckpt = tot_tracking_ckpts[0]
        cur_exp_tracking_ckpt = os.path.join(cur_exp_full_nn_folder, cur_exp_tracking_ckpt)
        exp_config_to_tracking_ckpt[(obj_type, traj_type)] = cur_exp_tracking_ckpt
    exp_statistics_folder = os.path.join(exp_root_folder, "statistics")
    os.makedirs(exp_statistics_folder, exist_ok=True)
    obj_type_to_optimized_res_sv_fn = "obj_type_to_optimized_res.npy"
    obj_type_to_optimized_res_sv_fn = os.path.join(exp_statistics_folder, obj_type_to_optimized_res_sv_fn)
    np.save(obj_type_to_optimized_res_sv_fn, exp_config_to_tracking_ckpt) 
    print(f"obj_type_to_optimized_res saved to {obj_type_to_optimized_res_sv_fn}") 
    
    return exp_config_to_tracking_ckpt


def inspect_exp_tag_to_optimized_res(exp_tag_to_optimized_res_fn):
    exp_tag_to_optimized_res = np.load(exp_tag_to_optimized_res_fn, allow_pickle=True).item()
    for key in exp_tag_to_optimized_res:
        cur_val = exp_tag_to_optimized_res[key]
        print(f"key: {key}, cur_val: {cur_val}")


def inspect_optimized_res(optimized_res_fn):
    tot_optimized_res = np.load(optimized_res_fn, allow_pickle=True).item()
    tot_keys_nn = len(tot_optimized_res)
    
    for key in tot_optimized_res:
        cur_val = tot_optimized_res[key]
        print(f"key: {key}, cur_val: {cur_val}")
        break
    tot_evaluated_grab_inst_fns = [key[0] for key in tot_optimized_res]
    for subj in range(1, 11):
        cur_subj_res_tag = f"_s{subj}_"
        cur_subj_grab_inst_fns = [ key for key in tot_evaluated_grab_inst_fns if cur_subj_res_tag in key  ]
        print(f"subj: {subj}, len(cur_subj_grab_inst_fns): {len(cur_subj_grab_inst_fns)}")
        
def inspect_inst_tag_to_optimized_res(inst_to_optimize_res_fn):
    inst_tag_to_optimized_res = np.load(inst_to_optimize_res_fn, allow_pickle=True).item()
    for inst_tag in inst_tag_to_optimized_res:
        cur_val = inst_tag_to_optimized_res[inst_tag]
        print(f"inst_tag: {inst_tag}, cur_val: {cur_val}")
   
     
# tracking_ori_grab_s4_apple_eat_1_OPTFR_ori_grab_s4_stapler_staple_1_obs_pure_state_wref_wdelta_density_500.0_trans_0.5_rot_0.5_goalcond_False_kinebias_t0.5r0.5f20_rfd_0.3_rh_0.5_26-02-16-52

def get_exp_info_from_folder_nm(exp_folder_fn):
    tracking_folder_fn = "tracking_"
    remains_folder_fn = exp_folder_fn[len(tracking_folder_fn): ]
    remains_folder_segs = remains_folder_fn.split("_") ## get the remains folder name ## 
    st_cur_obj_type = 0
    if '_OPTFR_' in remains_folder_fn:
        for ed_cur_obj_type in range(st_cur_obj_type, len(remains_folder_segs)):
            if remains_folder_segs[ed_cur_obj_type] == 'OPTFR':
                break
        st_fa_obj_type = ed_cur_obj_type + 1
        for ed_fa_obj_type in range(st_fa_obj_type, len(remains_folder_segs)):
            if remains_folder_segs[ed_fa_obj_type] == 'obs':
                break
        cur_obj_type = "_".join(remains_folder_segs[st_cur_obj_type: ed_cur_obj_type])
        fa_obj_type = "_".join(remains_folder_segs[st_fa_obj_type: ed_fa_obj_type])
    else:
        for ed_cur_obj_type in range(st_cur_obj_type, len(remains_folder_segs)):
            if remains_folder_segs[ed_cur_obj_type] == 'obs':
                break
        cur_obj_type = "_".join(remains_folder_segs[st_cur_obj_type: ed_cur_obj_type])
        fa_obj_type = cur_obj_type
    
    return cur_obj_type, fa_obj_type

def inspect_exp_info_to_optimized_res(exp_root_folder, subj_idx=None):
    tot_exp_folders = os.listdir(exp_root_folder)
    tracking_folder_fn = "tracking_"
    tot_exp_folders = [
        fn for fn in tot_exp_folders if fn[: len(tracking_folder_fn)] == tracking_folder_fn
    ]
    if subj_idx is not None:
        subj_tag = f"_s{subj_idx}_"
        tot_exp_folders = [
            fn for fn in tot_exp_folders if subj_tag in fn
        ]
    exp_info_to_optimized_res = { }
    for cur_exp_folder in tot_exp_folders:
        cur_obj_type, fa_obj_type = get_exp_info_from_folder_nm(cur_exp_folder)
        cur_full_exp_folder = os.path.join(exp_root_folder, cur_exp_folder)
        cur_full_exp_folder_nn = os.path.join(cur_full_exp_folder, "nn") 
        # get the ful exp folder # 
        if not os.path.exists(cur_full_exp_folder_nn):
            continue
        best_rew, best_ckpt_fn = find_best_rew(cur_full_exp_folder) 
        ### get the best rew and the ckpt fn ###
        exp_info_to_optimized_res[ ( cur_obj_type, fa_obj_type ) ] = (best_rew, best_ckpt_fn)
    statistics_folder = os.path.join(exp_root_folder, "statistics")
    os.makedirs(statistics_folder, exist_ok=True) ## statistics folder ## 
    exp_info_to_optimized_res_fn = os.path.join(statistics_folder, "exp_info_to_optimized_res.npy")
    np.save( exp_info_to_optimized_res_fn, exp_info_to_optimized_res ) # exp info to optimized res #
    return exp_info_to_optimized_res 


# def inspect_exp_info_to_optimized_res(exp_root_folder):
#     tot_exp_folders = os.listdir(exp_root_folder)
#     tracking_folder_fn = "tracking_"
#     tot_exp_folders = [
#         fn for fn in tot_exp_folders if fn[: len(tracking_folder_fn)] == tracking_folder_fn
#     ]
#     exp_info_to_optimized_res = { }
#     for cur_exp_folder in tot_exp_folders:
#         cur_obj_type, fa_obj_type = get_exp_info_from_folder_nm(cur_exp_folder)
#         cur_full_exp_folder = os.path.join(exp_root_folder, cur_exp_folder)
#         cur_full_exp_folder_nn = os.path.join(cur_full_exp_folder, "nn") 
#         # get the ful exp folder # 
#         if not os.path.exists(cur_full_exp_folder_nn):
#             continue
#         best_rew, best_ckpt_fn = find_best_rew(cur_full_exp_folder) 
#         ### get the best rew and the ckpt fn ###
#         exp_info_to_optimized_res[ ( cur_obj_type, fa_obj_type ) ] = (best_rew, best_ckpt_fn)
#     statistics_folder = os.path.join(exp_root_folder, "statistics")
#     os.makedirs(statistics_folder, exist_ok=True) ## statistics folder ## 
#     exp_info_to_optimized_res_fn = os.path.join(statistics_folder, "exp_info_to_optimized_res.npy")
#     np.save( exp_info_to_optimized_res_fn, exp_info_to_optimized_res ) # exp info to optimized res #
#     return exp_info_to_optimized_res 



def inspect_optfr_with_selfexp(exp_info_to_opt_res_fn, self_exp_res_to_opt_res_fn, save_res=False):
    exp_info_to_opt_res = np.load(exp_info_to_opt_res_fn, allow_pickle=True).item()
    self_exp_info_to_opt_res = np.load(self_exp_res_to_opt_res_fn, allow_pickle=True).item()
    
    inst_tag_to_opt_res = {}
    # k * n? since it should not be a deterministic mapping here #
    for exp_info in exp_info_to_opt_res:
        cur_inst_tag = exp_info[0]
        cur_inst_fa_tag = exp_info[1]
        print(f"exp_info: {exp_info}")
        if cur_inst_tag not in inst_tag_to_opt_res:
            
            inst_tag_to_opt_res[cur_inst_tag] = (exp_info_to_opt_res[exp_info][0], cur_inst_fa_tag) # rew and the father task tag #
        else:
            cur_best_rew = exp_info_to_opt_res[exp_info][0]
            prev_best_rew = inst_tag_to_opt_res[cur_inst_tag][0] ### best and the optimized res 
            if cur_best_rew > prev_best_rew:
                inst_tag_to_opt_res[cur_inst_tag] = ( exp_info_to_opt_res[exp_info][0], cur_inst_fa_tag )
                
            
            # inst_tag_to_opt_res[cur_inst_tag] = max(inst_tag_to_opt_res[cur_inst_tag], exp_info_to_opt_res[exp_info][0])
    # print(inst_tag_to_opt_res.keys())
    ### ###
    
    child_task_to_fa_task = {} 
    better_nn = 0
    tot_nn = 0
    for key in self_exp_info_to_opt_res:
        if key in inst_tag_to_opt_res: ## inst tag to opt res ##
            
            inherited_optimized_res = inst_tag_to_opt_res[key][0]
            self_optimized_res = self_exp_info_to_opt_res[key][0]
        
            if inherited_optimized_res > self_optimized_res: ### inst tag ###
                child_task_to_fa_task[key] = inst_tag_to_opt_res[key][1] ### inst tag ###
                better_nn += 1
                print(key, self_exp_info_to_opt_res[key][0], inst_tag_to_opt_res[key]) 
            tot_nn += 1
            
            # print(key, self_exp_info_to_opt_res[key][0], inst_tag_to_opt_res[key]) 
    print(f"better_nn/tot_nn: {better_nn}/{tot_nn}")
    
    if save_res:
        exp_info_to_opt_res_sv_folder = "/".join(exp_info_to_opt_res_fn.split("/")[:-1])
        child_task_to_fa_task_fn = "child_task_to_fa_task.npy"
        child_task_to_fa_task_fn = os.path.join(exp_info_to_opt_res_sv_folder, child_task_to_fa_task_fn)  
        np.save(child_task_to_fa_task_fn, child_task_to_fa_task) # 
        print(f"Child task to father task dict saved to {child_task_to_fa_task_fn}") 
    
    # is trajectory translation a good strategy #
    ## inspect thew selfexp ##
    
    ## chld ttask ##
    # child_to_fa_task = {}
    # for key in self_exp_info_to_opt_res: #
    # find the best task #
    # find the best task to solve #
    # a task planner? #
    # hierachical policy? #
    
    ###





def inspect_optfr_with_selfexp_list(exp_info_to_opt_res_fn, self_exp_res_to_opt_res_fn, save_res=False):
    exp_info_to_opt_res = np.load(exp_info_to_opt_res_fn, allow_pickle=True).item()
    self_exp_info_to_opt_res = np.load(self_exp_res_to_opt_res_fn, allow_pickle=True).item()
    
    inst_tag_to_opt_res = {}
    # k * n? since it should not be a deterministic mapping here #
    for exp_info in exp_info_to_opt_res:
        cur_inst_tag = exp_info[0]
        cur_inst_fa_tag = exp_info[1]
        print(f"exp_info: {exp_info}")
        if cur_inst_tag not in inst_tag_to_opt_res:
            inst_tag_to_opt_res[cur_inst_tag] = [(exp_info_to_opt_res[exp_info][0], cur_inst_fa_tag)]  
        else:
            cur_best_rew = exp_info_to_opt_res[exp_info][0]
            # prev_best_rew = inst_tag_to_opt_res[cur_inst_tag][0] ### best and the optimized res 
            # exp info #
            rew_w_fa_tag = ( cur_best_rew,   cur_inst_fa_tag)
            
            inst_tag_to_opt_res[cur_inst_tag].append(rew_w_fa_tag) # 
            
            # if cur_best_rew > prev_best_rew:
            #     inst_tag_to_opt_res[cur_inst_tag] = ( exp_info_to_opt_res[exp_info][0], cur_inst_fa_tag )
                
            
            # inst_tag_to_opt_res[cur_inst_tag] = max(inst_tag_to_opt_res[cur_inst_tag], exp_info_to_opt_res[exp_info][0])
    # print(inst_tag_to_opt_res.keys())
    ### ###
    
    child_task_to_fa_task = {} 
    better_nn = 0
    tot_nn = 0
    for key in self_exp_info_to_opt_res:
        if key in inst_tag_to_opt_res: ## inst tag to opt res ##
            self_optimized_res = self_exp_info_to_opt_res[key][0]
            tot_fa_infos = inst_tag_to_opt_res[key]
            for cur_fa_info in tot_fa_infos:
                cur_fa_rew, cur_fa_tag = cur_fa_info
                if cur_fa_rew > self_optimized_res:
                    if key not in child_task_to_fa_task:
                        better_nn += 1
                        child_task_to_fa_task[key] = [cur_fa_tag]
                    else:
                        child_task_to_fa_task[key].append(cur_fa_tag)
            
            
            # inherited_optimized_res = inst_tag_to_opt_res[key][0]
            # 
        
            # if inherited_optimized_res > self_optimized_res: ### inst tag ###
            #     child_task_to_fa_task[key] = inst_tag_to_opt_res[key][1] ### inst tag ###
            #     better_nn += 1
            #     print(key, self_exp_info_to_opt_res[key][0], inst_tag_to_opt_res[key]) 
            tot_nn += 1
            
            # print(key, self_exp_info_to_opt_res[key][0], inst_tag_to_opt_res[key]) 
    print(f"better_nn/tot_nn: {better_nn}/{tot_nn}")
    
    if save_res: # exp info to opt res #
        exp_info_to_opt_res_sv_folder = "/".join(exp_info_to_opt_res_fn.split("/")[:-1])
        child_task_to_fa_task_fn = "child_task_to_fa_task_list.npy" # child task to father task #
        child_task_to_fa_task_fn = os.path.join(exp_info_to_opt_res_sv_folder, child_task_to_fa_task_fn)  
        np.save(child_task_to_fa_task_fn, child_task_to_fa_task)
        print(f"Child task to father task dict saved to {child_task_to_fa_task_fn}") 





def inspect_opt_res(exp_info_to_opt_res_fn, self_exp_res_to_opt_res_fn, save_res=False):
    exp_info_to_opt_res = np.load(exp_info_to_opt_res_fn, allow_pickle=True).item()
    self_exp_info_to_opt_res = np.load(self_exp_res_to_opt_res_fn, allow_pickle=True).item()
    
    inst_tag_to_opt_res = {}
    
    tot_nn = 0
    better_nn = 0
    
    succ_rew = 15.0
    self_tot_nn = 0
    self_succ_nn = 0
    target_subj_tag = '_s9'
    for key in self_exp_info_to_opt_res:
        if target_subj_tag in key:
            cur_self_opt_rew = self_exp_info_to_opt_res[key][0]
            if cur_self_opt_rew > succ_rew:
                self_succ_nn += 1
            self_tot_nn += 1
            
    print(f"self_succ_nn/self_tot_nn: {self_succ_nn}/{self_tot_nn}")
    
    other_succ_nn = 0
    other_tot_nn = 0
    for key in exp_info_to_opt_res:
        if target_subj_tag in key:
            cur_self_opt_rew = exp_info_to_opt_res[key][0]
            if cur_self_opt_rew > succ_rew:
                other_succ_nn += 1
            other_tot_nn += 1
            
    print(f"other_succ_nn/other_tot_nn: {other_succ_nn}/{other_tot_nn}")
    
    
    
    for key in exp_info_to_opt_res:
        if key in self_exp_info_to_opt_res:
            cur_self_opt_res = self_exp_info_to_opt_res[key][0]
            cur_other_opt_res = exp_info_to_opt_res[key][0]
            if cur_other_opt_res > cur_self_opt_res:
                better_nn += 1
            tot_nn += 1
            
    print(f"better_nn/tot_nn: {better_nn}/{tot_nn}")
    
    




def inspect_child_task_to_fa_task(ch_to_fa_task_sv_fn):
    ch_to_fa_task = np.load(ch_to_fa_task_sv_fn, allow_pickle=True ).item()
    for key in ch_to_fa_task:
        print(key, ch_to_fa_task[key])
        # 
        
def inspect_grab_cross_obj_diff(grab_obj_name_idx_dict_fn):
    grab_obj_nm_idx = np.load(grab_obj_name_idx_dict_fn, allow_pickle=True).item()
    for key in grab_obj_nm_idx: 
        val = grab_obj_nm_idx[key]
        print(f"key: {key}, val: {val}")

# <<<<<<< HEAD
def merge_child_task_to_fa_task(local_dict_fn, glb_dict_fn):
    glb_dict = np.load(glb_dict_fn, allow_pickle=True).item()
    local_dict = np.load(local_dict_fn, allow_pickle=True).item()
    for key in local_dict:
        glb_dict[key] = local_dict[key]
    print(glb_dict.keys())
    np.save(glb_dict_fn, glb_dict)


# # ./uni_manip/isaacgym_rl_exp_grab_wdiffusion_samples
# =======
# >>>>>>> c6fbd593bf99644e2c520da3efc0c713832c4f66

def test_ckpt(ckpt_fn):
    ckpt_dict = torch.load(ckpt_fn, map_location='cpu')
    print(ckpt_dict.keys())
    

def merge_child_task_to_fa_task(local_dict_fn, glb_dict_fn):
    glb_dict = np.load(glb_dict_fn, allow_pickle=True).item()
    local_dict = np.load(local_dict_fn, allow_pickle=True).item()
    for key in local_dict:
        glb_dict[key] = local_dict[key]
    print(glb_dict.keys())
    np.save(glb_dict_fn, glb_dict)


def inspect_obj_feat_sample(obj_feat_sample_fn):
    obj_feat_samples =  np.load(obj_feat_sample_fn, allow_pickle=True).item()
    sample_key = 'samples'
    obj_feat_samples = obj_feat_samples[sample_key]
    for key in obj_feat_samples:
        cur_val = obj_feat_samples[key]
        # print(f"key: {key}, cur_val: {type(cur_val)}")
        if isinstance(cur_val, np.ndarray):
            print(f"key: {key}, cur_val: {cur_val.shape}")
        else:
            print(f"key: {key}, cur_val: {cur_val}")
# the feat dim is 256 here # 


def parse_object_info_from_kine_fn(kine_fn):
    
    kine_fn = kine_fn.split("/")[-1]
    
    if 'taco' in kine_fn:
        tracking_info_st_tag = "passive_active_info_ori_grab_s2_phone_call_1_interped_"
        inst_tag_fn = kine_fn.split(".")[0]
        inst_tag_fn = inst_tag_fn[len(tracking_info_st_tag): ]
        inst_tag_splits = inst_tag_fn.split("_")
        inst_tag_name = inst_tag_splits[0: 3]
        inst_tag = "_".join(inst_tag_name)
    else:
    
        tracking_info_st_tag = "passive_active_info_"
        inst_tag = kine_fn.split(".")[0][len(tracking_info_st_tag): ]
    return inst_tag

def summarize_traj_features(obj_sample_folder, nn_bsz):
    ep_idx = 0
    batch_st_idx = 0
    batch_ed_idx = nn_bsz
    obj_type_to_obj_feat = {}
    for cur_batch_idx in range(batch_st_idx, batch_ed_idx):
        cur_sample_batch_fn = f"samples_ep_{ep_idx}_batch_{cur_batch_idx}.npy"
        cur_sample_batch_full_fn = os.path.join(obj_sample_folder, cur_sample_batch_fn)
        cur_sample_batch = np.load(cur_sample_batch_full_fn, allow_pickle=True).item()
        print(f"cur_sample_batch: {cur_sample_batch.keys()}")
        tot_data_nm = cur_sample_batch['data_nm']
        feat_feat = cur_sample_batch['samples']['feat_feat']
        feat_feat = np.max(feat_feat, axis=0)
        print(f"feat_feat: {feat_feat.shape}, tot_data_nm: {len(tot_data_nm)}")
        for i_data, cur_data_nm in enumerate(tot_data_nm):
            cur_inst_tag = parse_object_info_from_kine_fn(cur_data_nm)
            cur_inst_feat_feat = feat_feat[i_data]
            obj_type_to_obj_feat[cur_inst_tag]=cur_inst_feat_feat
        
        # cur_sample_batch = cur_sample_batch['samples']
        # 
        # object_type = cur_sample_batch['object_type'][0][0]
        # pts_feat = cur_sample_batch['pts_feat']
        # for i_obj, cur_obj_type in enumerate(object_type):
        #     cur_obj_pts_feat = pts_feat[i_obj]
        #     obj_type_to_obj_feat[cur_obj_type] = cur_obj_pts_feat
    obj_type_to_obj_feat_fn = f"inst_tag_to_obj_feat.npy"
    obj_type_to_obj_feat_fn = os.path.join(obj_sample_folder, obj_type_to_obj_feat_fn)
    np.save(obj_type_to_obj_feat_fn, obj_type_to_obj_feat) 
    print(f"obj_type_to_obj_feat: {obj_type_to_obj_feat_fn}")



def summarize_obj_features(obj_sample_folder, nn_bsz):
    ep_idx = 0
    batch_st_idx = 0
    batch_ed_idx = nn_bsz
    obj_type_to_obj_feat = {}
    for cur_batch_idx in range(batch_st_idx, batch_ed_idx):
        cur_sample_batch_fn = f"samples_ep_{ep_idx}_batch_{cur_batch_idx}.npy"
        cur_sample_batch_full_fn = os.path.join(obj_sample_folder, cur_sample_batch_fn)
        cur_sample_batch = np.load(cur_sample_batch_full_fn, allow_pickle=True).item()
        cur_sample_batch = cur_sample_batch['samples']
        # object_type #
        # object_type = cur_sample_batch['object_type'][0][0]
        
        object_type = cur_sample_batch['data_nm'][0][0]
        # print(object_type)
        # cur_inst_tag = parse_object_info_from_kine_fn(cur_data_nm)
        object_type = [ parse_object_info_from_kine_fn(cur_obj_data_nm) for cur_obj_data_nm in object_type ]
        
        pts_feat = cur_sample_batch['pts_feat']
        for i_obj, cur_obj_type in enumerate(object_type):
            cur_obj_pts_feat = pts_feat[i_obj]
            obj_type_to_obj_feat[cur_obj_type] = cur_obj_pts_feat
    obj_type_to_obj_feat_fn = f"obj_type_to_obj_feat.npy"
    obj_type_to_obj_feat_fn = os.path.join(obj_sample_folder, obj_type_to_obj_feat_fn)
    np.save(obj_type_to_obj_feat_fn, obj_type_to_obj_feat) 
    print(f"obj_type_to_obj_feat: {obj_type_to_obj_feat_fn}")


def inspect_obj_feats(obj_type_to_obj_feat_fn):
    obj_type_to_obj_feat = np.load(obj_type_to_obj_feat_fn, allow_pickle=True).item()
    for obj_type in obj_type_to_obj_feat:
        cur_obj_feat = obj_type_to_obj_feat[obj_type]
        if 'taco_' in obj_type:
            print(f"obj_type: {obj_type}, obj_feat: {cur_obj_feat.shape}")

# grab data utils #

def inspect_ckpt(ckpt_fn):
    ckpt = torch.load(ckpt_fn, map_location='cpu')
    print(ckpt.keys())
    model_weights = ckpt['model']
    print(model_weights.keys())
    



def inspect_best_optimized_res(best_opt_fn):
    best_opt_dict = np.load(best_opt_fn, allow_pickle=True).item()
    print(best_opt_dict.keys())
    



def get_obj_inst_tag_to_best_opt_res(inst_tag_to_optimized_res_fn, target_subj_tag=None, random_select=False):
    data_inst_tag_to_res = np.load(inst_tag_to_optimized_res_fn, allow_pickle=True).item()
    # print(data_inst_tag_to_res.keys())
    cur_nn = 0
    data_inst_tag_to_best_opt_res = {}
    for inst_tag in data_inst_tag_to_res:
        if target_subj_tag is not None:
            if target_subj_tag not in inst_tag[0]:
                continue
        cur_inst_opt_res_fn = data_inst_tag_to_res[inst_tag][0]
        
        if not os.path.exists(cur_inst_opt_res_fn):
            changed_root_folder = "./uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_v2"
            pure_fn = "/".join(cur_inst_opt_res_fn.split("/")[-2:])
            actual_res_fn = os.path.join(changed_root_folder, pure_fn)
        else:
            actual_res_fn = cur_inst_opt_res_fn
        
        cur_inst_opt_res_fn_sorted = actual_res_fn.replace(".npy", "_sorted.npy")
        if random_select:
            cur_inst_opt_res_sorted = np.load(cur_inst_opt_res_fn_sorted, allow_pickle=True).item() # jet the opt res fn sorted #
            # optimized_obj_pose = cur_inst_opt_res_sorted['optimized_obj_pose']
            # optimized_obj_pose_diff = cur_inst_opt_res_sorted['optimized_hand_qtars']
            obj_pos_diff = cur_inst_opt_res_sorted['obj_pos_diff'] # nn_envs
            obj_pose_diff = cur_inst_opt_res_sorted['obj_pose_diff']
            obj_rot_diff = cur_inst_opt_res_sorted['obj_rot_diff']
            rnd_selected_nn = 8
            rnd_selected_idxes = np.random.choice(len(obj_pos_diff), rnd_selected_nn, replace=False)
            obj_pos_diff = obj_pos_diff[rnd_selected_idxes]
            obj_pose_diff = obj_pose_diff[rnd_selected_idxes]
            obj_rot_diff = obj_rot_diff[rnd_selected_idxes]
            sorted_pos_diff_idxes = np.argsort(obj_pos_diff)
            obj_pose_diff = obj_pose_diff[sorted_pos_diff_idxes]
            obj_rot_diff = obj_rot_diff[sorted_pos_diff_idxes]
            obj_pos_diff = obj_pos_diff[sorted_pos_diff_idxes]
            # best_obj_pose_diff = 
            # sorted_pose_diff_idxes = np.argsort(obj_pose_diff)
            # sorted_rot_diff_idxes = np.argsort(obj_rot_diff)
            # # obj_pos_diff = obj_pos_diff[sorted_pos_diff_idxes]
            best_obj_pose_diff = obj_pose_diff[0:1]
            best_obj_pos_diff = obj_pos_diff[0:1]
            best_obj_rot_diff = obj_rot_diff[0:1]
        else:
            cur_inst_opt_res_fn_sorted_best = cur_inst_opt_res_fn_sorted.replace(".npy", "_best.npy")
            if not os.path.exists(cur_inst_opt_res_fn_sorted_best):
                cur_inst_opt_res_fn_sorted_best=  cur_inst_opt_res_fn_sorted.replace(".npy", "_best_vv.npy")
            if not os.path.exists(cur_inst_opt_res_fn_sorted_best):
                print(f"cur_inst_opt_res_fn_sorted_best: {cur_inst_opt_res_fn_sorted_best} not exists")
                continue
            cur_inst_opt_res = np.load(cur_inst_opt_res_fn_sorted_best, allow_pickle=True).item()
            # dict_keys(['optimized_obj_pose', 'optimized_hand_qtars', 'optimized_hand_qs', 'obj_pose_diff', 'best_obj_pose_diff', 'best_obj_pos_diff', 'best_obj_rot_diff'])
            best_obj_pose_diff = cur_inst_opt_res['best_obj_pose_diff']
            best_obj_pos_diff = cur_inst_opt_res['best_obj_pos_diff']
            best_obj_rot_diff = cur_inst_opt_res['best_obj_rot_diff']
            
        data_inst_tag_to_best_opt_res[inst_tag] = {
            'obj_pos_diff': best_obj_pos_diff,
            'obj_rot_diff': best_obj_rot_diff,
            'obj_pose_diff': best_obj_pose_diff,
        }
        

        
        
        # print(f"[{cur_nn}/{len(data_inst_tag_to_res)}] {inst_tag}")
        # cur_inst_tag_optimized_res = data_inst_tag_to_res[inst_tag]
        # for cur_inst_tag_optimized_res_fn in cur_inst_tag_optimized_res:
        #     inspect_optimized_res_nn(cur_inst_tag_optimized_res_fn, inst_tag)
        # cur_nn = cur_nn + 1
        
    sorted_items = list(data_inst_tag_to_best_opt_res.items())
    sorted_items = sorted(sorted_items, key=lambda x: x[1]['obj_pos_diff'])
    print(sorted_items[:40])
    return data_inst_tag_to_best_opt_res
    pass




def inspect_data_inst_to_best_opt_res(data_inst_to_best_opt_res_fn, target_sub_tag=None):
    data_inst_to_best_opt_res = np.load(data_inst_to_best_opt_res_fn, allow_pickle=True).item()
    for cur_data_inst in data_inst_to_best_opt_res:
        if target_sub_tag is not None:
            if target_sub_tag not in cur_data_inst[0]:
                continue
        cur_val = data_inst_to_best_opt_res[cur_data_inst]
        print(f"cur_data_inst: {cur_data_inst}, cur_val: {cur_val}")

### ### --- test them all ? ####
### better than the origianl one ? ##
## no -- better than the jointly training results ##
def compare_best_opt_res(data_inst_to_opt_res_fn_a, data_inst_to_opt_fn_b):
    data_inst_to_opt_res_a = np.load(data_inst_to_opt_res_fn_a, allow_pickle=True).item()
    data_inst_to_opt_res_b = np.load(data_inst_to_opt_fn_b, allow_pickle=True).item()
    tot_nn = 0
    better_nn = 0
    for inst_tag in data_inst_to_opt_res_b:
        if (inst_tag, inst_tag) in data_inst_to_opt_res_a:
            cur_val_a = data_inst_to_opt_res_a[(inst_tag, inst_tag)]
            cur_val_b = data_inst_to_opt_res_b[inst_tag]
            cmp_obj_diff_key = 'obj_pose_diff'
            # cmp_obj_diff_key = 'obj_pos_diff'
            
            # print(f"inst_tag: {inst_tag}, cur_val_a: {cur_val_a['obj_pos_diff']}, cur_val_b: {cur_val_b['obj_pos_diff']}")
            
            cur_a_pos_diff = cur_val_a[cmp_obj_diff_key][0].item()
            cur_b_pos_diff = cur_val_b[cmp_obj_diff_key]
            tot_nn += 1
            if cur_a_pos_diff < cur_b_pos_diff:
                better_nn += 1
                print(f"inst_tag: {inst_tag}, cur_val_a: {cur_val_a['obj_pos_diff']}, cur_val_b: {cur_val_b['obj_pos_diff']}")
    print(f"better_nn/tot_nn: {better_nn}/{tot_nn}")


def calcu_eval_metrics():
    five_degree_arc = 5.0 * np.pi / 180.0
    print(five_degree_arc)
    ten_degree_arc = 10.0 * np.pi / 180.0
    print(ten_degree_arc)
    fifteen_degree_arc = 15.0 * np.pi / 180.0
    print(fifteen_degree_arc)
    twenty_degree_arc = 20.0 * np.pi / 180.0
    print(twenty_degree_arc)
    thirty_degree_arc = 30.0 * np.pi / 180.0
    forty_degree_arc = 40.0 * np.pi / 180.0
    print(thirty_degree_arc)
    print(forty_degree_arc)
    
    
def calcualte_succ_info(data_inst_to_opt_res_fn):
    data_inst_to_best_opt_res = np.load(data_inst_to_opt_res_fn, allow_pickle=True).item() # opt res fn # 
    pos_thres = 0.1
    ornt_thres = 0.6981317007977318
    # pos_thres = 0.05
    # ornt_thres = 0.6981317007977318
    
    tot_nn = 0
    succ_nn = 0
    # 's2' 
    # 
    target_inst_tag = 's2'
    for cur_data_inst_tag in data_inst_to_best_opt_res:
        if isinstance(cur_data_inst_tag, tuple):
            if target_inst_tag not in cur_data_inst_tag[0]: 
                continue
        elif isinstance(cur_data_inst_tag, str):
            if target_inst_tag not in cur_data_inst_tag:
                continue
        cur_data_inst_val = data_inst_to_best_opt_res[cur_data_inst_tag]
        cur_obj_pos_diff = cur_data_inst_val['obj_pos_diff'] # [0].item()
        cur_obj_rot_diff = cur_data_inst_val['obj_rot_diff'] # [0].item()
        
        if isinstance(cur_obj_pos_diff, np.ndarray):
            cur_obj_pos_diff = cur_obj_pos_diff[0].item()
        if isinstance(cur_obj_rot_diff, np.ndarray):
            cur_obj_rot_diff = cur_obj_rot_diff[0].item()
            
        
        if cur_obj_pos_diff < pos_thres and cur_obj_rot_diff < ornt_thres:
            succ_nn += 1
        tot_nn += 1
    print(f"succ_nn/tot_nn: {succ_nn}/{tot_nn}")


### NOTE: the fn_a is the original saved info file; and the fn_b is the re-saved by the jointly optimized strategy ####
def calcualte_merged_succ_info(data_inst_to_opt_res_fn_a, data_inst_to_opt_res_fn_b):
    data_inst_to_opt_res_a = np.load(data_inst_to_opt_res_fn_a, allow_pickle=True).item()
    data_inst_to_opt_res_b = np.load(data_inst_to_opt_res_fn_b, allow_pickle=True).item()
    pos_thres = 0.1
    ornt_thres = 0.6981317007977318
    # pos_thres = 0.05
    # ornt_thres = 0.6981317007977318
    tot_nn = 0
    succ_nn = 0
    target_inst_tag = 's2'
    # target_inst_tag = 's9'
    for cur_inst_tag in data_inst_to_opt_res_a:
        print(f"cur_inst_tag: {cur_inst_tag}")
        # if isinstance(cur_inst_tag, tuple):
        #     if target_inst_tag not in cur_inst_tag[0]: 
        #         continue
        cur_data_inst_val = data_inst_to_opt_res_a[cur_inst_tag]
        cur_a_pos_diff = cur_data_inst_val['obj_pos_diff'][0].item()
        cur_a_rot_diff = cur_data_inst_val['obj_rot_diff'][0].item()
        
        # if cur_inst_tag[0] in data_inst_to_opt_res_b:
        #     # print(f"cur_inst_tag: {cur_inst_tag}, xxx")
        #     cur_b_inst_val = data_inst_to_opt_res_b[cur_inst_tag[0]]
        #     cur_b_pos_diff = cur_b_inst_val['obj_pos_diff']
        #     cur_b_rot_diff = cur_b_inst_val['obj_rot_diff']
        #     cur_a_pose_diff = cur_a_pos_diff + cur_a_rot_diff * 0.33
        #     cur_b_pose_diff = cur_b_pos_diff + cur_b_rot_diff * 0.33
        #     # if cur_b_pose_diff < cur_a_pose_diff:
        #     if cur_b_pos_diff < cur_a_pos_diff:
        #         print(f"cur_inst_tag: {cur_inst_tag}, cur_a_pos_diff: {cur_a_pos_diff}, cur_a_rot_diff: {cur_a_rot_diff}, cur_b_pos_diff: {cur_b_pos_diff}, cur_b_rot_diff: {cur_b_rot_diff}")
        #         cur_a_pos_diff = cur_b_pos_diff
        #         cur_a_rot_diff = cur_b_rot_diff
                
        # if cur_a_pos_diff < pos_thres and cur_a_rot_diff < ornt_thres:
        if cur_a_pos_diff < pos_thres:
            succ_nn += 1
        tot_nn += 1
    print(f"succ_nn/tot_nn: {succ_nn}/{tot_nn}")
    
def calcualte_merged_succ_info_v2(data_inst_to_opt_res_fn_a, data_inst_to_opt_res_fn_b):
    data_inst_to_opt_res_a = np.load(data_inst_to_opt_res_fn_a, allow_pickle=True).item()
    data_inst_to_opt_res_b = np.load(data_inst_to_opt_res_fn_b, allow_pickle=True).item()
    pos_thres = 0.15
    
    
    
    
    pos_thres = 0.10
    ornt_thres = 0.6981317007977318
    # ornt_thres = 0.3490658503988659
    # ornt_thres = 0.17453292519943295
    # pos_thres = 0.05
    # ornt_thres = 0.6981317007977318 # 
    # 0.17453292519943295
    # 0.2617993877991494
    # 0.3490658503988659 # 20 degree
    # 0.5235987755982988 # 30 degree
    # 0.6981317007977318 # 40 degree
    tot_tot_nn = []
    tot_succ_nn = []
    for subj_inst_idx in range(1, 11):
        tot_nn = 0
        succ_nn = 0

        target_inst_tag = 's2'

        target_inst_tag = 's1'
        target_inst_tag = f's{subj_inst_idx}_'

        for cur_inst_tag in data_inst_to_opt_res_a:
            if isinstance(cur_inst_tag, tuple):
                if target_inst_tag not in cur_inst_tag[0]: 
                    continue
            cur_data_inst_val = data_inst_to_opt_res_a[cur_inst_tag]
            cur_a_pos_diff = cur_data_inst_val['obj_pos_diff'][0].item()
            cur_a_rot_diff = cur_data_inst_val['obj_rot_diff'][0].item()
            if cur_inst_tag in data_inst_to_opt_res_b:
                cur_b_inst_val = data_inst_to_opt_res_b[cur_inst_tag]
                cur_b_pos_diff = cur_b_inst_val['obj_pos_diff'][0].item()
                cur_b_rot_diff = cur_b_inst_val['obj_rot_diff'][0].item()
                cur_a_pose_diff = cur_a_pos_diff + cur_a_rot_diff * 0.33
                cur_b_pose_diff = cur_b_pos_diff + cur_b_rot_diff * 0.33
                if cur_b_pose_diff < cur_a_pose_diff:
                    print(f"cur_inst_tag: {cur_inst_tag}, cur_a_pos_diff: {cur_a_pos_diff}, cur_a_rot_diff: {cur_a_rot_diff}, cur_b_pos_diff: {cur_b_pos_diff}, cur_b_rot_diff: {cur_b_rot_diff}")
                    cur_a_pos_diff = cur_b_pos_diff
                    cur_a_rot_diff = cur_b_rot_diff

            # if cur_a_pos_diff < pos_thres and cur_a_rot_diff < ornt_thres: # --- get the single model #
            if cur_a_pos_diff < pos_thres:
                succ_nn += 1
            tot_nn += 1
        tot_tot_nn.append(tot_nn)
        tot_succ_nn.append(succ_nn)
        print(f"succ_nn/tot_nn: {succ_nn}/{tot_nn}")
    tot_tot_nn = sum(tot_tot_nn)
    tot_succ_nn = sum(tot_succ_nn)
    res = float(tot_succ_nn) / float(tot_tot_nn)
    print(f"tot_succ_nn/tot_tot_nn: {tot_succ_nn}/{tot_tot_nn}, res: {res}")




def calcualte_merged_succ_info_all_thres(data_inst_to_opt_res_fn_a):
    data_inst_to_opt_res_a = np.load(data_inst_to_opt_res_fn_a, allow_pickle=True).item()
    # data_inst_to_opt_res_b = np.load(data_inst_to_opt_res_fn_b, allow_pickle=True).item()
    pos_thres = 0.15
    
    tot_pos_threses = [0.10, 0.10, 0.15]
    tot_ornt_threses = [0.3490658503988659, 0.6981317007977318, 0.6981317007977318]
    
    tot_succ_rates = []
    
    
    for i_idx in range(len(tot_pos_threses)):
        pos_thres = tot_pos_threses[i_idx]
        ornt_thres = tot_ornt_threses[i_idx]
        # ornt_thres = 0.3490658503988659
        # ornt_thres = 0.17453292519943295
        # pos_thres = 0.05
        # ornt_thres = 0.6981317007977318 # 
        # 0.17453292519943295
        # 0.2617993877991494
        # 0.3490658503988659 # 20 degree
        # 0.5235987755982988 # 30 degree
        # 0.6981317007977318 # 40 degree
        tot_tot_nn = []
        tot_succ_nn = []
        # for subj_inst_idx in range(1, 11):
        tot_nn = 0
        succ_nn = 0

        #     target_inst_tag = 's2'

        target_inst_tag = 's1'
        # target_inst_tag = f's{subj_inst_idx}_'

        for cur_inst_tag in data_inst_to_opt_res_a:
            if isinstance(cur_inst_tag, tuple):
                if target_inst_tag not in cur_inst_tag[0]: 
                    continue
            cur_data_inst_val = data_inst_to_opt_res_a[cur_inst_tag]
            cur_a_pos_diff = cur_data_inst_val['obj_pos_diff'][0].item()
            cur_a_rot_diff = cur_data_inst_val['obj_rot_diff'][0].item()
            # if cur_inst_tag in data_inst_to_opt_res_b:
            #     cur_b_inst_val = data_inst_to_opt_res_b[cur_inst_tag]
            #     cur_b_pos_diff = cur_b_inst_val['obj_pos_diff'][0].item()
            #     cur_b_rot_diff = cur_b_inst_val['obj_rot_diff'][0].item()
            #     cur_a_pose_diff = cur_a_pos_diff + cur_a_rot_diff * 0.33
            #     cur_b_pose_diff = cur_b_pos_diff + cur_b_rot_diff * 0.33
            #     if cur_b_pose_diff < cur_a_pose_diff:
            #         print(f"cur_inst_tag: {cur_inst_tag}, cur_a_pos_diff: {cur_a_pos_diff}, cur_a_rot_diff: {cur_a_rot_diff}, cur_b_pos_diff: {cur_b_pos_diff}, cur_b_rot_diff: {cur_b_rot_diff}")
            #         cur_a_pos_diff = cur_b_pos_diff
                    # cur_a_rot_diff = cur_b_rot_diff

            if cur_a_pos_diff < pos_thres and cur_a_rot_diff < ornt_thres: # --- get the single model #
            # if cur_a_pos_diff < pos_thres:
                succ_nn += 1
            tot_nn += 1
        tot_tot_nn.append(tot_nn)
        tot_succ_nn.append(succ_nn)
        print(f"succ_nn/tot_nn: {succ_nn}/{tot_nn}")
        
        
        tot_tot_nn = sum(tot_tot_nn)
        tot_succ_nn = sum(tot_succ_nn)
        res = float(tot_succ_nn) / float(tot_tot_nn)
        print(f"tot_succ_nn/tot_tot_nn: {tot_succ_nn}/{tot_tot_nn}, res: {res}")
        tot_succ_rates.append(res)
    print(tot_succ_rates)



def calcualte_merged_succ_info_v3(data_inst_to_opt_res_fn_a, data_inst_to_opt_res_fn_b):
    data_inst_to_opt_res_a = np.load(data_inst_to_opt_res_fn_a, allow_pickle=True).item()
    data_inst_to_opt_res_b = np.load(data_inst_to_opt_res_fn_b, allow_pickle=True).item()
    pos_thres = 0.1
    ornt_thres = 0.6981317007977318
    # pos_thres = 0.05
    # ornt_thres = 0.6981317007977318
    for subj_inst_idx in range(1, 11):
        tot_nn = 0
        succ_nn = 0
        target_inst_tag = 's2'
        target_inst_tag = 's9'
        target_inst_tag = f's{subj_inst_idx}'
        for cur_inst_tag in data_inst_to_opt_res_a:
            # if isinstance(cur_inst_tag, tuple):
            if target_inst_tag not in cur_inst_tag:
                continue
            cur_data_inst_val = data_inst_to_opt_res_a[cur_inst_tag]
            cur_a_pos_diff = cur_data_inst_val['obj_pos_diff']
            cur_a_rot_diff = cur_data_inst_val['obj_rot_diff']
            # if cur_inst_tag in data_inst_to_opt_res_b:
            #     cur_b_inst_val = data_inst_to_opt_res_b[cur_inst_tag]
            #     cur_b_pos_diff = cur_b_inst_val['obj_pos_diff'][0].item()
            #     cur_b_rot_diff = cur_b_inst_val['obj_rot_diff'][0].item()
            #     cur_a_pose_diff = cur_a_pos_diff + cur_a_rot_diff * 0.33
            #     cur_b_pose_diff = cur_b_pos_diff + cur_b_rot_diff * 0.33
            #     if cur_b_pose_diff < cur_a_pose_diff:
            #         cur_a_pos_diff = cur_b_pos_diff
            #         cur_a_rot_diff = cur_b_rot_diff #
            #     print(f"cur_inst_tag: {cur_inst_tag}, cur_a_pos_diff: {cur_a_pos_diff}, cur_a_rot_diff: {cur_a_rot_diff}, cur_b_pos_diff: {cur_b_pos_diff}, cur_b_rot_diff: {cur_b_rot_diff}")
            # if cur_a_pos_diff < pos_thres and cur_a_rot_diff < ornt_thres:
            if cur_a_pos_diff < pos_thres:
                succ_nn += 1
            tot_nn += 1
        print(f"succ_nn/tot_nn: {succ_nn}/{tot_nn}")
    


def inspect_obj_type_to_optimized_res(opt_res_fn):
    opt_res = np.load(opt_res_fn, allow_pickle=True ).item()
    print(opt_res.keys())    
    for key in opt_res:
        val = opt_res[key]
        print(f"key: {key}, val: {val}")


def inpsect_data_optimized_res_w_obj_codes(data_opt_res_fn):
    data_opt_res = np.load(data_opt_res_fn, allow_pickle=True).item()
    print(data_opt_res.keys())


def inspect_sampled_res(sampled_res_fn):
    sampled_res = np.load(sampled_res_fn, allow_pickle=True).item()
    print(sampled_res.keys())
    env_obj_codes = sampled_res['env_object_codes']
    print(env_obj_codes)



# 

# ('ori_grab_s8_stapler_pass_1', 'ori_grab_s8_stapler_pass_1') 
def inspect_inst_tag_to_opt_res(inst_tag_to_opt_res_fn):
    inst_tag_to_opt_res = np.load(inst_tag_to_opt_res_fn, allow_pickle=True).item()
    tot_keys = inst_tag_to_opt_res.keys()
    tot_keys = list(tot_keys) # 
    print(len(tot_keys))
    first_key = tot_keys[0]
    print(f"first key: {first_key}")


#
# ./uni_manip/isaacgym_rl_exp_grab_OPTFR_v2/statistics/child_task_to_fa_task.npy
def inspect_child_task_to_fa_task(ch_to_fa_fn):
    # ? #
    ch_to_fa_dict = np.load(ch_to_fa_fn, allow_pickle=True).item()
    tot_ch_to_fa_task_nn = len(ch_to_fa_dict)
    print(f"tot_ch_to_fa_task_nn: {tot_ch_to_fa_task_nn}")
    for ch_task in ch_to_fa_dict:
        fa_task = ch_to_fa_dict[ch_task]
        print(f"ch_task: {ch_task}, fa_task: {fa_task}")
        



# <<<<<<< HEAD
def parse_time_from_tracking_folder_nm(folder_nm):
    folder_nm_segs = folder_nm.split("_")
    time_segs = folder_nm_segs[-1]
    time_segs = time_segs.split("-")
    time_segs = [ float(ts) for ts in time_segs ]
    ts_to_secs = [ 24 * 60 * 60, 60 * 60, 60, 1 ]
    time_secs = 0
    
    for i_ts, cur_ts in enumerate(time_segs):
        time_secs += cur_ts * ts_to_secs[i_ts]
    return time_secs

def move_tested_samples(samples_root, target_folder):
    tot_samples = os.listdir(samples_root)
    # /root/diffsim/IsaacGymEnvs2/isaacgymenvs/runs_generalist_x/tracking_ori_grab_s9_airplane_fly_1_obs_pure_state_wref_wdelta_density_500.0_trans_0.5_rot_0.5_goalcond_False_kinebias_t0.5r0.5f20_rfd_0.3_rh_0.5_05-22-00-06
    tracking_st_tag = "tracking_ori_grab_"
    tot_samples = [
        fn for fn in tot_samples if fn[: len(tracking_st_tag)] == tracking_st_tag
    ]
    
    tot_eval_fns_w_time = []
    for cur_fn in tot_samples:
        cur_time_secs = parse_time_from_tracking_folder_nm(cur_fn)
        tot_eval_fns_w_time.append((cur_fn, cur_time_secs))
        
    sorted_eval_fns = sorted(tot_eval_fns_w_time, key=lambda x: x[1])
    # print(sorted_eval_fns)
    
    # parse the 
    for idx in range(0, len(sorted_eval_fns) - 9):
        cur_fn = sorted_eval_fns[idx][0] # sorted evals fns #
        
        # cur_exp_obj_name = parse_obj_type_from_taco_grab_folder_fn(cur_fn)
        
        # if exclude_existing_data_inst_to_opt_res is not None:
        #     if cur_exp_obj_name in exclude_existing_data_inst_tags:
        #         continue
        
        # get full fn from the samples root and cur_fn #
        cur_full_fn = os.path.join(samples_root, cur_fn)
        
        
        print(f"mv {cur_full_fn} {target_folder}/")
        os.system(f"mv {cur_full_fn} {target_folder}/")
    
        

# =======

def inspect_child_task_to_fa_task_list(ch_to_fa_fn):
    # ? #
    ch_to_fa_dict = np.load(ch_to_fa_fn, allow_pickle=True).item()
    tot_ch_to_fa_task_nn = len(ch_to_fa_dict)
    print(f"tot_ch_to_fa_task_nn: {tot_ch_to_fa_task_nn}")
    tot_info_nn = 0
    for ch_task in ch_to_fa_dict:
        cur_fa_info_list = ch_to_fa_dict[ch_task]
        tot_info_nn += len(cur_fa_info_list)
    print(f"tot_info_nn: {tot_info_nn}")
    # for ch_task in ch_to_fa_dict:
    #     fa_task = ch_to_fa_dict[ch_task]
    #     print(f"ch_task: {ch_task}, fa_task: {fa_task}")


def inspect_saved_samples(saved_samples_fn):
    saved_samples = np.load(saved_samples_fn, allow_pickle=True ).item()
    print(saved_samples.keys())
    
    data_nm = saved_samples['data_nm']
    print(data_nm)


def save_obj_type_to_general_imit_policy_weights():
    policy_weights_fn = "./runs/tracking_ori_grab_s2_apple_lift_obs_pure_state_wref_wdelta_density_500.0_trans_0.5_rot_0.5_goalcond_False_kinebias_t0.5r0.5f20_rfd_0.3_rh_0.5_07-00-51-23/nn/tracking_ori_grab_s2_apple_lift_obs_pure_state_wref_wdelta_density_500.0_trans_0.5_rot_0.5_goalcond_False_kinebias_t0.5r0.5f20_rfd_0.3_rh_0.5.pth"
    obj_type_to_policy_weights = {
        'apple': policy_weights_fn
    }
    policy_folder = "/".join(policy_weights_fn.split("/")[:-1])
    obj_type_to_policy_weights_fn = os.path.join(policy_folder, "obj_type_to_policy_weights.npy")
    np.save(obj_type_to_policy_weights_fn, obj_type_to_policy_weights)
    print(f"obj_type_to_policy_weights_fn: {obj_type_to_policy_weights_fn}"  )


def inspect_eval_dict(eval_dict_fn):
    eval_dict = np.load(eval_dict_fn, allow_pickle=True).item()
    tot_keys = list(eval_dict.keys())
    print(tot_keys[0])
    for subj_idx in range(0, 11):
        cur_subj_tag = f"_s{subj_idx}"
        tot_subj_nn = 0
        for key in eval_dict:
            if cur_subj_tag in key[0]:
                tot_subj_nn += 1
                
                # cur_val = eval_dict[key]
                # print(f"key: {key}, cur_val: {cur_val}")
        print(f"subj_tag: {cur_subj_tag}, tot_subj_nn: {tot_subj_nn}")


def inspect_eval_dict_grab_nf_300(eval_dict_fn):
    eval_dict = np.load(eval_dict_fn, allow_pickle=True).item()
    tot_keys = list(eval_dict.keys())
    print(tot_keys[0])


# and use 
def inspect_taco_eval_dict(taco_eval_dict_fn):
    taco_eval_dict = np.load(taco_eval_dict_fn, allow_pickle=True).item()
    tot_eval_nns = len(taco_eval_dict)
    print(f"tot_eval_nns: {tot_eval_nns}")
    eval_root  = "./uni_manip/isaacgym_rl_exp_taco_grab_interpseq_interpfr_60_interpfr2_60_nntrans_40_eval"
    tot_eval_folders = os.listdir(eval_root)
    st_tag = "tracking_TACO"
    # ./uni_manip/isaacgym_rl_exp_taco_grab_interpseq_interpfr_60_interpfr2_60_nntrans_40_eval/tracking_TACO_taco_20230928_045_INTERPSEQ_ori_grab_s2_phone_call_1_obs_pure_state_wref_wdelta_density_500.0_trans_0.5_rot_0.5_goalcond_False_kinebias_t0.5r0.5f20_rfd_0.3_rh_0.5_interpfr_60_interpfr2_60_nntrans_40_04-14-35-12
    tot_eval_folders = [
        fn for fn in tot_eval_folders if fn[: len(st_tag)] == st_tag
    ]
    print(len(tot_eval_folders))


def get_taco_eval_dict(taco_eval_dict_fn):
    taco_eval_dict = np.load(taco_eval_dict_fn, allow_pickle=True).item()
    print(len(taco_eval_dict))

# 
# larger than 50 and also not good performed? #
# not good performed res # ? 
def compare_diff_opt_res_ori_w_samples(obj_type_to_optimized_res_fn, opt_res_fn_ori, opt_res_fn_samples, rew_threshold=50.0):
    obj_type_to_optimized_res = np.load(obj_type_to_optimized_res_fn, allow_pickle=True).item()
    opt_res_ori = np.load(opt_res_fn_ori, allow_pickle=True).item()
    opt_res_samples = np.load(opt_res_fn_samples, allow_pickle=True).item()
    better_nn = 0
    tot_nn = 0
    
    for key in obj_type_to_optimized_res:
        val = obj_type_to_optimized_res[key]
        key_rew = val[0]
        if key_rew < rew_threshold:
            key_tuple = (key, key)
            if key_tuple in opt_res_ori and key_tuple in opt_res_samples:
                res_ori = opt_res_ori[key_tuple]
                res_samples = opt_res_samples[key_tuple]
                res_ori_pos_diff = res_ori['obj_pos_diff'][0].item()
                res_samples_pos_diff = res_samples['obj_pos_diff'][0].item()
                if res_ori_pos_diff  > res_samples_pos_diff:
                    print(f"key: {key}, res_ori_pos_diff: {res_ori_pos_diff}, res_samples_pos_diff: {res_samples_pos_diff}")
                    better_nn += 1
                tot_nn += 1
    print(f"better_nn/tot_nn: {better_nn}/{tot_nn}")


def select_samples_fr_ori_cur_optimized_res(obj_type_to_optimized_res_fn, opt_res_fn_samples_fn):
    obj_type_to_optimized_res = np.load(obj_type_to_optimized_res_fn, allow_pickle=True).item()
    opt_res_fn_samples = np.load(opt_res_fn_samples_fn, allow_pickle=True).item()
    minn_thres = 50.0
    obj_type_to_opt_pos_diff = {}
    for key in opt_res_fn_samples:
        obj_type = key[0]
        obj_pos = opt_res_fn_samples[key]['obj_pos_diff'][0].item()
        obj_type_to_opt_pos_diff[obj_type] = obj_pos
    sorted_obj_type_pos_diff_items = sorted(obj_type_to_opt_pos_diff.items(), key=lambda x: -x[1])
    selected_obj_types = []
    # selected_obj_types 
    for i_obj_type in range(len(sorted_obj_type_pos_diff_items)):
        cur_obj_type, cur_obj_pos_diff = sorted_obj_type_pos_diff_items[i_obj_type]
        cur_obj_rew =   obj_type_to_optimized_res[cur_obj_type][0]
        if cur_obj_rew > minn_thres:
            selected_obj_types.append(cur_obj_type)
    print(len(selected_obj_types))
    selected_obj_types_idxes = {
        obj_type: i_obj_type for i_obj_type, obj_type in enumerate(selected_obj_types)
    }
    samples_root_folder = "/".join(opt_res_fn_samples_fn.split("/")[: -1])
    selected_obj_types_idxes_sv_fn = os.path.join(samples_root_folder, "selected_obj_types_idxes.npy")
    np.save(selected_obj_types_idxes_sv_fn, selected_obj_types_idxes)
    print(f"selected_obj_types_idxes_sv_fn: {selected_obj_types_idxes_sv_fn}")
    # 


def inspect_samples(opt_res_fn_samples):
    opt_res_samples = np.load(opt_res_fn_samples, allow_pickle=True).item()
    opt_obj_key_w_pos_diff = {}
    for key in opt_res_samples:
        obj_type = key[0]
        opt_pos_diff = opt_res_samples[key]['obj_pos_diff'][0].item()
        opt_obj_key_w_pos_diff[obj_type] = opt_pos_diff
    sorted_opt_obj_key_w_pos_diff = sorted(opt_obj_key_w_pos_diff.items(), key=lambda x: x[1])
    print(sorted_opt_obj_key_w_pos_diff[:10])
    

def inspect_obj_type_to_optimized_res(obj_type_to_optimized_res_fn):
    obj_type_to_optimized_res = np.load(obj_type_to_optimized_res_fn, allow_pickle=True).item()
    print(f"obj_type_to_optimized_res: {len(obj_type_to_optimized_res)}")
    tot_nn = 0
    above_thres_nn = 0
    for key in obj_type_to_optimized_res:
        cur_optimized_res = obj_type_to_optimized_res[key]
        rew = cur_optimized_res[0]
        if rew > 50:
            above_thres_nn += 1
        tot_nn += 1
    print(f"above_thres_nn/tot_nn: {above_thres_nn}/{tot_nn}")



def get_taco_meshes_fn():
    folder_fn ="/root/diffsim/UniDexGrasp/dexgrasp_policy/assets/meshdatav3_scaled/sem"
    tot_taco_mesh_fns = os.listdir(folder_fn)
    tot_taco_mesh_fns = [
        fn for fn in tot_taco_mesh_fns if fn[: len("taco")] == "taco" and "_modifed" not in fn
    ]
    return tot_taco_mesh_fns
    

def inspect_taco_mesh_folders():
    folder_fn ="/root/diffsim/UniDexGrasp/dexgrasp_policy/assets/meshdatav3_scaled/sem"
    tot_taco_mesh_fns = os.listdir(folder_fn)
    tot_taco_mesh_fns = [
        fn for fn in tot_taco_mesh_fns if fn[: len("taco")] == "taco" and "_modifed" not in fn
    ]
    print(len(tot_taco_mesh_fns))
    print(f"tot_taco_mesh_fns: {tot_taco_mesh_fns[:10]}")
    day_flag_to_nn = {}
    for cur_taco_fn in tot_taco_mesh_fns:
        cur_taco_segs = cur_taco_fn.split("_")
        day_flag = cur_taco_segs[1]
        if day_flag not in day_flag_to_nn:
            day_flag_to_nn[day_flag] = 1
        else:
            day_flag_to_nn[day_flag] += 1
    print(day_flag_to_nn)


def inspect_taco_optimized_res(opt_res_fn):
    opt_res=np.load(opt_res_fn, allow_pickle=True).item()
    # ./uni_manip/isaacgym_rl_exp_taco_grab_interpseq_interpfr_60_interpfr2_60_nntrans_40_eval/statistics/data_inst_tag_to_optimized_res.npy
    for key in opt_res:
        key_val = opt_res[key]
        if "./data/TACO_Tracking_PK/" not in key_val[0]:
            print(f"key: {key}, key_val: {key_val}")
    print(f"len(opt_res): {len(opt_res)}")
    return opt_res

def construct_all_taco_opt_to_optimized_res():
    
    opt_res_fn = "./uni_manip/isaacgym_rl_exp_taco_grab_interpseq_interpfr_60_interpfr2_60_nntrans_40_eval/statistics/data_inst_tag_to_optimized_res.npy"
    # data_inst_tag_to_optimized_res_beta_v2.npy
    # opt_res_fn = "./uni_manip/isaacgym_rl_exp_taco_grab_interpseq_interpfr_60_interpfr2_60_nntrans_40_eval/statistics/data_inst_tag_to_optimized_res_beta_v2.npy"
    real_opt_res = inspect_taco_optimized_res(opt_res_fn)
    # real opt res # 
    tot_opt_res = {}
    tot_taco_inst_tags = get_taco_meshes_fn()
    for cur_taco_inst_tag in tot_taco_inst_tags:
        cur_taco_inst_tag_tuple = (cur_taco_inst_tag, "ori_grab_s2_phone_call_1")
        if cur_taco_inst_tag_tuple in real_opt_res:
            tot_opt_res[cur_taco_inst_tag_tuple] = real_opt_res[cur_taco_inst_tag_tuple]
        else:
            # 
            kine_fn = f"./data/TACO_Tracking_PK/data/passive_active_info_ori_grab_s2_phone_call_1_interped_{cur_taco_inst_tag}_v2_interpfr_60_interpfr2_60_nntrans_40.npy"
            print(f"cur_taco_inst_tag: {cur_taco_inst_tag}")
            tot_opt_res[cur_taco_inst_tag_tuple] = [ kine_fn ]
    tot_opt_res_sv_fn = "./uni_manip/isaacgym_rl_exp_taco_grab_interpseq_interpfr_60_interpfr2_60_nntrans_40_eval/statistics/data_inst_tag_to_optimized_res_tot.npy"
    # opt_res_fn = 
    np.save(tot_opt_res_sv_fn, tot_opt_res) # tot opt res #
    print(f"tot_opt_res_sv_fn: {tot_opt_res_sv_fn}")
    print(f"len(tot_opt_res): {len(real_opt_res)}")
    # print()



def inspect_obj_type_to_latent_folders(obj_type_to_latent_folders_fn):
    obj_type_to_latent_folders = np.load(obj_type_to_latent_folders_fn, allow_pickle=True).item()
    tot_nn = 0
    for obj_type in obj_type_to_latent_folders:
        
        if 'taco' in obj_type:
            tot_nn += 1
    print(tot_nn)


def filter_inst_tag_to_all_res():
    tot_opt_res_sv_fn = "./uni_manip/isaacgym_rl_exp_taco_grab_interpseq_interpfr_60_interpfr2_60_nntrans_40_eval/statistics/data_inst_tag_to_optimized_res_tot.npy"
    opt_res = np.load(tot_opt_res_sv_fn, allow_pickle=True).item()
    
    obj_type_to_latent_features = "./uni_manip/tds_diffusion_exp/allegro_tracking_kine_diff_AE_Diff_trainAE_vnewv2_wtacodata_samples_/obj_type_to_obj_feat.npy"
    obj_type_to_latent_features = np.load(obj_type_to_latent_features, allow_pickle=True).item()
    filtered_inst_tag_to_opt_res = {}
    for key in opt_res:
        if key[0] in obj_type_to_latent_features:
            filtered_inst_tag_to_opt_res[key] = opt_res[key]
    print(len(filtered_inst_tag_to_opt_res))
    filtered_inst_tag_to_opt_res_fn = "./uni_manip/isaacgym_rl_exp_taco_grab_interpseq_interpfr_60_interpfr2_60_nntrans_40_eval/statistics/data_inst_tag_to_optimized_res_tot_filtered.npy"
    np.save(filtered_inst_tag_to_opt_res_fn, filtered_inst_tag_to_opt_res)
    print(f"filtered_inst_tag_to_opt_res_fn: {filtered_inst_tag_to_opt_res_fn}")
    
    
def inspect_inst_tag_to_opt_res():
    inst_tag_to_opt_res_fn = "./uni_manip/isaacgym_rl_exp_taco_grab_interpseq_interpfr_60_interpfr2_60_nntrans_40_eval/statistics/data_inst_tag_to_optimized_res_beta_v2.npy"
    # inspect_inst_tag_to_opt_res(inst_tag_to_opt_res_fn)
    inst_tag_to_opt_res = np.load(inst_tag_to_opt_res_fn, allow_pickle=True).item()
    date_to_nn = {}
    for key in  inst_tag_to_opt_res:
        grab_key = key[0]
        grab_key_segs = grab_key.split("_")
        grab_key_date = grab_key_segs[1]
        if grab_key_date not in date_to_nn:
            date_to_nn[grab_key_date] = 1
        else:
            date_to_nn[grab_key_date] += 1
    print(date_to_nn)
        
        
        
def reduce_kine_infos(grab_tracking_folder):
    # ./data/GRAB_Tracking_PK/data/passive_active_info_ori_grab_s1_airplane_offhand_1_nf_300.npy
    tot_fns = os.listdir(grab_tracking_folder)
    # tot_fns = [
    #     fn for fn in tot_fns if '_nf_300' in fn
    # ]
    tot_fns = [
        fn for fn in tot_fns if '_nf_300' not in fn
    ]
    reduced_keys = [
        'object_transl', 'object_rot_quat', 'robot_delta_states_weights_np'
    ]
    # reudced_folder = "./data/GRAB_Tracking_PK"
    # reduced_folder = "./data/GRAB_Tracking_PK_reduced_300/data"
    reduced_folder = "./data/GRAB_Tracking_LEAP_PK_Reduced/data"
    for fn in tot_fns:
        cur_full_fn = os.path.join(grab_tracking_folder, fn)
        data_dict = np.load(cur_full_fn, allow_pickle=True).item()
        print(data_dict.keys())
        reduced_data_dict = {
            key: data_dict[key] for key in reduced_keys
        }
        reduced_fn = os.path.join(reduced_folder, fn)
        np.save(reduced_fn, reduced_data_dict)
        print(f"reduced_fn: {reduced_fn}")
        



def calculate_evaluation_metrics(data_optimized_res_nn, data_inst_tag, index=None):
    optimized_res = np.load(data_optimized_res_nn, allow_pickle=True).item()
    
    # if '_nf_300' in data_inst_tag:
    #     kinematics_data_root = "./data/GRAB_Tracking_PK"
    
    kinematics_data_root = "./data/GRAB_Tracking_PK_reduced/data"
    
    if data_inst_tag.endswith(".npy"):
        cur_inst_kine_data_fn = data_inst_tag
    else:
        cur_inst_kine_data_fn = f"passive_active_info_{data_inst_tag}.npy"
        cur_inst_kine_data_fn = os.path.join(kinematics_data_root, cur_inst_kine_data_fn)
    
    # passive #
    save_info = np.load(cur_inst_kine_data_fn, allow_pickle=True).item()
        
        
    # hand_qs = save_info['robot_delta_states_weights_np'][ : ]
    # hand_qs = hand_qs[: , : ]
    
    goal_obj_trans = save_info['object_transl']
    goal_obj_rot_quat = save_info['object_rot_quat']

    goal_obj_pose = np.concatenate(
        [goal_obj_trans, goal_obj_rot_quat],  axis=-1
    )
    
    tot_optimized_obj_pose = []
    tot_optimized_hand_qs = []
    tot_optimized_hand_qtars = []
    # object_pose #
    tot_ts = list(optimized_res.keys())
    tot_ts = [ cur_ts for cur_ts in tot_ts if isinstance(cur_ts, int) ]
    tot_ts = sorted(tot_ts)
    for ts in tot_ts: # 
        cur_optimized_obj_pose = optimized_res[ts]['object_pose']
        tot_optimized_obj_pose.append(cur_optimized_obj_pose)
        
        cur_optimized_hand_qs = optimized_res[ts]['shadow_hand_dof_pos']
        cur_optimized_hand_qtars = optimized_res[ts]['shadow_hand_dof_tars']
        tot_optimized_hand_qs.append(cur_optimized_hand_qs)
        tot_optimized_hand_qtars.append(cur_optimized_hand_qtars)
        
        
    tot_optimized_obj_pose = np.stack(tot_optimized_obj_pose, axis=1) # nn_envs x nn_ts x 7 #
    tot_optimized_hand_qs = np.stack(tot_optimized_hand_qs, axis=1)
    tot_optimized_hand_qtars = np.stack(tot_optimized_hand_qtars, axis=1)
    
    if index is not None:
        tot_optimized_obj_pose = tot_optimized_obj_pose[index: index + 1]
        tot_optimized_hand_qs = tot_optimized_hand_qs[index: index + 1]
        tot_optimized_hand_qtars = tot_optimized_hand_qtars[index: index + 1]
    
    tot_env_diff_obj_pos, tot_env_diff_obj_rot = [], []
    tot_env_weighted_obj_pose_diff = []
    w_pos, w_ornt = 1.0, 0.33
    for i_env in range(tot_optimized_obj_pose.shape[0]):
        cur_optimized_obj_pose = tot_optimized_obj_pose[i_env]
        cur_diff_obj_pos, cur_diff_obj_rot = calculate_obj_traj_diffs(cur_optimized_obj_pose, goal_obj_pose)
        tot_env_diff_obj_pos.append(cur_diff_obj_pos)
        tot_env_diff_obj_rot.append(cur_diff_obj_rot)
        weighted_diff_obj_pose = w_pos * cur_diff_obj_pos + w_ornt * cur_diff_obj_rot
        tot_env_weighted_obj_pose_diff.append(weighted_diff_obj_pose)
    
    tot_env_weighted_obj_pose_diff = np.array(tot_env_weighted_obj_pose_diff)
    sorted_envs_idxes = np.argsort(tot_env_weighted_obj_pose_diff)
    tot_env_diff_obj_pos = np.array(tot_env_diff_obj_pos)
    tot_env_diff_obj_rot = np.array(tot_env_diff_obj_rot)
    # top # radius # 
    new_optimized_info = {
        'optimized_obj_pose': tot_optimized_obj_pose[sorted_envs_idxes],
        'optimized_hand_qs': tot_optimized_hand_qs[sorted_envs_idxes],
        'optimized_hand_qtars': tot_optimized_hand_qtars[sorted_envs_idxes],
        'obj_pose_diff': tot_env_weighted_obj_pose_diff[sorted_envs_idxes],
        'obj_pos_diff': tot_env_diff_obj_pos[sorted_envs_idxes],
        'obj_rot_diff': tot_env_diff_obj_rot[sorted_envs_idxes],
    }
    return new_optimized_info
 
 
 
 
def calculate_metrics(data_inst_tag, best_eval_info_fn):
    best_eval_info = np.load(best_eval_info_fn , allow_pickle=True).item()
    print(best_eval_info.keys()) 
    
    # dict_keys(['optimized_obj_pose', 'optimized_hand_qtars', 'optimized_hand_qs', 'obj_pose_diff', 'best_obj_pose_diff', 'best_obj_pos_diff', 'best_obj_rot_diff'])
    optimized_hand_qs = best_eval_info['optimized_hand_qs'][0]
    best_obj_pos_diff = best_eval_info['best_obj_pos_diff']
    best_obj_rot_diff = best_eval_info['best_obj_rot_diff']

    #  optimized_res = np.load(dataz  _optimized_res_nn, allow_pickle=True).item()
    
    # if '_nf_300' in data_inst_tag:
    #     kinematics_data_root = "./data/GRAB_Tracking_PK"
    
    kinematics_data_root = "./data/GRAB_Tracking_PK_reduced/data"
     
    # if data_inst_tag.endswith(".npy"): # data inst tag #
    #     cur_inst_kine_data_fn = data_inst_tag
    # else:
    cur_inst_kine_data_fn = f"passive_active_info_{data_inst_tag}.npy"
    cur_inst_kine_data_fn = os.path.join(kinematics_data_root, cur_inst_kine_data_fn)
    
    # passive #
    save_info = np.load(cur_inst_kine_data_fn, allow_pickle=True).item()
        
        
    goal_hand_qs = save_info['robot_delta_states_weights_np'][ : ]
    # hand_qs = hand_qs[: , : ]
    
    goal_obj_trans = save_info['object_transl']
    goal_obj_rot_quat = save_info['object_rot_quat']

    # goal_obj_pose = np.concatenate(
    #     [goal_obj_trans, goal_obj_rot_quat],  axis=-1
    # )
    
    clipped_ws = min(optimized_hand_qs.shape[0], goal_hand_qs.shape[0])
    optimized_hand_qs = optimized_hand_qs[:clipped_ws, :]
    goal_hand_qs = goal_hand_qs[:clipped_ws, :]
    
    opt_trans, opt_glbrot, opt_jointangles = optimized_hand_qs[..., :3], optimized_hand_qs[..., 3:6], optimized_hand_qs[..., 6:]
    goal_trans, goal_glbrot, goal_jointangles = goal_hand_qs[..., :3], goal_hand_qs[..., 3:6], goal_hand_qs[..., 6:]
    diff_opt_trans = np.mean(np.linalg.norm(
        (opt_trans - goal_trans), axis=-1, ord=2
    ))
    # between the radius differences #
    diff_opt_glb_rot = np.mean(
        np.mean(
            np.abs( (opt_glbrot - goal_glbrot) ), axis=-1
        )
    )
    diff_opt_jointangles = np.mean(
        np.mean(
            np.abs(opt_jointangles - goal_jointangles), axis=-1
        )
    )
    # weighted_hand_diff = 0.33 * diff_opt_trans + 0.33 * diff_opt_glb_rot + 0.33 * diff_opt_jointangles
    # print()
    
    # diff_opt_jointangles
    # 
    weighted_hand_diff_glb = 0.5 *  diff_opt_trans + 0.5  * diff_opt_glb_rot

    print(best_obj_pos_diff, best_obj_rot_diff,  weighted_hand_diff_glb, diff_opt_jointangles, )

    eval_metrics = {
        'hand_glb_diff': weighted_hand_diff_glb.item(),
        'hand_joint_diff': diff_opt_jointangles.item(),
        'obj_pos_diff': best_obj_pos_diff[0],
        'obj_rot_diff': best_obj_rot_diff[0]
    }
    return eval_metrics

#         cur_latent_folder = obj_type_to_latent_folders[obj_type]
#         print(f"obj_type: {obj_type}, cur_latent_folder: {cur_latent_folder}")
# 1104 
# 1104


def inspect_data_inst_tag_to_optimized_res_metrics(inst_tag_to_opt_res_fn):
    inst_tag_to_opt_res = np.load(inst_tag_to_opt_res_fn, allow_pickle=True).item()
    tot_eval_metrics_dict = {}
    for key in inst_tag_to_opt_res:
        val = inst_tag_to_opt_res[key]
        # print(f"key: {key}, val: {val}")
        inst_tag = key[0]
        if '_s1_' not in inst_tag:
            continue
        eval_res_fn = val[0]
        best_eval_res_fn = eval_res_fn.replace(".npy", "_sorted.npy").replace(".npy", "_best.npy")
        if not os.path.exists(best_eval_res_fn):
            continue
        cur_eval_metrics_dict = calculate_metrics(inst_tag, best_eval_res_fn)
        for eval_key in cur_eval_metrics_dict:
            if eval_key not in tot_eval_metrics_dict:
                tot_eval_metrics_dict[eval_key] = [ cur_eval_metrics_dict[eval_key] ]
            else:
                tot_eval_metrics_dict[eval_key].append(cur_eval_metrics_dict[eval_key])
    for eval_key in tot_eval_metrics_dict:
        tot_eval_vals=  tot_eval_metrics_dict[eval_key]
        sorted_tot_eval_vals = sorted(tot_eval_vals) 
        medium_val = sorted_tot_eval_vals[len(sorted_tot_eval_vals) // 2]
        tot_eval_vals = np.array(tot_eval_vals)
        print(f"eval_key: {eval_key}, mean: {np.mean(tot_eval_vals)}, medium: {medium_val}")
        




def copy_optimized_infos(interested_keys, data_inst_to_optimized_res_fn, dst_folder=None):
    # keys and the optimized res fn #
    # interested_keys = ["taco_20231104_035", "taco_20231027_008", "taco_20231020_036"]
    # data_inst_to_optimized_res_fn = "./uni_manip/isaacgym_rl_exp_taco_grab_interpseq_interpfr_60_interpfr2_60_nntrans_40_eval/statistics/data_inst_tag_to_optimized_res_beta_v2.npy"
    
    # interested_keys = ['taco_20231024_176', 'taco_20231024_045', 'taco_20231024_169', 'taco_20231024_124', 'taco_20231024_070']
    # data_inst_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_taco_400_train_wcustomidamping_samples_/statistics/data_inst_tag_to_optimized_res.npy'
    
    
    data_inst_to_optimized_res = np.load(data_inst_to_optimized_res_fn, allow_pickle=True).item()
    
    if interested_keys is None:
        interested_keys = list(data_inst_to_optimized_res.keys())
        interested_keys = [ cur_key[0] for cur_key in interested_keys ]
    
    if dst_folder is None:
        dst_folder = "/root/diffsim/IsaacGymEnvs2/assets/optimized_res"
    os.makedirs(dst_folder, exist_ok=True)
    print(list(data_inst_to_optimized_res.keys())[0],list(data_inst_to_optimized_res.values())[0] )
    for key in interested_keys:
        if 'taco' in key:
            cur_key_tuple =    (key, 'ori_grab_s2_phone_call_1')
            kine_ref_fn = f"./data/TACO_Tracking_PK/data/passive_active_info_ori_grab_s2_phone_call_1_interped_{key}_v2_interpfr_60_interpfr2_60_nntrans_40.npy"
        else:
            cur_key_tuple = (key, key)
            # if '_s1_' not in key:
            #     continue
            if '_nf_300' in key:
                kine_ref_fn = f"./data/GRAB_Tracking_PK_reduced_300/data/passive_active_info_{key}.npy"
            else:
                kine_ref_fn = f"./data/GRAB_Tracking_PK_reduced/data/passive_active_info_{key}.npy"
            # ./data/GRAB_Tracking_PK_reduced_300/data/passive_active_info_ori_grab_s1_banana_peel_1_nf_300.npy
            # kine_ref_fn = f"./data/GRAB_Tracking_PK_reduced_300/data/passive_active_info_{key}.npy"
            
        
        
        opt_res = data_inst_to_optimized_res[cur_key_tuple][0]
        
        opt_res_fn = opt_res.replace(".npy", "_sorted.npy").replace(".npy", "_best.npy")
        if not os.path.exists(opt_res_fn):
            opt_res_fn = opt_res.replace(".npy", "_sorted.npy").replace(".npy", "_best_vv.npy")
        
        if not os.path.exists(opt_res_fn):
            continue
        
        opt_folder = opt_res.split("/")[-2]
        cur_dst_folder = os.path.join(dst_folder, opt_folder)
        os.makedirs(cur_dst_folder, exist_ok=True)
        
        cp_cmd = f"cp {opt_res_fn} {cur_dst_folder}/"
        print(cp_cmd)
        os.system(cp_cmd)
        
        
        
        kine_sv_fn = os.path.join(cur_dst_folder, kine_ref_fn.split("/")[-1])
        cp_cmd =    f"cp {kine_ref_fn} {kine_sv_fn}"
        print(cp_cmd)
        os.system(cp_cmd)


def inspect_optimized_res_grab_long(inst_tag_to_optimized_res_fn):
    inst_tag_to_optimized_res = np.load(inst_tag_to_optimized_res_fn, allow_pickle=True).item()

    
    
def inpsect_data_inst_tag_to_best_optimized_res(inst_tag_to_best_opt_res):
    inst_tag_to_best_opt_res = np.load(inst_tag_to_best_opt_res, allow_pickle=True).item()
    print(len(inst_tag_to_best_opt_res))
    for key in inst_tag_to_best_opt_res:
        cur_opt_res_dict = inst_tag_to_best_opt_res[key]
        print(cur_opt_res_dict.keys())
        break
    
    data_inst_tag_to_opt_res = inst_tag_to_best_opt_res.items()
    data_inst_tag_to_opt_res = sorted(data_inst_tag_to_opt_res, key=lambda x: x[1]['obj_pos_diff'][0].item())
    print(data_inst_tag_to_opt_res[:10])
    
    # best optimized res #
    
def get_data_inst_tag_to_valid_optimized_res(inst_tag_to_best_opt_res, inst_tag_to_opt_res_fn, cur_root_path):
    inst_tag_to_best_opt_res = np.load(inst_tag_to_best_opt_res, allow_pickle=True).item()
    inst_tag_to_opt_res = np.load(inst_tag_to_opt_res_fn, allow_pickle=True).item()
    
    for key in inst_tag_to_best_opt_res:
        cur_opt_res_dict = inst_tag_to_best_opt_res[key]
        print(cur_opt_res_dict.keys())
        break
    
    data_inst_tag_to_opt_res = inst_tag_to_best_opt_res.items()
    data_inst_tag_to_opt_res = sorted(data_inst_tag_to_opt_res, key=lambda x: x[1]['obj_pos_diff'][0].item())
    print(data_inst_tag_to_opt_res[:10])
    top_k = 50
    data_inst_tag_to_opt_res = data_inst_tag_to_opt_res[: top_k ] 
    topk_inst_tag_to_opt_res_fn = {}
    # get he topk instnaces results #
    for cur_item in data_inst_tag_to_opt_res:
        cur_inst_tag = cur_item[0]
        tuple_key = cur_inst_tag #  (cur_inst_tag, cur_inst_tag)
        cur_inst_opt_res_fn = inst_tag_to_opt_res[tuple_key][0]
        # /root/diffsim/IsaacGymEnvs2/assets/optimized_res_grab_300_demo
        # ./uni_manip/isaacgym_rl_exp_grab_300_train_wcustomidamping_samples_realv3_
        ori_root_path = "./uni_manip/isaacgym_rl_exp_grab_300_train_wcustomidamping_samples_realv3_"
        # cur_root_path = "/root/diffsim/IsaacGymEnvs2/assets/optimized_res_grab_300_demo"
        cur_cur_inst_opt_res_fn = cur_inst_opt_res_fn.replace(ori_root_path, cur_root_path)
        # cur cur inst opt res fn # 
        cur_cur_inst_opt_res_fn = cur_cur_inst_opt_res_fn.replace(".npy", "_sorted.npy").replace(".npy", "_best.npy")
        topk_inst_tag_to_opt_res_fn[cur_inst_tag[0]] = cur_cur_inst_opt_res_fn # 
    cur_statistics_sv_path = os.path.join(cur_root_path, 'statistics')
    cur_statistics_sv_nm = f"data_inst_tag_to_optimized_res_top{top_k}.npy"
    cur_statistics_sv_fn = os.path.join(cur_statistics_sv_path, cur_statistics_sv_nm)
    np.save(cur_statistics_sv_fn, topk_inst_tag_to_opt_res_fn)
    print(f"cur_statistics_sv_fn: {cur_statistics_sv_fn}")
    

def inspect_topk_best_optimized_res_fn(best_optimized_res_fn):
    best_optimized_res = best_optimized_res_fn #  '/root/diffsim/IsaacGymEnvs2/assets/optimized_res_grab_300_demo/data_inst_tag_to_optimized_res_top50.npy'
    best_optimized_res = np.load(best_optimized_res, allow_pickle=True).item()
    for key in best_optimized_res:
        val = best_optimized_res[key]
        print(f"key: {key}, val: {val}")    

# top 50 # 
# def #
def combine_two_dict_fn(dict_fn_a, dict_fn_b):
    new_dict_to_fn = {}
    dict_a = np.load(dict_fn_a, allow_pickle=True).item()
    dict_b = np.load(dict_fn_b , allow_pickle=True).item()
    for ins_tag in dict_a:
        new_dict_to_fn[ins_tag] = dict_a[ins_tag]
    for ins_tag in dict_b:
        new_dict_to_fn[ins_tag] = dict_b[ins_tag]
    new_dict_to_fn_sv_fn = dict_fn_a.replace(".npy", "_cbd.npy")
    np.save(new_dict_to_fn_sv_fn, new_dict_to_fn)
    print(f"new_dict_to_fn saved to {new_dict_to_fn_sv_fn}")
    
    
def inspect_obj_type_to_optimized_res(dict_fn):
    obj_type_to_optimized_res = np.load(dict_fn, allow_pickle=True).item()
    for obj_type in obj_type_to_optimized_res:
        cur_opt_res = obj_type_to_optimized_res[obj_type]
        cur_opt_rew = cur_opt_res[0]
        print(f"obj_type: {obj_type}, cur_opt_rew: {cur_opt_rew}")  
        

# datanm_to_replay_fn_dict_fn #

# 
# succ_nn/tot_nn: 37/82 --- #
# 580 / 1113 # -- about half of the training set #
# so the question is can we get better results for trajectories using special sampling strategies? ## using all #
# 

# and the rewardis negative #
# seems that it is hard to accomplish the task? #
# python utils/grab_data_utils.py

# array[0].item() -- it should be the value in the dictionary #

# 5 cm -- 0.05
# 10 cm -- 0.1

# succ_nn/tot_nn: 57/84 -- origianl # succ_nn/tot_nn: 60/84 --- add the res from optimized together #
# succ_nn/tot_nn: 34/82 -- train together #
# succ_nn/tot_nn: 28/92 -- direct diffusion samples #



def inspect_demo_best_sv_fns(best_sv_res_fn):
    best_sv_res = np.load(best_sv_res_fn, allow_pickle=True).item()
    for key in best_sv_res:
        print(key )
        


# 0.08726646259971647
# 0.17453292519943295
# 0.2617993877991494
# 0.3490658503988659 # 20 degree
# 0.5235987755982988 # 30 degree
# 0.6981317007977318 # 40 degree




if __name__=='__main__':
    
    best_sv_res_fn = "/root/diffsim/IsaacGymEnvs2/assets/optimized_res_grab_300_demo/statistics/data_inst_tag_to_best_opt_res_all.npy"
    best_sv_res_fn = "/root/diffsim/IsaacGymEnvs2/assets/optimized_res_grab_300_demo/statistics/data_inst_tag_to_optimized_res_top50.npy"
    inspect_demo_best_sv_fns(best_sv_res_fn) 
    exit(0)
    
    
    # /root/diffsim/IsaacGymEnvs2/assets/optimized_res_grab_300_demo/statistics/data_inst_tag_to_best_opt_res_all.npy
    
    data_inst_tag_to_optimized_res_fn = "./uni_manip/isaacgym_rl_exp_taco_400_train_wcustomidamping_samples_realv3_/statistics/data_inst_tag_to_optimized_res.npy"
    interested_keys = None
    dst_folder = '/root/diffsim/IsaacGymEnvs2/assets/optimized_res_taco_400_demo'
    
    data_inst_tag_to_optimized_res_fn = "./uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_grab_gene_v10/statistics/data_inst_tag_to_optimized_res.npy"
    interested_keys = None
    # dst_folder = '/root/diffsim/IsaacGymEnvs2/assets/optimized_res_taco_400_demo'
    dst_folder = '/root/diffsim/IsaacGymEnvs2/assets/optimized_res_grab_baseline'
    
    copy_optimized_infos(interested_keys, data_inst_tag_to_optimized_res_fn, dst_folder=dst_folder)
    exit(0)
    
    
    # # grab_tracking_folder = "./data/GRAB_Tracking_PK/data"
    # grab_tracking_folder = "./data/GRAB_Tracking_LEAP_PK/data"
    # reduce_kine_infos(grab_tracking_folder)
    # exit(0)
    
    
    # 
    # dict_fn = "./uni_manip/isaacgym_rl_exp_grab_300_train_wstatebased_wcustomidamping_realleap_wovel/statistics/obj_type_to_optimized_res.npy"
    # dict_fn = "./uni_manip/isaacgym_rl_exp_grab_300_train_wstatebased_wcustomidamping_realleap/statistics/obj_type_to_optimized_res.npy"
    # inspect_obj_type_to_optimized_res(dict_fn)
    # exit(0)
    
    # train_root = './uni_manip/isaacgym_rl_exp_grab_300_train_wstatebased_wcustomidamping_realleap_wovel'
    # train_root = './uni_manip/isaacgym_rl_exp_grab_300_train_wstatebased_wcustomidamping_realleap'
    # train_root = './uni_manip/isaacgym_rl_exp_taco_400_train_wstatebased_wcustomidamping_modelv2_realleap'
    # train_root = './uni_manip/isaacgym_rl_exp_grab_300_train_wstatebased_wcustomidamping_modelv2_realleap_wvel_stiffv4_'
    # calculate_optimized_res(train_root)
    # exit(0)
    

    # dict_fn_a = '../assets/optimized_res_grab_300_demo/statistics/data_inst_tag_to_optimized_res_top50.npy'
    # dict_fn_b = '../assets/optimized_res_taco_400_demo/statistics/data_inst_tag_to_optimized_res_top50.npy'
    # combine_two_dict_fn(dict_fn_a, dict_fn_b)
    # exit(0)
    
    # the inst tag to best opt res fn for the taco dataset #
    # 
    
    # # best_optimized_res_fn = '/root/diffsim/IsaacGymEnvs2/assets/optimized_res_grab_300_demo/data_inst_tag_to_optimized_res_top50.npy'
    # best_optimized_res_fn = '/root/diffsim/IsaacGymEnvs2/assets/optimized_res_grab_300_demo/statistics/data_inst_tag_to_optimized_res_top50.npy'
    # inspect_topk_best_optimized_res_fn(best_optimized_res_fn)
    # exit(0)


    # combined_ob
    

    # inst_tag_to_best_opt_res = "./uni_manip/isaacgym_rl_exp_grab_300_train_wcustomidamping_samples_realv3_/statistics/data_inst_tag_to_best_opt_res_all.npy"
    # inst_tag_to_opt_res_fn = "./uni_manip/isaacgym_rl_exp_grab_300_train_wcustomidamping_samples_realv3_/statistics/data_inst_tag_to_optimized_res.npy"
    # cur_root_path = "/root/diffsim/IsaacGymEnvs2/assets/optimized_res_grab_300_demo"
    
    # inst_tag_to_best_opt_res = "./uni_manip/isaacgym_rl_exp_taco_400_train_wcustomidamping_samples_realv3_/statistics/data_inst_tag_to_best_opt_res_all.npy"
    # inst_tag_to_opt_res_fn = "./uni_manip/isaacgym_rl_exp_taco_400_train_wcustomidamping_samples_realv3_/statistics/data_inst_tag_to_optimized_res.npy"
    # cur_root_path = "/root/diffsim/IsaacGymEnvs2/assets/optimized_res_taco_400_demo"
    # get_data_inst_tag_to_valid_optimized_res(inst_tag_to_best_opt_res, inst_tag_to_opt_res_fn, cur_root_path)
    # exit(0)
    
    
    # inst_tag_to_best_opt_res = "./uni_manip/isaacgym_rl_exp_grab_300_train_wcustomidamping_samples_realv3_/statistics/data_inst_tag_to_best_opt_res_all.npy"
    
    # inpsect_data_inst_tag_to_best_optimized_res(inst_tag_to_best_opt_res)
    # exit(0)
    
    # get hte optimized 
    
    # inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_300_train_wcustomidamping_samples_realv3_/statistics/data_inst_tag_to_optimized_res.npy'
    # inspect_optimized_res_grab_long(inst_tag_to_optimized_res_fn)
    # exit(0)
    
    
    # data_inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_leap_grab_generalist_direct_samples_pertrj_v3_/statistics/data_inst_tag_to_optimized_res.npy'
    # # data #
    # interested_keys = None
    # dst_folder = '/root/diffsim/IsaacGymEnvs2/assets/optimized_res_grab_leap'
    # data isnt tag to optimzed # inst tag to optimized res # # optimized res #
    
    
    # data_inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_leap_taco_generalist_direct_samples_pertrj_v4_testall_/statistics/data_inst_tag_to_optimized_res.npy'
    # interested_keys = None
    # dst_folder = '/root/diffsim/IsaacGymEnvs2/assets/optimized_res_taco_leap'
    
    
    # data_inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_300_train_wcustomidamping_samples_realv3_/statistics/data_inst_tag_to_optimized_res.npy'
    # interested_keys = None
    # dst_folder = '/root/diffsim/IsaacGymEnvs2/assets/optimized_res_grab_300_demo'
    
    
    data_inst_tag_to_optimized_res_fn = "./uni_manip/isaacgym_rl_exp_taco_400_train_wcustomidamping_samples_realv3_/statistics/data_inst_tag_to_optimized_res.npy"
    data_inst_tag_to_optimized_res_fn = "./uni_manip/isaacgym_rl_exp_leap_grab_generalist_direct_samples_pertrj_v4_stiffness20_v2_/statistics/data_inst_tag_to_optimized_res.npy"
    interested_keys = None
    dst_folder = '/root/diffsim/IsaacGymEnvs2/assets/optimized_res_taco_400_demo'
    dst_folder = '/root/diffsim/IsaacGymEnvs2/assets/optimized_res_grab_stiff_res'
    dst_folder = '/root/diffsim/IsaacGymEnvs2/assets/optimized_res_grab_stiff_res_v3'
    
    copy_optimized_infos(interested_keys, data_inst_tag_to_optimized_res_fn, dst_folder=dst_folder)
    exit(0)
    
    
    # grab_eval_data_folder = "./uni_manip/isaacgym_rl_exp_grab_OPTFR_v2_eval"
    # grab_eval_data_folder = "./uni_manip/isaacgym_rl_exp_leap_taco_generalist_direct_samples_pertrj_v3_"
    # get_data_inst_tag_to_optimized_res(grab_eval_data_folder)
    # exit(0)
    
    
    # data_inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_OPTFR_v2_eval/statistics/data_inst_tag_to_optimized_res.npy'
    # target_inst_tag = None
    # resave_optimized_res(data_inst_tag_to_optimized_res_fn, target_inst_tag)
    # exit(0)
    
    #### grab eval data folder ####
    # # grab_eval_data_folder = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_succonlytrained' # 
    # grab_eval_data_folder = './uni_manip/isaacgym_rl_exp_grab_realgrab_gensamplesv1_' # 
    # grab_eval_data_folder = './uni_manip/isaacgym_rl_exp_grab_realgrab_gensamplesv1_' # 
    # grab_eval_data_folder = './uni_manip/isaacgym_rl_exp_grab_realgrab_gensamplesv4_' # 
    # grab_eval_data_folder = './uni_manip/isaacgym_rl_exp_grab_realgrab_gensamplesv4_300_/' # v4_300 #
    # grab_eval_data_folder = './uni_manip/isaacgym_rl_exp_grab_300_train_wcustomidamping_samples_realv3_' # 
    # grab_eval_data_folder = './uni_manip/isaacgym_rl_exp_grab_realgrab_gensamplesv3_' # 
    # grab_eval_data_folder = './uni_manip/isaacgym_rl_exp_leap_grab_generalist_direct_samples_pertrj_v3_' # 
    # grab_eval_data_folder = './uni_manip/isaacgym_rl_exp_grab_300_train_wcustomidamping_samples_realv3_' # 
    # grab_eval_data_folder = './uni_manip/isaacgym_rl_exp_leap_grab_generalist_direct_samples_pertrj_v4_stiffness20_v2_' # stiffness20_v2_ #
    # get_data_inst_tag_to_optimized_res(grab_eval_data_folder) #
    # exit(0) # exit(0) #
    
    # get data inst tag to optimized res #
    # ./uni_manip/isaacgym_rl_exp_leap_grab_generalist_direct_samples_pertrj_v3_/tracking_ori_grab_s1_torussmall_lift_leap_obs_pure_state_wref_wdelta_density_500.0_trans_0.5_rot_0.5_goalcond_False_kinebias_t0.5r0.5f20_rfd_0.3_rh_0.5_22-14-16-08/ts_to_hand_obj_obs_reset_1.npy
    
    # ./uni_manip/isaacgym_rl_exp_grab_300_train_wcustomidamping_samples_realv3_ # # realv3_ ##  real v3 ##
    
    # data_inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_succonlytrained/statistics/data_inst_tag_to_optimized_res.npy'
    # data_inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_realgrab_gensamplesv1_/statistics/data_inst_tag_to_optimized_res.npy'
    data_inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_realgrab_gensamplesv4_/statistics/data_inst_tag_to_optimized_res.npy'
    data_inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_realgrab_gensamplesv4_300_/statistics/data_inst_tag_to_optimized_res.npy'
    data_inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_300_train_wcustomidamping_samples_realv3_/statistics/data_inst_tag_to_optimized_res.npy'
    data_inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_realgrab_gensamplesv3_/statistics/data_inst_tag_to_optimized_res.npy'
    data_inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_leap_grab_generalist_direct_samples_pertrj_v3_/statistics/data_inst_tag_to_optimized_res.npy'
    data_inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_300_train_wcustomidamping_samples_realv3_/statistics/data_inst_tag_to_optimized_res.npy'
    data_inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_leap_grab_generalist_direct_samples_pertrj_v4_stiffness20_v2_/statistics/data_inst_tag_to_optimized_res.npy'
    target_inst_tag = 's1'
    target_inst_tag = None
    resave_optimized_res(data_inst_tag_to_optimized_res_fn, target_sub_tag=target_inst_tag)
    exit(0)
    
    # train_root = './uni_manip/isaacgym_rl_exp_grab_300_train_wcustomidamping'
    # train_root = './uni_manip/isaacgym_rl_exp_taco_400_train_wstatebased_wcustomidamping_realleap'
    # train_root = './uni_manip/isaacgym_rl_exp_grab_150_customdamping_leap'
    # calculate_optimized_res(train_root)
    # exit(0)
    
    inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_succonlytrained/statistics/data_inst_tag_to_optimized_res.npy'
    inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_realgrab_gensamplesv1_/statistics/data_inst_tag_to_optimized_res.npy'
    inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_300_train_wcustomidamping_genesamples_0.9sup_samples_/statistics/data_inst_tag_to_optimized_res.npy'
    inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_realgrab_gensamplesv3_/statistics/data_inst_tag_to_optimized_res.npy'
    inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_300_train_wcustomidamping_samples_realv3_/statistics/data_inst_tag_to_optimized_res.npy'
    inst_tag_to_optimized_res_fn = "./uni_manip/isaacgym_rl_exp_taco_400_train_wcustomidamping_samples_realv3_/statistics/data_inst_tag_to_optimized_res.npy"
    # 
    target_subj_tag = ''
    random_select = False
    data_inst_tag_to_best_opt_res = get_obj_inst_tag_to_best_opt_res(inst_tag_to_optimized_res_fn, target_subj_tag if len(target_subj_tag) > 0 else None, random_select=random_select)
    eval_statistics_sv_folder = "/".join(inst_tag_to_optimized_res_fn.split("/")[:-1])
    if len(target_subj_tag) > 0:
        data_inst_tag_to_best_opt_res_fn = f"data_inst_tag_to_best_opt_res_{target_subj_tag}.npy"
    else:
        if random_select:
            data_inst_tag_to_best_opt_res_fn = "data_inst_tag_to_best_opt_res_all_rndselect.npy"
        else:
            data_inst_tag_to_best_opt_res_fn = "data_inst_tag_to_best_opt_res_all.npy"

    data_inst_tag_to_best_opt_res_fn = os.path.join(eval_statistics_sv_folder, data_inst_tag_to_best_opt_res_fn)
    np.save(data_inst_tag_to_best_opt_res_fn, data_inst_tag_to_best_opt_res) # 
    print(f"Saved data_inst_tag_to_best_opt_res to {data_inst_tag_to_best_opt_res_fn} with length {len(data_inst_tag_to_best_opt_res)}")
    exit(0)
    
    
    inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_grab_gene_v13/statistics/data_inst_tag_to_best_opt_res_all.npy' 
    # [0.43252595155709345, 0.5813148788927336, 0.6851211072664359]
    # eval_key: hand_glb_diff, mean: 0.10011871187444563
    # eval_key: hand_joint_diff, mean: 0.48641870881634197
    # eval_key: obj_pos_diff, mean: 0.09177578062397139
    # eval_key: obj_rot_diff, mean: 0.42611799534709977 # 
    
    # eval_key: hand_glb_diff, mean: 0.17798857953464395, medium: 0.12256485968828201
    # eval_key: hand_joint_diff, mean: 0.5350225772275481, medium: 0.5218476057052612
    # eval_key: obj_pos_diff, mean: 0.11146851163357496, medium: 0.07806023955345154
    # eval_key: obj_rot_diff, mean: 0.48813456699771934, medium: 0.34438350796699524
    inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_grab_gene_v12/statistics/data_inst_tag_to_best_opt_res_all.npy' 
    # [0.47126436781609193, 0.6551724137931034, 0.7241379310344828]
    # eval_key: hand_glb_diff, mean: 0.1311615438992693
    # eval_key: hand_joint_diff, mean: 0.516579905289343
    # eval_key: obj_pos_diff, mean: 0.08651978972678383
    # eval_key: obj_rot_diff, mean: 0.4307191177838664 # 43.01/61.52
    # eval_key: hand_glb_diff, mean: 0.1311615438992693, medium: 0.11180009320378304
    # eval_key: hand_joint_diff, mean: 0.516579905289343, medium: 0.5047686696052551
    # eval_key: obj_pos_diff, mean: 0.08651978972678383, medium: 0.045269615948200226
    # eval_key: obj_rot_diff, mean: 0.4307191177838664, medium: 0.3302718698978424
    inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_grab_gene_v11/statistics/data_inst_tag_to_best_opt_res_all.npy' 
    # [0.39792387543252594, 0.5813148788927336, 0.6678200692041523]
    # eval_key: hand_glb_diff, mean: 0.15484016026830535
    # eval_key: hand_joint_diff, mean: 0.5335653240995846
    # eval_key: obj_pos_diff, mean: 0.08554807287806795 # and the taco
    # eval_key: obj_rot_diff, mean: 0.4158117506310515
    # eval_key: hand_glb_diff, mean: 0.15484016026830535, medium: 0.14834869280457497
    # eval_key: hand_joint_diff, mean: 0.5335653240995846, medium: 0.5264893174171448
    # eval_key: obj_pos_diff, mean: 0.08554807287806795, medium: 0.049710292369127274
    # eval_key: obj_rot_diff, mean: 0.4158117506310515, medium: 0.341532826423645
    
    # isaacgym_rl_exp_grab_generalist_direct_samples_taco_grab_v2_v5
    inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_grab_gene_v13/statistics/data_inst_tag_to_best_opt_res_all.npy' 
    inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_succonlytrained/statistics/data_inst_tag_to_best_opt_res_all.npy'
    inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_realgrab_gensamplesv1_/statistics/data_inst_tag_to_best_opt_res_all.npy'
    inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_realgrab_gensamplesv3_/statistics/data_inst_tag_to_best_opt_res_all.npy'
    # to use  # OMniGrasp reward #
    inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_grab_gene_300_v12/statistics/data_inst_tag_to_optimized_res.npy'
     
    # [0.35977011494252873, 0.5494252873563219, 0.7126436781609196]
    # eval_key: hand_glb_diff, mean: 0.1242386272187805, medium: 0.17229154095053673
    # eval_key: hand_joint_diff, mean: 0.5138634036498508, medium: 0.5641828751564026
    
    # no good hand tracking rewards.. #
    # eval_key: obj_pos_diff, mean: 0.09271082007486758, medium: 0.066922510266304016
    # eval_key: obj_rot_diff, mean: 0.43351146146312525, medium: 0.44048333764076233
    
    
    # 
    # DGRASP 
    # [0.3482758620689655, 0.5494252873563219, 0.735632183908046]
    # eval_key: hand_glb_diff, mean: 0.13414728739459453, medium: 0.13723480373620987
    # eval_key: hand_joint_diff, mean: 0.5152642141128408, medium: 0.603957211971283
    # eval_key: obj_pos_diff, mean: 0.0862584309893307, medium: 0.06752850905060768
    # eval_key: obj_rot_diff, mean: 0.42872774888943327, medium: 0.44938764572143555
    
    # interesting demos? #
    
    ## wati for the DGRa's results (using genesamplev3) ##  no randominesses ## # multiple envornments; change the camer view and interatct with different objects? #
    
    # PPO ours reward
    # [0.38788927335640137, 0.5505190311418685, 0.6058823529411765] # 0.5813 6.03 0.1730 0.5439 36.18/56.07
    # eval_key: hand_glb_diff, mean: 0.09165994453126158, medium: 0.10763877302408218
    # eval_key: hand_joint_diff, mean: 0.5027805625022143, medium: 0.58998644948005676
    # eval_key: obj_pos_diff, mean: 0.07644877166503333, medium: 0.061110482066869736
    # eval_key: obj_rot_diff, mean: 0.41904766399456167, medium: 0.3945021986961365
    
    # 
        
    calcualte_merged_succ_info_all_thres(inst_tag_to_optimized_res_fn)
    inst_tag_to_optimized_res_fn = inst_tag_to_optimized_res_fn.replace("data_inst_tag_to_best_opt_res_all.npy", "data_inst_tag_to_optimized_res.npy")
    inspect_data_inst_tag_to_optimized_res_metrics(inst_tag_to_optimized_res_fn)
    exit(0)
    
    # the succ rates #
    inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_eval_v2/statistics/data_inst_tag_to_optimized_res.npy'
    inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_grab_gene_v11/statistics/data_inst_tag_to_optimized_res.npy'
    # data_inst_to_opt_res_fn_a = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_grab_gene_v11/statistics/data_inst_tag_to_best_opt_res_all.npy' 
    inspect_data_inst_tag_to_optimized_res(inst_tag_to_optimized_res_fn)
    exit(0)
    
    # data_inst_tag = "ori_grab_s1_apple_eat_1"
    # best_eval_info_fn = "./uni_manip/isaacgym_rl_exp_grab_eval_v2/tracking_ori_grab_s1_apple_eat_1_obs_pure_state_wref_wdelta_density_500.0_trans_0.5_rot_0.5_goalcond_False_kinebias_t0.5r0.5f20_rfd_0.3_rh_0.5_19-22-51-41/ts_to_hand_obj_obs_reset_1_sorted_best.npy"
    # inspect_best_eval_info(data_inst_tag, best_eval_info_fn)
    # exit(0)
    
    # best_eval_info_fn = "./uni_manip/isaacgym_rl_exp_taco_grab_interpseq_interpfr_60_interpfr2_60_nntrans_40_eval/tracking_TACO_taco_20230928_044_INTERPSEQ_ori_grab_s2_phone_call_1_obs_pure_state_wref_wdelta_density_500.0_trans_0.5_rot_0.5_goalcond_False_kinebias_t0.5r0.5f20_rfd_0.3_rh_0.5_interpfr_60_interpfr2_60_nntrans_40_04-03-33-41/ts_to_hand_obj_obs_reset_1_sorted_best.npy"
    # inspect_best_eval_info(best_eval_info_fn)
    # exit(0)
    
    
    # grab_tracking_folder = "./data/GRAB_Tracking_PK/data"
    # reduce_kine_infos(grab_tracking_folder)
    # exit(0)
    
    # reduce the kinematic infos #
    # reduce the kinematic infos #
    # rotation and the translation errors #
    # wrist distances and the angle erros and the joint errors #
    
    # # compare the optimized 
    # ori_inst_tag_to_best_opt_res = './uni_manip/isaacgym_rl_exp_grab_eval_v2/statistics/data_inst_tag_to_best_opt_res_s10.npy'
    # cur_inst_tag_to_best_opt_res = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_grab_all_v12/statistics/data_inst_tag_to_best_opt_res_all.npy'
    
    
    train_root = './uni_manip/isaacgym_rl_exp_grab_150_customdamping_leap'
    train_root = './uni_manip/isaacgym_rl_exp_grab_300_train_wcustomidamping'
    calculate_optimized_res(train_root)
    exit(0)
    
    # inspect_inst_tag_to_opt_res()
    # exit(0)
    
    # filter_inst_tag_to_all_res()
    # exit(0)
    
    # # obj_type_to_latent_features = "./uni_manip/tds_diffusion_exp/allegro_tracking_kine_diff_AE_Diff_trainAE_vnewv2_wtacodata_samples_/obj_type_to_obj_feat.npy"
    # # inspect_obj_type_to_latent_folders(obj_type_to_latent_features)
    # # exit(0)
    
    # construct_all_taco_opt_to_optimized_res()
    # exit(0)
    
    # opt_res_fn = "./uni_manip/isaacgym_rl_exp_taco_grab_interpseq_interpfr_60_interpfr2_60_nntrans_40_eval/statistics/data_inst_tag_to_optimized_res.npy"
    # opt_res_fn = "./uni_manip/isaacgym_rl_exp_taco_grab_interpseq_interpfr_60_interpfr2_60_nntrans_40_eval/statistics/data_inst_tag_to_optimized_res_tot.npy"
    # inspect_taco_optimized_res(opt_res_fn)
    # exit(0)
    
    
    
    # inspect_taco_mesh_folders()
    # exit(0)
    
    # obj_type_to_optimized_res_fn = "./uni_manip/isaacgym_rl_exp_grab/statistics/obj_type_to_optimized_res_s1_s10.npy"
    # obj_type_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_taco_grab_interpseq_interpfr_60_interpfr2_60_nntrans_40/statistics/obj_type_to_optimized_res_beta_v1.npy'
    # obj_type_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_taco_grab_interpseq_interpfr_60_interpfr2_60_nntrans_40/statistics/obj_type_to_optimized_res.npy'
    # inspect_obj_type_to_optimized_res(obj_type_to_optimized_res_fn)
    # exit(0)
    
    
    
    # opt_res_fn_samples = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_grab_gene_v11/statistics/data_inst_tag_to_best_opt_res_all.npy'
    # inspect_samples(opt_res_fn_samples)
    # exit(0)
    
    
    # obj_type_to_optimized_res_fn = "./uni_manip/isaacgym_rl_exp_grab/statistics/obj_type_to_optimized_res_s1_s10.npy"
    # ## iteration 1 ##
    # data_inst_to_opt_res_fn_ori = './uni_manip/isaacgym_rl_exp_grab_eval_v2/statistics/data_inst_tag_to_best_opt_res_all.npy'
    # data_inst_to_opt_res_fn_samples = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_grab_gene_v11/statistics/data_inst_tag_to_best_opt_res_all.npy'
    # select_samples_fr_ori_cur_optimized_res(obj_type_to_optimized_res_fn, data_inst_to_opt_res_fn_samples)
    # exit(0)
    
    
    
    # obj_type_to_optimized_res_fn = "./uni_manip/isaacgym_rl_exp_grab/statistics/obj_type_to_optimized_res_s1_s10.npy"
    # # ## iteration 1 ##
    # data_inst_to_opt_res_fn_ori = './uni_manip/isaacgym_rl_exp_grab_eval_v2/statistics/data_inst_tag_to_best_opt_res_all.npy'
    # data_inst_to_opt_res_fn_samples = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_grab_gene_v11/statistics/data_inst_tag_to_best_opt_res_all.npy'
    
    
    # data_inst_to_opt_res_fn_ori = './uni_manip/isaacgym_rl_exp_grab_eval_v2/statistics/data_inst_tag_to_best_opt_res_all.npy'
    # data_inst_to_opt_res_fn_samples = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_grab_all_v12/statistics/data_inst_tag_to_best_opt_res_all.npy'
    
    # compare_diff_opt_res_ori_w_samples(obj_type_to_optimized_res_fn, data_inst_to_opt_res_fn_ori, data_inst_to_opt_res_fn_samples)
    # exit(0)
    
    
    # taco_eval_dict_fn = "./uni_manip/isaacgym_rl_exp_taco_grab_interpseq_interpfr_60_interpfr2_60_nntrans_40/statistics/obj_type_to_optimized_res_beta_v1.npy"
    # taco_eval_dict_fn = "./uni_manip/isaacgym_rl_exp_taco_grab_interpseq_interpfr_60_interpfr2_60_nntrans_40/statistics/obj_type_to_optimized_res_beta.npy"
    # get_taco_eval_dict(taco_eval_dict_fn)
    # exit(0)
    

    # eval_dict_fn = "./uni_manip/isaacgym_rl_exp_grab_nf_300_eval/statistics/data_inst_tag_to_optimized_res.npy"
    
    # inspect_eval_dict_grab_nf_300(eval_dict_fn)
    # exit(0)    

    # data_inst_tag_to_optimized_res_fn = './runs/statistics/data_inst_tag_to_optimized_res.npy'
    # # target_inst_tag = 's2'
    # data_inst_tag_to_optimized_res_fn = "./uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_grab_gene_v10/statistics/data_inst_tag_to_optimized_res.npy"

    # tot_eval_dict_fn = "./uni_manip/isaacgym_rl_exp_taco_grab_interpseq_interpfr_60_interpfr2_60_nntrans_40_eval/statistics/data_inst_tag_to_optimized_res.npy"
    # inspect_taco_eval_dict(tot_eval_dict_fn)
    # exit(0)    
    
    
    # eval_dict_fn = "./uni_manip/isaacgym_rl_exp_grab_nf_300_eval/statistics/data_inst_tag_to_optimized_res.npy"
    # inspect_eval_dict_grab_nf_300(eval_dict_fn)
    # exit(0)    

    data_inst_tag_to_optimized_res_fn = './runs/statistics/data_inst_tag_to_optimized_res.npy'
    data_inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_grab_gene_v12/statistics/data_inst_tag_to_optimized_res.npy'
    data_inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_grab_gene_v13/statistics/data_inst_tag_to_optimized_res.npy'
    data_inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_grab_gene_300_v12/statistics/data_inst_tag_to_optimized_res.npy'
    data_inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_leap_grab_generalist_direct_samples_pertrj_/statistics/data_inst_tag_to_optimized_res.npy'
    data_inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_grab_all_v12/statistics/data_inst_tag_to_optimized_res.npy'
    data_inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_succonlytrained/statistics/data_inst_tag_to_optimized_res.npy'
    # # target_inst_tag = 's2'

    target_inst_tag = 's1'

    
    # target_inst_tag = None
    

    resave_optimized_res(data_inst_tag_to_optimized_res_fn, target_sub_tag=target_inst_tag)
    exit(0)
    
    
    # grab_eval_data_folder= './runs'
    # # grab_eval_data_folder = './uni_manip/isaacgym_rl_exp_taco_grab_interpseq_eval_v2'
    grab_eval_data_folder = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_grab_gene_v10'
    grab_eval_data_folder = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_grab_gene_v12'
    grab_eval_data_folder = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_grab_gene_v13'
    grab_eval_data_folder = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_grab_gene_300_v12'
    grab_eval_data_folder = './uni_manip/isaacgym_rl_exp_leap_grab_generalist_direct_samples_pertrj_'
    grab_eval_data_folder = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_grab_all_v12/'
    grab_eval_data_folder = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_succonlytrained'
    get_data_inst_tag_to_optimized_res(grab_eval_data_folder) 
    exit(0)

    # samples_root = "/root/diffsim/IsaacGymEnvs2/isaacgymenvs/runs_generalist_x"
    # target_folder = "./uni_manip/isaacgym_rl_exp_grab_generalist_samples_init_specialist"
    # move_tested_samples(samples_root, target_folder)
    # exit(0)



    # # data_inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_nf_300_eval/statistics/data_inst_tag_to_optimized_res.npy'
    # data_inst_tag_to_optimized_res_fn = '/root/diffsim/IsaacGymEnvs2/isaacgymenvs/runs_generalist_test/statistics/data_inst_tag_to_optimized_res.npy'
    # data_inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_v2/statistics/data_inst_tag_to_optimized_res.npy'
    # data_inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_taco_grab_interpseq_interpfr_60_interpfr2_60_nntrans_40_eval/statistics/data_inst_tag_to_optimized_res.npy'
    # data_inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_grab_gene_v10/statistics/data_inst_tag_to_optimized_res.npy'
    # data_inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_grab_gene_v11/statistics/data_inst_tag_to_optimized_res.npy'
    # target_inst_tag = 's10'
    # target_inst_tag = None
    # resave_optimized_res(data_inst_tag_to_optimized_res_fn, target_sub_tag=target_inst_tag)
    # exit(0)
    
    
    # # grab_eval_data_folder = './uni_manip/isaacgym_rl_exp_grab_wdiffusion_samples_ws30_wohist_datav2_kineobjposcanon_'
    # grab_eval_data_folder = './uni_manip/isaacgym_rl_exp_grab_wdiffusion_samples_ws30_wohist_datav2_kineobjposcanon_/'
    # grab_eval_data_folder = './runs'
    # grab_eval_data_folder = "/root/diffsim/IsaacGymEnvs2/isaacgymenvs/runs_generalist_test"
    # grab_eval_data_folder = "./uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_v4"
    # # ./uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_grab_gene_v10/tracking_ori_grab_s10_waterbottle_pass_1_obs_pure_state_wref_wdelta_density_500.0_trans_0.5_rot_0.5_goalcond_False_kinebias_t0.5r0.5f20_rfd_0.3_rh_0.5_11-20-21-14/ts_to_hand_obj_obs_reset_1.npy
    # grab_eval_data_folder = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_grab_gene_v10'
    # grab_eval_data_folder = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_v5'
    # grab_eval_data_folder = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_grab_gene_v11'
    # # inst_tag_to_opt_res_fn = "data_inst_tag_to_optimized_res.npy"
    # get_data_inst_tag_to_optimized_res(grab_eval_data_folder)
    # exit(0)
    
    ## eval dict fn ## #
    # eval_dict_fn = "./uni_manip/isaacgym_rl_exp_grab_nf_300_eval/statistics/data_inst_tag_to_optimized_res.npy"
    # inspect_eval_dict(eval_dict_fn)
    # exit(0)
    
    # # /root/diffsim/tiny-differentiable-simulator/python/examples/rsc/objs/meshes/
    # exp_info_to_opt_res_fn = "./uni_manip/isaacgym_rl_exp_grab_OPTFR_v2/statistics/exp_info_to_optimized_res.npy"
    # # exp_info_to_opt_res_fn = "./uni_manip/isaacgym_rl_exp_grab_generalist_samples_init_specialist/statistics/obj_type_to_optimized_res.npy"
    # # exp_info_to_opt_res_fn = './uni_manip/isaacgym_rl_exp_grab_generalist_weights_init_specialist/statistics/obj_type_to_optimized_res.npy'
    # self_exp_res_to_opt_res_fn = "./uni_manip/isaacgym_rl_exp_grab/statistics/obj_type_to_optimized_res_s1_s10.npy"  
    
    # # inspect_opt_res(exp_info_to_opt_res_fn, self_exp_res_to_opt_res_fn)
    # save_res = True 
    # # # inspect_optfr_with_selfexp(exp_info_to_opt_res_fn, self_exp_res_to_opt_res_fn, save_res=save_res )
    # inspect_optfr_with_selfexp_list(exp_info_to_opt_res_fn, self_exp_res_to_opt_res_fn, save_res=save_res )
    # exit(0)
    
    # # optimized_data_sv_root = './uni_manip/isaacgym_rl_exp_grab_OPTFR_v2'
    # optimized_data_sv_root = './uni_manip/isaacgym_rl_exp_grab_generalist_samples_init_specialist'
    # optimized_data_sv_root = './uni_manip/isaacgym_rl_exp_grab_generalist_weights_init_specialist'
    # calculate_optimized_res(optimized_data_sv_root)
    # exit(0)
    
    # # waht about the succ rate on the TACO trajectories ? # 
    # what about the succ rate on the TACO trajectories #
    # how does it perform on TACO trajectories? #
    # save_obj_type_to_general_imit_policy_weights()
    # exit(0)
    
    
    
    # samples_fn = "./uni_manip/tds_diffusion_exp/allegro_tracking_kine_diff_AE_Diff_trainAE_vnewv2_v3data_sample_"
    # summarize_traj_features(samples_fn)
    # exit(0)
    
    # saved_samples_fn = "./uni_manip/tds_diffusion_exp/allegro_tracking_kine_diff_AE_Diff_trainAE_vnewv2_v3data_sample_/samples_ep_0_batch_0.npy"
    # inspect_saved_samples(saved_samples_fn)
    # exit(0)
    
    # ./runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__06-17-06-19/ts_to_hand_obj_obs_reset_1.npy# 
    
    
    # data_optimized_res_nn = "./runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__05-23-03-00/ts_to_hand_obj_obs_reset_1.npy"
    # data_inst_tag = "./data/GRAB_Tracking_PK_Sampled/ori_grab_s2_train_lift_sampled_kinematics_info.npy"
    # data_inst_tag = [data_inst_tag]
    # inspect_optimized_res_nn(data_optimized_res_nn, data_inst_tag)
    # exit(0)
    
    
    # ch_to_fa_fn = "./uni_manip/isaacgym_rl_exp_grab_OPTFR_v2/statistics/child_task_to_fa_task_list.npy"
    # inspect_child_task_to_fa_task_list(ch_to_fa_fn)
    # exit(0)
    
    # # cophfs # #
    # # ./uni_manip/isaacgym_rl_exp_grab_OPTFR_v2/statistics/child_task_to_fa_task.npy
    # def inspect_child_task_to_fa_task(ch_to_fa_fn):
    

    
    # ch_to_fa_fn  = "./uni_manip/isaacgym_rl_exp_grab_OPTFR_v2/statistics/child_task_to_fa_task.npy"
    # inspect_child_task_to_fa_task(ch_to_fa_fn)
    # exit(0) # 
        
    # # inst tag #
    # inst_tag_to_opt_res_fn = "./uni_manip/isaacgym_rl_exp_grab_eval_v2/statistics/data_inst_tag_to_optimized_res.npy"
    # inst_tag_to_opt_res_fn = "./uni_manip/isaacgym_rl_exp_taco_grab_interpseq_eval_v2/statistics/data_inst_tag_to_optimized_res.npy"
    # inst_tag_to_opt_res_fn = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_v2/statistics/data_inst_tag_to_optimized_res.npy'
    # inspect_inst_tag_to_opt_res(inst_tag_to_opt_res_fn)
    # exit(0)
    
    
    # sampled_res_fn = "runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__04-18-11-57/ts_to_hand_obj_obs_reset_1.npy"
    # inspect_sampled_res(sampled_res_fn)
    # exit(0)
    

    # local_dict_fn = '/root/diffsim/IsaacGymEnvs2/isaacgymenvs/runs/statistics/child_task_to_fa_task.npy'
    # glb_dict_fn = './uni_manip/isaacgym_rl_exp_grab_OPTFR_v2/statistics/child_task_to_fa_task.npy'
    # merge_child_task_to_fa_task(local_dict_fn, glb_dict_fn)
    # exit(0)

    # calcu eval metrics #
    # calcu_eval_metrics() # 
    # exit(0)
    
    # # #
    # data_optimized_res_nn = "./uni_manip/isaacgym_rl_exp_grab_123_runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__03-22-56-23/ts_to_hand_obj_obs_reset_1.npy" # find data optimized res nn # 
    # inpsect_data_optimized_res_w_obj_codes(data_optimized_res_nn)
    # exit(0)
    
    
    # opt_res_fn = './uni_manip/isaacgym_rl_exp_grab/statistics/obj_type_to_optimized_res_s1_s10.npy'
    # opt_res_fn = './uni_manip/isaacgym_rl_exp_grab_eval_v2/statistics/data_inst_tag_to_optimized_res.npy'
    # inspect_obj_type_to_optimized_res(opt_res_fn)
    # exit(0)
    

#     # # data_inst_to_opt_res_fn_a =  './uni_manip/isaacgym_rl_exp_grab_wdiffusion_samples_ws30_wohist_datav2_kineobjposcanon_/statistics/data_inst_tag_to_best_opt_res.npy'
#     data_inst_to_opt_res_fn_a = './uni_manip/isaacgym_rl_exp_grab_eval_v2/statistics/data_inst_tag_to_best_opt_res.npy'
#     data_inst_to_opt_res_fn_a = './uni_manip/isaacgym_rl_exp_grab_eval_v2/statistics/data_inst_tag_to_best_opt_res_s9.npy'
#     data_inst_to_opt_res_fn_a = './uni_manip/isaacgym_rl_exp_grab_eval_v2/statistics/data_inst_tag_to_best_opt_res_s10.npy'
#     data_inst_to_opt_res_fn_b = "runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__01-23-48-11/statistics/obj_code_to_best_opt_res.npy"
#     # data_inst_to_opt_res_fn_b = './uni_manip/isaacgym_rl_exp_grab_wdiffusion_samples_ws30_wohist_datav2_kineobjposcanon_/statistics/data_inst_tag_to_best_opt_res.npy'
#     ##### joint training with the demonstration -- test result on training trajectories ######
#     data_inst_to_opt_res_fn_b = "runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__02-12-41-38/statistics/obj_code_to_best_opt_res.npy"
#     data_inst_to_opt_res_fn_b = 'runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__03-22-56-23/statistics/obj_code_to_best_opt_res.npy'
#     # data_inst_to_opt_res_fn_b = "runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__02-13-30-08/statistics/obj_code_to_best_opt_res.npy"
#     data_inst_to_opt_res_fn_b = 'runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__04-01-08-35/ts_to_hand_obj_obs_reset_1.npy'
#     data_inst_to_opt_res_fn_b = 'runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__04-01-08-35/statistics/obj_code_to_best_opt_res.npy'
#     data_inst_to_opt_res_fn_b = '/root/diffsim/IsaacGymEnvs2/isaacgymenvs/runs/statistics/data_inst_tag_to_best_opt_res_s10.npy'
#     data_inst_to_opt_res_fn_a = data_inst_to_opt_res_fn_b
#     calcualte_merged_succ_info_v2(data_inst_to_opt_res_fn_a, data_inst_to_opt_res_fn_b)

    # # # # data_inst_to_opt_res_fn_a =  './uni_manip/isaacgym_rl_exp_grab_wdiffusion_samples_ws30_wohist_datav2_kineobjposcanon_/statistics/data_inst_tag_to_best_opt_res.npy'
    # # # data_inst_to_opt_res_fn_a = './uni_manip/isaacgym_rl_exp_grab_eval_v2/statistics/data_inst_tag_to_best_opt_res.npy'
    # # # # data_inst_to_opt_res_fn_a = './uni_manip/isaacgym_rl_exp_grab_eval_v2/statistics/data_inst_tag_to_best_opt_res_s9.npy'
    # # data_inst_to_opt_res_fn_b = "runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__01-23-48-11/statistics/obj_code_to_best_opt_res.npy"
    # data_inst_to_opt_res_fn_b = './uni_manip/isaacgym_rl_exp_grab_wdiffusion_samples_ws30_wohist_datav2_kineobjposcanon_/statistics/data_inst_tag_to_best_opt_res.npy'
    
    

#     # ### using only the succ trajs during the training ? #####
#     ##### joint training with the demonstration -- test result on training trajectories ######
#     data_inst_to_opt_res_fn_b = "runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__02-12-41-38/statistics/obj_code_to_best_opt_res.npy"
#     data_inst_to_opt_res_fn_b = 'runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__03-22-56-23/statistics/obj_code_to_best_opt_res.npy'
#     data_inst_to_opt_res_fn_a = './uni_manip/isaacgym_rl_exp_grab_eval_v2/statistics/data_inst_tag_to_best_opt_res_all.npy'



    ##### joint training with the demonstration -- test result on training trajectories ######
    data_inst_to_opt_res_fn_b = "runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__02-12-41-38/statistics/obj_code_to_best_opt_res.npy"
    data_inst_to_opt_res_fn_b = 'runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__03-22-56-23/statistics/obj_code_to_best_opt_res.npy'
    data_inst_to_opt_res_fn_a = './uni_manip/isaacgym_rl_exp_grab_eval_v2/statistics/data_inst_tag_to_best_opt_res_all.npy'
    # data_inst_to_opt_res_fn_a = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_grab_gene_v11/statistics/data_inst_tag_to_best_opt_res_all.npy' # without quality (after increased to the current one)
    # data_inst_to_opt_res_fn_a = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_grab_all_v12/statistics/data_inst_tag_to_best_opt_res_all.npy'
    # data_inst_to_opt_res_fn_a = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_grab_gene_v12/statistics/data_inst_tag_to_best_opt_res_all.npy' # all version 
    # data_inst_to_opt_res_fn_a = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_grab_gene_v10/statistics/data_inst_tag_to_best_opt_res_all.npy' # 
    # data_inst_to_opt_res_fn_a = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_grab_gene_v13/statistics/data_inst_tag_to_best_opt_res_all.npy' # without diversity (first xxx training res)
    # data_inst_to_opt_res_fn_a = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_grab_gene_v10/statistics/data_inst_tag_to_best_opt_res_all.npy'
    # data_inst_to_opt_res_fn_a = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_v4/statistics/data_inst_tag_to_best_opt_res_all.npy'
    # data_inst_to_opt_res_fn_a = './runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__09-14-58-35/statistics/obj_code_to_best_opt_res.npy'
    # data_inst_to_opt_res_fn_a = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_v2/statistics/data_inst_tag_to_best_opt_res_all.npy'
    # data_inst_to_opt_res_fn_a = './uni_manip/isaacgym_rl_exp_grab_eval_v2/statistics/data_inst_tag_to_best_opt_res_all_rndselect.npy'
    # data_inst_to_opt_res_fn_a = '/root/diffsim/IsaacGymEnvs2/isaacgymenvs/runs/statistics/data_inst_tag_to_best_opt_res_all.npy'
    # data_inst_to_opt_res_fn_b = "runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__02-13-30-08/statistics/obj_code_to_best_opt_res.npy"
    data_inst_to_opt_res_fn_b = 'runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__04-01-08-35/ts_to_hand_obj_obs_reset_1.npy'
    data_inst_to_opt_res_fn_b = 'runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__04-01-08-35/statistics/obj_code_to_best_opt_res.npy'

    data_inst_to_opt_res_fn_b = './runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__05-21-54-08/statistics/obj_code_to_best_opt_res.npy'

    data_inst_to_opt_res_fn_b = './runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__05-21-54-08/statistics/obj_code_to_best_opt_res.npy'

    data_inst_to_opt_res_fn_b = "./runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__05-23-07-10/statistics/obj_code_to_best_opt_res.npy"
    data_inst_to_opt_res_fn_b = "./runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__06-15-15-06/statistics/obj_code_to_best_opt_res.npy"
    data_inst_to_opt_res_fn_b = "./runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__06-15-19-50/statistics/obj_code_to_best_opt_res.npy"
    data_inst_to_opt_res_fn_b = "./runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__06-15-31-23/statistics/obj_code_to_best_opt_res.npy"
    data_inst_to_opt_res_fn_b = './runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__06-17-06-19/statistics/obj_code_to_best_opt_res.npy'
    data_inst_to_opt_res_fn_b = "./runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__06-22-47-09/statistics/obj_code_to_best_opt_res.npy"
    data_inst_to_opt_res_fn_b = "./runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__07-00-49-54/statistics/obj_code_to_best_opt_res.npy"
    data_inst_to_opt_res_fn_b = './runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__07-03-44-52/statistics/obj_code_to_best_opt_res.npy'
    data_inst_to_opt_res_fn_b = './runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__07-12-50-15/statistics/obj_code_to_best_opt_res.npy'
    data_inst_to_opt_res_fn_b  = './runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__07-13-03-27/statistics/obj_code_to_best_opt_res.npy'
    data_inst_to_opt_res_fn_b = './runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__07-13-12-21/statistics/obj_code_to_best_opt_res.npy'
    data_inst_to_opt_res_fn_b = './runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__07-13-20-29/statistics/obj_code_to_best_opt_res.npy'
    # data_inst_to_opt_res_fn_b = './runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__07-13-20-29/statistics/obj_code_to_best_opt_res.npy'
    # data_inst_to_opt_res_fn_b = './runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__07-13-50-10/statistics/obj_code_to_best_opt_res.npy'
    # data_inst_to_opt_res_fn_b = './runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__07-17-10-12/statistics/obj_code_to_best_opt_res.npy'
    # data_inst_to_opt_res_fn_b = './runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__07-19-39-53/statistics/obj_code_to_best_opt_res.npy'
    # # data_inst_to_opt_res_fn_b = './runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__07-22-35-04/statistics/obj_code_to_best_opt_res.npy'

    data_inst_to_opt_res_fn_b = './runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__08-00-58-23/statistics/obj_code_to_best_opt_res.npy'
    data_inst_to_opt_res_fn_b = './runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__08-04-21-37/statistics/obj_code_to_best_opt_res.npy'
    data_inst_to_opt_res_fn_b = './runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__08-13-39-24/statistics/obj_code_to_best_opt_res.npy'
    data_inst_to_opt_res_fn_b = './runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__09-14-58-35/statistics/obj_code_to_best_opt_res.npy'
    
    
    # data 
    # data_inst_to_opt_res_fn_b = "./runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__07-00-49-54/ts_to_hand_obj_obs_reset_1.npy" # find succ info ##
    ##### merged succ info ##### merged succ info ##### merged succ info ##### merged succ info #####
    # calcualte_merged_succ_info_v2(data_inst_to_opt_res_fn_a, data_inst_to_opt_res_fn_b)
    calcualte_merged_succ_info_v2(data_inst_to_opt_res_fn_a, data_inst_to_opt_res_fn_a)

    # calcualte_merged_succ_info(data_inst_to_opt_res_fn_a, data_inst_to_opt_res_fn_b)
    # calcualte_merged_succ_info_v3(data_inst_to_opt_res_fn_b, data_inst_to_opt_res_fn_b)
    exit(0)
    
    # data_inst_to_opt_res_fn = './uni_manip/isaacgym_rl_exp_grab_wdiffusion_samples_ws30_wohist_datav2_kineobjposcanon_/statistics/data_inst_tag_to_best_opt_res.npy'
    # # data_inst_to_opt_res_fn = "runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__01-23-48-11/statistics/obj_code_to_best_opt_res.npy"
    # # data_inst_to_opt_res_fn = './uni_manip/isaacgym_rl_exp_grab_eval_v2/statistics/data_inst_tag_to_best_opt_res.npy'
    # calcualte_succ_info(data_inst_to_opt_res_fn)
    # exit(0)
    
    # data_inst_to_opt_res_fn_a = './uni_manip/isaacgym_rl_exp_grab_wdiffusion_samples_ws30_wohist_datav2_kineobjposcanon_/statistics/data_inst_tag_to_best_opt_res.npy'
    # data_inst_to_opt_fn_b = "runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__01-23-48-11/statistics/obj_code_to_best_opt_res.npy"
    # compare_best_opt_res(data_inst_to_opt_res_fn_a, data_inst_to_opt_fn_b)
    # exit(0)
    
    
    # # inst_tag_to_opt_res_fn = "runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__01-23-35-23/statistics/obj_code_to_best_opt_res.npy"
    # inst_tag_to_opt_res_fn = "runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__01-23-48-11/statistics/obj_code_to_best_opt_res.npy"
    # inspect_data_inst_to_best_opt_res(inst_tag_to_opt_res_fn)
    # exit(0)
    
    
    # # data_optimized_res_nn = "runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__01-23-35-23/ts_to_hand_obj_obs_reset_1.npy"
    # # # data_optimized_res_nn = "runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__01-23-48-11/ts_to_hand_obj_obs_reset_1.npy"
    # # # ##### joint training with the demonstration -- test result on training trajectories ######
    # # data_optimized_res_nn = "runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__02-12-41-38/ts_to_hand_obj_obs_reset_1.npy" 
    # # data_optimized_res_nn = "runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__02-13-30-08/ts_to_hand_obj_obs_reset_1.npy"
    # # data_optimized_res_nn = "runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__01-23-48-11/ts_to_hand_obj_obs_reset_1.npy"
    # # ##### joint training with the demonstration -- test result on training trajectories ######
    # data_optimized_res_nn = "runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__02-12-41-38/ts_to_hand_obj_obs_reset_1.npy" 
    # data_optimized_res_nn = "runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__02-13-30-08/ts_to_hand_obj_obs_reset_1.npy"
    # data_optimized_res_nn = "runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__03-22-56-23/ts_to_hand_obj_obs_reset_1.npy"
    # data_optimized_res_nn = 'runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__04-01-08-35/ts_to_hand_obj_obs_reset_1.npy'
    # data_optimized_res_nn = "./runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__05-21-54-08/ts_to_hand_obj_obs_reset_1.npy"
    # data_optimized_res_nn = "./runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__05-23-07-10/ts_to_hand_obj_obs_reset_1.npy"
    # data_optimized_res_nn = "./runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__06-15-15-06/ts_to_hand_obj_obs_reset_1.npy"
    # data_optimized_res_nn = "./runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__06-15-19-50/ts_to_hand_obj_obs_reset_1.npy"
    # data_optimized_res_nn = "./runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__06-15-31-23/ts_to_hand_obj_obs_reset_1.npy"
    # data_optimized_res_nn = "./runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__06-17-06-19/ts_to_hand_obj_obs_reset_1.npy"
    # data_optimized_res_nn = "./runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__06-22-47-09/ts_to_hand_obj_obs_reset_1.npy"
    # data_optimized_res_nn = "./runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__07-00-23-01/ts_to_hand_obj_obs_reset_1.npy"
    # data_optimized_res_nn = "./runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__07-00-49-54/ts_to_hand_obj_obs_reset_1.npy"
    # data_optimized_res_nn = './runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__07-03-44-52/ts_to_hand_obj_obs_reset_1.npy'
    # data_optimized_res_nn = "./runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__07-12-50-15/ts_to_hand_obj_obs_reset_1.npy"
    # data_optimized_res_nn = "./runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__07-13-03-27/ts_to_hand_obj_obs_reset_1.npy"
    # data_optimized_res_nn = "./runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__07-13-12-21/ts_to_hand_obj_obs_reset_1.npy"
    # data_optimized_res_nn = "./runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__07-13-20-29/ts_to_hand_obj_obs_reset_1.npy"
    # data_optimized_res_nn = './runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__07-13-50-10/ts_to_hand_obj_obs_reset_1.npy'
    # data_optimized_res_nn = './runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__07-17-10-12/ts_to_hand_obj_obs_reset_1.npy'
    # data_optimized_res_nn = './runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__07-19-39-53/ts_to_hand_obj_obs_reset_1.npy'
    # data_optimized_res_nn = "./runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__07-22-35-04/ts_to_hand_obj_obs_reset_1.npy"
    # data_optimized_res_nn = "./runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__07-22-47-46/ts_to_hand_obj_obs_reset_1.npy"
    # data_optimized_res_nn = './runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__07-17-10-12/ts_to_hand_obj_obs_reset_1.npy'
    # data_optimized_res_nn = './runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__07-19-39-53/ts_to_hand_obj_obs_reset_1.npy'
    # data_optimized_res_nn = "./runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__07-22-35-04/ts_to_hand_obj_obs_reset_1.npy"
    # data_optimized_res_nn = "./runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__07-22-47-46/ts_to_hand_obj_obs_reset_1.npy"
    # data_optimized_res_nn = './runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__08-00-58-23/ts_to_hand_obj_obs_reset_1.npy'
    # data_optimized_res_nn = "./runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__08-04-21-37/ts_to_hand_obj_obs_reset_1.npy"
    # data_optimized_res_nn = "./runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__08-13-39-24/ts_to_hand_obj_obs_reset_1.npy"
    # data_optimized_res_nn = "./runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__09-14-58-35/ts_to_hand_obj_obs_reset_1.npy"
    # # data_optimized_res_nn = './runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__06-15-31-23/statistics/obj_code_to_best_opt_res.npy'
    # obj_code_to_best_opt_res = inspect_optimized_res_nn_w_object_codes(data_optimized_res_nn)
    # stats_root = "/".join(data_optimized_res_nn.split("/")[:-1])
    # stats_folder = os.path.join(stats_root, "statistics")
    # os.makedirs(stats_folder, exist_ok=True)
    # obj_code_to_best_opt_res_fn = "obj_code_to_best_opt_res.npy"
    # obj_code_to_best_opt_res_fn = os.path.join(stats_folder, obj_code_to_best_opt_res_fn)
    # np.save(obj_code_to_best_opt_res_fn, obj_code_to_best_opt_res)
    # print(f"Saved obj_code_to_best_opt_res to {obj_code_to_best_opt_res_fn}")
    # exit(0)
    
    # target_sub_tag = 's2'
    # data_inst_to_best_opt_res_fn = './uni_manip/isaacgym_rl_exp_grab_wdiffusion_samples_ws30_wohist_datav2_kineobjposcanon_/statistics/data_inst_tag_to_best_opt_res.npy'
    # inspect_data_inst_to_best_opt_res(data_inst_to_best_opt_res_fn, target_sub_tag)
    # exit(0)
    
    # # ./uni_manip/isaacgym_rl_exp_grab_wdiffusion_samples_ws30_wohist_datav2_kineobjposcanon_/statistics/data_inst_tag_to_best_opt_res.npy
    # inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_wdiffusion_samples_ws30_wohist_datav2_kineobjposcanon_/statistics/data_inst_tag_to_optimized_res.npy'
    # # inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_eval_v2/statistics/data_inst_tag_to_optimized_res.npy'
    # inst_tag_to_optimized_res_fn = '/root/diffsim/IsaacGymEnvs2/isaacgymenvs/runs/statistics/data_inst_tag_to_optimized_res.npy'
    # inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_eval_v2/statistics/data_inst_tag_to_optimized_res.npy'
    
    # # target_subj_tag = 's2'
    # # target_subj_tag = 's9'
    # target_subj_tag = 's10'
    # data_inst_tag_to_best_opt_res = get_obj_inst_tag_to_best_opt_res(inst_tag_to_optimized_res_fn, target_subj_tag)
    # eval_statistics_sv_folder = "/".join(inst_tag_to_optimized_res_fn.split("/")[:-1])
    # data_inst_tag_to_best_opt_res_fn = f"data_inst_tag_to_best_opt_res_{target_subj_tag}.npy"
    # # # # inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_wdiffusion_samples_ws30_wohist_datav2_kineobjposcanon_/statistics/data_inst_tag_to_optimized_res.npy'
    # inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_eval_v2/statistics/data_inst_tag_to_optimized_res.npy'
    inst_tag_to_optimized_res_fn = '/root/diffsim/IsaacGymEnvs2/isaacgymenvs/runs/statistics/data_inst_tag_to_optimized_res.npy'
    inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_eval_v2/statistics/data_inst_tag_to_optimized_res.npy'
    inst_tag_to_optimized_res_fn = '/root/diffsim/IsaacGymEnvs2/isaacgymenvs/runs/statistics/data_inst_tag_to_optimized_res.npy'
    inst_tag_to_optimized_res_fn = '/root/diffsim/IsaacGymEnvs2/isaacgymenvs/runs/statistics/data_inst_tag_to_optimized_res.npy'
    inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_v2/statistics/data_inst_tag_to_optimized_res.npy'
    inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_v4/statistics/data_inst_tag_to_optimized_res.npy'
    inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_grab_gene_v10/statistics/data_inst_tag_to_optimized_res.npy'
    inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_grab_gene_v10/statistics/data_inst_tag_to_optimized_res.npy'
    inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_grab_gene_v11/statistics/data_inst_tag_to_optimized_res.npy'
    inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_grab_gene_v12/statistics/data_inst_tag_to_optimized_res.npy'
    inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_grab_gene_v13/statistics/data_inst_tag_to_optimized_res.npy'
    inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_grab_all_v12/statistics/data_inst_tag_to_optimized_res.npy'
    inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_succonlytrained/statistics/data_inst_tag_to_optimized_res.npy'
    # target subj tag #
    target_subj_tag = ''
    
    random_select = False # 
    # random_select = True # true # # true # #
    
    data_inst_tag_to_best_opt_res = get_obj_inst_tag_to_best_opt_res(inst_tag_to_optimized_res_fn, target_subj_tag if len(target_subj_tag) > 0 else None, random_select=random_select)
    eval_statistics_sv_folder = "/".join(inst_tag_to_optimized_res_fn.split("/")[:-1])
    if len(target_subj_tag) > 0:
        data_inst_tag_to_best_opt_res_fn = f"data_inst_tag_to_best_opt_res_{target_subj_tag}.npy"
    else:
        if random_select:
            data_inst_tag_to_best_opt_res_fn = "data_inst_tag_to_best_opt_res_all_rndselect.npy"
        else:
            data_inst_tag_to_best_opt_res_fn = "data_inst_tag_to_best_opt_res_all.npy"

    data_inst_tag_to_best_opt_res_fn = os.path.join(eval_statistics_sv_folder, data_inst_tag_to_best_opt_res_fn)
    np.save(data_inst_tag_to_best_opt_res_fn, data_inst_tag_to_best_opt_res) # 
    print(f"Saved data_inst_tag_to_best_opt_res to {data_inst_tag_to_best_opt_res_fn} with length {len(data_inst_tag_to_best_opt_res)}")
    exit(0)
    
    # training dataset --- do we really have such differnet to optimize data? # # not necessary to train them better but you can get some results #
    # # best_opt_fn = "./uni_manip/isaacgym_rl_exp_grab_wdiffusion_samples_ws30_wohist_datav2_kineobjposcanon_/tracking_ori_grab_s9_eyeglasses_wear_1_obs_pure_state_wref_wdelta_density_500.0_trans_0.5_rot_0.5_slicing_hist_pred_deter_30-15-30-29/ts_to_hand_obj_obs_reset_1_sorted_best.npy"
    # inspect_best_optimized_res(best_opt_fn)
    # exit(0)
    
    # 
    # obj_code_to_best_opt_res = inspect_optimized_res_nn_w_object_codes(data_optimized_res_nn)
    
    # ckpt_fn = 'runs/tracking_ori_grab_s2_apple_lift_obs_pure_state_wref_wdelta_density_500.0_trans_0.5_rot_0.5_goalcond_False_kinebias_t0.5r0.5f20_rfd_0.3_rh_0.5_01-17-16-22/nn/tracking_ori_grab_s2_apple_lift_obs_pure_state_wref_wdelta_density_500.0_trans_0.5_rot_0.5_goalcond_False_kinebias_t0.5r0.5f20_rfd_0.3_rh_0.5.pth'
    # inspect_ckpt(ckpt_fn)
    # exit(0)
    
    
    # data_optimized_res_nn = 'runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__01-12-22-54/ts_to_hand_obj_obs_reset_1.npy'
    # data_inst_tag  = 'ori_grab_s1_cubesmall_offhand_1'
    # ### 
    # inspect_optimized_res_nn(data_optimized_res_nn, data_inst_tag,)
    
    # # data_inst_tag_to_opt
    
    # exit(0)
    
    # reward: -8.94 steps: 149.0
    # av reward: -13.87421875 av steps: 149.0
    # ori_grab_s5_watch_pass_1 -- best_pose_diff: 0.12948617503046989, obj_pos_diff: 0.035858746618032455, obj_rot_diff: 0.2837194800376892
    # ori_grab_s1_cubesmall_offhand_1 -- best_pose_diff: 0.12488595161587, obj_pos_diff: 0.012958609499037266, obj_rot_diff: 0.3391737639904022
    # /root/diffsim/UniDexGrasp/dexgrasp_policy/assets/meshdatav3_scaled/sem/ori_grab_s1_cubesmall_offhand_1/coacd/decomposed.obj
    # /root/diffsim/UniDexGrasp/dexgrasp_policy/assets/meshdatav3_scaled/sem/ori_grab_s5_watch_pass_1/coacd/decomposed.obj
    # data_optimized_res_nn = 'runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__01-02-16-09/ts_to_hand_obj_obs_reset_1.npy'
    # data_optimized_res_nn = 'runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__01-02-21-47/ts_to_hand_obj_obs_reset_1.npy'
    # data_optimized_res_nn = 'runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__01-02-25-58/ts_to_hand_obj_obs_reset_1.npy' # 1000, obj
    # # data_optimized_res_nn = 'runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__01-02-31-24/ts_to_hand_obj_obs_reset_1.npy' # 1000, hand, obj 
    # # av reward: -8.2059228515625 av steps: 149.0
    # # runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__01-11-11-34/ts_to_hand_obj_obs_reset_1.npy
    # data_inst_tag = 'ori_grab_s5_watch_pass_1'
    # data_inst_tag = 'ori_grab_s1_cubesmall_offhand_1'
    # new_optimized_info = best_optimized_res(data_optimized_res_nn, data_inst_tag, index=0)
    # obj_pose_diff = new_optimized_info['obj_pose_diff']
    # obj_pos_diff = new_optimized_info['obj_pos_diff']
    # obj_rot_diff = new_optimized_info['obj_rot_diff']
    # best_pose_diff = obj_pose_diff[0]
    # best_pos_diff, best_rot_diff = obj_pos_diff[0], obj_rot_diff[0]
    # print(f"best_pose_diff: {best_pose_diff}, obj_pos_diff: {best_pos_diff}, obj_rot_diff: {best_rot_diff}")
    # exit(0)
    
    # obj_type_to_obj_feat_fn = "./uni_manip/tds_diffusion_exp/allegro_tracking_kine_diff_AE_Diff_trainAE_vnew_/obj_type_to_obj_feat.npy"
    # obj_type_to_obj_feat_fn = "./uni_manip/tds_diffusion_exp/allegro_tracking_kine_diff_AE_Diff_trainAE_vnewv2_wtacodata_samples_/obj_type_to_obj_feat.npy"
    # inspect_obj_feats(obj_type_to_obj_feat_fn)
    # exit(0)
    
    # # obj_sample_folder = "./uni_manip/tds_diffusion_exp/allegro_tracking_kine_diff_AE_Diff_trainAE_vnew_"
    # # nn_bsz = 5
    # obj_sample_folder = "./uni_manip/tds_diffusion_exp/allegro_tracking_kine_diff_AE_Diff_trainAE_vnewv2_wtacodata_samples_"
    # nn_bsz = 12
    # # summarize_obj_features(obj_sample_folder, nn_bsz)
    # summarize_traj_features(obj_sample_folder, nn_bsz)
    # exit(0)
    
    # # 0-4 #
    # obj_feat_sample_fn = "./uni_manip/tds_diffusion_exp/allegro_tracking_kine_diff_AE_Diff_trainAE_vnew_/samples_ep_9_batch_3.npy" 
    # inspect_obj_feat_sample(obj_feat_sample_fn)
    # exit(0)
    
    # ckpt_fn = "./uni_manip/isaacgym_rl_exp_grab/tracking_ori_grab_s2_apple_lift_obs_pure_state_wref_wdelta_density_500.0_trans_0.5_rot_0.5_goalcond_False_kinebias_t0.5r0.5f20_rfd_0.3_rh_0.5_11-03-03-21/nn/tracking_ori_grab_s2_apple_lift_obs_pure_state_wref_wdelta_density_500.0_trans_0.5_rot_0.5_goalcond_False_kinebias_t0.5r0.5f20_rfd_0.3_rh_0.5.pth"
    # test_ckpt(ckpt_fn)
    # exit(0)
# >>>>>>> c6fbd593bf99644e2c520da3efc0c713832c4f66
    
    # grab_obj_name_idx_dict_fn = "../assets/grab_obj_name_idx_dict.npy"
    # inspect_grab_cross_obj_diff(grab_obj_name_idx_dict_fn)
    # exit(0)
    
    # ch_to_fa_task_sv_fn = "./uni_manip/isaacgym_rl_exp_grab_OPTFR_v2/statistics/child_task_to_fa_task.npy"
    # inspect_child_task_to_fa_task(ch_to_fa_task_sv_fn)
    # exit(0)
    
    # # exp_info_to_opt_res_fn = "/root/diffsim/IsaacGymEnvs2/isaacgymenvs/runs/statistics/exp_info_to_optimized_res.npy"
    # # exp_info_to_opt_res_fn = "./uni_manip/isaacgym_rl_exp_grab_OPTFR_v2/statistics/exp_info_to_optimized_res.npy"
    # exp_info_to_opt_res_fn = "./uni_manip/isaacgym_rl_exp_grab_OPTFR_v2/statistics/exp_info_to_optimized_res.npy" # exp info #
    # self_exp_res_to_opt_res_fn = "./uni_manip/isaacgym_rl_exp_grab/statistics/obj_type_to_optimized_res_s1_s10.npy"  
    # save_res = True 
    # # inspect_optfr_with_selfexp(exp_info_to_opt_res_fn, self_exp_res_to_opt_res_fn, save_res=save_res )
    # inspect_optfr_with_selfexp_list(exp_info_to_opt_res_fn, self_exp_res_to_opt_res_fn, save_res=save_res )
    # exit(0)
    
# <<<<<<< HEAD
#     subj_idx = 5
#     exp_root_folder = "./runs" # inspect exp info # # inspect the exp info # inspect the exp info # # inspect the exp info # # inspect the exp info #
#     exp_info_to_optimized_res = inspect_exp_info_to_optimized_res(exp_root_folder, subj_idx=subj_idx) 


    # # ./uni_manip/isaacgym_rl_exp_grab_OPTFR_v2/statistics/exp_info_to_optimized_res.npy
    # subj_idx = 2
    # subj_idx = None
    # # exp_root_folder = "./runs" # inspect exp info # # inspect the exp info # inspect the exp info # # inspect the exp info # # inspect the exp info #
    # exp_root_folder = "./uni_manip/isaacgym_rl_exp_grab_OPTFR_v2"
    # exp_root_folder = "./uni_manip/isaacgym_rl_exp_grab_OPTFR_v2"
    # exp_info_to_optimized_res = inspect_exp_info_to_optimized_res(exp_root_folder, subj_idx=subj_idx) 
    
    # exit(0)
    
    
    # inst_to_optimized_res_fn = "./uni_manip/isaacgym_rl_exp_grab_wdiffusion_samples/statistics/data_inst_tag_to_optimized_res.npy"
    # inspect_inst_tag_to_optimized_res(inst_to_optimized_res_fn)
    # exit(0)
    
    
    # optimized_res_fn = "./uni_manip/isaacgym_rl_exp_grab_eval_v2/statistics/data_inst_tag_to_optimized_res.npy"
    # inspect_optimized_res(optimized_res_fn)
    # exit(0)
    
    ### a direct traj optimized res fn ###
    ### a direct traj optimized res fn ###
    # exp_tag_to_optimized_res_fn = "./uni_manip/isaacgym_rl_exp_grab_eval/statistics/data_inst_tag_to_optimized_res.npy"
    # exp_tag_to_optimized_res_fn = "./uni_manip/isaacgym_rl_exp_grab_eval/statistics/obj_type_to_optimized_traj.npy"
    # inspect_exp_tag_to_optimized_res(exp_tag_to_optimized_res_fn)
    # exit(0)
    
    # ### save object type to optimized res ### ### 
    # # exp_root_folder = "./uni_manip/isaacgym_rl_exp_grab_OPTFR"
    # exp_root_folder  = './uni_manip/isaacgym_rl_exp_grab_OPTFR_v2'
    # # 
    # calculate_OPTFR_exp_to_optimized_res(exp_root_folder)
    # exit(0)
    
    # ./uni_manip/isaacgym_rl_exp_grab_OPTFR/tracking_ori_grab_s2_airplane_fly_1_OPTFR_ori_grab_s2_apple_lift_obs_pure_state_wref_wdelta_density_500.0_trans_0.5_rot_0.5_goalcond_False_kinebias_t0.5r0.5f20_rfd_0.3_rh_0.5_18-17-38-45
    # # target_grab_inst_tag = 'ori_grab_s2_airplane_fly_1'
    # # ./uni_manip/isaacgym_rl_exp_grab_OPTFR/tracking_ori_grab_s2_airplane_fly_1_OPTFR_ori_grab_s2_elephant_inspect_1_obs_pure_state_wref_wdelta_density_500.0_trans_0.5_rot_0.5_goalcond_False_kinebias_t0.5r0.5f20_rfd_0.3_rh_0.5_18-18-56-44/nn/tracking_ori_grab_s2_airplane_fly_1_OPTFR_ori_grab_s2_elephant_inspect_1_obs_pure_state_wref_wdelta_density_500.0_trans_0.5_rot_0.5_goalcond_False_kinebias_t0.5r0.5f20_rfd_0.3_rh_0.5.pth
    # target_grab_inst_tag = 'ori_grab_s2_apple_lift'
    # target_grab_inst_tag = 'ori_grab_s2_elephant_inspect_1'
    # data_inst_to_opt_res_fn = "./uni_manip/isaacgym_rl_exp_grab_eval/statistics/data_inst_tag_to_optimized_res.npy"
    # inspect_data_instance_to_optimized_res(data_inst_to_opt_res_fn, target_grab_inst_tag=target_grab_inst_tag)
    # exit(0)
    
    # data_statistics_fn = "/root/diffsim/softzoo/softzoo/diffusion/assets/data_statistics_ws_30_step_15.npy"
    # inspect_data_statistics(data_statistics_fn)
    # exit(0)
    
    # # ## inpsect optimized res nn ##
    # cur_inst_tag_optimized_res_fn = '/root/diffsim/IsaacGymEnvs2/isaacgymenvs/runs/tracking_ori_grab_s8_hammer_lift_obs_pure_state_wref_wdelta_density_500.0_trans_0.5_rot_0.5_goalcond_False_kinebias_t0.5r0.5f20_rfd_0.3_rh_0.5_20-19-37-40/ts_to_hand_obj_obs_reset_1.npy'
    # inst_tag = ['ori_grab_s8_hammer_lift', 'ori_grab_s8_hammer_lift']
    
    # cur_inst_tag_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_eval_v2/tracking_ori_grab_s8_apple_lift_obs_pure_state_wref_wdelta_density_500.0_trans_0.5_rot_0.5_goalcond_False_kinebias_t0.5r0.5f20_rfd_0.3_rh_0.5_20-19-59-53/ts_to_hand_obj_obs_reset_1.npy'
    # inst_tag = ['ori_grab_s8_apple_lift', 'ori_grab_s8_apple_lift']
    
    # cur_inst_tag_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_eval_v2/tracking_ori_grab_s8_banana_eat_1_obs_pure_state_wref_wdelta_density_500.0_trans_0.5_rot_0.5_goalcond_False_kinebias_t0.5r0.5f20_rfd_0.3_rh_0.5_20-19-52-28/ts_to_hand_obj_obs_reset_1.npy'
    # inst_tag = ['ori_grab_s8_banana_eat_1', 'ori_grab_s8_banana_eat_1']
    
    # # ./uni_manip/isaacgym_rl_exp_grab_eval_v2/tracking_ori_grab_s8_banana_peel_1_obs_pure_state_wref_wdelta_density_500.0_trans_0.5_rot_0.5_goalcond_False_kinebias_t0.5r0.5f20_rfd_0.3_rh_0.5_20-20-51-58/ts_to_hand_obj_obs_reset_1.npy
    # cur_inst_tag_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_eval_v2/tracking_ori_grab_s8_banana_peel_1_obs_pure_state_wref_wdelta_density_500.0_trans_0.5_rot_0.5_goalcond_False_kinebias_t0.5r0.5f20_rfd_0.3_rh_0.5_20-20-51-58/ts_to_hand_obj_obs_reset_1.npy'
    # inst_tag = ['ori_grab_s8_banana_peel_1', 'ori_grab_s8_banana_peel_1']
    
    # inspect_optimized_res_nn(cur_inst_tag_optimized_res_fn, inst_tag)
    # exit(0)
    
    # inst_tag_to_optimized_res_fn = "./uni_manip/isaacgym_rl_exp_grab_eval/statistics/data_inst_tag_to_optimized_res.npy"
    # inspect_inst_tag_to_optimized_res(inst_tag_to_optimized_res_fn)
    # exit(0)
    
    # target_eval_folder = "./uni_manip/isaacgym_rl_exp_grab_eval_v2"
    # forbid_subj_idx = 7
    # mv_evaled_data_to_eval_folder(target_eval_folder, forbid_subj_idx)
    # exit(0)
    
    # new_eval_res_sv_dict_fn ="/root/diffsim/IsaacGymEnvs2/isaacgymenvs/runs/tracking_ori_grab_s1_alarmclock_pass_1_obs_pure_state_wref_wdelta_density_500.0_trans_0.5_rot_0.5_goalcond_False_kinebias_t0.5r0.5f20_rfd_0.3_rh_0.5_20-00-11-57/ts_to_hand_obj_obs_reset_1.npy"
    # new_eval_res_sv_dict_fn  = "/root/diffsim/IsaacGymEnvs2/isaacgymenvs/runs/tracking_ori_grab_s7_airplane_lift_Retake_obs_pure_state_wref_wdelta_density_500.0_trans_0.5_rot_0.5_goalcond_False_kinebias_t0.5r0.5f20_rfd_0.3_rh_0.5_20-14-31-52/ts_to_hand_obj_obs_reset_1.npy"
    # inspect_new_eval_res(new_eval_res_sv_dict_fn)
    # exit(0)
    
    # ./uni_manip/isaacgym_rl_exp_grab/statistics/obj_type_to_optimized_res.npy
    # obj_type_to_optimized_res_fn = "./uni_manip/isaacgym_rl_exp_grab/statistics/obj_type_to_optimized_res.npy"
    # obj_type_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_eval/statistics/data_inst_tag_to_optimized_res.npy'
    # obj_type_to_res = np.load(obj_type_to_optimized_res_fn, allow_pickle=True).item()
    # print(obj_type_to_res.keys())
    # exit(0)
    
    # sv_res_fn = "./uni_manip/isaacgym_rl_exp_grab_eval/tracking_ori_grab_s1_alarmclock_offhand_1_obs_pure_state_wref_wdelta_density_500.0_trans_0.5_rot_0.5_goalcond_False_kinebias_t0.5r0.5f20_rfd_0.3_rh_0.5_17-19-05-48/ts_to_hand_obj_obs_reset_1.npy"
    # data_inst_tag = "ori_grab_s1_alarmclock_offhand_1"
    # sv_res = np.load(sv_res_fn, allow_pickle=True).item()
    # new_optimized_res = best_optimized_res(sv_res_fn, data_inst_tag)
    # print(f"new_optimized_res: {new_optimized_res.keys()}")
    # exit(0)
    
    # sv_res = np.load(sv_res_fn, allow_pickle=True).item()
    # for key in sv_res:
    #     cur_val = sv_res[key]
    #     print(cur_val.keys())
    #     break
    # # print(sv_res.keys())
    # exit(0)
    
    
    # # data_inst_tag_to_optimized_res_fn = "./uni_manip/isaacgym_rl_exp_grab_eval/statistics/data_inst_tag_to_optimized_res.npy"
    # # data_inst_tag_to_optimized_res_fn = "./uni_manip/isaacgym_rl_exp_taco_grab_interpseq_eval/statistics/data_inst_tag_to_optimized_res.npy"
    
    
    # cur_inst_tag_optimized_res_fn = 'runs/tracking_ori_grab_s8_watch_lift_obs_pure_state_wref_wdelta_hand_allegro_density_500_trans_0.5_rot_0.5_goalcond_False_kinebais_wdelta_rewhandpos_dist__04-19-10-33/ts_to_hand_obj_obs_reset_1.npy'
    # inst_tag = 'ori_grab_s9_waterbottle_pour_1'
    # inst_tag = (inst_tag, inst_tag)
    # inspect_optimized_res_nn(cur_inst_tag_optimized_res_fn, inst_tag)
    # exit(0)
    
    
    # data_inst_tag_to_optimized_res_fn = "./uni_manip/isaacgym_rl_exp_grab_eval_v2/statistics/data_inst_tag_to_optimized_res.npy"
    # data_inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_nf_300_eval/statistics/data_inst_tag_to_optimized_res.npy'
    # data_inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_wdiffusion_samples_ws30_wohist_datav2_kineobjposcanon_/statistics/data_inst_tag_to_optimized_res.npy'
    # data_inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_eval_v2/statistics/data_inst_tag_to_optimized_res.npy'
    # # target_inst_tag = 's2'
    
    # data_inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_nf_300_eval/statistics/data_inst_tag_to_optimized_res.npy'
    # data_inst_tag_to_optimized_res_fn = '/root/diffsim/IsaacGymEnvs2/isaacgymenvs/runs/statistics/data_inst_tag_to_optimized_res.npy'



    data_inst_tag_to_optimized_res_fn = '/root/diffsim/IsaacGymEnvs2/isaacgymenvs/runs/statistics/data_inst_tag_to_optimized_res.npy'
    target_inst_tag = 's10'
    
    data_inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_eval_v2/statistics/data_inst_tag_to_optimized_res.npy'
    target_inst_tag = 's10'
    # target_inst_tag = 's9'
    # target inst tag = 's9'
    data_inst_tag_to_optimized_res_fn = './uni_manip/isaacgym_rl_exp_grab_generalist_direct_samples_v4/statistics/data_inst_tag_to_optimized_res.npy'
    target_inst_tag = None

    resave_optimized_res(data_inst_tag_to_optimized_res_fn, target_sub_tag=target_inst_tag)
    exit(0)

    # target_inst_tag = 's10'

    
    # target_inst_tag = None
    

    # resave_optimized_res(data_inst_tag_to_optimized_res_fn, target_sub_tag=target_inst_tag)
    # exit(0)

    
    data_optimized_res_nn = "./uni_manip/isaacgym_rl_exp_grab_eval/tracking_ori_grab_s2_duck_inspect_1_obs_pure_state_wref_wdelta_density_500.0_trans_0.5_rot_0.5_goalcond_False_kinebias_t0.5r0.5f20_rfd_0.3_rh_0.5_12-23-05-11/ts_to_hand_obj_obs_reset_1.npy"
    # inspect_optimized_res_nn(data_optimized_res_nn)
    # exit(0)
    
    grab_eval_data_folder = "./uni_manip/isaacgym_rl_exp_grab_eval"
    grab_eval_data_folder = os.path.join(grab_eval_data_folder, "statistics")
    
    data_inst_tag_to_optimized_res_fn  = "data_inst_tag_to_optimized_res.npy"
    data_inst_tag_to_optimized_res_fn = os.path.join(grab_eval_data_folder, data_inst_tag_to_optimized_res_fn)
    
    # inspect_data_inst_tag_to_optimized_res(data_inst_tag_to_optimized_res_fn)
    # exit(0)
    
    
    
    # grab_eval_data_folder = "./uni_manip/isaacgym_rl_exp_grab_eval"
    # grab_eval_data_folder = "./uni_manip/isaacgym_rl_exp_grab_eval_v2"
    # grab_eval_data_folder = './uni_manip/isaacgym_rl_exp_grab_wdiffusion_samples'
    # grab_eval_data_folder = './uni_manip/isaacgym_rl_exp_grab_nf_300_eval'

    grab_eval_data_folder = './uni_manip/isaacgym_rl_exp_grab_wdiffusion_samples_ws30_wohist_datav2_kineobjposcanon_'
    grab_eval_data_folder= './uni_manip/isaacgym_rl_exp_grab_wdiffusion_samples_ws30_wohist_datav2_kineobjposcanon_/'
    grab_eval_data_folder = '/root/diffsim/IsaacGymEnvs2/isaacgymenvs/runs'
    get_data_inst_tag_to_optimized_res(grab_eval_data_folder)
    exit(0)

    # grab_eval_data_folder = './uni_manip/isaacgym_rl_exp_grab_wdiffusion_samples_ws30_wohist_datav2_kineobjposcanon_'
    # grab_eval_data_folder= './uni_manip/isaacgym_rl_exp_grab_wdiffusion_samples_ws30_wohist_datav2_kineobjposcanon_/'
    # # grab_eval_data_folder = './uni_manip/isaacgym_rl_exp_taco_grab_interpseq_eval_v2'
    # get_data_inst_tag_to_optimized_res(grab_eval_data_folder)
    # exit(0)

    #### calculating obj_type_to_optimized_res ####
    ## for calculating obj_type_to_optimized_res ##
    optimized_data_sv_root = './uni_manip/isaacgym_rl_exp_grab'
    optimized_data_sv_root = './uni_manip/isaacgym_rl_exp_grab_wdiffusion_samples_reopt'
    optimized_data_sv_root = './uni_manip/isaacgym_rl_exp_grab_nf_300'
    optimized_data_sv_root = './uni_manip/isaacgym_rl_exp_grab_wdiffusion_samples_ws30_wohist_datav2_kineobjposcanon_repot'
    optimized_data_sv_root = './uni_manip/isaacgym_rl_exp_grab_OPTFR_v2'
    calculate_optimized_res(optimized_data_sv_root)
    exit(0)
    
    grab_inst_tag = "ori_grab_s3_pyramidlarge_inspect_1"
    # inspect_optimized_res(grab_inst_tag)
    # exit(0)
    
    training_data_target_folder = "./uni_manip/isaacgym_rl_exp_grab_nf_300"
    nf = 300
    # mv_training_data_to_folder(training_data_target_folder, nf=nf)
    # exit(0)
    
    # /root/diffsim/IsaacGymEnvs2/isaacgymenvs/runs/tracking_ori_grab_s2_phone_call_1_obs_pure_state_wref_wdelta_density_500.0_trans_0.5_rot_0.5_goalcond_False_kinebias_t0.5r0.5f20_rfd_0.3_rh_0.5_18-00-33-11
    forbid_tag = "ori_grab_s2_phone_call_1"
    eval_folder = "./uni_manip/isaacgym_rl_exp_grab_eval"
    mv_eval_data_to_eval_folder(eval_folder=eval_folder, forbid_tag=forbid_tag)
    exit(0)
    
# obj type to optimized res #
    # else:
    #     obj_type_to_optimized_res = np.load(obj_type_to_optimized_res_sv_fn, allow_pickle=True).item() # true and the res sv fn #
    
        
        