AI作诗(文末附源码)

2023-10-24 03:40
文章标签 ai 源码 文末 作诗

本文主要是介绍AI作诗(文末附源码),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本文节选自我的博客:AI 作诗 (附源码)

  • 💖 作者简介:大家好,我是MilesChen,偏前端的全栈开发者。
  • 📝 CSDN主页:爱吃糖的猫🔥
  • 📣 我的博客:爱吃糖的猫
  • 📚 Github主页: MilesChen
  • 🎉 支持我:点赞👍+收藏⭐️+留言📝
  • 💬介绍:The mixture of WEB+DeepLearning+Iot+anything🍁

前言

使用RNN生成古诗,你给它输入一堆古诗词,它会学着生成和前面相关联的字词。如果你给它输入一堆姓名,它会学着生成姓名;给它输入一堆古典乐/歌词,它会学着生成古典乐/歌词,让电脑可以向人一样做诗。

原理

了解RNN

循环神经网络主要应用于序列数据的处理,因输入与输出数据之间有时间上的关联性,所以在常规神经网络的基础上,加上了时间维度上的关联性,也就是有了循环神经网络。因此对于循环神经网络而言,它能够记录很长时间的历史信息,即使在某一时刻有相同的输入,但由于历史信息不同,也会得到不同的输出,这也是循环神经网络相比于常规网络的不同之处。根据输入与输出之间的对应关系,可以将循环神经网络分为以下五大类别:

古诗生成RNN

基于字符集的文本生成原理可以这样简单理解:

  1. 将一个长文本序列依次输入到循环神经网络
  2. 对于给定前缀序列的序列数据,对序列中将要出现的下一个字符的概率分布建立模型
  3. 这样就可以每次产生一个新的字符

训练过程

前面我们介绍过 RNN 的输入和输出存在多种关系,比如一对多,多对多等等,不同的输入对应着不同的应用,比如多对多可以用来做机器翻译等等,今天我们要讲的 Char RNN 在训练网络的时候是一个相同长度的多对多类型,也就是输入一个序列,输出一个吸纳共同长度的序列。

具体的网络训练过程如下:

生成文本:
首先需要输入网络一段初始的序列进行预热,预热的过程并不需要实际的输出结果,只是为了生成拥有记忆效果的隐藏状态,并将隐藏状态保留下来,接着我们开始正式生成文本,不断地生成新的句子,这个过程是可以无限循环下去,或者到达我们的要求输出长度,具体可以看看下面

代码解析

目录结构

文本预处理

把文本文件进行字符编码并且建立数据集。

class TextConverter(object):def __init__(self, text_path, max_vocab=5000):with codecs.open(text_path, mode='r', encoding='utf-8') as f:text_file = f.readlines()word_list = [v for s in text_file for v in s]vocab = set(word_list)# 如果单词超过最长限制,则按单词出现频率去掉最小的部分vocab_count = {}for word in vocab:vocab_count[word] = 0for word in word_list:vocab_count[word] += 1vocab_count_list = []for word in vocab_count:vocab_count_list.append((word, vocab_count[word]))vocab_count_list.sort(key=lambda x: x[1], reverse=True)if len(vocab_count_list) > max_vocab:vocab_count_list = vocab_count_list[:max_vocab]vocab = [x[0] for x in vocab_count_list]self.vocab = vocabself.word_to_int_table = {c: i for i, c in enumerate(self.vocab)}self.int_to_word_table = dict(enumerate(self.vocab))@propertydef vocab_size(self):return len(self.vocab) + 1def word_to_int(self, word):if word in self.word_to_int_table:return self.word_to_int_table[word]else:return len(self.vocab)def int_to_word(self, index):if index == len(self.vocab):return '<unk>'elif index < len(self.vocab):return self.int_to_word_table[index]else:raise Exception('Unknow index!')def text_to_arr(self, text):arr = []for word in text:arr.append(self.word_to_int(word))return np.array(arr)def arr_to_text(self, arr):words = []for index in arr:words.append(self.int_to_word(index))return "".join(words)

模型结构

class CharRNN(g.Block):def __init__(self, num_classes, embed_dim, hidden_size, num_layers,dropout):super(CharRNN, self).__init__()self.num_layers = num_layersself.hidden_size = hidden_sizewith self.name_scope():self.word_to_vec = g.nn.Embedding(num_classes, embed_dim)self.rnn = g.rnn.GRU(hidden_size, num_layers, dropout=dropout)self.proj = g.nn.Dense(num_classes)def forward(self, x, hs=None):batch = x.shape[0]if hs is None:hs = nd.zeros((self.num_layers, batch, self.hidden_size), ctx=mx.gpu())word_embed = self.word_to_vec(x)  # batch x len x embedword_embed = word_embed.transpose((1, 0, 2))  # len x batch x embedout, h0 = self.rnn(word_embed, hs)  # len x batch x hiddenle, mb, hd = out.shapeout = out.reshape((le * mb, hd))out = self.proj(out)out = out.reshape((le, mb, -1))out = out.transpose((1, 0, 2))  # batch x len x hiddenreturn out.reshape((-1, out.shape[2])), h0

测试

成功训练之后,用parse传入‘test’命令开始让电脑作诗。

def sample(ctx, model, checkpoint, convert, arr_to_text, prime, text_len=20):'''将载入好权重的模型读入,指定开始字符和长度进行生成,将生成的结果保存到txt文件中checkpoint: 载入的模型convert: 文本和下标转换prime: 起始文本text_len: 生成文本长度'''model.load_params(checkpoint, ctx=ctx)samples = [convert(c) for c in prime]input_txt = nd.array(samples).reshape((-1 ,1)).as_in_context(ctx)embed = model[0](input_txt)hs = nd.zeros(model[1].state_info(1)[0]['shape'], ctx=ctx)_, init_state = model[1](embed, hs)result = samplesmodel_input = input_txt[:, input_txt.shape[1] - 1].reshape((-1, 1))for i in range(text_len):# out是输出的字符,大小为1 x vocab# init_state是RNN传递的hidden statewith mx.autograd.predict_mode():embed = model[0](model_input)out, init_state = model[1](embed, init_state)out = model[2](out)pred = pick_top_n(out)model_input = nd.array(pred).reshape((-1, 1)).as_in_context(ctx)result.append(pred[0])return arr_to_text(result)

效果

用古诗作为训练集,输入字符“我”,得到下面的结果:

总结

源码点这,本本环境使用的pytorch1.1,其他版应该也是兼容的。

常规网络中的输入与输出大多是向量与向量之间的关联,不考虑时间上的联系,而在循环神经网络中,输入与输出之间大多是序列与序列(Sequence-to-Sequence.)之间的联系,也就产生了多种模式。

  1. 一对一(one to one):最为简单的反向传播网络。
  2. 一对多(one to many):可用于图像捕捉(image captioning),将图像转换为文字。
  3. 多对一(many to one):常用于情感分析(sentiment analysis),将一句话中归为具体的情感类别。
  4. 多对多( many to many):常用于输入输出序列长度不确定时,例如机器翻译(machine translate),实质是两个神经网络的叠加。不确定长度的多对多(many to many)(最右方):常用于语音识别(speech recognition)中,输入与输出序列等长。

如果你觉得本文对你有所帮助,别忘记给我点个start,有任何疑问和想法,欢迎在评论区与我交流。

这篇关于AI作诗(文末附源码)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

PyCharm接入DeepSeek实现AI编程的操作流程

《PyCharm接入DeepSeek实现AI编程的操作流程》DeepSeek是一家专注于人工智能技术研发的公司,致力于开发高性能、低成本的AI模型,接下来,我们把DeepSeek接入到PyCharm中... 目录引言效果演示创建API key在PyCharm中下载Continue插件配置Continue引言

Go中sync.Once源码的深度讲解

《Go中sync.Once源码的深度讲解》sync.Once是Go语言标准库中的一个同步原语,用于确保某个操作只执行一次,本文将从源码出发为大家详细介绍一下sync.Once的具体使用,x希望对大家有... 目录概念简单示例源码解读总结概念sync.Once是Go语言标准库中的一个同步原语,用于确保某个操

Ubuntu系统怎么安装Warp? 新一代AI 终端神器安装使用方法

《Ubuntu系统怎么安装Warp?新一代AI终端神器安装使用方法》Warp是一款使用Rust开发的现代化AI终端工具,该怎么再Ubuntu系统中安装使用呢?下面我们就来看看详细教程... Warp Terminal 是一款使用 Rust 开发的现代化「AI 终端」工具。最初它只支持 MACOS,但在 20

Java汇编源码如何查看环境搭建

《Java汇编源码如何查看环境搭建》:本文主要介绍如何在IntelliJIDEA开发环境中搭建字节码和汇编环境,以便更好地进行代码调优和JVM学习,首先,介绍了如何配置IntelliJIDEA以方... 目录一、简介二、在IDEA开发环境中搭建汇编环境2.1 在IDEA中搭建字节码查看环境2.1.1 搭建步

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

AI绘图怎么变现?想做点副业的小白必看!

在科技飞速发展的今天,AI绘图作为一种新兴技术,不仅改变了艺术创作的方式,也为创作者提供了多种变现途径。本文将详细探讨几种常见的AI绘图变现方式,帮助创作者更好地利用这一技术实现经济收益。 更多实操教程和AI绘画工具,可以扫描下方,免费获取 定制服务:个性化的创意商机 个性化定制 AI绘图技术能够根据用户需求生成个性化的头像、壁纸、插画等作品。例如,姓氏头像在电商平台上非常受欢迎,

从去中心化到智能化:Web3如何与AI共同塑造数字生态

在数字时代的演进中,Web3和人工智能(AI)正成为塑造未来互联网的两大核心力量。Web3的去中心化理念与AI的智能化技术,正相互交织,共同推动数字生态的变革。本文将探讨Web3与AI的融合如何改变数字世界,并展望这一新兴组合如何重塑我们的在线体验。 Web3的去中心化愿景 Web3代表了互联网的第三代发展,它基于去中心化的区块链技术,旨在创建一个开放、透明且用户主导的数字生态。不同于传统

AI一键生成 PPT

AI一键生成 PPT 操作步骤 作为一名打工人,是不是经常需要制作各种PPT来分享我的生活和想法。但是,你们知道,有时候灵感来了,时间却不够用了!😩直到我发现了Kimi AI——一个能够自动生成PPT的神奇助手!🌟 什么是Kimi? 一款月之暗面科技有限公司开发的AI办公工具,帮助用户快速生成高质量的演示文稿。 无论你是职场人士、学生还是教师,Kimi都能够为你的办公文

Andrej Karpathy最新采访:认知核心模型10亿参数就够了,AI会打破教育不公的僵局

夕小瑶科技说 原创  作者 | 海野 AI圈子的红人,AI大神Andrej Karpathy,曾是OpenAI联合创始人之一,特斯拉AI总监。上一次的动态是官宣创办一家名为 Eureka Labs 的人工智能+教育公司 ,宣布将长期致力于AI原生教育。 近日,Andrej Karpathy接受了No Priors(投资博客)的采访,与硅谷知名投资人 Sara Guo 和 Elad G

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟&nbsp;开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚&nbsp;第一站:海量资源,应有尽有 走进“智听