「日拱一码」076 深度学习——自然语言处理NLP

目录

深度学习与NLP介绍

什么是自然语言处理(NLP)?

深度学习如何赋能NLP?

[核心概念:词嵌入(Word Embedding)](#核心概念:词嵌入(Word Embedding))

代码示例


深度学习与NLP介绍

什么是自然语言处理(NLP)?

自然语言处理是人工智能的一个子领域,它致力于使计算机能够理解、解释和生成人类语言。它的目标是填补人类自然语言与计算机二进制语言之间的鸿沟。

NLP的应用无处不在,例如:

  • 搜索引擎(如Google、百度)
  • 智能助手(如Siri、Alexa、小爱同学)
  • 机器翻译(如Google Translate、百度翻译)
  • 垃圾邮件过滤
  • 情感分析(分析评论的正负面情绪)
  • 文本自动摘要
  • 聊天机器人

深度学习如何赋能NLP?

在深度学习出现之前,传统的NLP方法严重依赖手工制作的特征和规则,处理过程繁琐且难以覆盖语言的复杂性。

深度学习,特别是循环神经网络(RNN)长短期记忆网络(LSTM)门控循环单元(GRU) 以及革命性的Transformer架构,彻底改变了NLP领域。它们能够:

  1. 自动学习特征:无需人工设计特征,模型能从海量文本数据中自动学习词汇、语法和语义的分布式表示(即词向量)。
  2. 处理序列数据:RNN、LSTM等架构专为处理文本这类序列数据而设计,能考虑上下文信息。
  3. 实现卓越性能:基于Transformer的模型(如BERT, GPT)在几乎所有NLP任务上都取得了前所未有的 state-of-the-art (SOTA) 性能。

核心概念:词嵌入(Word Embedding)

这是深度学习NLP的基石。它将词汇从高维稀疏的one-hot表示,映射到低维稠密的向量空间中。在这个空间中,语义相近的词,其向量在空间中的位置也更接近。例如,"国王"和"女王"的向量距离,会远小于"国王"和"苹果"的向量距离。

代码示例

我们使用一个非常流行的深度学习库 Keras 和一个经典数据集 IMDb电影评论数据集(包含5万条标注了正面/负面情感的评论)来构建一个简单的情感分析模型。

任务:训练一个模型,使其能够判断一条电影评论是正面的还是负面的。

python 复制代码
# 导入必要的库
import tensorflow as tf
from tensorflow.keras.datasets import imdb
from tensorflow.keras.models import Sequential
from tensorflow.keras.layers import Embedding, SimpleRNN, Dense
from tensorflow.keras.preprocessing import sequence

# 加载数据
# num_words=10000 表示只保留数据集中最常出现的10,000个单词
(top_train_data, top_train_labels), (top_test_data, top_test_labels) = imdb.load_data(num_words=10000)

# 数据预处理(标准化序列长度)
# 每条评论的单词数量不同,我们需要将其统一长度。
# maxlen=500 表示超过500词的评论会被截断,不足500词的会用0填充。
max_review_length = 500
X_train = sequence.pad_sequences(top_train_data, maxlen=max_review_length)
X_test = sequence.pad_sequences(top_test_data, maxlen=max_review_length)
y_train = top_train_labels
y_test = top_test_labels

# 构建模型
model = Sequential()
# 添加嵌入层:将10,000个词的索引映射为32维的向量
model.add(Embedding(input_dim=10000, output_dim=32, input_length=max_review_length))
# 添加一个简单的RNN层,带有32个神经元
model.add(SimpleRNN(32))
# 添加全连接层(Dense Layer)用于输出,使用sigmoid激活函数进行二分类(正面/负面)
model.add(Dense(1, activation='sigmoid'))

# 打印模型结构
model.summary()

# 编译模型
# 配置优化器、损失函数和评估指标
model.compile(optimizer='rmsprop',
              loss='binary_crossentropy',
              metrics=['accuracy'])

# 训练模型
# 将训练数据分为训练集和验证集,训练5个轮次
history = model.fit(X_train, y_train,
                    epochs=5,
                    batch_size=128,
                    validation_split=0.2) # 20%的数据用作验证

# 评估模型
# 在测试集上评估最终性能
test_loss, test_acc = model.evaluate(X_test, y_test)
print(f'\n测试集准确率: {test_acc:.4f}')  # 0.7821

# 进行预测
# 假设我们有一条新评论,需要将其转换为模型可接受的格式(这里用训练数据中的一条代替演示)
sample_review = X_test[0:1] # 取测试集第一条数据
prediction = model.predict(sample_review)
print(f"\n预测结果(值越接近1表示越正面,越接近0表示越负面): {prediction[0]}")  # [0.45097703]
if prediction[0] > 0.5:
    print("这是一条正面评论!")
else:
    print("这是一条负面评论!")  # 这是一条负面评论!
相关推荐
Java后端的Ai之路6 小时前
【Python 教程15】-Python和Web
python
那个村的李富贵6 小时前
光影魔术师:CANN加速实时图像风格迁移,让每张照片秒变大师画作
人工智能·aigc·cann
冬奇Lab7 小时前
一天一个开源项目(第15篇):MapToPoster - 用代码将城市地图转换为精美的海报设计
python·开源
腾讯云开发者8 小时前
“痛点”到“通点”!一份让 AI 真正落地产生真金白银的实战指南
人工智能
CareyWYR8 小时前
每周AI论文速递(260202-260206)
人工智能
hopsky8 小时前
大模型生成PPT的技术原理
人工智能
禁默9 小时前
打通 AI 与信号处理的“任督二脉”:Ascend SIP Boost 加速库深度实战
人工智能·信号处理·cann
心疼你的一切9 小时前
昇腾CANN实战落地:从智慧城市到AIGC,解锁五大行业AI应用的算力密码
数据仓库·人工智能·深度学习·aigc·智慧城市·cann
AI绘画哇哒哒9 小时前
【干货收藏】深度解析AI Agent框架:设计原理+主流选型+项目实操,一站式学习指南
人工智能·学习·ai·程序员·大模型·产品经理·转行
数据分析能量站10 小时前
Clawdbot(现名Moltbot)-现状分析
人工智能