Project Icon

build-nanogpt

从零构建GPT-2模型的开源教学项目

build-nanogpt是一个开源教学项目,演示如何从零构建GPT-2模型。通过详细的Git提交记录和YouTube视频讲解,项目展示了124M参数GPT-2模型的完整构建过程。用户可在约1小时内重现模型,并可扩展至GPT-3规模。项目还提供模型训练示例、FAQ和勘误表,是深入理解大型语言模型原理的实用资源。该项目适合对大型语言模型感兴趣的开发者和研究人员,不仅提供了代码实现,还包含详细的解释和实践指导,有助于深入理解现代自然语言处理技术。

构建 nanoGPT

本仓库包含了nanoGPT的从零开始的复现。Git提交被特意保持逐步且整洁,以便人们可以轻松浏览Git提交历史,看到它是如何逐步构建的。此外,还有一个配套的YouTube视频讲座,你可以看到我介绍每个提交并解释过程中的各个部分。

我们基本上从一个空文件开始,逐步完成对GPT-2(124M)模型的复现。如果你有更多的耐心或资金,这段代码也可以复现GPT-3模型。虽然GPT-2(124M)模型在当时(2019年,约5年前)可能需要相当长的时间来训练,但如今,复现它只需要约1小时和10美元。如果你没有足够的GPU,你需要一个云GPU服务器,对此我推荐Lambda

请注意,GPT-2和GPT-3都是简单的语言模型,在互联网文档上训练,它们所做的只是"梦见"互联网文档。因此,这个仓库/视频不涉及聊天微调,你无法像与ChatGPT交谈那样与它交谈。微调过程(从概念上讲相当简单 - SFT只是替换数据集并继续训练)在这部分之后进行,将在以后的时间涵盖。目前,这是124M模型在训练100亿个token后,当你用"Hello, I'm a language model,"提示它时所说的内容:

Hello, I'm a language model, and my goal is to make English as easy and fun as possible for everyone, and to find out the different grammar rules
Hello, I'm a language model, so the next time I go, I'll just say, I like this stuff.
Hello, I'm a language model, and the question is, what should I do if I want to be a teacher?
Hello, I'm a language model, and I'm an English person. In languages, "speak" is really speaking. Because for most people, there's

在训练400亿个token后:

Hello, I'm a language model, a model of computer science, and it's a way (in mathematics) to program computer programs to do things like write
Hello, I'm a language model, not a human. This means that I believe in my language model, as I have no experience with it yet.
Hello, I'm a language model, but I'm talking about data. You've got to create an array of data: you've got to create that.
Hello, I'm a language model, and all of this is about modeling and learning Python. I'm very good in syntax, however I struggle with Python due

哈哈。无论如何,一旦视频发布,这里也将成为FAQ的地方,以及修复和勘误的地方,我相信会有不少:)

对于讨论和问题,请使用Discussions标签,如需更快速的交流,请查看我的Zero To Hero Discord,频道**#nanoGPT**:

视频

让我们复现GPT-2(124M)YouTube讲座

勘误

小清理,我们忘记删除偏置的register_buffer,一旦我们切换到flash attention,这已通过最近的PR修复。

早期版本的PyTorch可能在从uint16转换为long时遇到困难。在load_tokens内,我们添加了npt = npt.astype(np.int32),使用numpy将uint16转换为int32,然后再转换为torch张量,最后转换为long。

torch.autocast函数接受一个device_type参数,我固执地尝试只传递device希望它能正常工作,但PyTorch实际上真的只想要类型,并在某些版本的PyTorch中创建错误。因此,我们希望例如设备cuda:3被简化为cuda。目前,设备mps(Apple Silicon)会变成device_type CPU,我不是100%确定这是PyTorch预期的方式。

令人困惑的是,model.require_backward_grad_sync实际上被前向和后向传播都使用。将该行上移,使其也应用于前向传播。

生产

对于与nanoGPT非常相似的更适合生产级别的运行,我建议查看以下仓库:

FAQ

许可

MIT

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号