关于机器学习/深度学习的一些事-答知乎问(二)

进化算法与深度强化学习算法结合如何进行改进?

(1)进化算法普遍存在着样本效率低下的问题,虽然其探索度较高,但其本质为全局随机性搜索,需要在整个回合结束后才能更新其种群,而深度强化学习在每个回合步中都会得到大量的信息并使用这些信息进行梯度更新,因此进化算法相较于深度强化学习来说样本效率较低.针对进化算法样本效率的问题,可以使用深度强化学习中的梯度和回合步中的其它信息对其进行指导,指引进化算法种群在解空间中的位置与下一代进化的方向。

(2)进化算法与深度强化学习的兼容性较差,目前进化算法与深度强化学习的组合与耦合方式较为单一,可以从探索和利用的角度进一步的分析和探究两者的其它结合方式。平衡强化学习中的探索和利用一直是强化学习领域中的一个重要问题,在与进化算法结合的深度强化学习中也需要对两者进行更为合理的平衡,如引人新颖度与探索度等一些度量方式在进化算法的探索和深度强化学习的利用中自动调节也是未来的方向之一。

(3)目前结合进化算法与深度强化学习的方法中均与最新的同类方法进行了比较,但很少有进行消融实验并进行进一步分析其算法获得提升的工作。进化算法本身为一种启发式算法,其理论基础较为薄弱,且与深度强化学习一样均不能保证其收敛性,因此需要加强对算法性能提升的分析与实验,从而为进一步的研究打下基础。

如何解决神经网络灾难性遗忘的问题?

1)探索生物怎样避免灾难性遗忘的机制,并根据该机制设计相似的神经网络模型。

2) 探索神经网络模型存储信息的新机制,如果神经网络模型在学习新知识后仍能保持对之前学习的知识不遗忘,必然需要存储一些关于之前学习的知识的一些信息,怎样高效地存储和利用这些信息值得研究。

3) 选取具有代表性的样本也是一种方法。该方法不仅存在于生物的认知中,也广泛存在于社会生活中。如社会生活中的选举,某一社会团体通常推选出该团体中的某几位成员而不是全体成员代表该社会团体,这也从另一个角度说明,部分样本往往可以近似代表总体样本。对比到神经网络模型中,选取某一任务中具有代表性的样本,而不是使用所有样本代表该任务; 该方法需要确定推选机制,即怎样确定样本集中的某些样本具有代表该样本集的能力。一个显而易见的事实是,神经网络模型是对生物神经网络的模仿,而现在神经网络模型出现灾难性遗忘的问题,说明对生物的神经网络研究的并不彻底,还有很多盲点。思路1) 进一步研究生物的避免研究灾难性遗忘的机制,应该是研究的重点和趋势。

随机梯度下降算法如何进一步改进?

1) 与二阶算法相比, 随机梯度下降算法的收敛速度相对较慢, 且需要更多的迭代次数。第2代和第3代改进算法虽然有效地提升了收敛速度, 但耗费了较大的时间成本和内存成本。随着数据规模的扩大和模型复杂度的提升, 单线程下的随机梯度下降算法已经不能满足大规模机器学习应用的需求。并行式随机梯度下降算法SimuParallelSGD适合于大规模学习范式和MapReduce 框架;Hogwild 算法对稀疏数据采用无锁异步更新策略, 从而有效地减少了特征更新时的冲突。目前, 研究者们已经实现了SVRG、SAGA 和MiG等改进算法的分布式和并行化版本, 但收敛速度却有待进一步提升。如何根据算法特点、数据对象和应用平台,设计并实现不同改进策略下的随机梯度下降算法的分布式与并行化版本, 使其在实际应用中发挥出较高的性能水平, 这是未来值得探索的问题。

2)随机梯度下降算法在每轮迭代过程中计算复杂度较低, 但只利用了一阶梯度, 忽略了目标函数的二阶信息及曲率, 从而限制了实际性能和收敛速度。如何结合一阶与二阶方法各自的长处,进一步设计迭代效率俱佳的随机梯度下降算法,是未来值得研究的问题。

3) 近年来, 研究者们将目光投向非凸的ERM模型, 并且提出了一些行之有效的解决方案, 其中具有代表性的策略包括添加动量跳出局部最优解、使用方差缩技术减少梯度方差和添加梯度噪声逃离鞍点等。然而, 对于更为一般的非凸、非光滑的优化问题却并未取得太大的突破, 目前仅有Prox-SAGA、Prox-SVRG+等算法, 但性能并不理想。随机梯度下降算法在非凸、非光滑条件下的策略研究, 不仅是当前面临的困局, 也是未来最具有应用价值的研究方向。

4) 对于非凸的优化问题, 梯度下降法通常存在两个缺陷: 易于陷入局部最优、无法逃离鞍点。而演化计算/智能计算无需计算梯度和确定步长, 且往往具有较好的全局收敛性。如何将随机梯度下降算法与演化计算/智能计算方法相结合, 将是一个非常值得关注的研究方向。

可解释人工智能方法的细粒度划分?

独立于模型的解释方法:特征相关解释,特征相关解释,代理模型解释等

特征相关解释包括:部分依赖图、个体条件期望、累计局部效应、特征交互、置换特征重要性、Shapley Values

基于样本的解释:对抗样本、原型、有影响力的样本

代理模型解释:全局代理模型、LIME及其变种

依赖于模型的解释方法:自解释模型和特定模型的解释等

自解释模型:线性回归、逻辑回归、决策树、朴素贝叶斯、RuleFIt

特定模型的解释:DeepLIFT、LRP、激活最大化、基于梯度的方法、类激活映射

因果解释方法:反事实解释

如何做可解释人工智能方法的定性评估?

定性评估方法依靠人的视觉感观来评价解释结果是否符合人的认知,该方法简单清晰,易于理解,对用户来说是更友好的。对于XAI方法的定性评估,主要从解释的基本单位和可视化效果两个方面进行评估。

解释的基本单位指解释是由什么组成的,可以是特征重要性值、训练集的实例,规则列表和像素等。 因此对于解释的基本单位我们想要知道其构成形式与数量。如果解释是由特征组成的,那么它是包含所有特征还是仅包含少数特征。如果提供的是反事实解释, 那么提供的解释与决策结果之间是否具有因果关系以及反事实结果对用户来说是否可行。

目前对于深度神经网络,更多采用可视化的方式进行解释,即构建显著性图来突出显示最相关的信息, 从而提供可解释性。因此对于可解释性的定性评估方法,主要从可视化效果方面考虑,包括两方面的问题: 一方面是观察目标区域的集中度和覆盖面,显著性图需要重点关注感兴趣的目标区域,而忽略其它不相关区域。显著性图中突出的区域对感兴趣目标的覆盖越全面,表明可视化效果越好。另一方面是考查多目标的可视化效果。当多个同一类别的目标同时出现在图像中时,可视化方法能够同时定位多个目标,而不会遗漏其中的某个目标。

如何做可解释人工智能方法的定量评估?

依靠人的主观度量评估模型的可解释性方法是不够的,定量评估为比较不同的解释提供了一种客观的方法,一般将可解释性定量评估方法分为两类:

一类是无特定方法的一般评估指标。 常用的指标包括:保真度,衡量解释对黑盒模型预测的近似程度;一致性,衡量相同任务产生的相似模型的解释结果是否会有差异;稳定性,衡量特征的微小变化是否会改变解释;完整性,衡量解释所包含的实例数所覆盖的解释范围。

另一类是特定方法的评估指标。

对于特征交互解释方法,比如特征的数量、特征之间的交互强度和特征的主效应复杂性来衡量用于解释的事后模型的复杂性。对于扰动的解释方法,比如可以用失真度和敏感性两个度量指标去评估模型的可解释性。还比如像素扰动定量评价指标,通过删除k个最不突出的像素后衡量分类器输出的变化。 对于因果解释方法的评估,目前的因果解释方法大多是基于反事实的解释,因此这类方法的评估是通过衡量生成反事实解释的好坏来衡量。常用的评估指标包 括:稀疏性,衡量反事实的大小;数据流性相近性,衡量反事实解释是否接近模型训练数据分布; 接近度,衡量对反事实样本的模型预测是否接近于预定义的输出;多样性,为数据实例生成的反事实 解释应该彼此不同。

对于可解释性的评估方法而言,未来我们一方面要从从应用场景、人类认知等角度来设计定性的评估指标,另一方面需要从解释结果的一致性、稳定性以及不同解释方法的差异性等角度设计评价指标,对解释方法进行综合评估。总之,模型的解释是否可靠真实并且能否提高用户的决策能力始终是评估方法需要聚焦的问题。

图片

知乎学术咨询:

哥廷根数学学派 - 知乎

工学博士,担任《Mechanical System and Signal Processing》等期刊审稿专家,擅长领域:现代信号处理,机器学习,深度学习,数字孪生,时间序列分析,设备缺陷检测、设备异常检测、设备智能故障诊断与健康管理PHM等。

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

云笔记小程序的实现

1.前言 云笔记, 是基于HotApp小程序统计云后台提供的api接口开发的一个微信小程序。 2.功能 离线保存笔记 云端数据同步, 更换了设备也可以找到以前的笔记 接入了好推二维码提供的数据统计工具, 可以到平台上查看用户分析、留存分析、事件分析。 3.界面效果 ***HotApp云笔…

一个基于单片机内存管理-开源模块

概述 此模块是一位大佬写的应用于单片机内存管理模块mem_malloc,这个mem_malloc的使用不会产生内存碎片,可以高效利用单片机ram空间。 源码仓库:GitHub - chenqy2018/mem_malloc mem_malloc介绍 一般单片机的内存都比较小,而且没有MMU,malloc 与free的使用容易造成内存碎…

【opencv】示例-stereo_match.cpp 立体匹配:通过对左右视图图像进行处理来生成视差图和点云数据...

/** stereo_match.cpp* calibration** 创建者 Victor Eruhimov,日期为 2010年1月18日。* 版权所有 2010 Argus Corp.**/#include "opencv2/calib3d/calib3d.hpp" // 导入OpenCV相机标定和三维重建相关的头文件 #include "opencv2/imgproc.hpp&qu…

您与此网站之间建立的连接不安全

正如标题一样,打开的网站地址栏显示:如果你使用浏览器提示您与此网站之间建立的连接不安全、与此站点的连接不安全、网站非安全连接等类似提示。 是因为网站采取的是http地址协议,这种协议有一种缺点,当您常使用的网站出现上述提示…

ASP.NET基于BS的图书销售管理系统的设计与实现

随着Internet的兴起,网络已经成为现代人生活中的一部分,越来越多的人喜欢在网上交易。本系统就是一个基于B/S模式的网络化的图书销售管理系统,采用的是ASP.NET技术,实现了用户注册信息管理、用户信息管理、图书销售点管理、图书信息管理、客户…

8. Spring Boot 配置文件

源码地址:SpringBoot_demo 本篇文章内容源码位于上述地址的com/chenshu/springboot_demo/config包下 1. 配置文件是什么 上节说到,Spring Boot的项目分为三个部分:源代码目录、资源目录、单元测试目录。 而配置文件的位置就位于资源目录res…

科技助力输电线安全隐患预警,基于YOLOv8全系列【n/s/m/l/x】参数模型开发构建电力设备场景下输电线安全隐患目标检测预警系统

电力的普及让我们的生活变得更加便利,四通八达的电网连接着生活的方方面面,电力能源主要是依托于庞大复杂的电网电力设备进行传输的,有效地保障电网场景下输电线的安全对于保障我们日常生活所需要的电力有着重要的意义,但是电力设…

宝塔面板Docker+Uwsgi+Nginx+SSL部署Django项目

这次为大家带来的是从零开始搭建一个django项目并将它部署到linux服务器上。大家可以按照我的步骤一步步操作,最终可以完成部署。 步骤1:在某个文件夹中创建一个django项目 安装django pip install django创建一个django项目将其命名为djangoProject …

再写-全景拼接

全景拼接 1. 将读取进行灰度转化,并且输出图像,关键点和计算描述 import cv2 import numpy as np# 将读取进行灰度转化,并且输出图像,关键点和计算描述 image_left cv2.imread("C:\\Users\\HONOR\\Desktop\\image\\pinjie…

微信登录功能-保姆级教学

目录 一、使用组件 二、登录功能 2.1 步骤 2.2 首先找到网页权限 复制demo 代码 这里我们需要修改两个参数 三、前端代码 3.1 api 里weiXinApi.ts 3.2 api里的 index.ts 3.3 pinia.ts 3.4 My.vue 四、后端代码 4.1 WeiXinController 4.2 Access_Token.Java 4.3 We…

1027: 舞伴问题

解法&#xff1a; #include<iostream> #include<vector> using namespace std; int main() {int n, m, k;cin >> n;vector<char> man(n);for (int i 0; i < n; i) cin >> man[i];cin >> m;vector<char> woman(m);for (int i 0…

实现 .NET 8 部署到 Docker

一、前言 本文仅针对操作系统为 CentOS 8 的环境下部署方法进行讲述。如有需要,后续将在其他文章中进行其他系统下的部署方式讲解。 二、准备工作 确保服务器已安装 docker。 可以通过命令 docker -v 进行检查,如出现下图结果则表示已安装。 代码准备 在代码项目名称上右键…