Synonyms

Synonyms

中文近义词自然语言处理工具包

Synonyms是一个开源的中文近义词工具包,用于自然语言处理任务。它支持文本对齐、相似度计算、语义偏移和关键词提取等功能。该工具包基于大规模词向量模型,覆盖43万余词汇,适用于聊天机器人、问答系统、推荐系统等场景。Synonyms提供词语和句子相似度计算API,可用于多种NLP应用。

Synonyms中文近义词自然语言处理相似度计算分词Github开源项目

PyPI PyPI download month License

同义词

用于自然语言处理和理解的中文同义词。

更好的中文近义词:聊天机器人、智能问答工具包。

synonyms可用于自然语言理解的多项任务:文本对齐、推荐算法、相似度计算、语义偏移、关键词提取、概念提取、自动摘要、搜索引擎等。

为提供稳定、可靠、长期优化的服务,Synonyms 改为使用春松许可证, v1.0并对机器学习模型的下载收费,详见证书商店。之前的贡献者(有突出贡献的代码贡献者)可与我们联系,讨论收费问题。-- Chatopera Inc. @ 2023年10月

目录:

欢迎

按照以下步骤安装并激活软件包。

1/3 安装源代码包

pip install -U synonyms

当前稳定版本为 v3.x。

2/3 配置许可证ID

Synonyms的机器学习模型包需要从Chatopera许可证商店获取许可证,首先购买许可证并从Chatopera许可证商店的许可证页面获取许可证ID许可证ID:在证书商店,证书详情页,点击【复制证书标识】)。

image

其次,在终端或shell脚本中设置环境变量,如下所示。

  • Shell用户

例如Linux、Windows、macOS上的Shell、CMD脚本。

# Linux / macOS export SYNONYMS_DL_LICENSE=YOUR_LICENSE ## 例如,如果您的许可证ID为`FOOBAR`,运行`export SYNONYMS_DL_LICENSE=FOOBAR` # Windows ## 1/2 命令提示符 set SYNONYMS_DL_LICENSE=YOUR_LICENSE ## 2/2 PowerShell $env:SYNONYMS_DL_LICENSE='YOUR_LICENSE'
  • Python代码用户

Jupyter Notebook等。

import os os.environ["SYNONYMS_DL_LICENSE"] = "YOUR_LICENSE" _licenseid = os.environ.get("SYNONYMS_DL_LICENSE", None) print("SYNONYMS_DL_LICENSE=", _licenseid)

提示:安装后首次使用会下载词向量文件,下载速度取决于网络情况。

3/3 下载模型包

最后,通过命令或脚本下载模型包 -

python -c "import synonyms; synonyms.display('能量')" # 下载词向量文件

使用

支持使用环境变量配置分词词表和word2vec词向量文件。

环境变量描述
SYNONYMS_WORD2VEC_BIN_MODEL_ZH_CN使用word2vec训练的词向量文件,二进制格式。
SYNONYMS_WORDSEG_DICT中文分词主字典,格式和使用参考
SYNONYMS_DEBUG["TRUE"|"FALSE"],是否输出调试日志,设置为"TRUE"输出,默认为"FALSE"

synonyms#nearby(word [, size = 10])

import synonyms print("人脸: ", synonyms.nearby("人脸")) print("识别: ", synonyms.nearby("识别")) print("NOT_EXIST: ", synonyms.nearby("NOT_EXIST"))

synonyms.nearby(WORD [,SIZE])返回一个元组,元组中包含两项:([nearby_words], [nearby_words_score])nearby_words是WORD的近义词,以list形式存储,并按距离由近及远排列,nearby_words_scorenearby_words对应位置词的距离分数,分数在(0-1)区间内,越接近1表示越相近;SIZE是返回词汇数量,默认为10。例如:

synonyms.nearby(人脸, 10) = ( ["图片", "图像", "通过观察", "数字图像", "几何图形", "脸部", "图象", "放大镜", "面孔", "Mii"], [0.597284, 0.580373, 0.568486, 0.535674, 0.531835, 0.530 095, 0.525344, 0.524009, 0.523101, 0.516046])

在OOV(词汇表外)的情况下,返回([], []),目前的字典大小:435,729。

synonyms#compare(sen1, sen2 [, seg=True])

比较两个句子的相似度

sen1 = "发生历史性变革" sen2 = "发生历史性变革" r = synonyms.compare(sen1, sen2, seg=True)

其中,参数seg表示synonyms.compare是否对sen1和sen2进行分词,默认为True。返回值:[0-1],越接近1表示两个句子越相似。

旗帜引领方向 vs 道路决定命运: 0.429 旗帜引领方向 vs 旗帜指引道路: 0.93 发生历史性变革 vs 发生历史性变革: 1.0

synonyms#display(word [, size = 10])

以友好的方式打印近义词,方便调试,display(WORD [, SIZE])调用了 synonyms#nearby 方法。

>>> synonyms.display("飞机") '飞机'近义词: 1. 飞机:1.0 2. 直升机:0.8423391 3. 客机:0.8393003 4. 滑翔机:0.7872388 5. 军用飞机:0.7832081 6. 水上飞机:0.77857226 7. 运输机:0.7724742 8. 航机:0.7664748 9. 航空器:0.76592904 10. 民航机:0.74209654

SIZE 是打印词汇表的数量,默认 10。

synonyms#describe()

打印当前包的描述信息:

>>> synonyms.describe()
词向量模型中的词汇量: 435729
模型路径: /Users/hain/chatopera/Synonyms/synonyms/data/words.vector.gz
版本: 3.18.0
{'vocab_size': 435729, 'version': '3.18.0', 'model_path': '/chatopera/Synonyms/synonyms/data/words.vector.gz'}

synonyms#v(word)

获得一个词语的向量,该向量为 numpy 的 array,当该词语是未登录词时,抛出 KeyError 异常。

>>> synonyms.v("飞机") array([-2.412167 , 2.2628384 , -7.0214124 , 3.9381874 , 0.8219283 , -3.2809453 , 3.8747153 , -5.217062 , -2.2786229 , -1.2572327 ], dtype=float32)

synonyms#sv(sentence, ignore=False)

获得一个分词后句子的向量,向量以 BoW 方式组成

sentence: 句子是分词后通过空格联合起来 ignore: 是否忽略OOV,False时,随机生成一个向量

synonyms#seg(sentence)

中文分词

synonyms.seg("中文近义词工具包")

分词结果,由两个 list 组成的元组,分别是单词和对应的词性。

(['中文', '近义词', '工具包'], ['nz', 'n', 'n'])

该分词不去停用词和标点。

synonyms#keywords(sentence [, topK=5, withWeight=False])

提取关键词,默认按照重要程度提取关键词。

keywords = synonyms.keywords("9月15日以来,台积电、高通、三星等华为的重要合作伙伴,只要没有美国的相关许可证,都无法供应芯片给华为,而中芯国际等国产芯片企业,也因采用美国技术,而无法供货给华为。目前华为部分型号的手机产品出现货少的现象,若该形势持续下去,华为手机业务将遭受重创。")

贡献

获取更多调试日志,设置环境变量。

SYNONYMS_DEBUG=TRUE

PCA

以"人脸"为例主要成分分析:

快速开始

$ pip install -r Requirements.txt $ python demo.py

更新日志

更新情况说明

用户评价

用户怎么说:

<img src="https://yellow-cdn.veclightyear.com/835a84d5/7b37caa4-00cf-416e-95d6-90213b46ffbe.png" width="600">

数据

数据基于wikidata-corpus构建。

评估

同义词词林

《同义词词林》是梅家驹等人于1983年编纂而成,现在使用广泛的是哈工大社会计算与信息检索研究中心维护的《同义词词林扩展版》,它精细的将中文词汇划分成大类和小类,梳理了词汇间的关系,同义词词林扩展版包含词语7万余条,其中3万余条被以开放数据形式共享。

知网, HowNet

HowNet,也被称为知网,它并不只是一个语义字典,而是一个知识系统,词汇之间的关系是其一个基本使用场景。知网包含词语8余条。

国际上对词语相似度算法的评价标准普遍采用Miller&Charles发布的英语词对集的人工判定值。该词对集由十对高度相关、十对中度相关、十对低度相关共30个英语词对组成,然后让38个受试者对这30对进行语义相关度判断,最后取他们的平均值作为人工判定标准。然后不同近义词工具也对这些词汇进行相似度评分,与人工判定标准做比较,比如使用皮尔森相关系数。在中文领域,使用这个词表的翻译版进行中文近义词比较也是常用的办法。

对比

Synonyms的词表容量是435,729,下面选择一些在同义词词林、知网和Synonyms都存在的几个词,给出其近似度的对比:

注:同义词林及知网数据、分数来源。Synonyms也在不断优化中,新的分数可能和上图不一致。

更多比对结果

使用者

Github关联用户列表

基准测试

使用 py3 在 MacBook Pro 上测试。

python benchmark.py

++++++++++ 操作系统名称和版本 ++++++++++

平台: Darwin

内核: 16.7.0

架构: ('64bit', '')

++++++++++ CPU 核心数 ++++++++++

核心数: 4

CPU 负载: 60

++++++++++ 系统内存 ++++++++++

内存信息 8GB

synonyms#nearby: 100000 次循环,3 个周期中最佳: 0.209 微秒/循环

在线分享

52nlp.cn

机器之心

线上分享实录:Synonyms 中文近义词工具包 @ 2018-02-07

声明

Synonyms采用MIT许可证发布。数据和程序可用于研究和商业产品,必须注明引用和地址,例如在发布的任何媒体、期刊、杂志或博客等内容中。

@online{Synonyms:hain2017,
  author = {Hai Liang Wang, Hu Ying Xi},
  title = {中文近义词工具包Synonyms},
  year = 2017,
  url = {https://github.com/chatopera/Synonyms},
  urldate = {2017-09-27}
}

参考文献

wikidata-corpus

word2vec 原理推导与代码分析

常见问题(FAQ)

  1. 是否支持添加单词到词表中?

不支持,欲了解更多请看 #5

  1. 词向量的训练是用哪个工具?

Google 发布的word2vec,该库由 C 语言编写,内存使用效率高,训练速度快。gensim 可以加载 word2vec 输出的模型文件。

  1. 相似度计算的方法是什么?

详见 #64

  1. #118 词向量文件一直下载不下来?

作者

王海良

胡英习

自然语言处理推荐入门&工具书

本书由 Synonyms 作者参与著作。

<p align="center"> <b>快速购书<a href="https://item.jd.com/12479014.html" target="_blank">链接</a></b><br> <a href="https://item.jd.com/12479014.html" target="_blank"> <img src="https://yellow-cdn.veclightyear.com/835a84d5/c1d3c82f-b0d0-410f-99af-d1166af8ce06.png" width="400"> </a> </p>

《智能问答与深度学习》 这本书面向准备入门机器学习和自然语言处理的学生和软件工程师,在理论上介绍了许多原理和算法,同时也提供了大量示例程序以增加实践性。这些程序被汇总到示例程序代码库中,主要用于帮助大家理解原理和算法,欢迎大家下载和执行。代码库的地址是:

https://github.com/l11x0m7/book-of-qna-code

致谢

Word2vec by Google

Wikimedia: 训练语料来源

gensim: word2vec.py

SentenceSim: 相似度评测语料

jieba: 中文分词

许可证

春松公共许可证,版本1.0

项目赞助商

Chatopera 云服务

https://bot.chatopera.com/

Chatopera 云服务是一站式实现聊天机器人的云服务,按接口调用次数计费。Chatopera 云服务是 Chatopera 机器人平台的软件即服务实例。在云计算基础上,Chatopera 云服务属于聊天机器人即服务的云服务。

Chatopera 机器人平台包括知识库、多轮对话、意图识别和语音识别等组件,标准化聊天机器人开发,支持企业 OA 智能问答、HR 智能问答、智能客服和网络营销等场景。企业 IT 部门、业务部门借助 Chatopera 云服务快速让聊天机器人上线!

编辑推荐精选

讯飞智文

讯飞智文

一键生成PPT和Word,让学习生活更轻松

讯飞智文是一个利用 AI 技术的项目,能够帮助用户生成 PPT 以及各类文档。无论是商业领域的市场分析报告、年度目标制定,还是学生群体的职业生涯规划、实习避坑指南,亦或是活动策划、旅游攻略等内容,它都能提供支持,帮助用户精准表达,轻松呈现各种信息。

AI办公办公工具AI工具讯飞智文AI在线生成PPTAI撰写助手多语种文档生成AI自动配图热门
讯飞星火

讯飞星火

深度推理能力全新升级,全面对标OpenAI o1

科大讯飞的星火大模型,支持语言理解、知识问答和文本创作等多功能,适用于多种文件和业务场景,提升办公和日常生活的效率。讯飞星火是一个提供丰富智能服务的平台,涵盖科技资讯、图像创作、写作辅助、编程解答、科研文献解读等功能,能为不同需求的用户提供便捷高效的帮助,助力用户轻松获取信息、解决问题,满足多样化使用场景。

热门AI开发模型训练AI工具讯飞星火大模型智能问答内容创作多语种支持智慧生活
Spark-TTS

Spark-TTS

一种基于大语言模型的高效单流解耦语音令牌文本到语音合成模型

Spark-TTS 是一个基于 PyTorch 的开源文本到语音合成项目,由多个知名机构联合参与。该项目提供了高效的 LLM(大语言模型)驱动的语音合成方案,支持语音克隆和语音创建功能,可通过命令行界面(CLI)和 Web UI 两种方式使用。用户可以根据需求调整语音的性别、音高、速度等参数,生成高质量的语音。该项目适用于多种场景,如有声读物制作、智能语音助手开发等。

Trae

Trae

字节跳动发布的AI编程神器IDE

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

AI工具TraeAI IDE协作生产力转型热门
咔片PPT

咔片PPT

AI助力,做PPT更简单!

咔片是一款轻量化在线演示设计工具,借助 AI 技术,实现从内容生成到智能设计的一站式 PPT 制作服务。支持多种文档格式导入生成 PPT,提供海量模板、智能美化、素材替换等功能,适用于销售、教师、学生等各类人群,能高效制作出高品质 PPT,满足不同场景演示需求。

讯飞绘文

讯飞绘文

选题、配图、成文,一站式创作,让内容运营更高效

讯飞绘文,一个AI集成平台,支持写作、选题、配图、排版和发布。高效生成适用于各类媒体的定制内容,加速品牌传播,提升内容营销效果。

热门AI辅助写作AI工具讯飞绘文内容运营AI创作个性化文章多平台分发AI助手
材料星

材料星

专业的AI公文写作平台,公文写作神器

AI 材料星,专业的 AI 公文写作辅助平台,为体制内工作人员提供高效的公文写作解决方案。拥有海量公文文库、9 大核心 AI 功能,支持 30 + 文稿类型生成,助力快速完成领导讲话、工作总结、述职报告等材料,提升办公效率,是体制打工人的得力写作神器。

openai-agents-python

openai-agents-python

OpenAI Agents SDK,助力开发者便捷使用 OpenAI 相关功能。

openai-agents-python 是 OpenAI 推出的一款强大 Python SDK,它为开发者提供了与 OpenAI 模型交互的高效工具,支持工具调用、结果处理、追踪等功能,涵盖多种应用场景,如研究助手、财务研究等,能显著提升开发效率,让开发者更轻松地利用 OpenAI 的技术优势。

Hunyuan3D-2

Hunyuan3D-2

高分辨率纹理 3D 资产生成

Hunyuan3D-2 是腾讯开发的用于 3D 资产生成的强大工具,支持从文本描述、单张图片或多视角图片生成 3D 模型,具备快速形状生成能力,可生成带纹理的高质量 3D 模型,适用于多个领域,为 3D 创作提供了高效解决方案。

3FS

3FS

一个具备存储、管理和客户端操作等多种功能的分布式文件系统相关项目。

3FS 是一个功能强大的分布式文件系统项目,涵盖了存储引擎、元数据管理、客户端工具等多个模块。它支持多种文件操作,如创建文件和目录、设置布局等,同时具备高效的事件循环、节点选择和协程池管理等特性。适用于需要大规模数据存储和管理的场景,能够提高系统的性能和可靠性,是分布式存储领域的优质解决方案。

下拉加载更多