
import pandas as pd
import json
import numpy as np
from omegaconf import OmegaConf, DictConfig
import os
import yaml
from template_bash import bash_heads
from tqdm import tqdm
import glob
import shutil

df = pd.read_parquet('/path/to/data/csv')
captions = df['caption']
df_animal = df[~df['Animal'].isin(['None', None])]
vid_path = '/path/to/source/video/mp4'
frame_path = '/path/to/source/video/frames'

captions = list(df_animal['caption'])
prompts = list(df_animal['CE_animal'])
keys = list(df_animal['key'])
animals = list(df_animal['Animal'])
animals = [item.split(', ') for item in animals]
editing_entity = list(df_animal['CE_animal_editing_entity'])
video_files = [os.path.join(vid_path, f'{key}.mp4') for key in keys]
frame_files = [os.path.join(frame_path, key) for key in keys]


config_path = '/save/config/path'
save_path = '/output/path'

prompt_bashes = []
for i in range(len(frame_files)):
    output_path = os.path.join(save_path, keys[i])
    input_path = frame_files[i].replace('sampled_frames', 'sampled_frames_6d')
    inversion_path = os.path.join(config_path, keys[i], 'inversion_no_finetune')
    cur_bash = f'export CUDA_VISIBLE_DEVICES=$$$d$$$\npython -u test_cfg.py --input_path {input_path} --output_path {output_path} --inversion_path {inversion_path} --org_prompt \'{captions[i]}\' --edit_prompt \'{prompts[i]}\''
    prompt_bashes.append(cur_bash)

device_id = [7]
devide_count = len(device_id)
total_len = len(prompt_bashes)
length_per_device = total_len // devide_count
run_string = bash_heads['pix2video']

for i in range(devide_count):
    new_list = []
    start = i * length_per_device
    end = (i+1) * length_per_device if i != (devide_count-1) else total_len
    for j in range(start, end):
        new_list.append(prompt_bashes[j].replace('$$$d$$$', str(device_id[i])))
    with open(f'run_ce_animals_pix2video_p{device_id[i]}.sh', 'w') as s:
        s.write(run_string + '\n')
        s.write('\n\n'.join(new_list))
        s.close()
