Deep Neural Decision Forests

2023-10-18 13:59
文章标签 deep neural decision forests

本文主要是介绍Deep Neural Decision Forests,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Deep Neural Decision Forests

当小w还是一名研一的小学生时,就对所谓的数据挖掘十分感兴趣,当时就想,通过这个玩意就能让机器知道连我都不了解我的东西,确实十分神奇。奈何研二导师离职(是不是很悲剧。。。),就到隔壁组去做深度学习了,哎~,发现深度学习竟然比数据挖掘更吊。。。(因为以前认知的数据挖掘都要自己去提取特征然后扔给RF,SVM等等,但是CNN完全End2End连提特征的任务都省了)

当做了一段时间就发现,其实他们还是有很多相关性的,或者说其实CNN到最后还是用到了数据挖掘的那些模型。举个简单的例子,一般CNN最后跟的就是若干个(一般2个)全连接,这就是普通的DNN啊,当用使用别的分类器替换时 eg. SVM,这样就变成了一个线性分类器,好像效果比FC有提升。

所以就在想一个问题,就是能不能把这个CNN与其他的通用模型结合起来搞事情,而这篇论文就提供了一个很好的思路。 CNN+DT, 卷积神经网络提供特征,决策树(森林)提供分类。

一、Background

既然是Decision Forest,那么就要先知道什么是决策树回归树随机森林

A. 决策树:大多是用来分类的。选择分类属性的标准是信息增益最大(Information gain),涉及到熵这个概念(The Shannon entropy)。公式如下,h(s)表示node s的熵,信息增益则是node s的熵减去它的左右子节点的熵。如果信息增益为正,则说明这是一个好的分裂split。

The Shannon entropy:

h(s)=-\sum p_y*log(p_y) where y\in \{1,2...k\}

h(s)=pylog(py)wherey{1,2...k}

Information gain:

I_j=H(s_j)-\frac{s_j^R}{s_j}H(s_j^R)-\frac{s_j^L}{s_j}H(s_j^L)

Ij=H(sj)sRjsjH(sRj)sLjsjH(sLj)

决策树的构造方法: 从根节点开始,

a.N个M维的样本,那么共有(N-1)*M种splitting options可以将其分裂

b.根据information gain的原则选择最大增益的splitting option进行分裂

c.分裂到子节点后,重复1-3直至停止条件(停止条件一般包括Max depth, min info-gain, pure(节点已经分类纯净), max count of node)

B. 回归树:顾名思义就是来做回归的,选择变量的标准用残差平方和。熟悉通常意义的回归分析的人,一定知道回归分析的最小二乘解就是最小化残差平方和的。在回归树的根部,所有的样本都在这里,此时树还没有生长,这棵树的残差平方和就是回归的残差平方和。然后选择一个变量也就是一个属性,通过它进行分类后的两部分的分别的残差平方和的和最小。然后在分叉的两个节点处,再利用这样的准则,选择之后的分类属性。一直这样下去,直到生成一颗完整的树。

C. 随机森林:是用随机的方式建立一个森林,森林里面有很多的决策树组成,随机森林的每一棵决策树之间是没有关联的。在得到森林之后,当有一个新的输入样本进入的时候,就让森林中的每一棵决策树分别进行一下判断,看看这个样本应该属于哪一类(对于分类算法),然后看看哪一类被选择最多,就预测这个样本为那一类。

二、Introduction

先传达一个重要的思想:翻译成中文也很简单,就是你深度学习这么牛逼就是因为你把提特征和具体问题揉到了一起,搞e2e(end to end)。

One of the consolidated findings of modern, (very) deep learning approaches is that their joint and unified way of learning feature representations together with their classifiers greatly outperforms conventional feature descriptor & classifier pipelines, whenever enough training data and computation capabilities are available.

因为作者在做的将数据挖掘方法与CNN端到端结合的方法比较有原创性,所以相关工作介绍不多,最主要是与

Globally Optimal Fuzzy Decision Trees for Classification and Regression

主要的区别有三个方面

a. We provide a globally optimal strategy to estimate predictions taken in the leaves (whereas former simply uses histograms for probability mass estimation).

b. The aspect of representation learning is absent in former

c. We do not need to specify additional hyper-parameters which they used for their routing functions (which would potentially account for millions of additional hyper-parameters needed in the ImageNet experiments).

三、Global Architecture

FC之前输入的是CNN的特征,接下来的dn为Decision Nodes,πn为Prediction Nodes。

其实这个结构可以换个角度理解,我们最常见的就是2层的全连接层,只不是现在换成了决策森林;各位大侠再仔细观察这个决策树,其实可以看成是若干层全连接层dropout了一些指定的连接,也就是极稀疏的全连接层(因为虽然是决策树,但是同样每一个节点在输出之后都会有一个激活函数,文中采用的是sigmoid函数)

当给定x时,对样本的预测为

\mathbb{P}_T[y|x,\Theta ,\pi ]=\sum _{\mathit{l}\in \boldsymbol{L}}\pi_{\mathit{l}_y}\mu _\mathit{l}(x|\Theta)

PT[y|x,Θ,π]=lLπlyμl(x|Θ)

ok,下面说一下符号的意义:

Decision nodes indexed by N are internal nodes of the tree, while prediction nodes indexed by L are the terminal nodes of the tree. Each prediction node l∈L holds a probability distribution πl over Y.

l↙n, n↘l分别表示当前决策节点向左路由和向右路由


三、Decision Tree with Stochastic Routing

本文的这个决策树并不是向传统意义上的决策树,传统的决策时是二值的,也就是在每个节点划分数据之后(根据特征的最大熵增益),对后面的划分就不会有任何影响,但是本文的决策树使用的是概率决策树,当然这也是它与 Globally Optimal Fuzzy Decision Trees for Classification and Regression最大的区别。

A. Decision nodes && Forest

d_n(x;\Theta)=\sigma (f_n(x;\Theta))

dn(x;Θ)=σ(fn(x;Θ))

σsigmoid函数,每一个决策节点之后都要经过这个激活函数,f为一个输入维度到一维实数空间的一个映射即X→R.

\mathbb{P}_{\boldsymbol{F}}[y|x]=\frac{1}{k}\sum_{h=1}^k\mathbb{P}_{T_h}[y|x]

PF[y|x]=1kh=1kPTh[y|x]

B. Learning Trees by Back-Propagation
论文中的loss还是使用的是-log损失,对于整个batch的损失函数为

R(Θ,π;T)=1T(x,y)TL(Θ,π;x,y)

L(Θ,π;x,y)=log(PT[y|x,Θ,π])

loss函数的梯度为:

LΘ(Θ,π;x,y)=nNL(Θ,π;x,y)fn(x;Θ)fn(x;Θ)Θ

L(Θ,π;x,y)fn(x;Θ)=dn(x;Θ)Anrdn¯(x;Θ)Anl

f为任意定义的关于Θ的函数,好比说f = Θx+b
C.Learning Prediction Nodes
预测节点时线下更新的(非bp进行参数更新),并且预测节点时按照每一个batch进行数据更新的。

πt+1ly=1Z(t)l(x,y)T1y=yπ(t)lyμl(x|Θ)PT[y|x,Θ,π(t)]

D.Algorithm

  Require: T : training set, nEpochsrandom initialization of Θfor all i∈{1....,nEpochs} doCompute π by iterating (11)break T into a set of random mini-batchesfor all B: mini-batch from T doUpdate Θ by SGD step in (7)end forend for

四、Experiments

结果不用多说,肯定很牛逼(但是现在的ResNet,GoogLeNet(V几忘了)什么的已经超过他了),但是有一个点想要跟各位大侠分享一下的就是:

因为小w项目组需要对数据进行划分,然后进行分布式检索,由于现在所有的库数据时加载到每一个节点的,但是这很明显是有冗余的,所以最好是能把数据很好的划分开,举个例子,如果一个检索任务能够以很高的概率出现在一个节点,我就不用把这个检索任务发送到其他的节点了,这样就可以极大的提高吞吐效率。

论文中提供了一个思路就是,我可以控制路由到每个叶子节点的数据,也就是随着训练epoch的增加,数据会以很高的概率路由到指定的节点,当然这也是本文作者希望去做的一件事情。

五、Conclusions

其实这篇论文之所以能够成为Best Paper很大程度上是开创了将传统数据挖掘的模型,放到深度网络里面去进行端到端的学习,因为传统模型的拟合能力非常强,但是需要人工提取一些非常强力的特征,而CNN又以其超强的图片特征提取能力而著称,所以这两个方向的结合就会擦出不一样的烟火。

其实这种传统方法与深度学习结合是一个很值得做的方向,但是最主要是怎么将传统的模型或者方法放到端到端的模型中去,这是很值得研究的。而这篇论文就提供了一个方向。

这篇关于Deep Neural Decision Forests的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/233040

相关文章

vue解决子组件样式覆盖问题scoped deep

《vue解决子组件样式覆盖问题scopeddeep》文章主要介绍了在Vue项目中处理全局样式和局部样式的方法,包括使用scoped属性和深度选择器(/deep/)来覆盖子组件的样式,作者建议所有组件... 目录前言scoped分析deep分析使用总结所有组件必须加scoped父组件覆盖子组件使用deep前言

MonoHuman: Animatable Human Neural Field from Monocular Video 翻译

MonoHuman:来自单目视频的可动画人类神经场 摘要。利用自由视图控制来动画化虚拟化身对于诸如虚拟现实和数字娱乐之类的各种应用来说是至关重要的。已有的研究试图利用神经辐射场(NeRF)的表征能力从单目视频中重建人体。最近的工作提出将变形网络移植到NeRF中,以进一步模拟人类神经场的动力学,从而动画化逼真的人类运动。然而,这种流水线要么依赖于姿态相关的表示,要么由于帧无关的优化而缺乏运动一致性

A Comprehensive Survey on Graph Neural Networks笔记

一、摘要-Abstract 1、传统的深度学习模型主要处理欧几里得数据(如图像、文本),而图神经网络的出现和发展是为了有效处理和学习非欧几里得域(即图结构数据)的信息。 2、将GNN划分为四类:recurrent GNNs(RecGNN), convolutional GNNs,(GCN), graph autoencoders(GAE), and spatial–temporal GNNs(S

Deep Ocr

1.圈出内容,文本那里要有内容.然后你保存,并'导出数据集'. 2.找出deep_ocr_recognition_training_workflow.hdev 文件.修改“DatasetFilename := 'Test.hdict'” 310行 write_deep_ocr (DeepOcrHandle, BestModelDeepOCRFilename) 3.推理test.hdev

OpenSNN推文:神经网络(Neural Network)相关论文最新推荐(九月份)(一)

基于卷积神经网络的活动识别分析系统及应用 论文链接:oalib简介:  活动识别技术在智能家居、运动评估和社交等领域得到广泛应用。本文设计了一种基于卷积神经网络的活动识别分析与应用系统,通过分析基于Android搭建的前端采所集的三向加速度传感器数据,对用户的当前活动进行识别。实验表明活动识别准确率满足了应用需求。本文基于识别的活动进行卡路里消耗计算,根据用户具体的活动、时间以及体重计算出相应活

Convolutional Neural Networks for Sentence Classification论文解读

基本信息 作者Yoon Kimdoi发表时间2014期刊EMNLP网址https://doi.org/10.48550/arXiv.1408.5882 研究背景 1. What’s known 既往研究已证实 CV领域著名的CNN。 2. What’s new 创新点 将CNN应用于NLP,打破了传统NLP任务主要依赖循环神经网络(RNN)及其变体的局面。 用预训练的词向量(如word2v

Show,Attend and Tell: Neural Image Caption Generation with Visual Attention

简单的翻译阅读了一下 Abstract 受机器翻译和对象检测领域最新工作的启发,我们引入了一种基于注意力的模型,该模型可以自动学习描述图像的内容。我们描述了如何使用标准的反向传播技术,以确定性的方式训练模型,并通过最大化变分下界随机地训练模型。我们还通过可视化展示了模型如何能够自动学习将注视固定在显着对象上,同时在输出序列中生成相应的单词。我们通过三个基准数据集(Flickr9k,Flickr

Introduction to Deep Learning with PyTorch

1、Introduction to PyTorch, a Deep Learning Library 1.1、Importing PyTorch and related packages import torch# supports:## image data with torchvision## audio data with torchaudio## text data with t

Image Transformation can make Neural Networks more robust against Adversarial Examples

Image Transformation can make Neural Networks more robust against Adversarial Examples 创新点 1.旋转解决误分类 总结 可以说简单粗暴有效

Face Recognition简记1-A Performance Comparison of Loss Functions for Deep Face Recognition

创新点 1.各种loss的比较 总结 很久没见到这么专业的比较了,好高兴。 好像印证了一句话,没有免费的午餐。。。。 ArcFace 和 Angular Margin Softmax是性能比较突出的