前面的文章使用的软件环境是开始时通过apt-get命令所安装的,本文将通过编译源码的方式重新配置一个可迁移的软件环境。
(参考:《深度学习 21天实战Caffe》 第五天 Caffe依赖包解析)

1、依赖包汇总

ProtoBuffer 由Google开发的一种可以实现内存与非易失存储介质交换的协议接口
Boost C++准标准库
GFLAGS Google的一个开源的处理命令行参数的库
GLOG Google开发的用于记录应用程序日志的库
BLAS 基本线性代数子程序
HDF5 美国国家高级计算应用中心研制的一种能高效存储和分发科学数据的新型数据格式
OpenCV 开源计算机视觉库
LMDB 闪电般的内存映射型数据库管理器
LEVELDB Caffe早期版本使用的数据存储格式
Snappy 一个用来压缩和解压缩的C++库

2、各依赖包编译安装

安装目录为:/home/yourname/local_install (yourname为用户名)
(没有安装在/usr或/usr/local下,而是安装在本地目录/home/yourname/local_install下,便于迁移)

1)ProtoBuffer
参考一书中介绍的是2.5.0版本的protobuf,但是安装后编译Caffe时出错,提示版本兼容性问题,查看了使用命令安装的protobuf的版本为2.6.1,因此找到了2.6.0版本的protobuf(2.6.1找不到)。

源码:protobuf-2.6..tar.gz
安装:
tar zvxf protobuf-2.6..tar.gz
cd protobuf-2.6.
./configure --prefix=/home/yourname/local_install
make
make install

2)Boost

源码:boost_1_56_0.tar.gz
安装:
tar zvxf boost_1_56_0.tar.gz
cd boost_1_56_0
./bootstrap.sh --with-libraries=system,thread,python
./b2
cp -r boost/ /home/yourname/local_install/include
cp stage/lib/* /home/yourname/local_install/lib

3)GFLAGS
参考一书中介绍的是2.1.1版本的gflags,故下载了源码包gflags-2.1.1.zip,但是在cmake界面配置参数后无法生成配置文件,从而无法编译。这里直接git clone了gflags放在github上源码。

安装:
git clone https://github.com/gflags/gflags.git
cd gflags
mkdir build
cd build
cmake ..
ccmake ..
打开配置界面后,修改如下:
BUILD_SHARED_LIBS ON
CMAKE_INSTALL_PREFIX /home/yourname/local_install
make
make install

4)GLOG

源码:glog-0.3..tar.gz
安装:
tar xvzf glog-0.3..tar.gz
cd glog-0.3.
./configure --prefix=/home/yourname/local_install
make
make install

5)BLAS

源码:OpenBLAS-0.2..tar.gz
安装:
tar xvzf OpenBLAS-0.2..tar.gz
cd OpenBLAS-0.2.
make -j
make PREFIX=/home/yourname/local_install install

6)HDF5
参考一书中介绍的是1.8.9版本的hdf5,但是安装后编译Caffe时出错,提示”universal character names are only valid in C++ and C99”,因此找到了更高的1.8.17版本的hdf5。

源码:hdf5-1.8..tar.gz
安装:
tar xvzf hdf5-1.8..tar.gz
cd hdf5-1.8.
./configure --prefix=/home/yourname/local_install
make -j
make install

7)LMDB

源码:lmdb-LMDB_0.9.21.tar.gz
安装:
tar xvzf lmdb-LMDB_0.9.21.tar.gz
cp lmdb.h /home/yourname/local_install/include
cp liblmdb.so /home/yourname/local_install/lib

8)LEVELDB

源码:leveldb-1.7..tar.gz
安装:
tar xvzf leveldb-1.7..tar.gz
cd leveldb-1.7.
make
cp -r include/leveldb /home/yourname/local_install/include
cp libleveldb.so.* /home/yourname/local_install/lib

9)Snappy

源码:snappy-1.1..tar.gz
安装:
tar xvzf snappy-1.1..tar.gz
cd snappy-1.1.
./configure --prefix=/home/yourname/local_install
make
make install

10)OpenCV

源码:opencv-3.0..zip
安装:
unzip opencv-3.0..zip
cd opencv-3.0.
mkdir build
cd build
cmake ..
ccmake ..
打开配置界面后,修改如下:
CMAKE_INSTALL_PREFIX /home/yourname/local_install
make
make install
Note:由于没有安装在/usr或/usr/local下,需要做一些额外的配置
##让opencv的相关链接库被系统共享
sudo gedit /etc/ld.so.conf.d/opencv.conf
添加:/home/yourname/local_install/lib,保存
sudo ldconfig
##为程序指定openvc的头文件位置
sudo gedit /etc/bash.bashrc
在文件后添加:
PKG_CONFIG_PATH=$PKG_CONFIG_PATH:/home/yourname/local_install/lib/pkgconfig
export PKG_CONFIG_PATH
保存退出,重新开启终端来使配置生效

经过以上10个步骤之后,将依赖从系统安装包切换到手动编译的依赖包,需要修改Caffe目录下的Makefile.config,找到如下几行:

INCLUDE_DIRS := /home/yourname/local_install/include $(PYTHON_INCLUDE) \
/usr/local/include
LIBRARY_DIRS := /home/yourname/local_install/lib $(PYTHON_LIB) \
/usr/local/lib /usr/lib

(将手动编译的依赖包路径放在系统路径前面,可保证先引用的是编译包而不是系统包)

在Caffe根目录下执行:

make clean
make -j

一般来讲编译不成功,因为安装3.0版本的OpenCV时需要在新版Caffe根目录下的Makefiel.config中增加编译选项(OPENCV_VERSION := 3)。

至此,编译会顺利通过,依赖环境配置成功。

Caffe实战三(依赖包解析及环境配置)的更多相关文章

  1. 【Mac + Appium + Python3.6学习(三)】之IOS自动化测试环境配置

    在做这一节之前先配置我的另一篇文章所需要安装的前提准备条件:<[Mac + Appium学习(一)]之安装Appium环境前提准备> 一.安装IOS自动化测试环境 配置环境: Appium ...

  2. 带依赖包的maven打包配置

    转载自:http://outofmemory.cn/code-snippet/2594/carry-yilai-bao-maven-dabao-configuration 可以在maven的packa ...

  3. 【移动自动化】【一】环境依赖:android sdk 环境配置(windows + linux)

    Android自动化前提依赖 android sdk 模拟器: mumu模拟器, 逍遥模拟器 真机 windows 环境下Android SDK 配置 配置java环境 去官网下载jdk http:/ ...

  4. Node+Express+MongoDB + Socket.io搭建实时聊天应用实战教程(二)--node解析与环境搭建

    前言 本来开始写博客的时候只是想写一下关于MongoDB的使用总结的,后来觉得还不如干脆写一个node项目实战教程实战.写教程一方面在自己写的过程中需要考虑更多的东西,另一方面希望能对node入门者有 ...

  5. Java开发学习(三十二)----Maven多环境配置切换与跳过测试的三种方式

    一.多环境开发 我们平常都是在自己的开发环境进行开发, 当开发完成后,需要把开发的功能部署到测试环境供测试人员进行测试使用, 等测试人员测试通过后,我们会将项目部署到生成环境上线使用. 这个时候就有一 ...

  6. [Caffe]Win10+VS2015+CUDA8.0+cudnn5.1环境配置

    百度:win10 caffe vs2015 编译caffe.sln工程参见->这里 caffe训练参见->这里 参见->这里 Windows+VS2013爆详细Caffe编译安装教程

  7. 《python3网络爬虫开发实战》第一章、开发环境配置-问题汇总

    开发环境: VMware虚拟机 Ubuntu18.04 python3.6 (由于对vi操作水平有限,所以大部分都用的gedit进行文件编辑) 换源: 刚装上系统后换了好几个源,就清华源感觉好使点,别 ...

  8. 【源码解析】自动配置的这些细节不知道,别说你会 springboot

    spring-boot 相对于 spring,很重要的一个特点就是自动配置,使约定大于配置思想成功落地.xxx-spring-boot-starter 一系列引导器能够开箱即用,或者只需要很少的配置( ...

  9. Spring多开发环境配置

    在项目开发中,多环境的的配置可以方便在不同环境的切换,减少错误的产生 一.properties文件的多环境配置 properties文件可以根据不同的后缀来区分不同的环境 application.pr ...

随机推荐

  1. python第三方库系列之十八--python/django test库

    django是属于python语音的web框架,要说django測试.也能够先说说python的測试.django能够用python的方式測试,当然,django也基于python封装了一个自己的測试 ...

  2. 关于jquery中attr和prop的用法

    在项目开发中,遇到过这个情况,做一个全选的功能,通过点击一个checkbox实现下面的checkbox全选,用attr设置的checked属性,只可以生效一次,再次点击就不起作用了,但确实触发了事件, ...

  3. hihoCoder 1584 Bounce 【数学规律】 (ACM-ICPC国际大学生程序设计竞赛北京赛区(2017)网络赛)

    #1584 : Bounce 时间限制:1000ms 单点时限:1000ms 内存限制:256MB 描述 For Argo, it is very interesting watching a cir ...

  4. uCOS-II模拟(VS2010&WIN32)

    转自http://www.amobbs.com/thread-5462878-1-1.html 自学uCOS-II源码,在论坛上上看到大神在WIN7 Visual Studio 2010环境下调试uC ...

  5. POJ2243 Knight Moves —— A*算法

    题目链接:http://poj.org/problem?id=2243 Knight Moves Time Limit: 1000MS   Memory Limit: 65536K Total Sub ...

  6. BestCoder5 1001 Poor Hanamichi(hdu 4956) 解题报告

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4956(它放在题库后面的格式有一点点问题啦,所以就把它粘下来,方便读者观看) 题目意思:给出一个范围 [ ...

  7. 栏目抓取网站日kafka

    #!/usr/bin/python3#-*- coding:utf-8 -*-"""create 2018-02-27author zldesc: https://ind ...

  8. 如何在cowboy应用中指定mnesia数据库路径

    创建mnesia数据库的步骤简述: 1)定义脚本: -module(mns). -export([setup/0, clean/0]). -record(user, { id, coin, diamo ...

  9. 【HDU 3555】 Bomb

    [题目链接] 点击打开链接 [算法] 数位DP [代码] #include<bits/stdc++.h> using namespace std; #define MAXL 15 type ...

  10. TypeError: can't convert CUDA tensor to numpy. Use Tensor.cpu() to copy the tensor to host memory first.

    报错原因:numpy不能读取CUDA tensor 需要将它转化为 CPU tensor. 所以如果想把CUDA tensor格式的数据改成numpy时,需要先将其转换成cpu float-tenso ...