

## Requirements

To install requirements:

```setup
conda install pytorch==2.5.1 torchvision==0.20.1 torchaudio==2.5.1 pytorch-cuda=12.4 huggingface_hub transformers ipykernel accelerate -c pytorch -c nvidia -c conda-forge
pip install modelscope spacy
pip install flash-attn --no-build-isolation
```

<!-- >📋  Describe how to set up the environment, e.g. pip/conda/docker commands, download datasets, etc... -->



## Evaluation

You can reproduce our experiments for three tasks with the scripts in the `sst_exp`, `mmlu_exp`, and `nq_exp` folders. 

Generally speaking, the method to run these methods are similar. First you should get into the corresponding directory, and then follow the steps below:

**Step 1: Perturbing data**
If you use the dataset we provided, you can skip this step. 
Put the offictial SST dataset in `SST2` directory (`mmlu` and `nq` folder for other tasks), and then run the following command to generate the perturbed dataset for LIME and Kernel SHAP:
```bash
python generate_samples.py
python generate_samples_shap.py
```
Then obtain the model output for the perturbed dataset:
```bash
generate_model_sample.py --model_name <model_name> --model_short_name <model_short_name> --sample_folder <lime_sample/shap_sample>
generate_api_sample.py --model_name <model_name> --model_short_name <model_short_name> --sample_folder <lime_sample/shap_sample>
```
model_name and model_short_name can be found in `model_list.txt`.

**Step 2: Generating explanations**
Run the following command to generate explanations for the perturbed dataset:
```bash
python generate_exp.py
python generate_exp_shap.py
```
if you use our datasets, please put them in `lime_samples` and `shap_samples` folder.

**Step 3: Evaluating explanations**
You can use the following command to evaluate the explanations:
```bash
# Fidelity
python calc_fidelity.py --exp_method <lime/shap>
python calc_aopc --exp_method <lime/shap>
```
It will show you the results in `heatmaps` folder.

