
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 = '/output/path/of/vidtome'
base_config = '/path/to/VidToMe/configs/base.yaml'

starts = []
for i in range(len(video_files)):
    base_conf = OmegaConf.load(base_config)
    base_conf['input_path'] = video_files[i]
    base_conf['height'] = 480
    base_conf['width'] = 480
    base_conf['inversion']['prompt'] = captions[i]
    base_conf['inversion']['n_frames'] = 25
    base_conf['work_dir'] = f'batch_outputs_ce_animals/{keys[i]}'
    del base_conf['generation']['prompt']['VG']
    del base_conf['generation']['prompt']['desert']

    base_conf['generation']['prompt']['ce_animal'] = prompts[i]
    save_yaml_path = os.path.join(config_path, f'{keys[i]}.yaml')
    with open(save_yaml_path, 'w') as yaml_file:
        OmegaConf.save(config=base_conf, f=yaml_file)
    # python -u run_vidtome.py --config=configs/dog_style_v2.yaml
    cur_start_up = f'python -u run_vidtome.py --config={save_yaml_path}'
    starts.append(cur_start_up)

bash_file = 'run_ce_animals_vidtome.sh'
with open(bash_file, 'w') as s:
    s.write(bash_heads['vidtome'] + '\n')
    s.write('\n'.join(starts))
    s.close()
print(f'nohup bash {bash_file} > {bash_file.replace(".sh", ".log")} 2>&1 &')