深度学习推理和训练

优化和泛化
深度学习的根本问题是优化和泛化之间的对立。
优化(optimization)是指调节模型以在 训练数据 上得到最佳性能(即机器学习中的学习)。
泛化(generalization)是指训练好的模型在 前所未见的数据 上的性能好坏。
数据集的分类
数据集可以分为:
1. 训练集:实际训练算法的数据集;用来计算梯度,并确定每次迭代中网络权值的更新;
2. 验证集:用于跟踪其学习效果的数据集;是一个指示器,用来表明训练数据点之间所形成的网络函数发生了什么,并且验证集上的误差值在整个训练过程中都将被监测;
3. 测试集:用于产生最终结果的数据集 。
为了让测试集能有效反映网络的泛化能力:
1. 测试集绝不能以任何形式用于训练网络,即使是用于同一组备选网络中挑选网络。测试集只能在所有的训练和模型选择完成后使用;
2. 测试集必须代表网络使用中涉及的所有情形。
交叉验证
这里有一堆数据,我们把他切成3个部分(当然还可以分的更多)
第一部分做测试集,二三部分做训练集,算出准确度;
第二部分做测试集,一三部分做训练集,算出准确度;
第三部分做测试集,一二部分做训练集,算出准确度;
之后算出三个准确度的平局值,作为最后的准确度。

 

bp 神经网络
BP网络(Back-Propagation Network) 是1986年被提出的,是一种按误差逆向传播算法训练的
多层前馈网络,是目前应用最广泛的神经网络模型之一,用于函数逼近、模型识别分类、数据压
缩和时间序列预测等。
BP网络又称为反向传播神经网络,它是一种有监督的学习算法,具有很强的自适应、自学习、非
线性映射能力,能较好地解决数据少、信息贫、不确定性问题,且不受非线性模型的限制。
一个典型的BP网络应该包括三层:输入层、隐藏层和输出层。各层之间全连接,同层之间无连接。
隐藏层可以有很多层。
1.将训练集数据输入到神经网络的输入层,经过隐藏层,最后达到输出层并输出结果,这就是前
向传播过程。
2.由于神经网络的输出结果与实际结果有误差,则计算估计值与实际值之间的误差,并将该误差
从输出层向隐藏层反向传播,直至传播到输入层;
3.在反向传播的过程中,根据误差调整各种参数的值(相连神经元的权重),使得总损失函数减
小。
4.迭代上述三个步骤(即对数据进行反复训练),直到满足停止准则。
我们利用神经网络去解决图像分割,边界探测等问题时候,我们的输入(假设为x),与期望的
输出(假设为y)之间的关系究竟是什么?也就是 y=f(x) 中, f是什么 ,我们也不清楚,但是我们
对一点很确信,那就是 f不是一个简单的线性函数 ,应该是一个抽象的复杂的关系,那么利用神
经网络就是去学习这个关系,存放在model中,利用得到的model去推测训练集之外的数据,得
到期望的结果。
训练(学习)过程:
正向传播
输入信号从输入层经过各个隐藏层向输出层传播。在输出层得到实际的响应值,若实际值与期
望值误差较大,就会转入误差反向传播阶段。
反向传播
按照梯度下降的方法从输出层经过各个隐含层并逐层不断地调整各神经元的连接权值和阈值,
反复迭代,直到网络输出的误差减少到可以接受的程度,或者进行到预先设定的学习次数。

 

 

(Epoch):使用训练集的全部数据对模型进行一次完整训练,被称为“一代训练”。
批大小(Batch size):使用训练集的一小部分样本对模型权重进行一次反向传播的参数更新,这一小部分样本被称为“一批数据”

 

迭代(Iteration):使用一个Batch数据对模型进行一次参数更新的过程,被称为“一次训练”(一次迭代)。 每一次迭代得到的结果都会被作为下一次迭代的初始值。一个迭代=一个正向通过+一个反向通过。
比如训练集有 500 个样本, batchsize = 10 ,那么训练完整个样本集: iteration=50 epoch=1
神经网络的训练过程
1.提取特征向量作为输入。
2.定义神经网络结构。包括隐藏层数,激活函数等等。
3.通过训练利用反向传播算法不断优化权重的值,使之达到最合理水平。
4.使用训练好的神经网络来预测未知数据(推理),这里训练好的网络就是指权重达到最优的情
况。
神经网络的训练过程
1、选择样本集合的一个样本(Ai,Bi),Ai为数据、Bi为标签(所属类别)
2、送入网络,计算网络的实际输出Y,(此时网络中的权重应该都是随机量)
3、计算D=Bi Y(即预测值与实际值相差多少)
4、根据误差D调整权重矩阵W
5、对每个样本重复上述过程,直到对整个样本集来说,误差不超过规定范围
更具体的:
1 参数的随机初始化
2 前向传播计算每个样本对应的输出节点激活函数值
3 计算损失函数
4 反向传播计算偏导数
5 使用梯度下降或者先进的优化方法更新权值
参数的随机初始化
对于所有的参数我们必须初始化它们的值,而且它们的初始值不能设置成一样,比如都设置成0或1。
如果设置成一样那么更新后所有参数都会相等。即所有神经元的功能都相等,造成了高度冗余。所
以我们必须随机化初始参数。
特别的,如果神经网络没有隐藏层,则可以把所有参数初始化为0。(但这也不叫深度神经网络了)
标准化( Normalization
原因:由于进行分类器或模型的建立与训练时,输入的数据范围可能比较大,同时样本中各数据可
能量纲不一致,这样的数据容易对模型训练或分类器的构建结果产生影响,因此需要对其进行标准
化处理,去除数据的单位限制,将其转化为无量纲的纯数值,便于不同单位或量级的指标能够进行
比较和加权。
其中最典型的就是数据的归一化处理,即将数据统一映射到[0,1]区间上

 

z-score标准化(零均值归一化 zero-mean normalization ):
经过处理后的数据均值为0,标准差为1(正态分布)
其中μ是样本的均值, σ是样本的标准差

 

损失函数
损失函数用于描述模型预测值与真实值的差距大小。一般有有两种常见的算法——均值平方差
(MSE)和交叉熵。
均值平方差(Mean Squared Error,MSE),也称“均方误差”:

 

交叉熵(cross entropy)也是loss算法的一种,一般用在分类问题上,表达意思为预测输入
样本属于哪一类的概率。值越小,代表预测结果越准。(y代表真实值分类(0或1),a代
表预测值):
损失函数的选取取决于输入标签数据的类型:
1. 如果输入的实数、无界的值,损失函数使用MSE。
2. 如果输入标签是位矢量(分类标志),使用交叉熵会更适合
梯度下降法
梯度 f=( x1 ​∂ f; x2 ​∂ f;…; xn ​∂ f)指函数关于变量x的导数,梯度的方向表示函数值增大的方向,梯度
的模表示函数值增大的速率。
那么只要不断将参数的值向着梯度的反方向更新一定大小,就能得到函数的最小值(全局最小值或者局部最小值)。
一般利用梯度更新参数时会将梯度乘以一个小于1的 学习速率(learning rate) ,这是因为往往梯度的模还是比较大的,直接用其更新参数会使得函数值不断波动,很难收敛到一个平衡点(这也是学习率不宜过大的原因)。

 

 

学习率
是一个重要的超参数,它控制着我们基于损失梯度调整神经网络权值的速度。
学习率越小,我们沿着损失梯度下降的速度越慢。
从长远来看,这种谨慎慢行的选择可能还不错,因为可以避免错过任何局部最优解,但它也意味
着我们要花更多时间来收敛,尤其是如果我们处于曲线的至高点。
新权值 = 当前权值 - 学习率 × 梯度

 紫色部分:正确结果与节点输出结果的差值,也就是误差;

红色部分:节点的激活函数,所有输入该节点的链路把经过其上的信号与链路权重做乘积后加总,再把加总结果进行激活函数运算;
绿色部分:链路w(jk)前端节点输出的信号值。
泛化能力分类
欠拟合:模型没有能够很好的表现数据的结构,而出现的拟合度不高的情况。模型不能在训练集上获得足够低的误差;
拟合:测试误差与训练误差差距较小;
过拟合:模型过分的拟合训练样本,但对测试样本预测准确率不高的情况,也就是说模型泛化能力很差。训练误差和测试误差之间的差距太大;
不收敛:模型不是根据训练集训练得到的。

 

过拟合
过拟合指的是给定一堆数据,这堆数据带有噪声,利用模型去拟合这堆数据,可能会把噪声数据也给拟合了。
一方面会造成模型比较复杂;
另一方面,模型的泛化性能太差了,遇到了新的数据,用所得到的过拟合的模型,正确率是很差的。

 

出现的原因:
1、建模样本选取了错误的选样方法、样本标签等,或样本数量太少,所选取的样本数据不足以代表预定的分类规则
2、样本噪音干扰过大,使得机器将部分噪音认为是特征从而扰乱了预设的分类规则
3、假设的模型无法合理存在,或者说是无法达到假设成立的条件
4、参数太多导致模型复杂度过高
5、对于神经网络模型:a)对样本数据可能存在分类决策面不唯一,随着学习的进行,,BP算法使权值可能收敛过于复杂的决策面;b)权值学习迭代次数足够多,拟合了训练数据中的噪声和训练样例中没有代表性的特征
过拟合的解决方法:
1. 减少特征:删除与目标不相关特征,如一些特征选择方法
2. Early stopping
        • 在每一个Epoch结束时,计算validation data的accuracy,当accuracy不再提高时,就停止训练。
        • 那么该做法的一个重点便是怎样才认为validation accurary不再提高了呢?并不是说validationaccuracy一降下来便认为不再提高了,因为可能经过这个Epoch后,accuracy降低了,但是随后的Epoch又让accuracy又上去了,所以不能根据一两次的连续降低就判断不再提高。
        • 一般的做法是,在训练的过程中,记录到目前为止最好的validation accuracy,当连续10次Epoch(或者更多次)没达到最佳accuracy时,则可以认为accuracy不再提高了。此时便可以停止迭代了(Early Stopping)。
        • 这种策略也称为“No-improvement-in-n”,n即Epoch的次数,可以根据实际情况取,如10、20、30
3. 更多的训练样本。
4. 重新清洗数据。
5. Dropout
 
        在神经网络中,dropout方法是通过修改神经网络本身结构来实现的:
        1. 在训练开始时,随机删除一些(可以设定为1/2,也可以为1/3,1/4等)隐藏层神经元,即
认为这些神经元不存在,同时保持输入层与输出层神经元的个数不变。
        2. 然后按照BP学习算法对ANN中的参数进行学习更新(虚线连接的单元不更新,因为认为这
些神经元被临时删除了)。这样一次迭代更新便完成了。下一次迭代中,同样随机删除一 些神经元,与上次不一样,做随机选择。这样一直进行,直至训练结束。
        Dropout方法是通过修改ANN中隐藏层的神经元个数来防止ANN的过拟合。
为什么Dropout能够减少过拟合:
        1. Dropout是随机选择忽略隐层节点,在每个批次的训练过程,由于每次随机忽略的隐层节点都不同,这样就使每次训练的网络都是不一样的, 每次训练都可以当做一个“新”模型;
        2. 隐含节点都是以一定概率随机出现,因此不能保证每2个隐含节点每次都同时出现。
这样权值的更新不再依赖有固定关系隐含节点的共同作用,阻止了某些特征仅仅在其他特定特征下才有效果的情况。
        总结:Dropout是一个非常有效的神经网络模型平均方法,通过训练大量的不同的网络,来平均预测概率。不同的模型在不同的训练集上训练(每个epoch的训练数据都是随机选择),最后在每个模型用相同的权重来“融合”
经过交叉验证,隐藏节点dropout率等于0.5的时候效果最好。
dropout也可以被用作一种添加噪声的方法,直接对input进行操作。输入层设为更接近1的数。使
得输入变化不会太大(0.8)
dropout的缺点就在于训练时间是没有dropout网络的2-3倍。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/44020.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

2023JAVA 架构师面试 130 题含答案:JVM+spring+ 分布式 + 并发编程》...

此文包含 Java 面试的各个方面,史上最全,苦心整理最全 Java 面试题目整理包括基JVM算法数据库优化算法数据结构分布式并发编程缓存等,使用层面广,知识量大,涉及你的知识盲点。要想在面试者中出类拔萃就要比人付出更多的…

nginx怎么做负载均衡

Nginx怎么做负载均衡 Nginx 是一个高性能的开源反向代理服务器,可以用于实现负载均衡。负载均衡指的是将用户请求平均分配给多个服务器,以提高整体系统性能和可靠性。下面是一个详细介绍如何使用 Nginx 实现负载均衡的步骤: 步骤 1&#xf…

【Nodejs】Node.js简介

1.前言 Node 的重要性已经不言而喻,很多互联网公司都已经有大量的高性能系统运行在 Node 之上。Node 凭借其单线程、异步等举措实现了极高的性能基准。此外,目前最为流行的 Web 开发模式是前后端分离的形式,即前端开发者与后端开发者在自己喜…

提升Web3安全性和用户体验:元事务和加密技术的应用

在Web3中,去中心化应用程序(DApps)是一种基于区块链技术的应用程序,它们通过智能合约实现透明、安全、去中心化的业务逻辑。然而,DApps的使用门槛比传统的中心化应用程序更高,需要用户具备一定的技术知识&a…

工厂能耗管理系统解决方案

1、概述 随着碳达峰、碳中和成为政府工作主要任务,工厂作为能耗密集,用能情况较为复杂的大型建筑,有效的降低能源消耗,减少能源成本,避免用能过程中的“跑冒滴漏”现象,实施能效综合考评是个非常必要的管理…

C语言学习笔记 VScode设置C环境-06

目录 一、下载vscode软件 二、安装minGW软件 三、VS Code安装C/C插件 3.1 搜索并安装C/C插件 3.2 配置C/C环境 总结 一、下载vscode软件 在官网上下载最新的版本 Download Visual Studio Code - Mac, Linux, Windowshttps://code.visualstudio.com/download 二、安装minGW…

添加USB转串口设备驱动-迅为i.MX8M开发板

对于通过 USB 接口访问的模块,在 Linux 内核中集成 USB 驱动程序。我们需要配置内核选中支持 GSM 和 CDMA 模块的 USB 转串口驱动 > Device Drivers -> USB support (USB_SUPPORT [y]) -> USB Serial Converter support (USB_SERIAL [y]) -> USB driver…

2023 年第二届钉钉杯大学生大数据挑战赛初赛 初赛 A:智能手机用户监测数据分析 问题二分类与回归问题Python代码分析

2023 年第二届钉钉杯大学生大数据挑战赛初赛 初赛 A:智能手机用户监测数据分析 问题二分类与回归问题Python代码分析 相关链接 【2023 年第二届钉钉杯大学生大数据挑战赛初赛】 初赛 A:智能手机用户监测数据分析 问题一Python代码分析 【2023 年第二届…

day42-servlet下拉查询/单例模式

0目录 1.Servlet实现下拉查询(两表) 2.单例模式 1.实战 1.1 创建工程,准备环境... 1.2 接口 1.3 重写方法 1.4 servlet 1.5 list.jsp list.jsp详解 2.单例模式 2.1 饿汉模式:在程序加载时直接创建对象&#…

基于SpringBoot+Vue的摄影跟拍预定管理系统设计与实现(源码+lw+部署文档等)

博主介绍: 大家好,我是一名在Java圈混迹十余年的程序员,精通Java编程语言,同时也熟练掌握微信小程序、Python和Android等技术,能够为大家提供全方位的技术支持和交流。 我擅长在JavaWeb、SSH、SSM、SpringBoot等框架…

fastadmin 项目gitee管理

gitee创建一个仓库使用sourcetree等工具拉取代码使用phpstorm远程同步代码到本地设置忽略代码文件 注意:如果是直接把远程代码同步到本地,默认是你在 .gitignore中设置是无效的,代码一样会提交,需要先使用上面的截图去掉缓存&…

jmeter随记3:常用jmeter功能(附带场景)

常用jmeter功能(附带场景) 一、jmeter其他特性1、请求的接口有多个 且 域名相同2、 jmeter支持统一管理参数的设置a、创建HTTP Header Managerb、用户定义参数c、csv数据文件设置 3、接口a的返回值作为 接口b的入参a、 json提取器b、 正则表达式 4、if c…

小程序中vant-weapp时间选择使用方法

一、选择单个时间点&#xff1a; wxml&#xff1a; <van-celltitle"选择预约时间"value"{{ time }}"bind:click"onDisplay"/><van-calendarshow"{{ show }}"bind:close"onClose"bind:confirm"onConfirm"…

嵌入式Linux驱动开发——常见框架梳理

前言 本文主要介绍了Linux驱动开发中一些常用的驱动框架&#xff0c;platform、input、iic、spi等&#xff0c;硬件平台使用的是正点原子的imx6ull开发板。 一&#xff1a;Pinctrl子系统、Gpio子系统 不管什么框架最后都是要追溯到配置IO的电气属性和复用功能 如果要使用外部…

seatunnel hive source 未设置分隔符导致多个字段合并成一个的问题定位解决

seatunnel hive source 未设置分隔符导致多个字段没有切分全保存在一个字段中了,翻看源码发现分隔符是是通过delimiter设置的,只要设置这个delimiter","就可以了。 设置这个属性 delimiter“,” 他的默认值是\u0001,如果没有设置delimiter属性则会根据文件类型判断…

如何用3D格式转换工具HOOPS Exchange读取颜色和材料信息?

作为应用程序开发人员&#xff0c;非常希望导入部件的图形表示与它们在创作软件中的外观尽可能接近。外观可以在每个B-Rep面的基础上指定&#xff0c;而且&#xff0c;通过装配层次结构的特定路径可以在视觉外观上赋予父/子覆盖。HOOPS ExchangeHOOPS Exchange可捕获有关来自各…

介电陶瓷类材料介电测试

介电陶瓷类材料介电测试 介电陶瓷类材料介电测试 介电陶瓷又称电介质陶瓷。在电场作用下具有极化能力&#xff0c;且能在体内长期建立起电场的功能陶瓷&#xff0c;能承受较强的电场而不被击穿。它具有较高的介电常数、较低的介质损耗和适当的介电常数温度系数。用于各类电容…

办公室安全升级,如何保障人身财产安全?

视频监控&#xff0c;一种常见的安全措施&#xff0c;以监视和记录办公室内的活动。这项技术为企业提供了许多优势&#xff0c;包括保障员工和财产安全、帮助调查犯罪事件、提高业务管理效率以及应对突发事件。 因此&#xff0c;在合理范围内应用视频监控&#xff0c;将为企业提…

Pytorch从入门到精通:二、dataset与datalodar

数据是深度学习的基础&#xff0c;一般来说&#xff0c;数据量越大&#xff0c;训练出来的模型也越强大。如果现在有了一些数据&#xff0c;该怎么把这些数据加到模型中呢&#xff1f;Pytorch中提供了dataset和dataloader&#xff0c;让我们一起来学习一下吧&#xff0c;datase…

物通博联5G+工业互联网解决方案助力打造5G智能工厂

面对来自成本和市场等压力挑战&#xff0c;工业企业正通过数字化升级提升效益降低成本&#xff0c;拓展发展空间。 随着科技的不断发展&#xff0c;5G技术已经成为了全球关注的焦点。5G技术的高速度、低延迟和大连接特性为各行各业带来了巨大的变革机遇。工业和信息化部有关负…