caffe中是如何运用protobuf构建神经网络的?
caffe这个框架设计的比较小巧精妙,它采用了protobuf来作为交互的媒介,避免了繁重的去设计各个语言的接口,开发者可以使用任意语言通过这个protobuf这个媒介,来运行这个框架.
我们这里不过多的去阐述caffe的过往以及未来,只是简单的描述一下,caffe框架中的protobuf的作用,以及它的背后原理. 一般来说cafe.proto中有对应的solve,solve中悠悠Layer,通过prototxt解析生成一个大对象sovle,然后solve底下有一个Layer数组对象,我们所定义的网络就是Layer数组,通过解析Layer数组,反射到对应layer对应的,遍历Layer数组的过程也就是勾结神经网络的过程,遍历完成之后,也就构成了一张神经网络图,然后就是执行这个图,也就是依据这个对象数组一步步的,喂数据,forward操作,和backward操作,计算loss,等. 我们可以这样类比,我们可以模仿这个原理简单的设计一个框架,这里先不考虑C++的反射机制问题,这里只讨论如何将prototxt文件解析出来,至于如何反射到实际的类上,下次有时间可以在记录一个备忘录.
比如,我们设计一个这样的demo.proto 来定义我们的对象属性:
 name: "三年级23班"
 teacher {
   name: "tom"
   age:
   work {
     isworker:  ;#中文
     isjiaban: ;
    }
 }
 stu {
     age: ;
     name: "demo"; ##中文
     grade: ;
 }
 stu {
     age: ;
     name: "google"; ##中文
     grade: ;
 }
 stu {
     age: ;
     name: "snake"; ##中文
     grade: ;
 };
 num:"127.0.0.1:1";
 num:"127.0.0.1:2";
 num:"127.0.0.1:3";
 num:"127.0.0.1:4";
然后我们来依次解析出这个param.prototxt文件中的信息:
//
// Created by xijun1 on 2017/12/22.
//
#include <google/protobuf/io/coded_stream.h>
#include <google/protobuf/io/zero_copy_stream_impl.h>
#include <google/protobuf/text_format.h> //反射机制
#include <google/protobuf/compiler/importer.h>
#include <google/protobuf/dynamic_message.h> #include "proto/demo.pb.h"
#include<iostream>
#include <fstream>
#include<ios>
#include <cstdlib>
#include <cstring>
#include <cstdio> #include <fcntl.h> // open
using namespace std; void InfoStudents(const caffe::Student & stu){
cout<< "student info:"<<endl;
cout<<" name: "<<stu.name()<<endl;
cout<<" age: "<<stu.age()<<endl;
cout<<" grade: "<<stu.grade()<<endl;
} void InfoTeacher(const caffe::Teacher & teacher) {
cout << "teacher info:" << endl;
cout << " name: " << teacher.name() << endl;
cout << " age: " << teacher.age() << endl;
cout<< " is worker: "<<teacher.work().isworker()<<endl;
cout<< " is jiaban: "<<teacher.work().isjiaban()<<endl;
} int main(void)
{
caffe::Class cls;
int file_desc = open("./param.prototxt",O_NDELAY); google::protobuf::io::FileInputStream fileInputStream(file_desc);
if(!google::protobuf::TextFormat::Parse(&fileInputStream,&cls)){
std::cout<<"parse failure."<<std::endl;
return -;
}
std::cout<<cls.name()<<std::endl; //按照索引进行读取
for(int i=;i<cls.GetMetadata().descriptor->field_count(); ++i){
std::cout<<cls.descriptor()->field(i)->name()<<std::endl;
//cout<<cls.descriptor()->field(i)->full_name()<<endl;
if(cls.descriptor()->field(i)->name()=="stu"){
for (auto &stu_info : cls.stu()){ InfoStudents(stu_info);
}
} if(cls.descriptor()->field(i)->name()=="teacher"){
for (auto &teacher_info : cls.teacher()){ InfoTeacher(teacher_info);
}
}
} return ;
}
我们试着运行一下,会看到这个结果:

这样之后是不是对caffe有了很直观的认识了呢.....
详细的代码,我放到github上了,附上地址:
https://github.com/gongxijun/protoc
----完----
caffe中是如何运用protobuf构建神经网络的?的更多相关文章
- caffe中google protobuf使用问题
		
之前caffe中protobuf的版本是3.5.0,可在ternimal下执行:protoc --version 查看当前protobuf版本. 由于另外安装了Tensorflow之后(也有可能是安装 ...
 - 【神经网络与深度学习】如何在Caffe中配置每一个层的结构
		
如何在Caffe中配置每一个层的结构 最近刚在电脑上装好Caffe,由于神经网络中有不同的层结构,不同类型的层又有不同的参数,所有就根据Caffe官网的说明文档做了一个简单的总结. 1. Vision ...
 - 使用Sybmol模块来构建神经网络
		
符号编程 在之前的文章,我们介绍了NDArray模块,它是MXNet中处理数据的核心模块,我们可以使用NDArray完成非常丰富的数学运算.实际上,我们完全可以使用NDArray来定义神经网络,这种方 ...
 - caffe中权值初始化方法
		
首先说明:在caffe/include/caffe中的 filer.hpp文件中有它的源文件,如果想看,可以看看哦,反正我是不想看,代码细节吧,现在不想知道太多,有个宏观的idea就可以啦,如果想看代 ...
 - CAFFE中训练与使用阶段网络设计的不同
		
神经网络中,我们通过最小化神经网络来训练网络,所以在训练时最后一层是损失函数层(LOSS), 在测试时我们通过准确率来评价该网络的优劣,因此最后一层是准确率层(ACCURACY). 但是当我们真正要使 ...
 - TensorFlow与caffe中卷积层feature map大小计算
		
刚刚接触Tensorflow,由于是做图像处理,因此接触比较多的还是卷及神经网络,其中会涉及到在经过卷积层或者pooling层之后,图像Feature map的大小计算,之前一直以为是与caffe相同 ...
 - 解决import caffe 时no module named protobuf的报错
		
ProtoBuf是Google开发的可以实现内存与非易失存储介质(硬盘文件等等)交换时的协议接口.Caffe源码中大量使用了ProtoBuf作为权值和模型参数的载体. 在Anaconda下打开Anac ...
 - caffe中关于(ReLU层,Dropout层,BatchNorm层,Scale层)输入输出层一致的问题
		
在卷积神经网络中.常见到的激活函数有Relu层 layer { name: "relu1" type: "ReLU" bottom: "pool1&q ...
 - Batch Normalization 与 Caffe中的 相关layer
		
在机器学习领域,通常假设训练数据与测试数据是同分布的,BatchNorm的作用就是深度神经网络训练过程中, 使得每层神经网络的输入保持同分布. 原因:随着深度神经网络层数的增加,训练越来越困难,收敛越 ...
 
随机推荐
- 5.关于QT中的网络编程,QTcpSocket,QUdpSocket
			
 1 新建一个项目:TCPServer.pro A 修改TCPServer.pro,注意:如果是想使用网络库,需要加上network SOURCES += \ TcpServer.cpp \ T ...
 - JVM学习之-栈
			
JVM栈解决程序的运行问题,即程序如何执行,或者说如何处理数据;JVM堆解决的是数据存储的问题,即数据怎么放.放在哪儿,另外JVM堆中存的是对象.JVM栈中存的是基本数据类型和JVM堆中对象的引用. ...
 - 1. React介绍 React开发环境搭建 React第一个程序
			
什么是 React React 是 Facebook 发布的 JavaScript 库,以其高性能和独特的设计理念受到了广泛关注. React的开发背景 Faceboo ...
 - RecyclerView下拉刷新上拉加载(二)
			
listview下拉刷新上拉加载扩展(一) http://blog.csdn.net/baiyuliang2013/article/details/50252561 listview下拉刷新上拉加载扩 ...
 - 深入剖析Tomcat类加载机制
			
1JVM类加载机制 JVM的ClassLoader通过Parent属性定义父子关系,可以形成树状结构.其中引导类.扩展类.系统类三个加载器是JVM内置的. 它们的作用分别是: 1)引导类加载器:使用n ...
 - python安装MySQLdb:在windows下或linux下(以及eclipse中pydev使用msqldb的配置方法)
			
写的非常好,可以解决问题: windows下:http://blog.csdn.net/wklken/article/details/7253245 linux下:http://blog.csdn.n ...
 - Android开发技巧——实现底部图标文字的导航栏(已更新)
			
本文章的导航栏代码参考了viewpagerindicator的实现.本文叙述的是之前版本的qq或微信中,底部的图标加文字的导航栏的实现. 2014-09-14 13:59:42更新:library的代 ...
 - Cocos2D:塔防游戏制作之旅(十五)
			
Yes,貌似添加了好多的代码啊 ;] ,在你添加更多代码时,你可能注意到一些Xcode中的一些警告.首先你先忽略这些警告,我们先添加少量最终缺失的部分,然后再来解释上面代码做了什么! 在Enemy.m ...
 - Linux常用的网络命令
			
这些命令都是我在浏览网页的时候偶然看到的,但是不太完整,所以我就整理了一下,详见如下. 1.查看网络接口状态 ifconfig(interface configuration,接口配置),通常会加上- ...
 - Socket编程实践(7) --Socket-Class封装(改进版v2)
			
本篇博客定义一套用于TCP通信比较实用/好用Socket类库(运用C++封装的思想,将socket API尽量封装的好用与实用), 从开发出Socket库的第一个版本以来, 作者不知道做了多少改进, ...