2024-02-28 20:14:46 +08:00
|
|
|
|
# EmoLLM通用指标评估
|
|
|
|
|
|
|
|
|
|
## 简介
|
|
|
|
|
|
2024-03-01 21:01:56 +08:00
|
|
|
|
本文档提供了关于如何使用 `eval.py` 和 `metric.py` 两个脚本的指导。这些脚本用于评估 EmoLLM-心理健康大模型的生成结果。
|
2024-02-28 20:14:46 +08:00
|
|
|
|
|
|
|
|
|
## 安装
|
|
|
|
|
|
|
|
|
|
- Python 3.x
|
|
|
|
|
- PyTorch
|
2024-03-03 18:24:55 +08:00
|
|
|
|
- Transformers
|
|
|
|
|
- Datasets
|
|
|
|
|
- NLTK
|
|
|
|
|
- Rouge
|
|
|
|
|
- Jieba
|
2024-02-28 20:14:46 +08:00
|
|
|
|
|
|
|
|
|
可以使用以下命令安装:
|
|
|
|
|
|
|
|
|
|
```bash
|
|
|
|
|
pip install torch transformers datasets nltk rouge jieba
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
## 用法
|
|
|
|
|
|
|
|
|
|
### convert.py
|
2024-03-03 18:24:55 +08:00
|
|
|
|
|
2024-02-28 20:14:46 +08:00
|
|
|
|
将原始多轮对话数据转换为测评用的单轮数据。
|
|
|
|
|
|
|
|
|
|
### eval.py
|
|
|
|
|
|
|
|
|
|
`eval.py` 脚本用于生成医生的回复并进行评估,主要分为以下几部分:
|
|
|
|
|
|
|
|
|
|
1. 加载模型和分词器。
|
|
|
|
|
2. 设置测试参数,如测试数据数量和批处理大小。
|
|
|
|
|
3. 准备数据。
|
|
|
|
|
4. 生成响应并评估。
|
|
|
|
|
|
|
|
|
|
### metric.py
|
|
|
|
|
|
|
|
|
|
`metric.py` 脚本包含计算评估指标的函数,可设置按字符级别或按词级别进行评估,目前包含 BLEU 和 ROUGE 分数。
|
|
|
|
|
|
|
|
|
|
## 测试结果
|
|
|
|
|
|
2024-03-03 17:20:16 +08:00
|
|
|
|
对data.json中的数据进行测试,结果如下:
|
|
|
|
|
|
|
|
|
|
| Model | ROUGE-1 | ROUGE-2 | ROUGE-L | BLEU-1 | BLEU-2 | BLEU-3 | BLEU-4 |
|
|
|
|
|
|----------|---------|---------|---------|---------|---------|---------|---------|
|
|
|
|
|
| Qwen1_5-0_5B-Chat | 27.23% | 8.55% | 17.05% | 26.65% | 13.11% | 7.19% | 4.05% |
|
|
|
|
|
| InternLM2_7B_chat | 37.86% | 15.23% | 24.34% | 39.71% | 22.66% | 14.26% | 9.21% |
|