速揽2500星,Andrej Karpathy重写了一份minGPT库
来源:51CTO.COM
时间:2023-05-03 10:41:24 164浏览 收藏
小伙伴们有没有觉得学习科技周边很有意思?有意思就对了!今天就给大家带来《速揽2500星,Andrej Karpathy重写了一份minGPT库》,以下内容将会涉及到,若是在学习中对其中部分知识点有疑问,或许看了本文就能帮到你!
作为人工智能领域「暴力美学」的代表作,GPT 可谓是出尽风头,从诞生之初的 GPT 1.17 亿参数,一路狂飙到 GPT-3 1750 亿参数。随着 GPT-3 的发布,OpenAI 向社区开放了商业 API,鼓励大家使用 GPT-3 尝试更多的实验。然而,API 的使用需要申请,而且你的申请很有可能石沉大海。
为了让资源有限的研究者也能体验一把玩大模型的乐趣,前特斯拉 AI 负责人 Andrej Karpathy 基于 PyTorch,仅用 300 行左右的代码就写出了一个小型 GPT 训练库,并将其命名为 minGPT。这个 minGPT 能够进行加法运算和字符级的语言建模,而且准确率还不错。
时隔两年,minGPT 迎来更新,Karpathy 又上线新版本,并命名为 NanoGPT,该库用于训练和微调中型大小的 GPT。上线短短几天,狂揽 2.5K 星。
项目地址:https://github.com/karpathy/nanoGPT
在项目介绍中,Karpathy 这样写道:「NanoGPT 是用于训练和微调中型尺度 GPT 最简单、最快的库。是对 minGPT 的重写,因为 minGPT 太复杂了,以至于我都不愿意在使用它。NanoGPT 还在开发当中,当前致力于在 OpenWebText 数据集上重现 GPT-2。
NanoGPT 代码设计目标是简单易读,其中 train.py 是一个约 300 行的代码;model.py 是一个约 300 行的 GPT 模型定义,它可以选择从 OpenAI 加载 GPT-2 权重。」
为了呈现数据集,用户首先需要将一些文档 tokenize 为一个简单的 1D 索引数组。
$ cd data/openwebtext $ python prepare.py
这将生成两个文件:train.bin 和 val.bin,每个文件都包含一个代表 GPT-2 BPE token id 的 uint16 字节原始序列。该训练脚本试图复制 OpenAI 提供的最小的 GPT-2 版本,即 124M 版本。
$ python train.py
假如你想使用 PyTorch 分布式数据并行(DDP)进行训练,请使用 torchrun 运行脚本。
$ torchrun --standalone --nproc_per_node=4 train.py
为了让代码更有效,用户也可以从模型中进行取样:
$ python sample.py
Karpathy 表示,该项目目前在 1 个 A100 40GB GPU 上一晚上的训练损失约为 3.74,在 4 个 GPU 上训练损失约为 3.60。在 8 x A100 40GB node 上进行 400,000 次迭代(约 1 天)atm 的训练降至 3.1。
至于如何在新文本上微调 GPT,用户可以访问 data/shakespeare 并查看 prepare.py。与 OpenWebText 不同,这将在几秒钟内运行。微调只需要很少的时间,例如在单个 GPU 上只需要几分钟。下面是运行微调的一个例子
$ python train.py config/finetune_shakespeare.py
项目一上线,已经有人开始尝试了:
想要尝试的小伙伴,可以参考原项目运行。
理论要掌握,实操不能落!以上关于《速揽2500星,Andrej Karpathy重写了一份minGPT库》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
417 收藏
-
430 收藏
-
315 收藏
-
319 收藏
-
170 收藏
-
410 收藏
-
470 收藏
-
196 收藏
-
461 收藏
-
382 收藏
-
332 收藏
-
391 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 508次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习
-
- 彩色的小蝴蝶
- 这篇文章内容真及时,太细致了,真优秀,收藏了,关注老哥了!希望老哥能多写科技周边相关的文章。
- 2023-06-23 11:47:25
-
- 壮观的面包
- 受益颇多,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,看完之后很有帮助,总算是懂了,感谢老哥分享文章!
- 2023-06-10 15:11:02
-
- 优秀的发箍
- 细节满满,码起来,感谢大佬的这篇文章,我会继续支持!
- 2023-06-05 07:51:22
-
- 传统的书本
- 很棒,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,看完之后很有帮助,总算是懂了,感谢博主分享文章!
- 2023-05-25 02:17:14
-
- 聪明的花卷
- 写的不错,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,看完之后很有帮助,总算是懂了,感谢师傅分享技术文章!
- 2023-05-20 19:22:34
-
- 单身的高跟鞋
- 这篇技术文章真是及时雨啊,很详细,太给力了,mark,关注作者大大了!希望作者大大能多写科技周边相关的文章。
- 2023-05-18 06:19:49
-
- 踏实的宝马
- 太细致了,mark,感谢作者大大的这篇技术贴,我会继续支持!
- 2023-05-17 16:08:21
-
- 爱笑的大侠
- 这篇博文真及时,很详细,很好,码起来,关注博主了!希望博主能多写科技周边相关的文章。
- 2023-05-15 09:57:18
-
- 朴素的饼干
- 这篇博文太及时了,作者加油!
- 2023-05-12 17:28:22
-
- 典雅的黑夜
- 这篇文章太及时了,老哥加油!
- 2023-05-12 12:49:50
-
- 妩媚的砖头
- 太细致了,收藏了,感谢up主的这篇技术文章,我会继续支持!
- 2023-05-11 06:39:40