# Goal-oriented Backdoor Attack against Vision-Language-Action Models via Physical Objects

## Environment Setup

Follow the original requirements in [OpenVLA](OpenVLA_README.md) and [LIBERO](LIBERO/README.md) (follow the OpenVLA and clone from the their github repo).

Please note that Mujoco has changed its lighting conditions after version 3.3.3. Ensure that the samples you create use the same version as the evaluation environment.

## Step 1 : Create your own malicious samples

Please follow the original LIBERO data collect methods. [HERE](LIBERO/README.md)

## Step 2 : Regenrate malicious samples follow OpenVLA requirements

Please use the same BDDL you used when collecting the samples.

Change different tasks in {libero_10, libero_goal, libero_object, libero_spatial}

```
python ./experiments/robot/libero/regenerate_libero_dataset_backdoor.py --bddl_dir "path/to/your/file"
```

## Step 3 : Get the poisoned dataset

Please ensure you have downloaded LIBERO and recompiled it to the no_noops version to meet OpenVLA requirements.[HERE](#step-2--regenrate-malicious-samples-follow-openvla-requirements)

By runing the following command, you will get the poisoned dataset.

```
python ./LIBERO/scripts/inject_backdoor.py \
    --inject_rate 0.1 \
    --clean_root path/to/your/original/dataset \
    --backdoor_root path/to/your/malicious/sample/dataset \
    --output_root path/to/output
```

## Step 4 : Get the backdoor OpenVLA

Follow the hardware used by the original OpenVLA training recipt, such as [HERE](https://huggingface.co/openvla) 


## Step 5 : Three-level evalation

Modify all BDL files used in creating your own malicious samples by replacing the goal with the original (benign) goal.

For example, in our BadLIBERO, the goal in [bddl](LIBERO/libero/libero/bddl_files-knife/libero_object/pick_up_the_alphabet_soup_and_place_it_in_the_basket.bddl) used for generate malicious samples is:
```
  (:goal
    (And (In knife_1 floor_checking_region))
  )
```
and replace this line with:
```
  (:goal
    (And (In alphabet_soup_1 basket_1_contain_region))
  )
```
as shown in the [files](LIBERO/libero/libero/bddl_files-knife_eval/libero_object/pick_up_the_alphabet_soup_and_place_it_in_the_basket.bddl) ending in "_eval" in this project

Then run the follow command:
```
python ./experiments/robot/libero/3level_eval.py \
    --pretrained_checkpoint path/to/your/backdoored/OpenVLA \
    --local_log_dir path/to/your/output/file \
    --rollouts_dir path/to/your/output/file \
    --bddl_dir path/to/your/modified/bddl/file \
    --check_mode " " \ # select from "ontop" and "in", up to your backdoor goal
    --trigger_obj " " \ # up to your backdoor goal
    --checking_region " " \ # up to your backdoor goal
    --seed 42
```
If you want to eval the performance under the clean input, follow the original OpenVLA [instruction](OpenVLA_README.md)


