deepke/README.md

158 lines
8.7 KiB
Markdown
Raw Normal View History

2021-08-19 15:33:03 +08:00
<p align="center">
2021-09-27 16:47:04 +08:00
<a href="https://github.com/zjunlp/deepke"> <img src="pics/logo.png" width="400"/></a>
2021-08-19 15:33:03 +08:00
<p>
2021-09-27 16:47:04 +08:00
<p align="center">
2021-10-09 14:42:23 +08:00
<a href="https://deepke.openkg.cn">
2021-09-27 16:47:04 +08:00
<img alt="Documentation" src="https://img.shields.io/badge/DeepKE-website-green">
2021-08-19 15:33:03 +08:00
</a>
2021-10-09 14:42:23 +08:00
<a href="https://pypi.org/project/deepke/#files">
<img alt="PyPI" src="https://img.shields.io/pypi/v/deepke">
</a>
<a href="https://github.com/zjunlp/DeepKE/blob/master/LICENSE">
<img alt="GitHub" src="https://img.shields.io/github/license/zjunlp/deepke">
</a>
</p>
<p align="center">
<b>简体中文 | <a href="https://github.com/zjunlp/DeepKE/blob/test_new_deepke/README_ENGLISH.md">English</a></b>
2021-08-19 15:33:03 +08:00
</p>
2021-08-19 18:43:15 +08:00
2021-09-28 19:53:58 +08:00
<h1 align="center">
2021-08-19 15:33:03 +08:00
<p>基于深度学习的开源中文知识图谱抽取框架</p>
2021-09-28 19:53:58 +08:00
</h1>
2020-12-02 16:53:45 +08:00
2021-10-11 00:12:58 +08:00
DeepKE 是一个支持**低资源、长篇章**的知识抽取工具可以基于pytorch实现命名实体识别、关系抽取和属性抽取功能。
2020-12-02 17:57:03 +08:00
2021-09-28 20:13:25 +08:00
<br>
2021-08-19 15:33:03 +08:00
## 在线演示
2020-12-02 16:53:45 +08:00
2021-10-09 14:45:35 +08:00
在线演示 [demo](https://deepke.openkg.cn)
2020-12-02 16:53:45 +08:00
2021-09-29 13:53:45 +08:00
### 进行预测
下面使用一个demo展示预测过程
2021-09-29 14:40:07 +08:00
<img src="pics/demo.gif" width="636" height="494" align=center>
2021-09-29 13:53:45 +08:00
2021-09-28 20:13:25 +08:00
<br>
2021-09-27 16:47:04 +08:00
## 模型架构
2021-09-28 19:53:58 +08:00
2021-09-27 16:47:04 +08:00
Deepke的架构图如下所示
2020-12-02 16:53:45 +08:00
2021-09-27 16:47:04 +08:00
<h3 align="center">
2021-09-27 18:29:57 +08:00
<img src="pics/architectures.png">
2021-09-27 16:47:04 +08:00
</h3>
2020-12-02 16:53:45 +08:00
2021-09-27 16:47:04 +08:00
DeepKE包括了三个模块可以进行关系抽取、实体命名识别以及属性抽取的任务在各个模块下包括各自的子模块。其中关系抽取模块就有常规模块、文档级抽取模块以及低资源少样本模块。在每一个子模块中分为分词、预处理等的一个工具集合以及编码和训练预测部分。
2020-12-02 16:53:45 +08:00
2021-09-28 20:13:25 +08:00
<br>
2021-09-27 20:51:38 +08:00
2021-08-19 15:33:03 +08:00
## 快速上手
2020-12-02 16:53:45 +08:00
2021-10-11 17:18:38 +08:00
DeepKE支持pip安装使用以常规全监督设定关系抽取为例
2021-10-12 17:45:24 +08:00
1、下载代码 ```git clone https://github.com/zjunlp/DeepKE.git```别忘记star和fork哈
2021-10-11 17:18:38 +08:00
2、创建虚拟环境 ```conda create -n deepke python=3.8```
3、进入虚拟环境 ```conda activate deepke```
4、pip安装需要的依赖包```pip install deepke```
5、进入使用位置 ```cd DeepKE/example/re/standard```
6、进行训练 ```python run.py```,训练用到的参数可在conf文件夹内修改
2021-10-12 17:45:24 +08:00
如果需要修改使用的代码,修改之后运行```python setup.py develop```即可
2021-10-11 17:18:38 +08:00
7、进行预测```python predict.py```,预测用到的参数可在conf文件夹内修改
2021-09-27 20:51:38 +08:00
### 环境依赖
2019-08-20 21:25:34 +08:00
2021-09-28 19:53:58 +08:00
> python == 3.8
2019-12-03 22:41:47 +08:00
2021-10-09 14:42:23 +08:00
- torch == 1.5
2021-09-27 20:51:38 +08:00
- hydra-core == 1.0.6
2021-10-09 14:42:23 +08:00
- tensorboard == 2.4.1
- matplotlib == 3.4.1
- transformers == 3.4.0
- jieba == 0.42.1
- scikit-learn == 0.24.1
- pytorch-transformers == 1.2.0
- seqeval == 1.2.2
- tqdm == 4.60.0
2021-10-10 20:53:41 +08:00
- opt-einsum==3.3.0
- ujson
2021-10-09 14:42:23 +08:00
2019-09-18 19:45:45 +08:00
2021-09-28 20:13:25 +08:00
1. **命名实体识别NER**
2021-09-16 21:10:33 +08:00
2021-09-28 20:13:25 +08:00
数据为txt文件样式范例为
2021-10-07 16:49:04 +08:00
| Sentence | Person | Location | Organization |
| :----------------------------------------------------------: | :------------------------: | :------------: | :----------------------------: |
| 本报北京9月4日讯记者杨涌报道部分省区人民日报宣传发行工作座谈会9月3日在4日在京举行。 | 杨涌 | 北京 | 人民日报 |
| 《红楼梦》是中央电视台和中国电视剧制作中心根据中国古典文学名著《红楼梦》摄制于1987年的一部古装连续剧由王扶林导演周汝昌、王蒙、周岭等多位红学家参与制作。 | 王扶林,周汝昌,王蒙,周岭 | 中国 | 中央电视台,中国电视剧制作中心 |
| 秦始皇兵马俑位于陕西省西安市1961年被国务院公布为第一批全国重点文物保护单位是世界八大奇迹之一。 | 秦始皇 | 陕西省,西安市 | 国务院 |
2021-09-27 17:15:57 +08:00
2021-09-28 20:13:25 +08:00
具体流程请进入详细的README中
2021-09-27 17:15:57 +08:00
2021-10-11 17:18:38 +08:00
**[常规全监督STANDARD](https://github.com/zjunlp/deepke/blob/test_new_deepke/example/ner/standard)**
2021-09-28 20:13:25 +08:00
常规模块为预训练模型可进入其目录修改数据集以及conf文件夹下的目录```python run.py```即可训练,```python predict.py```即可预测。
2021-09-28 19:53:58 +08:00
2021-10-11 17:18:38 +08:00
**[少样本FEW-SHOT](https://github.com/zjunlp/DeepKE/tree/test_new_deepke/example/ner/few-shot)**
2021-10-12 19:14:36 +08:00
少样本模块可进入其目录模型加载和保存位置以及配置可以在shell脚本中修改```python run.py```训练conll2003,```python run.py +train=few_shot```直接进行few-shot训练,若要加载模型修改few_shot.yaml中的load_path,```python predict.py```即可预测。
2021-09-27 17:15:57 +08:00
2021-09-28 20:13:25 +08:00
2. **关系抽取RE**
2021-09-27 20:51:38 +08:00
2021-09-28 20:13:25 +08:00
关系抽取是从非结构化的文本中抽取出实体之间的关系以下为几个样式范例数据为csv文件
2021-09-28 19:53:58 +08:00
2021-09-28 20:13:25 +08:00
| Sentence | Relation | Head | Head_offset | Tail | Tail_offset |
| :----------------------------------------------------: | :------: | :--------: | :---------: | :--------: | :---------: |
| 《岳父也是爹》是王军执导的电视剧,由马恩然、范明主演。 | 导演 | 岳父也是爹 | 1 | 王军 | 8 |
| 《九玄珠》是在纵横中文网连载的一部小说,作者是龙马。 | 连载网站 | 九玄珠 | 1 | 纵横中文网 | 7 |
| 提起杭州的美景,西湖总是第一个映入脑海的词语。 | 所在城市 | 西湖 | 8 | 杭州 | 2 |
2021-09-28 19:53:58 +08:00
2021-09-28 20:13:25 +08:00
具体流程请进入详细的README中RE包括了以下三个子功能
2021-09-28 19:53:58 +08:00
2021-10-11 17:18:38 +08:00
**[常规全监督STANDARD](https://github.com/zjunlp/deepke/blob/test_new_deepke/example/re/standard)**
2021-09-28 20:13:25 +08:00
常规模块为常用的深度学习模型有CNN、RNN、Capsule、GCN、Transforemer以及预训练模型可进入其目录修改数据集以及conf文件夹下的目录```python run.py```即可训练,```python predict.py```即可预测。
2021-09-28 19:53:58 +08:00
2021-10-11 17:18:38 +08:00
**[少样本FEW-SHOT](https://github.com/zjunlp/deepke/blob/test_new_deepke/example/re/few-shot)** :
2021-10-10 21:08:23 +08:00
进入其目录修改数据集以及conf文件夹下的目录```python run.py```即可训练,如需从上次训练的模型开始训练:设置.yaml中的train_from_saved_model为上次保存模型的路径每次训练的日志保存路径默认保存在根目录可以通过.yaml中的log_dir来配置```python predict.py```即可预测。
2021-09-28 19:53:58 +08:00
2021-10-11 17:18:38 +08:00
**[文档级DOCUMENT](https://github.com/zjunlp/deepke/blob/test_new_deepke/example/re/document)** :
2021-10-10 21:08:23 +08:00
```train_distant.json```由于文件太大请自行从Google Drive上下载到data/目录下.进入其目录修改数据集以及conf文件夹下的目录```python run.py```即可训练,如需从上次训练的模型开始训练:设置.yaml中的train_from_saved_model为上次保存模型的路径每次训练的日志保存路径默认保存在根目录可以通过.yaml中的log_dir来配置```python predict.py```即可预测。
2021-09-27 20:51:38 +08:00
2021-09-28 20:13:25 +08:00
3. **属性抽取AE**
2021-09-27 20:51:38 +08:00
2021-09-28 20:13:25 +08:00
数据为csv文件样式范例为
2021-09-27 20:51:38 +08:00
2021-09-28 20:13:25 +08:00
| Sentence | Att | Ent | Ent_offset | Val | Val_offset |
| :----------------------------------------------------------: | :------: | :------: | :--------: | :-----------: | :--------: |
| 张冬梅汉族1968年2月生河南淇县人 | 民族 | 张冬梅 | 0 | 汉族 | 6 |
| 杨缨,字绵公,号钓溪,松溪县人,祖籍将乐,是北宋理学家杨时的七世孙 | 朝代 | 杨缨 | 0 | 北宋 | 22 |
| 2014年10月1日许鞍华执导的电影《黄金时代》上映 | 上映时间 | 黄金时代 | 19 | 2014年10月1日 | 0 |
2019-09-18 19:45:45 +08:00
2021-09-28 20:13:25 +08:00
具体流程请进入详细的README中:
2021-09-14 16:08:14 +08:00
2021-10-11 17:18:38 +08:00
**[常规全监督STANDARD](https://github.com/zjunlp/deepke/blob/test_new_deepke/example/ae/standard)**
2021-09-28 20:13:25 +08:00
常规模块为常用的深度学习模型有CNN、RNN、Capsule、GCN、Transforemer以及预训练模型可进入其目录修改数据集以及conf文件夹下的目录```python run.py```即可训练,```python predict.py```即可预测。
2021-09-14 16:08:14 +08:00
2021-09-28 20:13:25 +08:00
<br>
2021-09-14 16:08:14 +08:00
2021-09-12 15:26:22 +08:00
## 备注(常见问题)
1. 使用 Anaconda 时,建议添加国内镜像,下载速度更快。如[清华镜像](https://mirrors.tuna.tsinghua.edu.cn/help/anaconda/)。
1. 使用 pip 时,建议使用国内镜像,下载速度更快,如阿里云镜像。
1. 安装后提示 `ModuleNotFoundError: No module named 'past'`,输入命令 `pip install future` 即可解决。
2021-09-16 14:30:03 +08:00
1. 使用语言预训练模型时,在线安装下载模型比较慢,更建议提前下载好,存放到 pretrained 文件夹内。具体存放文件要求见文件夹内的 readme.md。
2021-09-28 20:13:25 +08:00
<br>
2021-10-11 14:04:32 +08:00
## 项目成员
2021-09-12 15:26:22 +08:00
2021-10-15 15:36:48 +08:00
张宁豫、陶联宽、余海洋、陈想、田玺、李磊、黎洲波、徐欣、邓淑敏、姚云志、叶宏彬、谢辛、郑国轴、陈华钧等
2021-10-11 00:12:35 +08:00