ChatGPT进化的过程简介

Chat GPT可以做什么?

  • 分点列条的回答问题

  • 写代码或SQL

  • 翻译

  • 语法检查

ChatGPT官方还未公开论文,ChatGPT有一个“孪生兄弟”InstructGPT,InstructGPT有论文,可以根据InstructGPT论文推导ChatGPT的训练过程:

  • ChatGPT的训练过程

  • InstructGPT的训练过程

可以看到两者差距非常小,区别是两者使用的GPT版本不同。

所以看了InstructGPT论文应该就可以知道ChatGPT大致怎么被训练出来的了。

ChatGPT学习的四阶段

1 学习文字接龙

扫描二维码关注公众号,回复: 15333387 查看本文章

给GPT一个不完整的句子,GPT会想办法猜出这个句子接下来应该接哪字才是正确的。

怎么教一个模型做文字接龙?

文字接龙的学习是不需要人工标注的。

GPT要做的事情就是在网络上收集大量的文字,让GPT学文字接龙。

比如从网络上看到“跟人类对话”这句话,让GPT知道了“跟”后面跟“人”,“跟人”后面跟“类”,“跟人类”后面跟“对”。

“你好”这个不完整的句子后面可能接的词汇有很多,

GPT在学习做文字接龙的过程中,GPT真正输出的是一个几率分布。

比如输入“你好” ,后面跟“美”的几率,跟“高”的几率,跟“吗“的几率分别是多少。

接下来再从几率分布里随机抽取一个文字出来,几率比较高的字比较容易被抽取出来,几率比较低的字不太容易被抽取出来。

GPT的输出每一次都是不一样的。

让GPT补充一个不完整的句子,它每次补的结果都是随机性的。

每次补出来的结果都是不一样的,那学习文字接龙有什么用?

告诉GPT这是一个不完整的句子,接下来GPT想接哪个字呢?

第一个问题回答是“玉”,再将“玉”追加到第一个问题上作为新的问题再问GPT,回答“山”。

GPT的输出是随机的,GPT每次只会产生一个字。

把所有产生的结果一次输出来,这样就形成一道选择题。

但实际产生的时候,还是一个字一个字产生的。

或者回答“谁来告诉我答案呀”,因为你并没有让它回答问题,所以可能会有这个答案。

GPT看到网络上有谁说过什么句子,它都可以拿来接,所以GPT在实际的使用上并没有那么好用,那怎么引导GPT产生有用的输出?

这就进入下一个阶段,

2 由人类老师引导文字接龙的方向

需要找人类来思考想问GPT的问题,提出问题之后,还需要人工把答案标记出来,有了这些资料以后,再丢给GPT做进一步的学习。

之前GPT在网络上看到一些有用的或没用的内容,GPT它不能分辨, 反正就是照单全收。

现在由人类提供想问GPT的问题并由人类提供标准的答案。

就让GPT多读一些我们觉着有意义的语料,真正帮人类做事的有用的内容,期待它可以变成人类真正的帮手。

那我们会不会穷举所有人类可能会问到的问题呢?答案是不用的。

虽然今天ChatGPT的论文还没有出,但是看instruct GPT你会发现并没有使用非常多人为标注的问题和答案,只有数万字而已。

那为什么不需要标注非常多的问题跟答案呢

因为这些答案本来GPT是就有能力产生的,只是它不知道哪些答案是人类希望它产生的。

GPT在网络上看到各式各样的内容,所以可能会产生各式各样奇怪的答案。

人类要做的事情只是激发它本来就有的力量,叫它讲出我们希望它讲的话,所以在第二阶段,可能每种类型的问题,提供几个范例可能就足够了。

3 模仿人类老师的喜好

openai线上公开GPT api,就会有很多人使用这个api,就会有很多人不断的去问,接下来把这些问题收集好,让GPT产生这些问题的答案,因为GPT的答案是有随机性的,所以同一个问题会产生不同的答案。

接下来就由人类去标注哪些答案是好的答案,哪些答案是差的答案,人类老师并不一定要提供完整的正确答案,只需要告诉机器说哪个答案是比较好的,哪个答案是比较差的。

有了这个信息以后,接下来就要训练一个模仿老师的模型Teacher model,

这个模型的作用是给GPT的问题和GPT输出的答案输出一个分数,这个模型学习的目标就是模仿人类老师评分的标准,如果人类的标注告诉GPT,“玉山”这个答案好于“谁来告诉我”这个答案,那Teacher model模型就可以模仿人类的偏好。

4 用增强式学习向模拟老师学习

用增强式学习(Reinforcement Learning)让GPT向模拟老师学习,

比如问这个问题,回答这个答案。

这虽然是一个正确的接法,但不是人类想要的。

那现在GPT有了一个老师的模型,那就把输入的问题和答案一起丢给老师模型,这个老师模型就会学了人类的偏好。

GPT在前面的学习中知道,如果答案是一个问句,则不是一个好的答案,应该要给予低分。

那Teacher model模型输出的就是增强式学习(Reinforcement Learning)的reward。

接下来用增强式学习的技术来调整GPT参数,调整的目标就是希望得到最高的reward,即希望GPT的输出结果会让Teacher model给予高分,也就是人类会觉的满意的答案。

透过Reinforcement Learning技术让GPT可能会学到:问“世界上最高的山是哪座?“,不会再随便接一个问句,而是输出“喜马拉雅山”。

即把问题和答案都丢给Teacher model模型,这个模型会评估出一个分数比较高的答案。

GPT经过增强式学习(Reinforcement Learning)之后,就是Chat GPT了。

猜你喜欢

转载自blog.csdn.net/qq_16485855/article/details/130375867