## Enviroment
```
conda create -n crf_video python=3.9
conda activate crf_video
pip install -r requirements.txt
```

## LLM for generating causal counterfactual parent prompts
To generate the initial causal counterfactual parent prompts, inside `counterfactual_video/data/celebv_bench` run the following command (You will need an OpenAI key):
```
python openai_gen_causal_prompts.py
```
We also provide the initial causal counterfactual prompts in `counterfactual_explicit.json`

## LDM-based video editing methods for counterfactual video generation
### Preprocess 
#### Tune-A-Video
To fine-tune the T2I model for video editing, inside `counterfactual_video/` run the following command:
```
python train_tuneavideo.py --base_config methods/tuneavideo/configs/config_tune.yaml --source_prompts data/celebv_bench/source_prompts.json --data_dir data/celebv_bench/frames
```
#### TokenFlow
To produce and save the inverted latents for TokenFlow, inside `counterfactual_video/` run:
```
python tokenflow_preprocess.py 
```

## Inference with baseline editing methods
To produce counterfactual videos using the vanilla editing methods, specify the method, the corresponding config file, and the initial counterfactual prompts. We provide an example with TokenFlow.
```
python inference.py --method tokenflow --base_config_path config_pnp.yaml --crf_config_path data/celebv_bench/counterfactual_explicit.json
```

## Causal Steering for Video Counterfactuals (CSVC)
To produce counterfactual videos using our proposed VLM causal steering, use the following command. You will need an OpenAI API key.
We provide an example with TokenFlow.
```
python counterfactual_editor.py --method tokenflow --base_config_path methods/tokenflow/configs/config_pnp.yaml --crf_config_path data/celebv_bench/counterfactual_explicit.json
```

```
method: video editing baseline method to be used.
base_config_path: path to the configuration file corresponding to the selected method.
crf_config_path: path to the file containing the initial counterfactual (target) prompts.
```
## VLM-based metrics
### Causal effectiveness
Inside `counterfactual_video/vlm_metrics` run:
```
python effectiveness_llava.py --outputs_path /path/to/generated_videos tokenflow --method tokenflow --questions_path ../data/celebv_bench/questions_explicit.json
```
`questions_explicit.json` file contains the mutliple-choice questions extracted from the initial counterfactual prompts.

### Minimality
Inside `counterfactual_video/vlm_metrics`,  use the following command. You will need an OpenAI API key:
```
python gpt_minimality.py --model gpt-4o --outputs_path /path/to/generated_videos --method tokenflow --crf_config_path ../data/celebv_bench/counterfactual_explicit.json
```

## Dataset
###  [CelebV-Text]
The file `counterfactual_video/data/celebv_bench/samples.txt` contains the video identifiers used in our evaluation dataset.