自然语言处理概述(Natural Language Process)

2024-03-17 14:08

本文主要是介绍自然语言处理概述(Natural Language Process),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

近年来,人工智能逐渐成为了当前社会最热门的行业之一,也逐渐的进入了寻常百姓家。比如我们熟知的AlphaGo击败韩国围棋冠军李世石,小米的语音助手小爱同学,英国的智能机器人Sophia,喜马拉雅的小雅音响,Tesla的自动驾驶汽车等等。一方面我们在享受着人工智能带来的种种便利,一方面我们也在担心自己的工作会不会很快被人工智(Ai)能替代。其实在此我举一个Google translator的例子,这是2020年的翻译水平。

学过历史的我们都知道林则徐虎门销烟这段历史,可是机器它不并知道,所以它翻译出来的结果是林则徐在虎门卖香烟。我们可能觉得机器就是逐词翻译,然后把翻译结果拼在一起,翻译出来的结果很生硬。其实在过去一段时间,自然语言处理这一领域取得了很大的突破,机器翻译不光只考虑单个词语,还必须考虑上下文语义。Google translator是众多翻译软件中最好的一个,现在还增加了语音翻译,极大地方便了论文翻译和出国旅行。通过这个例子,可以看出现在的人工智能水平远没有我们平时听到的那么科幻,那么遥不可及。现在的Ai基本上都是一种弱Ai,只能达到知其然的水平,还达不到知其所以然的水平。

Google translator.png

目前Ai发展有三个方向,分别是计算机视觉(Computer Vision)、自然语言处理(Natural Language Process)、机器人(Robot)。

计算机视觉如今发展的已经比较成熟了,应用也非常的广泛。比如火车站的人脸识别(安防领域),手机里的智能美颜(拍照领域),自动贩卖机上的刷脸支付(支付领域),道路和路标的识别(自动驾驶领域)。

自然语言处理的难度则要大很多,平时我们人在理解的时候也会犯错,更何况计算机呢。再加上这个世界上有很多种语言,又分为不同的语系(如东亚语系,拉丁语系),语法更是错综复杂。联合国官方使用的语言是法语,是因为法语被认为是世界上最精确的语言,不像汉语与英语,有那么多一词多义的现象。在我们国内,每个地方都有自己的方言,比如聊咋咧,巴适得板,贼拉香,表达的都是好的意思。同样一句话,在不同的地方也会有不同的理解,前几天听了一个段子。比如“你愁啥”,在上海,对方就会跟你慢慢讲他在看啥;在东北,说不好,就是派出所里见了。由此可见自然语言处理的难度之大。当然难度大,也意味着该领域的发展空间更大。

计算机眼中的语言长啥样?

我们都知道,任何东西(文字,声音,视频,图片)在计算机的底层都是以0,1,0,1…这样的二进制数存在的。所以为了能够让计算机更好的理解自然语言,我们的计算机科学家制定出了很多规则,用以将我们的语言转换为数值。例如:

words = ['Today is sunday', 'i stay home learning nlp',
'I think nlp is a difficult theme', 'and need more efforts']
​#计算机按照一定的规则对原文进行变化,将会变成下面这样的向量
[[0.         0.         0.         0.         0.48693426 0.  0.         0.         0.         0.         0.61761437 0.  0.         0.61761437] 
[0.         0.         0.         0.52547275 0.         0.52547275  0.         0.         0.41428875 0.52547275 0.         0.  0.         0.        ] 
[0.         0.48546061 0.         0.         0.38274272 0.  0.         0.         0.38274272 0.         0.         0.48546061  0.48546061 0.        ][0.5        0.         0.5        0.         0.         0.  0.5        0.5        0.         0.         0.         0.  0.         0.        ]]

如何学习自然语言理解?

前面说了自然语言处理有多么多么的厉害,但真正做起来也是件挺难的事。不过再难的问题都可以被拆解为一小步一小步的过程。掌握每一步,再拼起来就是一个完整的过程。这也是程序设计中的一个很重要的思想,分而治之。

我们最常用的语言就是中文和英文了,在处理中文和英文,大部分过程都是相同的。唯一不同的是英文句子中的每个单词都是天然分开的,中文的词语则是连在一块的,对于中文的处理多了一步分词处理。

我们使用的语言是:Python

如果对Python语言不熟,我推荐以下两个教程,可以帮助大家快速熟悉python编程。

莫凡python

同济子豪-python

推荐一本简单易学的教材,可以很快就看完了。点击下方链接,可以下载该电子书。

链接:https://pan.baidu.com/s/12zzZgzKYR9kl4lEsia5zqg 提取码:djmm

当然光学习python是不够的,数据分析的三板斧也要掌握Numpy, Pandas, Matplotlib,网上有很多学习资源。

莫凡数据分析

在学习自然语言处理的时候,我们不是学完所有基础知识,才开始学习自然语言处理,这样会很耗费时间。基本上都是边学边查,不懂的地方查博客(CSDN,知乎,Github),查API文档,这也是一个不断积累与提高的过程。如果你有收获了,也可以将你的经验写为博客,发布在简书,知乎,CSDN这些平台上,可以帮助到更多的人。

我们学习自然语言处理的过程:

  • 词语(汉语,英语)的切分

  • 词向量的构造

  • 机器学习sklearn库分析文本

  • 深度神经网络分析文本

这篇关于自然语言处理概述(Natural Language Process)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/819178

相关文章

水位雨量在线监测系统概述及应用介绍

在当今社会,随着科技的飞速发展,各种智能监测系统已成为保障公共安全、促进资源管理和环境保护的重要工具。其中,水位雨量在线监测系统作为自然灾害预警、水资源管理及水利工程运行的关键技术,其重要性不言而喻。 一、水位雨量在线监测系统的基本原理 水位雨量在线监测系统主要由数据采集单元、数据传输网络、数据处理中心及用户终端四大部分构成,形成了一个完整的闭环系统。 数据采集单元:这是系统的“眼睛”,

无人叉车3d激光slam多房间建图定位异常处理方案-墙体画线地图切分方案

墙体画线地图切分方案 针对问题:墙体两侧特征混淆误匹配,导致建图和定位偏差,表现为过门跳变、外月台走歪等 ·解决思路:预期的根治方案IGICP需要较长时间完成上线,先使用切分地图的工程化方案,即墙体两侧切分为不同地图,在某一侧只使用该侧地图进行定位 方案思路 切分原理:切分地图基于关键帧位置,而非点云。 理论基础:光照是直线的,一帧点云必定只能照射到墙的一侧,无法同时照到两侧实践考虑:关

【生成模型系列(初级)】嵌入(Embedding)方程——自然语言处理的数学灵魂【通俗理解】

【通俗理解】嵌入(Embedding)方程——自然语言处理的数学灵魂 关键词提炼 #嵌入方程 #自然语言处理 #词向量 #机器学习 #神经网络 #向量空间模型 #Siri #Google翻译 #AlexNet 第一节:嵌入方程的类比与核心概念【尽可能通俗】 嵌入方程可以被看作是自然语言处理中的“翻译机”,它将文本中的单词或短语转换成计算机能够理解的数学形式,即向量。 正如翻译机将一种语言

Java 创建图形用户界面(GUI)入门指南(Swing库 JFrame 类)概述

概述 基本概念 Java Swing 的架构 Java Swing 是一个为 Java 设计的 GUI 工具包,是 JAVA 基础类的一部分,基于 Java AWT 构建,提供了一系列轻量级、可定制的图形用户界面(GUI)组件。 与 AWT 相比,Swing 提供了许多比 AWT 更好的屏幕显示元素,更加灵活和可定制,具有更好的跨平台性能。 组件和容器 Java Swing 提供了许多

【编程底层思考】垃圾收集机制,GC算法,垃圾收集器类型概述

Java的垃圾收集(Garbage Collection,GC)机制是Java语言的一大特色,它负责自动管理内存的回收,释放不再使用的对象所占用的内存。以下是对Java垃圾收集机制的详细介绍: 一、垃圾收集机制概述: 对象存活判断:垃圾收集器定期检查堆内存中的对象,判断哪些对象是“垃圾”,即不再被任何引用链直接或间接引用的对象。内存回收:将判断为垃圾的对象占用的内存进行回收,以便重新使用。

论文翻译:arxiv-2024 Benchmark Data Contamination of Large Language Models: A Survey

Benchmark Data Contamination of Large Language Models: A Survey https://arxiv.org/abs/2406.04244 大规模语言模型的基准数据污染:一项综述 文章目录 大规模语言模型的基准数据污染:一项综述摘要1 引言 摘要 大规模语言模型(LLMs),如GPT-4、Claude-3和Gemini的快

Thymeleaf:生成静态文件及异常处理java.lang.NoClassDefFoundError: ognl/PropertyAccessor

我们需要引入包: <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-thymeleaf</artifactId></dependency><dependency><groupId>org.springframework</groupId><artifactId>sp

jenkins 插件执行shell命令时,提示“Command not found”处理方法

首先提示找不到“Command not found,可能我们第一反应是查看目标机器是否已支持该命令,不过如果相信能找到这里来的朋友估计遇到的跟我一样,其实目标机器是没有问题的通过一些远程工具执行shell命令是可以执行。奇怪的就是通过jenkinsSSH插件无法执行,经一番折腾各种搜索发现是jenkins没有加载/etc/profile导致。 【解决办法】: 需要在jenkins调用shell脚

Java 多线程概述

多线程技术概述   1.线程与进程 进程:内存中运行的应用程序,每个进程都拥有一个独立的内存空间。线程:是进程中的一个执行路径,共享一个内存空间,线程之间可以自由切换、并发执行,一个进程最少有一个线程,线程实际数是在进程基础之上的进一步划分,一个进程启动之后,进程之中的若干执行路径又可以划分成若干个线程 2.线程的调度 分时调度:所有线程轮流使用CPU的使用权,平均分配时间抢占式调度

论文翻译:ICLR-2024 PROVING TEST SET CONTAMINATION IN BLACK BOX LANGUAGE MODELS

PROVING TEST SET CONTAMINATION IN BLACK BOX LANGUAGE MODELS https://openreview.net/forum?id=KS8mIvetg2 验证测试集污染在黑盒语言模型中 文章目录 验证测试集污染在黑盒语言模型中摘要1 引言 摘要 大型语言模型是在大量互联网数据上训练的,这引发了人们的担忧和猜测,即它们可能已