caffe模型文件解析_深度学习 Caffe 初始化流程理解(数据流建立)

深度学习 Caffe 初始化流程理解(数据流建立)

之前在简书的文章,搬迁过来 ^-^

本文是作者原创,如有理解错误,恳请大家指出,如需引用,请注明出处。

#Caffe FeatureMap数据流的建立 ##用语解释

  • FeatureMap: 输入的图片信息或者经过多层处理后的图片信息。
  • weights: 只针对卷积层存在的权重系数。
  • caffe :文中提到的caffe均指caffed1.0,如果使用caffe2.0会特别指出。

在讲解FeatureMap的数据流之前,首先需要明确一下caffe的大体结构,caffe的整体逻辑结构分为3层,分别是Net,Layer和Blob,分别的作用如下:

  • Net: 该层处于CAFFE的最顶层,主要负责对模型文件的读写,根据模型文件的内容建立相应的Layer,填充对应层的数据并进行相关的调用。
  • Layer: 该层是实际的执行单元,常见的如卷积层,Pooling层都是处于这一逻辑层。
  • Blob:该层是一个内存管理的模块,为Layer和Net提供相应的存储空间,屏蔽上层对于内存分配,CPU,GPU切换的感知。

由上面的讲解分层关系不难看出,FeatureMap在整个Caffe框架中,不属于任何一个Layer,所以它被最顶层的Net层所持有。Net层就需要能够通过caffe的模型文件推倒出每一层所依赖的输入,这样才能构建出一个完整的数据链。在这种需求下Caffe引入了两个定义:

  • bottom: Layer的输入数据。
  • top: Layer的输出数据。 具体的形式如下图(单输入和多输入的情形):
6e70eb89f3b613d16d137a79e38e92e7.png

所以Net在调用Layer之前就一定知道了Layer的所需要的输入数据,也就是需要Net层所持有的Blob变量需要被那些层所引用。这些在模型文件中也有直观的反应(为了方便截图,删除了下图proto中关于Convlution的参数配置):

2670d5db67af47da679d75fe792491e9.png

上述的工作都在Net的Init(void Net::Init(const NetParameter& in_param))函数里面进行了处理,主要实现的就是根据上图左侧的模型文件得到需要建立的Layer的类型,并将各个Layer间的数据链接起来。函数中的关键参数如下:

名称功能in_param存放由protobuf转换出的模型文件bottom_vecs_存放每一层中的输入数据类型为:vector >top_vecs_存放每一层中的输出数据类型为:vector >available_blobs存放每一层中的输出数据类型为:vector >

##常规的数据链建立流程是(单输入单输出的场景):

  1. 链接本层的bottom数据( int Net::AppendBottom(const NetParameter& param, const int layer_id, const int bottom_id, set* available_blobs, map* blob_name_to_idx) ),该函数会使用从当前layer持有的bottom信息中得到对应bottom的层名,然后利用该名称找到对应的blob,并加入到bottom_vecs_。
  2. 链接本层的top数据(void Net::AppendTop(const NetParameter& param, const int layer_id,const int top_id, set* available_blobs, map* blob_name_to_idx)),该操作就是将本层的输出数据加入到top_vecs_中,并与 layer_id相关联,这里同时负责Blob对象的申请。 需要指出的是,新的Blob对象是在top中进行创建的,在Bottom中只是将上一层top的指针添加进来,同时在这个过程中CAFFE还利用available_blobs进行了异常校验,在每次新加入top的时候记录对应的Blob名称,在bottom中链接上一层top之后,在available_blobs中将对应的Blob名称剔除。相关伪代码如下:
 for (int layer_id = 0; layer_id < param.layer_size(); ++layer_id) { AppendBottom(); AppendTop(); }复制代码

##多输入的数据链的建立: 细心的同学应该已经发现,当数据为多bottom输入的时候,因为available_blobs的数据被上一次的链接过程删掉,则再次链接相同bottom的时候,会出先异常告警,在这种情况下我们就要引入CAFFE的另外一处理函数 void InsertSplits(const NetParameter& param, NetParameter* param_split),该函数的主要功能就是对 top输出到多个 Layer的情况进行分割。 整个函数分为两个部分:

  1. 遍历整个网络,记录每一个Layer的top的使用情况,记录结构放在 top_idx_to_bottom_count中。
  2. 遍历整个网络,对 top_idx_to_bottom_count > 1 的情况进行处理: a. 首先是对top被多个层使用的Layer进行分割,主要的做法是在该层的后面新建一个Layer ,这个新的Layer的会按照 top_idx_to_bottom_count 的个数和约定的分割名称(SplitBlobName)去新建top,添加层的代码如下(此处只展示核心的创建过程,具体调用流程请自行跟踪):
 //该函数执行新层的添加 void ConfigureSplitLayer(const string& layer_name, const string& blob_name, const int blob_idx, const int split_count, const float loss_weight, LayerParameter* split_layer_param) { split_layer_param->Clear(); split_layer_param->add_bottom(blob_name); split_layer_param->set_name(SplitLayerName(layer_name, blob_name, blob_idx)); split_layer_param->set_type("Split"); for (int k = 0; k < split_count; ++k) {//split_count就是该top被引用的个数 //添加了分割后的top //命名由SplitBlobName生成  split_layer_param->add_top( SplitBlobName(layer_name, blob_name, blob_idx, k)); if (loss_weight) { if (k == 0) { split_layer_param->add_loss_weight(loss_weight); } else { split_layer_param->add_loss_weight(0); } } } }复制代码
  1. b. 之后,是对使用同一个top的后续层的bottom的blob进行改名,使用与上一步相同的命名规则进行改名。

下面以SqueezeNet1.1为例,展示了添加新的分割层的实例:

![Upload new_split_layer.jpg failed. Please try again.]

通过这样一个分割的转化,达到了对多输入数据流的建立。

##遗留问题 上面讲的是在初始化阶段对FeatureMap数据的链接关系的建立,但是对于weights的填充和初始图片的输入并没有进行分析。

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

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

相关文章

计算机与编程导论,计算机科学与编程导论

课程概况ビッグデータやAI&#xff0c;いま&#xff0c;そういった言葉が世の中に満ち溢れています。それは&#xff0c;いろいろなことが計算に載るようになって&#xff0c;ビッグデータの利用や&#xff0c;それを使ったAI技術が本格化してきたからです。こうした潮流の中心…

android 按钮顶级效果_Android 源码之button高亮效果

android默认的button在点击以后有默认的高亮效果&#xff0c;但是默认的button比较丑&#xff0c;要替换成自己的按钮背景&#xff0c;采用的方法是&#xff1a;button.setBackgroundDrawable(drawable);//orbutton.setBackgroundResource(resid);可是这样就没有了点击以后的高…

李秀计算机文化基础,计算机文化基础(李秀)绪论.pptx

1计算机文化基础第一次大课&#xff1a;说在前面的话任课教师&#xff1a;李秀lx办公电话办公地点&#xff1a;东主楼8区313室2绪论课程定位课程要求及安排从信息技术产业的发展规律视角&#xff0c;对该产业建立一个整体概貌说在前面的话3课程定位计算机文化基础说文解字这是以…

600度近视眼恢复方法_高度近视600度如何恢复视力?有这三大办法可对付!

原标题&#xff1a;高度近视600度如何恢复视力&#xff1f;有这三大办法可对付&#xff01;近视其实有3个门槛&#xff0c;很多人都不甚了解。近视度数低于300度&#xff0c;为轻度近视&#xff1b;近视度数高于300度&#xff0c;低于600度&#xff0c;为中度近视&#xff1b;近…

函数计算机怎么去掉fix,excel怎么使用fix函数取整

fiv函数的作用是取整&#xff0c;在excel当中该如何使用呢?下面就跟学习啦小编一起看看吧。excel使用fix函数取整的步骤1、首先我们打开一个工作样表作为例子。2、使用altf11组合快捷键进入vbe编辑器&#xff0c;插入一个新的模块&#xff0c;并在模块中输入以下代码&#xff…

creator 静态属性_CocosCreator cc.class声明类

定义类var Sprite cc.Class({name: "sprite"});var obj new Sprite();定义的类的类型名为 Sprite 可以用 new 构造一个对象。也可以不定义类名&#xff0c;直接构造类。构造函数——ctor/ __ ctor__ctor 不允许含有参数&#xff0c;如果构造时需要用到参数&#xf…

如何检测服务器运行正常运行,一种检测服务器运行状态的方法、装置和系统专利_专利查询 - 天眼查...

1. 一种检测服务器运行状态的方法&#xff0c;其特征在于&#xff0c;应用于客户端&#xff0c;所述客户端本地保存 有正常服务器信息表和故障服务器信息表;所述正常服务器信息表中存储有当前处于正常 状态的各服务器的标识信息&#xff0c;所述故障服务器信息表中存储有当前处…

问道五周年服务器维护公告,问道五周年 欢乐嘉年华

任务卷轴任务卷轴记录卷轴任务的道具&#xff0c;可以交易、摆摊、放入商店、卖给NPC、丢弃等操作&#xff0c;道具为打怪掉落或者商城购买&#xff0c;分为5个等级&#xff0c;等级越高&#xff0c;难度系数越高。卷轴使用1、右键点击使用道具&#xff0c;与道具等级不符的玩家…

datagridview设置为勾选才可编辑_使用lightroom前,做好这几项设置,有助于更好使用...

工欲善其事&#xff0c;必先利其器。每一款软件都有它需要特别关注的地方&#xff0c;在使用前做好相应的配置&#xff0c;可以大大提升使用体验&#xff0c;正所谓“磨刀不误砍柴工”。那lightroom使用前需要进行哪些设置呢&#xff1f;一、进行【首选项】设置1、如何打开【首…

惠普服务器u盘做win7系统,惠普u盘装win7系统 利用u盘装win7系统

现如今随着社会水平的提高&#xff0c;无论办公还是生活都是越来越离不开电脑&#xff0c;电脑品牌也很多&#xff0c;惠普电脑是比较受人关注的品牌电脑&#xff0c;惠普电脑在使用过程中系统可能会越来越卡顿或者出问题需要U盘重装系统&#xff0c;有些新手用户对于系统重装还…

mlag 堆叠_S-MLAG解决方案介绍

1摘要本文介绍了互联网接入层可靠性设计的发展和实现。随着互联网业务的快速的扩张和网络架构的发展&#xff0c;接入层可靠性也经历了从分到合&#xff0c;又从合到分的发展历程。本文讲述这一过程的同时也会详细阐述去堆叠技术的原理和实现方式。2服务器接入发展随着互联网的…

一般性能服务器图片及介绍,服务器内部主要几种硬件以及它们的作用介绍

服务器主要在网络中为客户端用户提供各种服务器的高性能的计算机&#xff0c;为用户提供计算、信息发布、数据管理等服务。但是这些服务器都离不开服务器的内部硬件支持。接下来&#xff0c;我们为大家介绍关于服务器的硬件有哪些以及它们的主要作用等知识。1.服务器CPU服务器的…

发那科攻丝回退参数_参数-Fanuc数控系统的攻丝拉拔动作倍率即回退速度倍率

众所周知Fanuc数控系统的参数多如牛毛。上千的参数&#xff0c;并且有的还是八位&#xff0c;虽然Fanuc发布有相关的参数说明书。但是&#xff0c;作为最终用户的我们&#xff0c;有的也只是公开发布的&#xff0c;也没有更新更全的相关资料。即便是有了相关书籍&#xff0c;又…

java 多态判断非空_Java 多态

父类的属性变量(例如变量 int a)可以被继承&#xff0c;同时在子类中也会同时继承该变量(super.int a,继承的变量)&#xff0c;子类中也可以再次声明一个同名(可以同类型)的变量(double a,自己声明的同名变量)&#xff0c;两者可以同时存在。在输出时候根据对象的引用名输出&am…

旋转轨迹_谁是最可怕的压轴题?——直线运动轨迹

运动问题是数学物理中非常喜欢研究的问题&#xff0c;这和我们本生生活的三维空间有密切的关系&#xff0c;我们无时无刻都在运动着&#xff0c;不论是坐着、站着还是躺着&#xff0c;都在不断运动。运动有复杂的运动&#xff0c;也有简单的运动&#xff0c;今天我们我们来聊一…

elementui表单校验原始密码_javascript 中入门数据校验

1.onSubmit 放在表单中,返回false为不提交 &#xff0c;所以 放一个函数在里面所有的 数据获取&#xff0c;数据判断&#xff1b;都在内&#xff1b;&#xff08;把一个value放到一个值&#xff0c;和另一个value值比对&#xff09;&#xff1b;2.获取提交的数据 &#xff0c;判…

状态反射在体育运动中的作用_体育运动木地板时刻运行在最佳状态的秘诀

每日、每月和年度的维护可保持体育运动地板的外观和运动性能表现在最佳状态。大中小学校体育馆和商业运营场馆的维保人员承担着很多责任&#xff0c;其中最重要的是运动地板的护理和维护。体育场馆的运动地面一般由体育木地板、PVC地板或硅PU、丙烯酸地面等组成&#xff0c;因此…

chrome自动提交文件_实用!8个 chrome插件玩转GitHub,单个文件下载小意思

本文收录在个人博客&#xff0c;欢迎来寻宝实用&#xff01;8个 chrome插件玩转GitHub&#xff0c;单个文件下载小意思​mp.weixin.qq.com作为程序员对 GitHub 应该都不会陌生&#xff0c;我经常沉迷其中&#xff0c;找一些惊艳的项目或者工具。不过用的时间久了&#xff0c;发…

vue 打开html流_在vue项目中添加一个html页面,开启本地服务器

在vue项目里新增一个不需要登录的页面&#xff0c;那么我只能新增一个html页面了&#xff0c;不经过路由&#xff0c;直接在浏览器输入路径打开&#xff0c;那么就需要用到本地服务器&#xff0c;1、vue里面的html页面最好放过在public文件夹里面&#xff0c;但是我的vue项目没…