search
HomeTechnology peripheralsAIUndergraduate students use 60 lines of code to teach you how to make a large GPT model by hand. The technical introduction is comparable to a tutorial.

Currently, large language models (LLM) are considered to be the direction of breakthroughs in artificial intelligence. People are trying to use them to do all kinds of complex things, such as question and answer, creation, mathematical reasoning, and writing code. The recent explosion of ChatGPT is the best example.

However, for machine learning practitioners, the threshold for large models is very high: because they are too large and difficult to train, this direction has been monopolized by large companies for a long time. However, recently, there are more and more ways to simplify the GPT model. In mid-January, former Tesla AI Senior Director Andrej Karpathy (now returning to OpenAI) released a complete tutorial on building a GPT model from scratch​. However, compared with the trained GPT and OpenAI's GPT-3, the size difference between the two is 10,000-1 million times. Recently, Jay Mody, a software engineering undergraduate student at McMaster University in Canada, implemented a GPT model from scratch with only 60 lines of code after importing the NumPy library. It's named PicoGPT. Not only that, he also loaded the trained GPT-2 model weights into his implementation and generated some text. 60 lines of code are shown below.

Undergraduate students use 60 lines of code to teach you how to make a large GPT model by hand. The technical introduction is comparable to a tutorial.

But to do this, you need to be familiar with Python and NumPy, and some Basic experience in training neural networks. The author stated that this blog aims to provide a simple, easy-to-understand and complete introduction to GPT. Therefore, the author only uses the already trained model weights to implement the forward pass code.

Undergraduate students use 60 lines of code to teach you how to make a large GPT model by hand. The technical introduction is comparable to a tutorial.

## Code address:

​https://github.com/jaymody/picoGPT/blob/29e78cc52b58ed2c1c483ffea2eb46ff6bdec785/gpt2_pico.py#L3-L58​

For this item Research, Andrej Karpathy gave four words: late but arrived. Back then, the minGPT and nanoGPT built by Karpathy required 300 lines of code.

It is worth mentioning that this tutorial is not completely zero-threshold. In order to let readers understand, the author first introduces what GPT is, its input, output and other contents, all in great detail. Undergraduate students use 60 lines of code to teach you how to make a large GPT model by hand. The technical introduction is comparable to a tutorial.

Undergraduate students use 60 lines of code to teach you how to make a large GPT model by hand. The technical introduction is comparable to a tutorial.## As for what GPT can do, the author gave several examples. It can write Email, summarize a book, give you instagram caption ideas, explain black holes to a 5 year old, write code in SQL, etc.

After reading this part carefully, you can roughly understand some basic knowledge of GPT. With this background information, the next step is how to set it up.

Project Introduction

Settings

##This chapter mainly introduces how to set up the encoder , hyperparameters and parameters.

##What you have to do is to clone the code base:

Undergraduate students use 60 lines of code to teach you how to make a large GPT model by hand. The technical introduction is comparable to a tutorial.

Then install the dependencies:

Undergraduate students use 60 lines of code to teach you how to make a large GPT model by hand. The technical introduction is comparable to a tutorial.

Note that if you are using an M1 Macbook, you need to change tensorflow to tensorflow-macos in requirements.txt before running pip install. Under this project, the files include encoder.py, utils.py, gpt2.py, gpt2_pico.py:

  • ##encoder.py: Contains the code of OpenAI BPE Tokenizer, directly Taken from gpt-2 repo;
  • ##utils.py: Contains code for downloading and loading GPT-2 model weights, tokenizers, and hyperparameters;
  • gpt2.py: Contains the GPT model and generated code, which can be run as a python script;
  • gpt2_pico.py: Same as gpt2.py, but with fewer lines of code.
gpt2.py needs to be implemented from scratch, so what you have to do is to delete gpt2.py first and create an empty file again:

Undergraduate students use 60 lines of code to teach you how to make a large GPT model by hand. The technical introduction is comparable to a tutorial.

##Then copy the following code into gpt2.py:

Undergraduate students use 60 lines of code to teach you how to make a large GPT model by hand. The technical introduction is comparable to a tutorial.

The above code contains 4 main parts:

gpt2 function is used to implement GPT this time Actual code;
  • generate function implements the autoregressive decoding algorithm;
  • main function;
  • fire.Fire (main) Convert the file into a CLI application so that you can finally run the code: python gpt2.py "some prompt here".
  • The main function contains encode, hparams, and params parameters and executes the following code:

Undergraduate students use 60 lines of code to teach you how to make a large GPT model by hand. The technical introduction is comparable to a tutorial.

Then the necessary model and tokenizer files will be downloaded to the models/124M file.

After the setup is completed, the author begins to introduce some details of the encoder, hyperparameters, and parameters. Taking the encoder as an example, the encoder in this article is the same as the BPE tokenizer used by GPT-2. Here are some examples of text encoded and decoded by this encoder:

Undergraduate students use 60 lines of code to teach you how to make a large GPT model by hand. The technical introduction is comparable to a tutorial.

The actual token length This looks like:

Undergraduate students use 60 lines of code to teach you how to make a large GPT model by hand. The technical introduction is comparable to a tutorial.Note that sometimes tokens are words (e.g. Not), sometimes they are words but preceded by a space (e.g. Ġall, Ġ represents a space), sometimes they are part of a word (e.g. capes is split into Ġcap and es), sometimes they are punctuation marks (e.g. .).

One benefit of BPE is that it can encode arbitrary strings, and if it encounters something that doesn't exist in the vocabulary, it will break it into substrings that it understands :

Undergraduate students use 60 lines of code to teach you how to make a large GPT model by hand. The technical introduction is comparable to a tutorial.The more detailed content will not be repeated. Next, we will introduce the basic neural network. This part is even more basic, mainly including GELU, Softmax function, Layer Normalization and Linear.

Undergraduate students use 60 lines of code to teach you how to make a large GPT model by hand. The technical introduction is comparable to a tutorial.

There are code examples in each small section. For example, in the Linear section, the author shows the standard matrix multiplication offset:

Undergraduate students use 60 lines of code to teach you how to make a large GPT model by hand. The technical introduction is comparable to a tutorial.

The code for projecting a linear layer from one vector space to another vector space is as follows:

Undergraduate students use 60 lines of code to teach you how to make a large GPT model by hand. The technical introduction is comparable to a tutorial.

##GPT Architecture

This part introduces the structure of GPT itself.

Undergraduate students use 60 lines of code to teach you how to make a large GPT model by hand. The technical introduction is comparable to a tutorial.

##Transformer structure is as follows:

Undergraduate students use 60 lines of code to teach you how to make a large GPT model by hand. The technical introduction is comparable to a tutorial.

Transformer uses only the decoder stack (right part of the diagram):

Undergraduate students use 60 lines of code to teach you how to make a large GPT model by hand. The technical introduction is comparable to a tutorial.

It should be noted that due to getting rid of the encoder, the middle cross-attention layer is also deleted. ​

At a high level, the GPT architecture has the following three parts:

    Text position embedding;
  • Transformer decoder stack;
  • Project to vocabulary.
The code looks like this:

Undergraduate students use 60 lines of code to teach you how to make a large GPT model by hand. The technical introduction is comparable to a tutorial.

Code part screenshot

Next, each of the above three parts will be decomposed in more detail, and I will not go into details here.

The above is the author's implementation of GPT. The next step is to combine them together and run the code to get gpt2.py. Its entire content is only 120 lines of code (60 lines if you remove comments and whitespace).

The author tested the results by:

Undergraduate students use 60 lines of code to teach you how to make a large GPT model by hand. The technical introduction is comparable to a tutorial.

##The output results are as follows:

Undergraduate students use 60 lines of code to teach you how to make a large GPT model by hand. The technical introduction is comparable to a tutorial.

##As the author said: This experiment was successful.

This article only briefly introduces the overall process following the author's ideas. Friends who want to know more can refer to the original link.

Original link: https://jaykmody.com/blog/gpt-from-scratch/#basic-layers

The above is the detailed content of Undergraduate students use 60 lines of code to teach you how to make a large GPT model by hand. The technical introduction is comparable to a tutorial.. For more information, please follow other related articles on the PHP Chinese website!

Statement
This article is reproduced at:51CTO.COM. If there is any infringement, please contact admin@php.cn delete
从VAE到扩散模型:一文解读以文生图新范式从VAE到扩散模型:一文解读以文生图新范式Apr 08, 2023 pm 08:41 PM

1 前言在发布DALL·E的15个月后,OpenAI在今年春天带了续作DALL·E 2,以其更加惊艳的效果和丰富的可玩性迅速占领了各大AI社区的头条。近年来,随着生成对抗网络(GAN)、变分自编码器(VAE)、扩散模型(Diffusion models)的出现,深度学习已向世人展现其强大的图像生成能力;加上GPT-3、BERT等NLP模型的成功,人类正逐步打破文本和图像的信息界限。在DALL·E 2中,只需输入简单的文本(prompt),它就可以生成多张1024*1024的高清图像。这些图像甚至

找不到中文语音预训练模型?中文版 Wav2vec 2.0和HuBERT来了找不到中文语音预训练模型?中文版 Wav2vec 2.0和HuBERT来了Apr 08, 2023 pm 06:21 PM

Wav2vec 2.0 [1],HuBERT [2] 和 WavLM [3] 等语音预训练模型,通过在多达上万小时的无标注语音数据(如 Libri-light )上的自监督学习,显著提升了自动语音识别(Automatic Speech Recognition, ASR),语音合成(Text-to-speech, TTS)和语音转换(Voice Conversation,VC)等语音下游任务的性能。然而这些模型都没有公开的中文版本,不便于应用在中文语音研究场景。 WenetSpeech [4] 是

普林斯顿陈丹琦:如何让「大模型」变小普林斯顿陈丹琦:如何让「大模型」变小Apr 08, 2023 pm 04:01 PM

“Making large models smaller”这是很多语言模型研究人员的学术追求,针对大模型昂贵的环境和训练成本,陈丹琦在智源大会青源学术年会上做了题为“Making large models smaller”的特邀报告。报告中重点提及了基于记忆增强的TRIME算法和基于粗细粒度联合剪枝和逐层蒸馏的CofiPruning算法。前者能够在不改变模型结构的基础上兼顾语言模型困惑度和检索速度方面的优势;而后者可以在保证下游任务准确度的同时实现更快的处理速度,具有更小的模型结构。陈丹琦 普

解锁CNN和Transformer正确结合方法,字节跳动提出有效的下一代视觉Transformer解锁CNN和Transformer正确结合方法,字节跳动提出有效的下一代视觉TransformerApr 09, 2023 pm 02:01 PM

由于复杂的注意力机制和模型设计,大多数现有的视觉 Transformer(ViT)在现实的工业部署场景中不能像卷积神经网络(CNN)那样高效地执行。这就带来了一个问题:视觉神经网络能否像 CNN 一样快速推断并像 ViT 一样强大?近期一些工作试图设计 CNN-Transformer 混合架构来解决这个问题,但这些工作的整体性能远不能令人满意。基于此,来自字节跳动的研究者提出了一种能在现实工业场景中有效部署的下一代视觉 Transformer——Next-ViT。从延迟 / 准确性权衡的角度看,

Stable Diffusion XL 现已推出—有什么新功能,你知道吗?Stable Diffusion XL 现已推出—有什么新功能,你知道吗?Apr 07, 2023 pm 11:21 PM

3月27号,Stability AI的创始人兼首席执行官Emad Mostaque在一条推文中宣布,Stable Diffusion XL 现已可用于公开测试。以下是一些事项:“XL”不是这个新的AI模型的官方名称。一旦发布稳定性AI公司的官方公告,名称将会更改。与先前版本相比,图像质量有所提高与先前版本相比,图像生成速度大大加快。示例图像让我们看看新旧AI模型在结果上的差异。Prompt: Luxury sports car with aerodynamic curves, shot in a

​什么是Transformer机器学习模型?​什么是Transformer机器学习模型?Apr 08, 2023 pm 06:31 PM

译者 | 李睿审校 | 孙淑娟​近年来, Transformer 机器学习模型已经成为深度学习和深度神经网络技术进步的主要亮点之一。它主要用于自然语言处理中的高级应用。谷歌正在使用它来增强其搜索引擎结果。OpenAI 使用 Transformer 创建了著名的 GPT-2和 GPT-3模型。自从2017年首次亮相以来,Transformer 架构不断发展并扩展到多种不同的变体,从语言任务扩展到其他领域。它们已被用于时间序列预测。它们是 DeepMind 的蛋白质结构预测模型 AlphaFold

五年后AI所需算力超100万倍!十二家机构联合发表88页长文:「智能计算」是解药五年后AI所需算力超100万倍!十二家机构联合发表88页长文:「智能计算」是解药Apr 09, 2023 pm 07:01 PM

人工智能就是一个「拼财力」的行业,如果没有高性能计算设备,别说开发基础模型,就连微调模型都做不到。但如果只靠拼硬件,单靠当前计算性能的发展速度,迟早有一天无法满足日益膨胀的需求,所以还需要配套的软件来协调统筹计算能力,这时候就需要用到「智能计算」技术。最近,来自之江实验室、中国工程院、国防科技大学、浙江大学等多达十二个国内外研究机构共同发表了一篇论文,首次对智能计算领域进行了全面的调研,涵盖了理论基础、智能与计算的技术融合、重要应用、挑战和未来前景。论文链接:​https://spj.scien

AI模型告诉你,为啥巴西最可能在今年夺冠!曾精准预测前两届冠军AI模型告诉你,为啥巴西最可能在今年夺冠!曾精准预测前两届冠军Apr 09, 2023 pm 01:51 PM

说起2010年南非世界杯的最大网红,一定非「章鱼保罗」莫属!这只位于德国海洋生物中心的神奇章鱼,不仅成功预测了德国队全部七场比赛的结果,还顺利地选出了最终的总冠军西班牙队。不幸的是,保罗已经永远地离开了我们,但它的「遗产」却在人们预测足球比赛结果的尝试中持续存在。在艾伦图灵研究所(The Alan Turing Institute),随着2022年卡塔尔世界杯的持续进行,三位研究员Nick Barlow、Jack Roberts和Ryan Chan决定用一种AI算法预测今年的冠军归属。预测模型图

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
2 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. How to Fix Audio if You Can't Hear Anyone
2 weeks agoBy尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Atom editor mac version download

Atom editor mac version download

The most popular open source editor

PhpStorm Mac version

PhpStorm Mac version

The latest (2018.2.1) professional PHP integrated development tool

VSCode Windows 64-bit Download

VSCode Windows 64-bit Download

A free and powerful IDE editor launched by Microsoft