# HARP: Hallucination Detection via Reasoning Subspace Projection

## 0. Prepare

### Local path configuration

If you have a downloaded MODEL locally, you can modify the PATH corresponding to the MODEL PATH in **<u>main.py</u>**.

```python
MODEL_PATH = {
    # "Qwen2.5-7B-Instruct": "/path/to/Qwen2.5-7B-Instruct",
    # "Llama-3.1-8B": "/path/to/Meta-Llama-3.1-8B",
    # "BLEURT-20": "/path/to/BLEURT-20",
    "Qwen2.5-7B-Instruct": "Qwen/Qwen2.5-7B-Instruct",
    "Llama-3.1-8B": "meta-llama/Llama-3.1-8B",
    "BLEURT-20": "lucadiliello/BLEURT-20",
}

DATASET_PATH = {
    "truthful_qa": "truthfulqa/truthful_qa",
    # "truthful_qa": "/path/to/truthful_qa",
    "tydiqa": "google-research-datasets/tydiqa",
    "trivia_qa": "mandarjoshi/trivia_qa",
    "nq_open": "google-research-datasets/nq_open",
}
```



### Python environment configuration

```shell
# 1. base environment configuration
pip install -r requirements.txt

# 2. bleurt model environment configuration
pip install git+https://github.com/lucadiliello/bleurt-pytorch.git
```



## 1. Example

Run the command to obtain the experimental results in the paper.

```python
python ./main.py --train_ratio=0.75 --train_batch_size=128 --train_epochs=50 --model_name="Qwen2.5-7B-Instruct" --dataset_name="nq_open"

python ./main.py --train_ratio=0.75 --train_batch_size=128 --train_epochs=50  --epoch_log=100 --model_name="Llama-3.1-8B" --dataset_name="tydiqa"
```

