服务展示

服务展示
<<返回上一页

从做菜的角度来更形象的理解什么是大模型的参数 以及为什么要训练 训练原理与过程

发布时间:2024-11-15 00:47:22点击:

在前面的​ ​大模型参数的文章​ ​中讲了什么是大模型的参数,以及大模型为什么要训练;

不过那个讲的比较抽象,这里就用一个更形象的例子来解释一下大模型的参数到底是什么,以及训练的原理。

01、大模型和厨师

从我们使用者的角度来说,大模型就是一个黑盒,它需要输入,然后给出一个输出。

如下图就是大模型的黑盒模型:

而从我们使用上来看,基本上就是一个聊天框,然后我们输入文字/图片/视频等,然后大模型给我们一个输出。

而这种模式和我们去饭店吃饭一样,我们到饭店之后点菜,然后厨师就会把我们的菜做好,而厨房对我们来说也是一个黑盒。

大模型那么多参数是干什么的呢?厨师又是怎么做菜的呢?

如果把没有训练过的大模型比作一个新东方烹饪学校的学生;那么刚开始这个学生并不会做菜,如果你让他做菜,那么他只能根据自己的感觉乱七八糟的一通操作。

这个就是初始化的大模型,它虽然可以输出结果,但它输出的结果乱七八糟。

所以学生需要去学习怎么做菜;不论会不会做饭的人应该都知道,炒菜需要控制火候与调料,不同的菜需要不同的火候和调料。

火候有大火小火中火,调料有必须的葱姜蒜,还有盐,辣椒,鸡精,麻辣虾,油等等。

做菜的时候,不同的菜需要不同的搭配,而且需要不同的火候和调料;比如,西红柿炒蛋需要有西红柿和鸡蛋,然后调料需要有盐,也可以放葱姜蒜;

而如果做辣椒炒肉,那么就需要有肉和辣椒,然后口味重的人就可以多放一点辣椒和盐,口味清淡的人就可以少放一点。

对比到大模型也是如此,厨师做菜的材料,调料与火候是厨师的参数;而大模型也有自己的参数,比如权重,偏置,卷机网络的卷积核,嵌入矩阵,损失函数参数,激活值,参数梯度,训练轮次等。

从技术等角度来说,大模型的参数就是大模型的一些变量,之所以是变量是因为这些参数的值并不是固定的,而是可以变化的;

就像做菜一样,盐可以多放一点,也可以少放一点;并不是每次必须放多少盐。

02、做菜与大模型的训练

专业的厨师学习做菜时,会测试不同的菜品放不同含量的调料会有什么样的效果,比如放一克盐和放十克盐,放葱姜蒜和不放葱姜蒜在口味上的区别。

然后经过很多次的测试之后,厨师就知道做什么菜需要放多少盐,放多少辣椒,然后口味会是什么样。

而大模型的训练也是如此,大模型是基于神经网络的架构而开发的;而一个大模型有很多神经网络层,每一层又有很多的神经元节点;

那么,不同的神经元节点的权重和偏置,会对其它神经元以及神经层会产生什么样的影响及效果?

不同神经网络的架构的参数又会有什么样的影响?比如卷积神经网络的卷积层的个数,多一层和少一层的区别?如果是循环神经网络呢?

而这些问题都是需要经过大量的数据训练,然后给大模型找到一个最优的参数值。

而具体怎么训练呢?

比如第一次训练,所有神经元的权重都是1,然后生成了一个结果;这就类似于第一次做菜,所有的调料都放1克,然后做出之后尝尝好不好吃。

而因为神经网络是有层的,这样数据在一层一层神经网络之间的传递就叫做正向传播。

当用1克调料把“菜”做出来之后,尝了一下发现盐放少了;这时第二次做菜的时候,就可以把盐多放一点,比如放四克或五克。

而大模型毕竟不是人,所以需要有一个方法来测试它做的“菜”是否合格,而这个东西就是损失差,损失差越大,说明输出效果越差,“菜”做的越差。

而具体的损失差怎么计算,不同的大模型和架构有不同的方法,比如交叉熵损失。

而这时,就需要告诉大模型做的“菜”不好吃,这个告诉的过程就叫做反向传播。

厨师知道菜做的不好吃的时候,就可以直接调整下次放调料的数量和种类;而大模型也有这种类似的功能,这个功能就是优化器,优化器的功能就是去调整大模型的参数,下次把“盐”放多一点,“辣椒”放少一点。

最小二乘法损失函数

而这个盐和辣椒就是大模型中的权重,偏置,损失函数参数等参数。

而训练次数就是厨师锻炼做菜的次数,可能是十次,也可能是一百次,一千次。

所以说,厨师训练是不断的调整其调料的数量和含量;大模型的训练本质上也是在不断的去调整它的参数。

等厨师全部学会之后,还会找一个专业的老师去评价他做的菜;而在大模型里面,这个就是大模型的评估函数,去测试其效果。

当然,大模型并不是参数和训练次数越多越好,最重要的是合适。

这就是大模型的参数以及训练的过程及原理。

原文链接:​ ​​ ​

免责声明:凡未注明来自本站的稿件和图片作品,系转载自其它网站,及网友投稿,转载目的在于信息传递,并不代表本站赞同其观点和对其真实性负责,如若涉及侵权违规可向站长举报 。