我用ChatGPT写神经网络:一字不改,结果竟然很好用

2023

点击蓝字 关注我们

关注并星标

从此不迷路

计算机视觉研究院

57ed4e1cfdbfcf4599ba0972f630f4e0.gif

计算机视觉研究院专栏

作者:Edison_G

AI 写 AI,来得比预料中更快一些。

公众号ID|ComputerVisionGzq

学习群|扫码在主页获取加入方式

转自《机器之心》

自从去年底推出以来,对话式 AI 模型 ChatGPT 火遍了整个社区。

ChatGPT 的确是一个了不起的工具,就像一个「潘多拉魔盒」。一旦找到正确的打开方式,你或许会发现,自己再也离不开它了。

作为一个全能选手,人们给 ChatGPT 提出的要求五花八门,有人用它写论文,有人让它陪聊,这些都是常见的玩法。脑洞再打开一点,既然 ChatGPT 是 AI 中的「王者」,那它会不会写一个 AI?

近日,一位机器学习领域的博主突发奇想,他决定让 ChatGPT 构建一个神经网络,使用 Keras 解决 MNIST 问题。

MNIST 算是机器学习领域的经典问题。即使这个手写数字数据集逐渐淡出了计算机视觉领域,但它的纪念意义仍然不可忽视,很多人入门深度学习的第一个数据集、验证算法的第一个实验都是 MNIST。

我用ChatGPT写神经网络:一字不改,结果竟然很好用_第1张图片

话不多说,想到了就开工。作者直接让 ChatGPT 写了一段代码,看上去完美无缺,甚至不需要更改任何内容。

我用ChatGPT写神经网络:一字不改,结果竟然很好用_第2张图片

这是一个很好的开始。

ChatGPT 选择了分类交叉熵作为损失函数。作者提出重写分类交叉熵这部分代码,ChatGPT 将其替换为稀疏分类交叉熵,更新之后的代码仍能 Work。可以发现,新的损失函数放弃了标签的分类转换。

我用ChatGPT写神经网络:一字不改,结果竟然很好用_第3张图片

ChatGPT 生成的代码使用了全连接层,但作者想使用卷积层。因此,ChatGPT 按照指示修改了代码,并添加了一个 Conv2D 和一个最大池化层(MaxPooling layer)。

我用ChatGPT写神经网络:一字不改,结果竟然很好用_第4张图片

然后来到了评估最终模型阶段,作者让 ChatGPT 使用测试集编写代码。

我用ChatGPT写神经网络:一字不改,结果竟然很好用_第5张图片

结果看起来很棒,而且 ChatGPT 的每一次回复都带有完整的解释。比如在这次评估中,它这样解释:

「评估」方法将测试数据和测试标签作为参数,并返回模型编译(此处为准确率)期间指定的损失和度量。上面的代码片段输出了测试的准确率,这应该可以让你了解到模型对新数据的概括性。‍

模型在训练期间使用了整个测试集作为验证数据。然后,作者让 ChatGPT 将其更改为训练数据的 20%。

我用ChatGPT写神经网络:一字不改,结果竟然很好用_第6张图片

此外,作者还想要更小的 batch 并运行更少 epoch 的代码。虽然这一步未必要用到 ChatGPT,但他不想在不更新 ChatGPT 上下文的情况下更改代码。

所以这项任务还是落在了 ChatGPT 头上:

我用ChatGPT写神经网络:一字不改,结果竟然很好用_第7张图片

接下来,作者打算绘制训练过程中的训练和测试损失图。ChatGPT 的建议是:需要更改适合模型的 line 以捕获其结果值。

我用ChatGPT写神经网络:一字不改,结果竟然很好用_第8张图片

我用ChatGPT写神经网络:一字不改,结果竟然很好用_第9张图片

为了展示数据集中的一些示例,作者让 ChatGPT 编写代码来输出图像和标签的组合。这些输出的代码也很完美,附有 20 张图片的合集。

我用ChatGPT写神经网络:一字不改,结果竟然很好用_第10张图片

我用ChatGPT写神经网络:一字不改,结果竟然很好用_第11张图片

构建模型时,查看其结构也是必要的。如果用这个问题去问 ChatGPT ,回复是:

我用ChatGPT写神经网络:一字不改,结果竟然很好用_第12张图片

ChatGPT 给出的是关于模型的总结:

我用ChatGPT写神经网络:一字不改,结果竟然很好用_第13张图片

模型的总结很有用,但作者更想看到显示模型结构的图。所以继续问:

我用ChatGPT写神经网络:一字不改,结果竟然很好用_第14张图片

我用ChatGPT写神经网络:一字不改,结果竟然很好用_第15张图片

结果是满意的,最后就是准备部署这个模型了,让 ChatGPT 将模型保存到磁盘吧:

我用ChatGPT写神经网络:一字不改,结果竟然很好用_第16张图片

现在,作者想创建一个使用保存的模型进行预测的类。这是 prompt 很有趣,解决方案也很完美。

我用ChatGPT写神经网络:一字不改,结果竟然很好用_第17张图片

现在编写一个示例,使用预测器的类来预测 10 个随机图像的标签:

我用ChatGPT写神经网络:一字不改,结果竟然很好用_第18张图片

为了完成这个,作者让 ChatGPT 展示了一个混淆矩阵:

我用ChatGPT写神经网络:一字不改,结果竟然很好用_第19张图片

该说不说,ChatGPT 使用的样式还真挺好看。

我用ChatGPT写神经网络:一字不改,结果竟然很好用_第20张图片

完成所有试验后,作者将所有 ChatGPT 生成的代码公布了出来,你也可以上手试试:

地址:https://colab.research.google.com/drive/1JX1AVIfGtIlnLGqgHrK6WPylPhZvu9qe?usp=sharing

© THE END 

转载请联系本公众号获得授权

d15f5d5ef784f0ead02ea89d4515b91f.gif

计算机视觉研究院学习群等你加入!

计算机视觉研究院主要涉及深度学习领域,主要致力于人脸检测、人脸识别,多目标检测、目标跟踪、图像分割等研究方向。研究院接下来会不断分享最新的论文算法新框架,我们这次改革不同点就是,我们要着重”研究“。之后我们会针对相应领域分享实践过程,让大家真正体会摆脱理论的真实场景,培养爱动手编程爱动脑思考的习惯!

我用ChatGPT写神经网络:一字不改,结果竟然很好用_第21张图片

扫码关注

计算机视觉研究院

公众号ID|ComputerVisionGzq

学习群|扫码在主页获取加入方式

 往期推荐 

  • YOLO系列迎来YOLOv8,迅速包揽目标检测、实例分割新SOTA

  • 利用TRansformer进行端到端的目标检测及跟踪(附源代码)

  • 小型深度学习框架 | TinyGrad,不到1K行代码(附代码下载)

  • Sparse R-CNN:稀疏框架,端到端的目标检测(附源码)

  • 利用TRansformer进行端到端的目标检测及跟踪(附源代码)

  • 细粒度特征提取和定位用于目标检测(附论文下载)

  • 特别小的目标检测识别(附论文下载)

  • 目标检测 | 基于统计自适应线性回归的目标尺寸预测

你可能感兴趣的:(我用ChatGPT写神经网络:一字不改,结果竟然很好用)