news 2026/5/1 0:36:08

对比多线程与batch(在极简单cnn上操作)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
对比多线程与batch(在极简单cnn上操作)

batch,从学习dos时,就认识了这个单词,它叫做批处理!

现在我发现他与并行或多线程是有差别的!

我们前头所有程序凡是用到batch,均是如下操作,比如batch=3:

输入一张图片,forward一次,backward一次

再输入一张图片,forward一次,backward一次,梯度累加第一次

再输入一张图片,forward一次,backward一次,梯度累加第二次

好batch=3了,我们更新一次每层的权值:

在我们极简cnn上体现如下:

for(batch=0;batch<3;batch++)

{

wcnn的偏差[1][0] += E偏导zII * aI[0];//梯度累加3次
wcnn的偏差[1][1] += E偏导zII * aI[1];
wcnn的偏差[1][2] += E偏导zII * aI[2];
wcnn的偏差[1][3]+=E偏导zII * aI[3];

}
————————————————

for(batch=0;batch<3;batch++)

{//梯度累加3次

wcnn的偏差[0][0] += delta11*a0[0] + delta12*a0[1] + delta21*a0[3] + delta22*a0[4];//0,1,3,4
wcnn的偏差[0][1] += delta11*a0[1] + delta12*a0[2] + delta21*a0[4] + delta22*a0[5];//1,2,4,5
wcnn的偏差[0][2] += delta11*a0[3] + delta12*a0[4] + delta21*a0[6] + delta22*a0[7];//3,4,6,7
wcnn的偏差[0][3]+=delta11*a0[4] + delta12*a0[5] + delta21*a0[7] + delta22*a0[8];//4,5,7,8

}

————————————————

//0,上面batch执行了三次,但更新只执行一次

//w1,第二层的一个卷积核
for (int i = 0; i < 4; i++)//卷积核执行更新一次
{
wcnn[1][i] = wcnn[1][i] - 常数a * wcnn的偏差[1][i]/3;
}

//w0,第一层的一个卷积核
for (int i = 0; i < 4; i++)//卷积核执行更新一次
{
wcnn[0][i] = wcnn[0][i] - 常数a * wcnn的偏差[0][i]/3;
}

以上就是我们的批梯度下降法,而多线程怎么做呢?

假定我们也开启三个线程,每个线程处理一幅图片,关键是这个线程动作是并发的!

如果说上面batch处理是一个人,轮流做了3次

而线程是3个人,每个人做一次!这就是多线程并发的好处,人多力量大,速度还快!

每个线程只做一次:

wcnn的偏差[1][0] += E偏导zII * aI[0];//梯度累加3次
wcnn的偏差[1][1] += E偏导zII * aI[1];
wcnn的偏差[1][2] += E偏导zII * aI[2];
wcnn的偏差[1][3]+=E偏导zII * aI[3];

以及:

wcnn的偏差[0][0] += delta11*a0[0] + delta12*a0[1] + delta21*a0[3] + delta22*a0[4];//0,1,3,4
wcnn的偏差[0][1] += delta11*a0[1] + delta12*a0[2] + delta21*a0[4] + delta22*a0[5];//1,2,4,5
wcnn的偏差[0][2] += delta11*a0[3] + delta12*a0[4] + delta21*a0[6] + delta22*a0[7];//3,4,6,7
wcnn的偏差[0][3]+=delta11*a0[4] + delta12*a0[5] + delta21*a0[7] + delta22*a0[8];//4,5,7,8

最后我们要判断线程结束了

比如说:if(线程1执行完成&&线程2执行完成&&线程3执行完成==1),再执行:

for (int i = 0; i < 4; i++)//卷积核执行更新一次
{
wcnn[1][i] = wcnn[1][i] - 常数a * wcnn的偏差[1][i]/3;
}

//w0,第一层的一个卷积核
for (int i = 0; i < 4; i++)//卷积核执行更新一次
{
wcnn[0][i] = wcnn[0][i] - 常数a * wcnn的偏差[0][i]/3;
}

这样看来,多线程会比批处理batch快很多!比如开启10个线程时,差别会更大!

以后,我的程序会超这个方向改进!

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 9:53:08

孩子学编程到底有没有用?这篇文章告诉你!

最近好多家长都在问&#xff1a;现在满大街都在说少儿编程&#xff0c;是不是真的值得学习&#xff1f;我家孩子天天这就知道玩游戏&#xff0c;学这个真的有用吗&#xff1f;说实话&#xff0c;我们能理解大家的焦虑。咱们小时候学的是奥数、英语&#xff0c;现在的孩子起跑线…

作者头像 李华
网站建设 2026/4/30 12:31:45

保姆级教程:用Dify搭建企业级本地知识库,解决数据安全等痛点

本文详细介绍了如何使用Dify搭建企业级本地知识库&#xff0c;解决了远程调用方案的痛点。文章从知识库概念、私有化部署必要性入手&#xff0c;提供了完整的环境准备、文档上传、分段清洗、索引设置等实操步骤&#xff0c;并解答了数据安全、PDF解析、文件格式限制等常见问题。…

作者头像 李华
网站建设 2026/4/28 4:01:06

当学术开题撞上AI革命:Paperzz如何用“智能骨架”重构你的研究起点——一份不靠堆砌术语、只讲真实效率的深度体验报告

Paperzz-AI官网免费论文查重复率AIGC检测/开题报告/文献综述/论文初稿 paperzz - 开题报告https://www.paperzz.cc/proposal 一、开题报告&#xff0c;为什么总让人如临大敌&#xff1f; 你有没有过这样的经历&#xff1f; 深夜两点&#xff0c;电脑屏幕幽幽发亮&#xff0c…

作者头像 李华
网站建设 2026/4/22 22:29:27

组件开发躲不过的隔离,Shadow Dom 了解下吧!

HTML Shadow DOM 深度解析&#xff1a;封装与隔离的艺术 使用过前端微服务框架或者写过React、Vue组件的同学&#xff0c;知道什么是 Shadow Dom 吗&#xff1f;前端微服务架构、开发组件一个要处理的问题就是子服务之间、组件之间需要 隔离&#xff1b; 样式隔离、javascript…

作者头像 李华
网站建设 2026/4/28 16:49:55

Excel突然蹦出八国语言?别慌,三分钟让表格说回人话!

凌晨一点&#xff0c;领导甩过来一份“欧洲区销售汇总.xlsx”&#xff0c;五万张单元格里夹杂着德语、法语、西班牙语&#xff0c;我瞬间清醒——这要是手工复制粘贴到网页翻译&#xff0c;得干到明年。好在前辈早就教会我几个“Excel翻译”骚操作&#xff0c;我不仅在天亮前交…

作者头像 李华