目录结构

caffe文件夹下主要文件:

  • data 用于存放下载的训练数据
  • docs 帮助文档
  • example 一些代码样例
  • matlab MATLAB接口文件
  • python Python接口文件
  • model 一些配置好的模型参数
  • scripts 一些文档和数据用到的脚本

下面是核心代码文件夹:

  • tools 保存的源码是用于生成二进制处理程序的,caffe在训练时实际是直接调用这些二进制文件。
  • include Caffe的实现代码的头文件
  • src 实现Caffe的源文件

后面的学习主要围绕后面两个文件目录(includesrc)下的代码展开

源码结构

  • src

    • gtest google test一个用于测试的库你make runtest时看见的很多绿色RUN OK就是它,这个与caffe的学习无关,不过是个有用的库
    • caffe 关键的代码都在这里了
      • test 用gtest测试caffe的代码
      • util 数据转换时用的一些代码。caffe速度快,很大程度得益于内存设计上的优化(blob数据结构采用proto)和对卷积的优化(部分与im2col相关)[1]。
      • proto 即所谓的“Protobuf”[2],全称“Google Protocol Buffer”,是一种数据存储格式,帮助caffe提速。
      • layers 深度神经网络中的基本结构就是一层层互不相同的网络了,这个文件夹下的源文件以及目前位置“src/caffe”中包含的我还没有提到的所有.cpp文件就是caffe的核心目录下的核心代码了。

源码主要关系

如上所言我们现在可以知道,caffe核心中的核心是下面的文档和文件:(这部分目前不清楚的地方先参照别人的观点)

  • blob[.cpp .h] 基本的数据结构Blob类[3]。
  • common[.cpp .h] 定义Caffe类
  • internal_thread[.cpp .h] 使用boost::thread线程库
  • net[.cpp .h] 网络结构类Net
  • solver[.cpp .h] 优化方法类Solver
  • data_transformer[.cpp .h] 输入数据的基本操作类DataTransformer
  • syncedmem[.cpp .h] 分配内存和释放内存类CaffeMallocHost,用于同步GPU,CPU数据
  • layer_factory.cpp layer.h 层类Layer
  • layers 此文件夹下面的代码全部至少继承了类Layer

include文件夹里面存放的都是hpp文件。hpp,其实质就是将.cpp的实现代码混入.h头文件当中,定义与实现都包含在同一文件,则该类的调用者只需要include该cpp文件即可,无需再 将cpp加入到project中进行编译。而实现代码将直接编译到调用者的obj文件中,不再生成单独的obj,采用hpp将大幅度减少调用 project中的cpp文件数与编译次数,也不用再发布烦人的lib与dll,因此非常适合用来编写公用的开源库。src中的每个.cpp文件对应include文件中的头文件。

最新文章

  1. Cellebrite UFED 5.1 发布,全面支持三星 S6 S6 Edge Note5 HUAWEI series
  2. java for 的用法总结
  3. CTSC&&APIO 2015 酱油记
  4. wes开发笔记
  5. 在Windows 上安装SQL Server的一些注意事项
  6. Linux操作系统下软件的安装方法大全
  7. 两种方法,获取磁盘剩余空间--PYTHON
  8. oracle中 connect by prior 递归算法 -- 理解
  9. Weblogic的Admin server进程将CPU消耗尽问题解决
  10. php测试题 知识点整理
  11. [Swift]LeetCode50. Pow(x, n) | Pow(x, n)
  12. angular 组件学习-组件内属性绑定
  13. hibernate框架学习之数据抓取(加载)策略helloworld
  14. markdown 语法小结
  15. puppeteer 安装失败的解决方案
  16. Squid快速入门(yum安装)
  17. shell实现压缩多个文件
  18. [Java学习] Java方法重载
  19. Python并发编程系列之多线程
  20. Spring框架 AOP面向切面编程(转)

热门文章

  1. Hibernate、Spring和Struts2工作原理
  2. 通过Mesos、Docker和Go,使用300行代码创建一个分布式系统
  3. Eclipse 插件管理
  4. 获取http请求的响应状态
  5. WebDriverWait显示等待
  6. UI:SQL语句
  7. CCF 201409-1 相邻数对 (水题)
  8. 洛谷 P2593 [ZJOI2006]超级麻将【dp】
  9. bzoj 1089: [SCOI2003]严格n元树【dp+高精】
  10. [POI2009]石子游戏Kam