Welcome to LexEval, the comprehensive Chinese legal benchmark designed to evaluate the performance of large language models (LLMs) in legal applications.
- [2024.10] 🥳 LexEval is accepted by NeurIPs 2024
Large language models (LLMs) have made significant progress in natural language processing tasks and have shown considerable potential in the legal domain. However, the legal applications often have high requirements on accuracy, reliability and fairness. Applying existing LLMs to legal systems without careful evaluation of their potentials and limitations could lead to significant risks in legal practice. Therefore, to facilitate the healthy development and application of LLMs in the legal domain, we propose a comprehensive benchmark LexEval for evaluating LLMs in legal domain.
Ability Modeling: We propose a novel Legal Cognitive Ability Taxonomy (LexCog) to organize different legal tasks systematically. This taxonomy includes six core abilities: Memorization, Understanding, Logic Inference, Discrimination, Generation, and Ethics.
Scale: LexEval is currently the largest legal benchmark in China, comprising 23 tasks and 14,150 questions. Additionally, LexEval will be continuously updated to enable more comprehensive evaluations.
Data Sources: LexEval combines data from existing legal datasets, real-world exam datasets, and newly annotated datasets created by legal experts to provide a comprehensive assessment of LLM capabilities.
Inspired by Bloom's taxonomy and real-world legal application scenarios, we propose a legal cognitive ability taxonomy (LexCog) to provide guidance for the evaluation of LLMs. Our taxonomy categorizes the application of LLMs in the legal domain into six ability levels: Memorization, Understanding, Logic Inference, Discrimination, Generation, and Ethic.
-
Memorization: The memorization level examines the model’s ability to recall basic legal concepts and rules. Strong memorization skills can lay a solid foundation for more advanced cognitive abilities.
-
Understanding: The understanding level assesses large language models’ ability to interpret and explain facts, concepts, and relationships between events, as well as their ability to organize and summarize legal texts.
-
Logic Inference: The logical inference level involves the ability to analyze information and identify its components, relationships, and patterns.
-
Discrimination: The discrimination level evaluates the model's ability to identify and distinguish complex legal issues and legal facts.
-
Generation: The discrimination level evaluates the model's ability to identify and distinguish complex legal issues and legal facts.
-
Ethics: The ethics level assesses the model’s ability to recognize and analyze legal ethical issues, make ethical decisions, and weigh pros and cons.
LexCog is not a linear learning process. During training, models can move between different levels and design tasks across these levels for learning. Different legal tasks may involve multiple model ability levels simultaneously, and a model’s performance at one ability level should be evaluated comprehensively based on its performance across various legal tasks. We hope that the introduction of this taxonomy can help researchers better design training objectives and evaluation tasks, thus promoting the development of legal cognitive abilities in large language models.
The dataset for Lexeval consists of 14,150 questions carefully designed to cover the breadth of legal cognitive abilities outlined in the LexCog. The questions span 23 tasks relevant to legal scenarios, providing a diverse set for evaluating LLM performance.
The following table shows the details of the tasks in LexEval:
To help researchers quickly understand evaluation data of each task, we provide Dataset Viewer at Huggingface Dataset: 🤗 LexEval. Further experimental details and analyses can be found in our paper.
The evaluation process mainly consists of two steps: "model result generation" and "model result evaluation".
-
Prepare the data files, naming the original data files as
i_j.json
, and the few-shot examples files asi_j_few_shot.json
. Here,i_j
should be a task name composed of Arabic numerals and underlines. -
Directly run the
./generation/main.py
. Here is an example for1_1
task:cd generation MODEL_PATH='xxx' MODEL_NAME='xxx' DATA_DIR='xxx' EXAMPLE_DIR='xxx' # Zero-shot python main.py \ --f_path $DATA_DIR/1_1.json \ --model_path $MODEL_PATH \ --model_name $MODEL_NAME \ --output_dir ../../model_output/zero_shot/$MODEL_NAME \ --log_name running.log \ --device "0" # Few-shot python main.py \ --f_path $DATA_DIR/1_1.json \ --few_shot_path $EXAMPLE_DIR/1_1_few_shot.json \ --model_path $MODEL_PATH \ --model_name $MODEL_NAME \ --output_dir ../../model_output/few_shot/$MODEL_NAME \ --log_name running.log \ --device "0" \ --is_few_shot # For some models, using vllm to make fast inference python main.py \ --f_path $DATA_DIR/1_1.json \ --model_path $MODEL_PATH \ --model_name $MODEL_NAME \ --output_dir ../../model_output/zero_shot/$MODEL_NAME \ --log_name running.log \ --device "0" \ --batch_size 50 \ --is_vllm
--f_path
: The path for original datai_j.json
.--model_path
: The path for model's checkpoint.--model_name
: The name of the model. You can find all available model names inmodel_name.txt
.--output_dir
: The name of the output directory for model's generation.--log_name
: The path for the log.--is_few_shot
: Whether to use few-shot examples.--few_shot_path
: The path for few-shot examples, only valid in few-shot setting.--api_key
: The name of model's api key, only valid when using api.--api_base
: The name of model's api base, only valid when using api.--device
: The device id forcuda
.--is_vllm
: Whether to use vllm for faster inference, and currently it is not available for all models.--batch_size
: The number of questions processed per inference time by vllm, only effective when using vllm.
-
If you want to run multiple model results in batch, please refer to
run.sh
. -
Take zero-shot setting as an example. You can check the results in
./zero_shot_output/$MODEL_NAME
. The.jsonl
file format for each line is as follows:{"input": xxx, "output": xxx, "answer": xxx}
-
Directly run
./evaluation/evaluate.py
.cd evaluation python evaluate.py \ --input_dir ../../model_output/zero_shot \ --output_dir ../../evaluation_output \ --metrics_choice "Accuracy" \ --metrics_gen "Rouge_L" \
--input_dir
: The directory path for the model's generation.--output_dir
: The output directory for evaluation result.--metrics_choice
: Evaluation metric for multiple-choice tasks, 'Accuracy' and 'F1' are currently supported.--metrics_gen
: Evaluation metric for generation tasks, 'Rouge_L', 'Bertscore' and 'Bartscore' are currently supported.--model_path
: The path for bert and bart model, only valid when the evaluation metric is 'Bertscore' or 'Bartscore'.--device
: The device id forcuda
.
-
Go to
./evaluation_output/evaluation_result.csv
to check the full results. The example format is as follows:task model metrics score 1_1 Chatglm3_6B Accuracy 0.192 5_1 Baichuan_13B_base Rouge_L 0.215 ... ... ... ...
LexEval is an ongoing project, and we welcome contributions from the community. You can contribute by:
-
Adding new tasks and insights to the LexAbility Taxonomy
-
Submitting new datasets or annotations
-
Improving the evaluation framework
Please contact [email protected]
LexEval is released under the MIT License.
If you find our work useful, please do not save your star and cite our work:
@misc{li2024lexevalcomprehensivechineselegal,
title={LexEval: A Comprehensive Chinese Legal Benchmark for Evaluating Large Language Models},
author={Haitao Li and You Chen and Qingyao Ai and Yueyue Wu and Ruizhe Zhang and Yiqun Liu},
year={2024},
eprint={2409.20288},
archivePrefix={arXiv},
primaryClass={cs.CL},
url={https://arxiv.org/abs/2409.20288},
}