ChatGPT From Zero To Hero - LLM学习笔记(一)

如何训练一个chatGPT from zero to hero,主要来源是Karpathy 大神的视频

一、预训练 (Pretraining)

Unsupervised Training --- 让模型"学会说话"

Step 1: Download and preprocessing the internet 下载并清洗互联网数据
  • 从开放语料抓取:Common Crawl、Wikipedia、Books、GitHub、StackExchange、ArXiv
  • 去重、过滤低质量和有害内容
  • 保证语料领域、语言分布均衡

现代大模型的预训练通常使用 10~15 万亿 tokens 的数据,覆盖多领域文本。


Step 2: Tokenization

Transform the raw data into unique IDs sequences

把原始文本转成唯一的 token ID 序列

  • 编码算法 / Algorithm :Byte Pair Encoding (BPE)
    高频连续出现的 bytes 对重新组合成 token
  • 示例 / Example
    playingplay + ing
  • 工具 / Tool在线分词工具

模型看到的是 token 而不是字母,因此它对拼写和数字敏感度低,容易数错。


Step 3: Neural network training
  1. Give you an intuition of the process of training

    Take a window of tokens → predict the next token

    取一个 token 窗口,让模型预测下一个 token

  2. Model structure

    Transformer Decoder 堆叠,包含多层自注意力和前馈网络

    可视化参考:LLM Visualization

  3. 训练目标 / Objective

    最小化交叉熵损失 (Cross-Entropy Loss),优化下一个 token 的概率分布


Demo: Reproducing OpenAI's GPT-2

推荐入门用 nanoGPT 复现小型 GPT-2 模型,几百行代码即可跑通。


二、后训练 (Post-training)

Supervised Training --- 让模型"学会对话"

  1. Make some conversations
    收集高质量对话语料,让模型学会对话风格

  2. Encoding conversations
    用特殊 token 表示角色切换:

    <|im_start|>user
    What is 2+2?
    <|im_end|>
    <|im_start|>assistant
    4
    <|im_end|>


Hallucinations 幻觉问题

  1. What is & Why it is?
    Hallucination = 模型编造不存在的事实,只因它按概率预测最可能的下一个词
  2. How to solve it?
  • Allow the model to say "I don't know"

  • 设计事实一致性训练:给模型真假陈述,强制学会拒绝编造

  • 更好的方案:让模型调用工具,如搜索、数据库,得到事实后再回答

    <Search_START>who is Orson Kovacs?<Search_END>

→ 将搜索结果插入上下文,让模型更新回答


RLHF (Reinforcement Learning with Human Feedback)

通过人类反馈或奖励模型对回答排序,用 PPO/DPO 调整参数,让模型更符合人类偏好

目标:有用 Helpful + 无害 Harmless + 诚实 Truthful


三、SFT(Supervised Fine-tuning)

Problems Practice --- 让模型"刷题

  • 收集特定任务的数据集:数学题、逻辑推理、代码挑战
  • 从简单到复杂,逐步训练(Curriculum Learning)
  • 可结合 Chain-of-Thought 提示,提升推理稳定性
    效果:显著提升模型在数学、推理、专业考试上的表现

四 Demo 资源推荐

  • 复现 GPT-2Andrej Karpathy 的 nanoGPT
    小规模 GPT 预训练示例,几百行代码就能跑通
  • RLHF 实践trl (HuggingFace)
    提供 PPO/DPO 的实现,能直接用来做偏好优化
  • 开源大模型 : Llama 3 / Qwen
    可在已有权重上做 SFT 或 RLHF,成本更低

References:
1. Karpathy 大神讲解

相关推荐
我想我不够好。5 分钟前
2026.5.20 消防监控学习 1.5hour
学习
穗余20 分钟前
2026 AI x Web3 School共学营笔记-Day1
人工智能·笔记·web3
sheeta199821 分钟前
LeetCode 每日一题笔记 日期:2026.05.20 题目:2657. 找到前缀公共数组
笔记·算法·leetcode
爱喝水的鱼丶31 分钟前
SAP-ABAP:数据类型与数据对象(8篇) 第七篇:进阶优化篇——基于类型与对象特征的性能优化技巧
运维·数据库·学习·性能优化·sap·abap·开发交流
ABAP 成38 分钟前
删除+新增原始BOM工序+订单BOM+工序笔记
笔记
Lyon1985052841 分钟前
ChatGPT的最终总结分析-《文字定律》随笔
人工智能·ai·chatgpt
知识分享小能手42 分钟前
Flask入门学习教程,从入门到精通, 认识Flask路由 — 知识点详解 (2)
python·学习·flask
XS03010644 分钟前
MyBatis基础实战笔记一
笔记·mybatis
清平乐的技术专栏1 小时前
【Flink学习】(六)Flink 三大时间语义 + 水位线 Watermark
大数据·学习·flink
Oll Correct1 小时前
实验二十五:从IPv4向IPv6过渡所使用的隧道技术
网络·笔记