import os
import os.path as osp
import numpy as np
from rekognition_online_action_detection.utils.parser import load_cfg
def main(args,phase="train"):
    args.new_data_root="data/THUMOS_10/class"
    args.data_root="data/THUMOS"
    num_frames=[]
    for i in range(0,22):
        num_frames.append([])
    
     
      
    save_dir="data/THUMOS_10/class"
    save_name=".npy"
    num_action_dir="data/THUMOS_10/num_action"
    result_dir="data/THUMOS_10"
    sessions = getattr(args.DATA, phase.upper() + '_SESSION_SET') 
    args.training = phase == 'train'
    num_videos = np.ones([22])
    
    jjj=0
    for session in sessions:
        jjj=jjj+1
        if jjj==74:
            print(1)
        target = np.load(osp.join(args.data_root, 'target_perframe', session + '.npy')) 
        camera_inputs = np.load(
            osp.join(args.data_root, args.INPUT.VISUAL_FEATURE, session + '.npy'), mmap_mode='r') 
        motion_inputs = np.load(
            osp.join(args.data_root, args.INPUT.MOTION_FEATURE, session + '.npy'), mmap_mode='r') 
        
        height,width=target.shape
        exist_camera=[]
        exist_motion=[]
        exist_target=[]
        sum_target=target.sum(axis=0)
        action_classes=np.count_nonzero(sum_target)
        if (action_classes==2 and sum_target[0]!=0) or (action_classes==2 and sum_target[21]!=0)or (action_classes==3 and sum_target[21]!=0 and sum_target[0]!=0):
            for i in range(1,21):
                if sum_target[i]>0:
                    np.save(osp.join(save_dir + str(i),
                                     str(int(num_videos[int(i)])) + "_rgb" + save_name), camera_inputs)
                    np.save(osp.join(save_dir + str(i),
                                     str(int(num_videos[int(i)])) + "_flow" + save_name), motion_inputs)
                    np.save(osp.join(save_dir + str(i),
                                     str(int(num_videos[int(i)])) + "_target" + save_name), target)
                    exist_camera = []
                    exist_motion = []
                    exist_target = []
                    num_videos[int(i)] = num_videos[int(i)] + 1
                    num_frames[i].append(height)
        else:   
            classes_perframe=1  
            classes_group=[]
            re_target = np.copy(target)
            for frame in range(height):   
                re_target[frame][0]=0
                re_target[frame][21]=0
                classes=np.count_nonzero(re_target[frame])
                if classes>1 :
                    classes_perframe=classes
                    classes_group.append(np.nonzero(target[frame]))   
            if classes_perframe==1: 
                video_class=0  
                add_frames=0   
                add_class_frames=0 
                for i in range(height) : 
                    classes = np.count_nonzero(target[i])
                    if classes==1:  
                        truth=target[i].argmax()
                        if truth==21:
                            truth=0
                        if i==0 :  
                            exist_camera.append(camera_inputs[i])
                            exist_motion.append(motion_inputs[i])
                            exist_target.append(target[i])
                            if truth!=0:
                                video_class=truth
                            add_frames=add_frames+1
                        elif i==height-1: 
                            np.save(osp.join(save_dir + str(video_class),
                                             str(int(num_videos[int(video_class)])) + "_rgb" + save_name), exist_camera)
                            np.save(osp.join(save_dir + str(video_class),
                                             str(int(num_videos[int(video_class)])) + "_flow" + save_name),
                                    exist_motion)
                            np.save(osp.join(save_dir + str(video_class),
                                             str(int(num_videos[int(video_class)])) + "_target" + save_name),
                                    exist_target)
                            num_videos[int(video_class)]=num_videos[int(video_class)]+1
                            num_frames[video_class].append(add_frames)
                            exist_camera=[]
                            exist_target=[]
                            exist_motion=[]
                            video_class =0
                            add_frames = 0
                            add_class_frames = 0
                        else:   
                            truth_previous = target[i - 1].argmax()  
                            if truth_previous==21:
                                truth_previous=0
                            if truth==truth_previous :
                                exist_camera.append(camera_inputs[i])
                                exist_motion.append(motion_inputs[i])
                                exist_target.append(target[i])
                                add_frames=add_frames+1
                                if truth==0 and video_class!=0:
                                    add_class_frames=add_class_frames+1
                            else:
                                if truth==0:
                                    exist_camera.append(camera_inputs[i])
                                    exist_motion.append(motion_inputs[i])
                                    exist_target.append(target[i])
                                    add_frames=add_frames+1
                                    add_class_frames=1  
                                else:
                                    if truth_previous==0:
                                        if video_class==0: 
                                            exist_camera.append(camera_inputs[i])
                                            exist_motion.append(motion_inputs[i])
                                            exist_target.append(target[i])
                                            add_frames = add_frames + 1
                                            video_class=truth
                                        else: 
                                            if truth==video_class:
                                                exist_camera.append(camera_inputs[i])
                                                exist_motion.append(motion_inputs[i])
                                                exist_target.append(target[i])
                                                add_frames = add_frames + 1
                                            else: 
                                                add_class_frames=add_class_frames//2  
                                                store_camera=np.copy(exist_camera[0:add_frames-add_class_frames])  
                                                store_motion=np.copy(exist_motion[0:add_frames-add_class_frames])
                                                store_target=np.copy(exist_target[0:add_frames - add_class_frames])
                                                np.save(osp.join(save_dir + str(video_class),
                                                             str(int(num_videos[int(video_class)])) + "_rgb" + save_name), store_camera)
                                                np.save(osp.join(save_dir + str(video_class),
                                                             str(int(num_videos[int(video_class)])) + "_flow" + save_name), store_motion)
                                                np.save(osp.join(save_dir + str(video_class),
                                                             str(int(num_videos[int(video_class)])) + "_target" + save_name), store_target)
                                                num_frames[video_class].append(add_frames-add_class_frames)
                                                num_videos[int(video_class)] = num_videos[int(video_class)] + 1
                                                exist_camera = np.copy(
                                                    exist_camera[add_frames - add_class_frames:add_frames]).tolist()
                                                exist_motion = np.copy(
                                                    exist_motion[add_frames - add_class_frames:add_frames]).tolist()
                                                exist_target = np.copy(
                                                    exist_target[add_frames - add_class_frames:add_frames]).tolist()
                                                exist_camera.append(camera_inputs[i])
                                                exist_motion.append(motion_inputs[i])
                                                exist_target.append(target[i])
                                                video_class=truth  
                                                add_frames=add_class_frames+1  
                                                add_class_frames=0  

                                    else:
                                        np.save(osp.join(save_dir + str(video_class),
                                                        str(int(num_videos[int(video_class)])) + "_rgb" + save_name), exist_camera)
                                        np.save(osp.join(save_dir + str(video_class),
                                                        str(int(num_videos[int(video_class)])) + "_flow" + save_name),
                                             exist_motion)
                                        np.save(osp.join(save_dir + str(video_class),
                                                       str(int(num_videos[int(video_class)])) + "_target" + save_name),
                                               exist_target)
                                        num_frames[video_class].append(add_frames)
                                        num_videos[int(video_class)]=num_videos[int(video_class)]+1
                                        exist_camera=[]
                                        exist_motion=[]
                                        exist_target=[]
                                        exist_camera.append(camera_inputs[i])
                                        exist_motion.append(motion_inputs[i])
                                        exist_target.append(target[i])
                                        video_class = truth
                                        add_frames = 1
                                        add_class_frames = 0
            else:
                for c in range(2):   
                    num_two_class=0    
                    for frame in range(height):
                        classes=np.count_nonzero(re_target[frame])
                        if classes>1:
                            target[frame][classes_group[num_two_class][0][c]]=0 
                            target[frame][classes_group[num_two_class][0][abs(c-1)]] = 1
                            num_two_class=num_two_class+1
                    if (action_classes == 2 and sum_target[0] != 0) or (
                            action_classes == 2 and sum_target[21] != 0) or (
                            action_classes == 3 and sum_target[21] != 0 and sum_target[0] != 0):  
                        for i in range(1, 21):
                            if sum_target[i] > 0:
                                np.save(osp.join(save_dir + str(i),
                                                 str(int(num_videos[int(i)])) + "_rgb" + save_name), camera_inputs)
                                np.save(osp.join(save_dir + str(i),
                                                 str(int(num_videos[int(i)])) + "_flow" + save_name), motion_inputs)
                                np.save(osp.join(save_dir + str(i),
                                                 str(int(num_videos[int(i)])) + "_target" + save_name), target)
                                exist_camera = []
                                exist_motion = []
                                exist_target = []
                                num_videos[int(i)] = num_videos[int(i)] + 1
                                num_frames[i].append(height)
                    else:
                        video_class = 0  
                        add_frames = 0  
                        add_class_frames = 0  
                        for i in range(height):  
                            classes = np.count_nonzero(target[i])
                            if classes>0:
                                truth = target[i].argmax()  
                                if truth == 21:  
                                    truth = 0
                                if i == 0:  
                                    exist_camera.append(camera_inputs[i])
                                    exist_motion.append(motion_inputs[i])
                                    exist_target.append(target[i])
                                    if truth != 0:
                                        video_class = truth
                                    add_frames = add_frames + 1
                                elif i == height-1:  
                                    np.save(osp.join(save_dir + str(video_class),
                                                     str(int(num_videos[int(video_class)])) + "_rgb" + save_name),
                                            exist_camera)
                                    np.save(osp.join(save_dir + str(video_class),
                                                     str(int(num_videos[int(video_class)])) + "_flow" + save_name),
                                            exist_motion)
                                    np.save(osp.join(save_dir + str(video_class),
                                                     str(int(num_videos[int(video_class)])) + "_target" + save_name),
                                            exist_target)
                                    num_videos[int(video_class)] = num_videos[int(video_class)] + 1
                                    num_frames[video_class].append(add_frames)
                                    exist_camera = []
                                    exist_target = []
                                    exist_motion = []
                                    video_class = 0
                                    add_frames = 0
                                    add_class_frames = 0
                                else:  
                                    truth_previous = target[i - 1].argmax()  
                                    if truth_previous==21:
                                        truth_previous =0
                                    if truth == truth_previous:  
                                        exist_camera.append(camera_inputs[i])
                                        exist_motion.append(motion_inputs[i])
                                        exist_target.append(target[i])
                                        add_frames = add_frames + 1
                                        if truth == 0 and video_class != 0:
                                            add_class_frames = add_class_frames + 1
                                    else:
                                        if truth == 0:  
                                            exist_camera.append(camera_inputs[i])
                                            exist_motion.append(motion_inputs[i])
                                            exist_target.append(target[i])
                                            add_frames = add_frames + 1
                                            add_class_frames = 1  
                                        else:
                                            if truth_previous == 0:  
                                                if video_class == 0:  
                                                    exist_camera.append(camera_inputs[i])
                                                    exist_motion.append(motion_inputs[i])
                                                    exist_target.append(target[i])
                                                    add_frames = add_frames + 1
                                                    video_class = truth
                                                else:  
                                                    if truth == video_class:  
                                                        exist_camera.append(camera_inputs[i])
                                                        exist_motion.append(motion_inputs[i])
                                                        exist_target.append(target[i])
                                                        add_frames = add_frames + 1
                                                    else:  
                                                        add_class_frames = add_class_frames // 2  
                                                        store_camera = np.copy(
                                                            exist_camera[0:add_frames - add_class_frames])  
                                                        store_motion = np.copy(
                                                            exist_motion[0:add_frames - add_class_frames])
                                                        store_target = np.copy(
                                                            exist_target[0:add_frames - add_class_frames])
                                                        np.save(osp.join(save_dir + str(video_class),
                                                                         str(int(num_videos[
                                                                                     int(video_class)])) + "_rgb" + save_name),
                                                                store_camera)
                                                        np.save(osp.join(save_dir + str(video_class),
                                                                         str(int(num_videos[
                                                                                     int(video_class)])) + "_flow" + save_name),
                                                                store_motion)
                                                        np.save(osp.join(save_dir + str(video_class),
                                                                         str(int(num_videos[
                                                                                     int(video_class)])) + "_target" + save_name),
                                                                store_target)
                                                        num_frames[video_class].append(add_frames - add_class_frames)
                                                        num_videos[int(video_class)] = num_videos[int(video_class)] + 1
                                                        exist_camera = np.copy(
                                                            exist_camera[add_frames - add_class_frames:add_frames]).tolist()
                                                        exist_motion = np.copy(
                                                            exist_motion[add_frames - add_class_frames:add_frames]).tolist()
                                                        exist_target = np.copy(
                                                            exist_target[add_frames - add_class_frames:add_frames]).tolist()
                                                        exist_camera.append(camera_inputs[i])
                                                        exist_motion.append(motion_inputs[i])
                                                        exist_target.append(target[i])
                                                        video_class = truth  
                                                        add_frames = add_class_frames + 1  
                                                        add_class_frames = 0  

                                            else:  
                                                if num_videos[int(video_class)] == 8 and video_class == 6:
                                                    print(1)
                                                np.save(osp.join(save_dir + str(video_class),
                                                                 str(int(
                                                                     num_videos[int(video_class)])) + "_rgb" + save_name),
                                                        exist_camera)
                                                np.save(osp.join(save_dir + str(video_class),
                                                                 str(int(
                                                                     num_videos[int(video_class)])) + "_flow" + save_name),
                                                        exist_motion)
                                                np.save(osp.join(save_dir + str(video_class),
                                                                 str(int(num_videos[
                                                                             int(video_class)])) + "_target" + save_name),
                                                        exist_target)
                                                num_frames[video_class].append(add_frames)
                                                num_videos[int(video_class)] = num_videos[int(video_class)] + 1
                                                exist_camera = []
                                                exist_motion = []
                                                exist_target = []
                                                exist_camera.append(camera_inputs[i])
                                                exist_motion.append(motion_inputs[i])
                                                exist_target.append(target[i])
                                                video_class = truth
                                                add_frames = 1
                                                add_class_frames = 0
    for i in range(22):
        num_frames[i].append(int(len(num_frames[i])))
        np.savetxt(osp.join(save_dir+str(i),"class"+str(i)+"_frames_num.txt"),np.array (num_frames[i]),fmt="%d")  
if __name__ == '__main__':
        main(load_cfg())