# Max Explainability Score with Confidence Interval (MES-CI): A Quantitative Metric for Interpretability in Knowledge Graph-Based Recommender Systems
This repository contains the source code of the Explainable Recommendation

## Datasets
Two Amazon datasets (Amazon_Beauty, Amazon_Clothing) are available in the "data/" directory and the split is consistent with [1].
All four datasets used in this paper can be downloaded [here](https://drive.google.com/uc?export=download&confirm=Tiux&id=1CL4Pjumj9d7fUDQb1_leIMOot73kVxKB).

## Requirements
- Python >= 3.12
- PyTorch = 2.5
- Install requirement.txt
```bash
pip install -r /path/to/requirements.txt
```


## How to run the code
1. Proprocess the data first:
```bash
python preprocess.py --dataset <dataset_name>
```
"<dataset_name>" should be one of "cd", "beauty", "cloth", "cell" (refer to utils.py).

2. Train knowledge graph embeddings (TransE in this case):
```bash
python train_transe_model.py --dataset <dataset_name>
```

3. Train RL agent:
```bash
python train_RL_agent.py --dataset <dataset_name>
```

4. Evaluation - MESCI - Example call
```bash
python test_RL_agent.py --dataset beauty --run_path True --run_eval True --users 21001 --debug True
```
If "run_path" is True, the program will generate paths for recommendation according to the trained policy.
If "run_eval" is True, the program will evaluate the recommendation performance based on the resulting paths.

4. Evaluation - MESCI - Generic call
```bash
python test_RL_agent.py --dataset <dataset_name> --run_path True --run_eval True --users <user_id> --debug True
```
If "run_path" is True, the program will generate paths for recommendation according to the trained policy.
If "run_eval" is True, the program will evaluate the recommendation performance based on the resulting paths.

4. Evaluation
```bash
python test_RL_agent.py --dataset <dataset_name> --run_path True --run_eval True
```
If "run_path" is True, the program will generate paths for recommendation according to the trained policy.
If "run_eval" is True, the program will evaluate the recommendation performance based on the resulting paths.

