import os
import numpy as np
import subprocess

def parse_skeleton_file(file_path):
    with open(file_path, 'r') as file:
        lines = file.readlines()
    
    colorX = []
    colorY = []
    
    for line in lines:
        joint_info = line.strip().split()
        if len(joint_info) == 12:  
            colorX.append(float(joint_info[5]))
            colorY.append(float(joint_info[6]))

    return np.array(colorX), np.array(colorY)

def calculate_crop_parameters(colorX, colorY, video_width=1920, video_height=1080, expansion_w=0.2, expansion_h=0.3):
    min_x, max_x = np.min(colorX), np.max(colorX)
    min_y, max_y = np.min(colorY), np.max(colorY)

    width = max_x - min_x
    height = max_y - min_y

    # Apply 1.2x on width (0.2 expansion) and 1.3x on height (0.3 expansion) per paper
    expanded_min_x = max(0, min_x - width * expansion_w)
    expanded_max_x = min(video_width, max_x + width * expansion_w)
    expanded_min_y = max(0, min_y - height * expansion_h)
    expanded_max_y = min(video_height, max_y + height * expansion_h)

    crop_left = int(expanded_min_x)
    crop_right = int(expanded_max_x)
    crop_top = int(expanded_min_y)
    crop_bottom = int(expanded_max_y)

    return crop_left, crop_right, crop_top, crop_bottom


def generate_v2e_command(skeleton_file, rgb_video_file, output_folder, crop_parameters):
    sample_name = os.path.basename(skeleton_file).replace('.skeleton', '')
    crop_left, crop_right, crop_top, crop_bottom = crop_parameters
    crop_param = f"{crop_left},{crop_right},{crop_top},{crop_bottom}"
    
    v2e_command = [
        "python", "v2e.py",
        "-i", rgb_video_file,
        "--overwrite", "--timestamp_resolution", "0.01", "--dvs_exposure", "source",
        "--output_folder", output_folder,
        "--pos_thres", "0.15", "--neg_thres", "0.15", "--sigma_thres", "0.03",
        "--dvs640", 
        "--cutoff_hz", "15", "--disable_slomo", "--no_preview",
        "--crop", crop_param,
        "--dvs_vid", f"{output_folder}/{sample_name}_dvs.avi"
    ]
    
    return v2e_command


def read_available_samples(file_path):
    with open(file_path, 'r') as file:
        available_samples = file.read().splitlines()
    return available_samples

def main():
    skeleton_folder = 'Dataprocess/ProcessEvent/BaseData/Skeleton'
    rgb_video_base_folder = 'Dataprocess/ProcessEvent/BaseData/RGB'
    output_folder = 'Dataprocess/ProcessEvent/Output'
    available_samples_file = 'Dataprocess/ProcessEvent/BaseData/action_classes_filtered.txt'

    available_samples = read_available_samples(available_samples_file)


    if not os.path.exists(output_folder):
        os.makedirs(output_folder)

    for sample_name in available_samples:
        skeleton_file_path = os.path.join(skeleton_folder, f"{sample_name}.skeleton")
        rgb_video_file_path = None

        for root, files in os.walk(rgb_video_base_folder):
            if files == f"{sample_name}_rgb.avi":
                rgb_video_file_path = os.path.join(root, files)
                break
            if rgb_video_file_path:
                break

        if rgb_video_file_path:
        
            colorX, colorY = parse_skeleton_file(skeleton_file_path)
            if colorX.size > 0 and colorY.size > 0: 
                crop_parameters = calculate_crop_parameters(colorX, colorY)


                v2e_command = generate_v2e_command(skeleton_file_path, rgb_video_file_path, output_folder, crop_parameters)
                

                print(f"Processing video: {rgb_video_file_path}")
                print(f"Generated .avi file: {output_folder}/{sample_name}_dvs.avi")

                subprocess.run(v2e_command, stdout=subprocess.PIPE, stderr=subprocess.PIPE)
            else:
                print(f"No skeleton data in: {skeleton_file_path}")
        else:
            print(f"No corresponding RGB video found for: {sample_name}")

if __name__ == "__main__":
    main()
