This is the official release accompanying our paper, FaithScore: Fine-grained Evaluations of Hallucinations in Large Vision-Language Models . FAITHSCORE is available as a PIP package as well.
If you find FAITHSCORE useful, please cite:
@inproceedings{jing-etal-2024-faithscore,
title = "{F}aith{S}core: Fine-grained Evaluations of Hallucinations in Large Vision-Language Models",
author = "Jing, Liqiang and
Li, Ruosen and
Chen, Yunmo and
Du, Xinya",
editor = "Al-Onaizan, Yaser and
Bansal, Mohit and
Chen, Yun-Nung",
booktitle = "Findings of the Association for Computational Linguistics: EMNLP 2024",
month = nov,
year = "2024",
address = "Miami, Florida, USA",
publisher = "Association for Computational Linguistics",
url = "https://aclanthology.org/2024.findings-emnlp.290",
pages = "5042--5063"
}
-
Install LLaVA 1.5.
Note that you don't need to download parameter weights of LLaVA 1.5 if you use OFA to realize fact verification.
-
Install modelscope;
pip install modelscope pip install "modelscope[multi-modal]"
-
Install our package.
pip install faithscore==0.0.9
You can evaluate answers generated by large vision-language models via our metric.
from faithscore.framework import FaithScore
images = ["./COCO_val2014_000000164255.jpg"]
answers = ["The main object in the image is a colorful beach umbrella."]
scorer = FaithScore(vem_type="...", api_key="...", llava_path=".../llava/eval/checkpoints/llava-v1.5-13b", use_llama=False,
llama_path="...llama2/llama-2-7b-hf")
score, sentence_score = scorer.faithscore(answers, images)
Parameters for FaithScore class:
vem_type
: You can set this parameter asofa-ve
,ofa
, orllava
. This parameter decides which model is used to do fact verification.api_key
: OpenAI API Key.llava_path
: The model folder for LLaVA 1.5. If you don't setvem_type
asllava
, you needn't to set it.use_llama
: Whether use llave to achieve sub-sentence identification. If it is False, the code uses ChatGPT for this stage.llama_path
: The model folder for LLaMA 2 7B. Before using it, please convert the model weight into huggingface format. For details, you can refer to this link. If you don't use LLaMA, skip this parameter.
You can also evaluate answers generated by the following command line.
python run.py --answer_path {answer_path} --openai_key {openai_key} --vem_type {vem_type} --llava_path {llava_path} --llama_path {llama_path} --use_llama {use_llama}
Parameters:
--answer_path
: The answer file can be something like test.jsonl. It should be a .jsonl format where each line is a dict {"answer": "xxx", "image": "xxxx"} that contains answer generated by LVLMs and image path.--openai_key
: OpenAI API Key.--llava_path
: The model folder for LLaVA 1.5. If you don't setvem_type
asllava
, you needn't to set it.--use_llama
: Whether use llave to achieve sub-sentence identification. If it is False, the code uses ChatGPT for this stage.--llama_path
: The model folder for LLaMA 2 7B. Before using it, please convert the model weight into huggingface format. For details, you can refer to this link. If you don't use LLaMA, skip this parameter.
The data is given in a json format file. For example,
{"id": "000000525439", "answer": "The skateboard is positioned on a ramp, with the skateboarder standing on it.", "stage 1": {"The skateboard is positioned on a ramp": 1, " with the skateboarder standing on it": 1}, "stage 2": {"There is a skateboard.": 1, "There is a ramp.": 0, "There is a skateboarder.": 1, "The skateboarder is standing on a skateboard.": 0}}
Data Format:
id
: question_id. You can get the corresponding image name in the COCO validation dataset (2014) by this formatCOCO_val2014_{id}.jpg
.answer
: answer generated by the Large Vision-Language Model.stage 1
: All the sub-sentences and their corresponding labels}.1
denotes analytical sub-sentence.stage 2
: All the atomic facts and their corresponding labels}.1
denotes the atomic fact contains hallucination.
You can download our annotation dataset.
You can download our automatic evaluation benchmarks.
Public LVLM leaderboard computed on LLaVA-1k.
Model | FaithScore | Sentence-level Faithscore |
---|---|---|
Multimodal-GPT | 0.53 | 0.49 |
MiniGPT-4 | 0.57 | 0.65 |
mPLUG-Owl | 0.72 | 0.70 |
InstructBLIP | 0.81 | 0.72 |
LLaVA | 0.84 | 0.73 |
LLaVA-1.5 | 0.86 | 0.77 |
Public LLM leaderboard computed on MSCOCO-Cap.
Model | FaithScore | Sentence-level Faithscore |
---|---|---|
Multimodal-GPT | 0.54 | 0.63 |
MiniGPT-4 | 0.64 | 0.60 |
mPLUG-Owl | 0.85 | 0.67 |
InstructBLIP | 0.94 | 0.80 |
LLaVA | 0.87 | 0.64 |
LLaVA-1.5 | 0.94 | 0.83 |