IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 人工智能 -> 【Chinese Coreference resolution】StanfordNLP代码实现 -> 正文阅读

[人工智能]【Chinese Coreference resolution】StanfordNLP代码实现

最近在做一个角色识别的项目,项目中需要用到共指消解的方法,大体了解的有四种:

  1. 基于Spenbert(https://github.com/troublemaker-r/Chinese_Coreference_Resolution/blob/2b88450eeb3da248fb0f6365c38a32b9fffcb962/README.md)
  2. 基于问答系统的Span prediction(https://github.com/ShannonAI/CorefQA)
  3. 参考Emory NLP的工作,他们也是做角色识别(https://github.com/emorynlp/character-identification/)
  4. 基于StanfordNLP的API

目前暂时用StanfordNLP的方式进行了实现,由于StanfordNLP的坑有点多,因此特地来记录一下(小本本记下)

1. 下载相关库和包

CoreNLP下载CoreNLP 4.4.0和Chinese的jar (stanford-corenlp-4.4.0-models-chinese.jar),也可以去Hugging上下载,不过官网和Hugging上下载的不太一样,官网下载到的是stanford-corenlp-4.4.0-models-chinese.jar,Hugging下载的是StanfordCoreNLP_chinese_properties,这里主要用的是jar。然后将jar放入到CoreNLP 4.4.0的文件夹下;

2. 服务器运行

在pycharm命令行或者是cmd进入CoreNLP 4.4.0,输入命令

java -Xmx4g -cp "*" edu.stanford.nlp.pipeline.StanfordCoreNLPServer \ -serverProperties StanfordCoreNLP-chinese.properties -port 9000 -timeout 15000

这里的timeout(防止runtime out)和port可以自己设计,结束后记得kill掉,不然会占用端口

3. 贴上代码

import stanza
from stanza.server import CoreNLPClient
# StanfordCoreNLP_chinese_properties = get_StanfordCoreNLP_chinese_properties() 
from StanfordCoreNLP import get_StanfordCoreNLP_chinese_properties
StanfordCoreNLP_chinese_properties = get_StanfordCoreNLP_chinese_properties()
text ='胖大叔在后厨准备了一个大木盆,盆里装满不太好处理的兽肉骨骼,还有太肥的肉。很不错,肥肉对蛇来说无所谓且营养丰富。'

import json
with CoreNLPClient(
        annotators=['tokenize','ssplit','pos','lemma','ner', 'parse', 'depparse','coref'],
        # properties=StanfordCoreNLP_chinese_properties, 这个就是Hug下载的文件
        timeout=30000,
        memory='16G',
        start_server='http://127.0.0.1:9000') as client:
    ann = client.annotate(text)
mychains = list()
chains = ann.corefChain
for chain in chains:
    mychain = list()
    for mention in chain.mention:
        words_list = ann.sentence[mention.sentenceIndex].token[mention.beginIndex:mention.endIndex]
        #build a string out of the words of this mention
        ment_word = ' '.join([x.word for x in words_list])
        mychain.append(ment_word)
    mychains.append(mychain)

for chain in mychains:
    print(' <-> '.join(chain))

另外~
import corenlp这个方法已经outdated啦,大家用了可能会出现一系列无法解决的bug,建议不用~

  人工智能 最新文章
2022吴恩达机器学习课程——第二课(神经网
第十五章 规则学习
FixMatch: Simplifying Semi-Supervised Le
数据挖掘Java——Kmeans算法的实现
大脑皮层的分割方法
【翻译】GPT-3是如何工作的
论文笔记:TEACHTEXT: CrossModal Generaliz
python从零学(六)
详解Python 3.x 导入(import)
【答读者问27】backtrader不支持最新版本的
上一篇文章      下一篇文章      查看所有文章
加:2022-04-28 11:50:53  更:2022-04-28 11:52:11 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/6 17:59:22-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码