Spaces:
Running
on
T4
A newer version of the Gradio SDK is available:
5.13.1
title: SKB Explorer
emoji: 🏢
colorFrom: pink
colorTo: red
sdk: gradio
sdk_version: 4.29.0
python_version: 3.8.17
app_file: interactive/pyvis_graph.py
pinned: false
STaRK: Benchmarking LLM Retrieval on Textual and Relational Knowledge Bases
What is STaRK?
STaRK is a large-scale semi-structure retrieval benchmark on Textual and Relational Knowledge Bases. Given a user query, the task is to extract nodes from the knowledge base that are relevant to the query.
Why STaRK?
Novel Task: Recently, large language models have demonstrated significant potential on information retrieval tasks. Nevertheless, it remains an open question how effectively LLMs can handle the complex interplay between textual and relational requirements in queries.
Large-scale and Diverse KBs: We provide three large-scale knowledge bases across three areas, which are constructed from public sources.
Natural-sounding and Practical Queries: The queries in our benchmark are crafted to incorporate rich relational information and complex textual properties, and closely mirror questions in real-life scenarios, e.g., with flexible query formats and possibly with extra contexts.
Access benchmark data
1) Env Setup
Create a conda env with python 3.8 and install required packages in requirements.txt
.
conda create -n stark python=3.8
conda activate stark
pip install -r requirements.txt
2) Data loading
Demo: See load_dataset.ipynb
for more
from src.benchmarks.get_qa_dataset import get_qa_dataset
from src.benchmarks.get_semistruct import get_semistructured_data
dataset_name = 'amazon'
# Load the retrieval dataset
qa_dataset = get_qa_dataset(dataset_name)
idx_split = qa_dataset.get_idx_split()
# Load the knowledge base
kb = get_semistructured_data(dataset_name, download_processed=True)
Data of the Retrieval Task
Question answer pairs for the retrieval task are locally included in data/{dataset}/stark_qa
. We provided official split in data/{dataset}/split
.
Data of the Knowledge Bases
There are two ways to load the knowledge base data:
- (Recommended) Instant downloading: The knowledge base data of all three benchmark will be automatically downloaded and loaded when setting
download_processed=True
. - Process data from raw: We also provided all of our preprocessing code for transparency. Therefore, you can process the raw data from scratch via setting
download_processed=False
. In this case, STaRK-PrimeKG takes around 5 minutes to download and load the processed data. STaRK-Amazon and STaRK-MAG may takes around an hour to process from the raw data.
3) Evaluation on benchmark
Our evaluation requires embed the node documents into
candidate_emb_dict.pt
, which is a dictionarynode_id -> torch.Tensor
. Query embeddings will be automatically generated if not available. You can either run the following the python script to download query embeddings and document embeddings generated bytext-embedding-ada-002
. (We provide them so you can run on our benchmark right away.)python download_emb.py --dataset amazon --emb_dir emb/
Or you can run the following code to generate the query or document embeddings by yourself. E.g.,
python generate_emb.py --dataset amazon --mode query --emb_dir emb/ --emb_model text-embedding-ada-002
dataset
: one ofamazon
,mag
orprimekg
.mode
: the content to embed, one ofquery
ordoc
(node documents).emb_dir
: the directory to store embeddings.emb_model
: the LLM name to generate embeddings, such astext-embedding-ada-002
,text-embedding-3-large
.- See
generate_emb.py
for other arguments.
Run the python script for evaluation. E.g.,
python eval.py --dataset amazon --model VSS --emb_dir emb/ --output_dir output/ --emb_model text-embedding-ada-002 --save_pred
python eval.py --dataset amazon --model LLMReranker --emb_dir emb/ --output_dir output/ --emb_model text-embedding-ada-002 --llm_model gpt-4-1106-preview --save_pred
dataset
: the dataset to evaluate on, one ofamazon
,mag
orprimekg
.model
: the model to be evaluated, one ofVSS
,MultiVSS
,LLMReranker
.- Please specify the name of embedding model with argument
--emb_model
. - If you are using
LLMReranker
, please specify API keys atconfig/openai_api_key.txt
orconfig/claude_api_key.txt
and the LLM name with argument--llm_model
.
- Please specify the name of embedding model with argument
emb_dir
: the directory to store embeddings.output_dir
: the directory to store evaluation outputs.
Reference
Please cite our paper if you use our benchmark or code in your work:
@article{wu24stark,
title = {STaRK: Benchmarking LLM Retrieval on Textual and Relational Knowledge Bases},
author = {
Shirley Wu and Shiyu Zhao and
Michihiro Yasunaga and Kexin Huang and
Kaidi Cao and Qian Huang and
Vassilis N. Ioannidis and Karthik Subbian and
James Zou and Jure Leskovec
},
eprinttype = {arXiv},
eprint = {2404.13207},
year = {2024}
}