#!/bin/bash -l
source activate
DATA_NAME=WildValley
SV4D_PATH=
RECON_PATH=
IN_VIDEO=$RECON_PATH/Dataset/37081-413303986_large.mp4

DATA_DIR=$RECON_PATH/Dataset/$DATA_NAME
SV4D_INPUT_PATH=$DATA_DIR/smoke_white_bg.mp4
python tools/vid2imgs.py  $IN_VIDEO $DATA_DIR 2

# ############### Step: label images to $DATA_DIR/infer_image.png & $DATA_DIR/infer_label.json ###########
python tools/json_lbl2msk.py $DATA_DIR/infer_label2.json $DATA_DIR/target_mask.png

cd SegGPT_inference
python seggpt_inference.py --input_video $DATA_DIR/ori_processed.mp4 --prompt_image $DATA_DIR/infer_image2.png --prompt_target $DATA_DIR/target_mask.png --output_dir $DATA_DIR/
cd ..
python tools/extract_smoke.py $DATA_DIR/output_maskori_processed.mp4 $DATA_DIR

# ############### Duster initialization ###############################################################
conda activate hy
cd Duster
python getposes_oneref.py --data_root $DATA_DIR --voxel 0.005  # voxel depends on data and decides num of points initialized
cd ..

# ############### SV4D 2.0 Generation ###############################################################
python tools/sv4d_preprocess.py --data_root $DATA_DIR
conda activate diff310
cd $SV4D_PATH
python scripts/sampling/simple_video_sample_4d2.py --input_path $SV4D_INPUT_PATH --output_folder ./out


# ############### Train Gaussians ###############################################################
cd $RECON_PATH
python tools/sv4d_postprocess.py --data_root $DATA_DIR  --input_video $SV4D_INPUT_PATH --out_dir $SV4D_PATH/out/sv4d2 --generate_id 17
python tools/generate_train_json.py --data_root $DATA_DIR

conda activate fixed_nexus
cd FluidDynamics


exp_name=wildvalley_nexus
train_json_path=transforms_train_wild_smoke_sv4d.json
# train_json_path=transforms_train_wild_smoke.json
test_json_path=transforms_test_wild_smoke.json
train_name=wild_valley_nexus

data_dir=$RECON_PATH/Dataset/$DATA_NAME
log_path=$RECON_PATH/fluid_dynamics_logs

train_cfg=configs/${train_name}.json
future_cfg=configs/${train_name}_future.json

data_name=wild_smoke
phy_name=${exp_name}_physical
vis_name=${exp_name}_visual
ftr_name=${exp_name}_future
phy_pth=${log_path}/${phy_name}
ftr_pth=${log_path}/${ftr_name} 
vis_pth=${log_path}/${vis_name}


python entries_wild_smoke/train_physical_particle.py \
    --loader $data_name  \
    --data_path $data_dir  \
    --config $train_cfg \
    --model_path $phy_pth \
    --train_json $train_json_path \
    --test_json $test_json_path 

python entries_wild_smoke/train_visual_particle.py \
    --loader $data_name  \
    --data_path $data_dir  \
    --config $train_cfg \
    --load_path $phy_pth \
    --model_path $vis_pth \
    --train_json $train_json_path \
    --test_json $test_json_path 

python entries_wild_smoke/future_simulation.py \
    --loader $data_name \
    --data_path $data_dir \
    --config $future_cfg \
    --use_level_two_in_future \
    --load_path $phy_pth \
    --level_two_load_path $vis_pth \
    --model_path $ftr_pth \
    --train_json $train_json_path \
    --test_json $test_json_path 

cd ..

# ############### evaluation ###############################################################
exps="['wildforest2_nexus','wildforest2_ours','wildvalley_nexus','wildvalley_ours']"
python tools/metrics.py --log_dir $log_path --exps "$exps"