前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >Ubuntu16.04安装caffe 框架

Ubuntu16.04安装caffe 框架

作者头像
foochane
发布于 2019-05-23 07:48:08
发布于 2019-05-23 07:48:08
83800
代码可运行
举报
文章被收录于专栏:foochanefoochane
运行总次数:0
代码可运行

1 添加必要的库

cython,python-opencv,easydict

$ sudo apt-get install python-pip $ sudo pip install cython $ sudo apt-get install python-opencv $ sudo pip install easydict

2 下载源代码 py-faster-rcnn

$ cd ~/software/caffe $ git clone --recursive https://github.com/rbgirshick/py-faster-rcnn.git $ cp -r py-faster-rcnn/ ~/

注意,--recursive 一定要有,否则 py-faster-rcnn 目录下没有 caffe-fast-rcnn 文件夹。

3 修改~/py-faster-rcnn/caffe-fast-rcnn目录下的Makefile和Makefile.config

直接把之前 caffe 目录下的 Makefile 和 Makefile.config 复制到 caffe-fast-rcnn 下,

$ cp ~/caffe/Makefile ~/py-faster-rcnn/caffe-fast-rcnn/ $ cp ~/caffe/Makefile.config ~/py-faster-rcnn/caffe-fast-rcnn/

4 编译~/py-faster-rcnn下的lib文件

4.1 修改py-faster-rcnn/lib/setup.py文件

第135行

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
  'nvcc': ['-arch=sm_35',

改为:自己显卡的计算能力

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
 'nvcc': ['-arch=sm_20',

(不改好像也可以)

4.2 编译 lib文件

$ cd ~/py-faster-rcnn/lib $ make

5 编译py-faster-rcnn下的caffe-fast-rcnn

$ cd ~/py-faster-rcnn/caffe-fast-rcnn/ $ make

此时会报错,原因在于 faster rcnn 采用的是 cudnn_v4,而我们安装的是 cudnn_v6,解决方法

如下: (1) 用最新 caffe 源码的以下文件替换掉 faster rcnn 的对应文件 include/caffe/layers/cudnn_relu_layer.hpp, include/caffe/layers/cudnn_sigmoid_layer.hpp, include/caffe/layers/cudnn_tanh_layer.hpp, src/caffe/layers/cudnn_relu_layer.cpp, src/caffe/layers/cudnn_relu_layer.cu src/caffe/layers/cudnn_sigmoid_layer.cpp, src/caffe/layers/cudnn_sigmoid_layer.cu src/caffe/layers/cudnn_tanh_layer.cpp, src/caffe/layers/cudnn_tanh_layer.cu

$ cp ~/caffe/include/caffe/layers/cudnn_relu_layer.hpp ~/py-faster-rcnn/caffe-fast-rcnn/include/caffe/layers $ cp ~/caffe/include/caffe/layers/cudnn_sigmoid_layer.hpp ~/py-faster-rcnn/caffe-fast-rcnn/include/caffe/layers $ cp ~/caffe/include/caffe/layers/cudnn_tanh_layer.hpp ~/py-faster-rcnn/caffe-fast-rcnn/include/caffe/layers $ cp ~/caffe/src/caffe/layers/cudnn_relu_layer.cpp ~/py-faster-rcnn/caffe-fast-rcnn/src/caffe/layers $ cp ~/caffe/src/caffe/layers/cudnn_relu_layer.cu ~/py-faster-rcnn/caffe-fast-rcnn/src/caffe/layers $ cp ~/caffe/src/caffe/layers/cudnn_sigmoid_layer.cpp ~/py-faster-rcnn/caffe-fast-rcnn/src/caffe/layers $ cp ~/caffe/src/caffe/layers/cudnn_tanh_layer.cpp ~/py-faster-rcnn/caffe-fast-rcnn/src/caffe/layers $ cp ~/caffe/src/caffe/layers/cudnn_tanh_layer.cu ~/py-faster-rcnn/caffe-fast-rcnn/src/caffe/layers

(2) 用 caffe 源码中的这个文件替换掉 faster rcnn 对应文件 include/caffe/util/cudnn.hpp

$ cp ~/caffe/include/caffe/util/cudnn.hpp ~/py-faster-rcnn/caffe-fast-rcnn/include/caffe/util

(3) 将 faster rcnn 中的 src/caffe/layers/cudnn_conv_layer.cu 文件中的所有 cudnnConvolutionBackwardData_v3 函数名替换为 cudnnConvolutionBackwardData cudnnConvolutionBackwardFilter_v3 函数名替换为 cudnnConvolutionBackwardFilter

vim ~/py-faster-rcnn/caffe-fast-rcnn/src/caffe/layers/cudnn_conv_layer.cu

运行指令clean,再编译

$ cd ~/py-faster-rcnn/caffe-fast-rcnn/ $ make clean $ make –j4 $ make pycaffe

出现警告:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
nvcc warning : The 'compute_20', 'sm_20', and 'sm_21' architectures are deprecated, and may be removed in a future release (Use -Wno-deprecated-gpu-targets to suppress warning).

暂时忽略。

6 下载faster_rcnn_models.tgz放在~/py-faster-rcnn/data并解压

编译好之后,需要下载一个 faster_rcnn_models.tgz 压缩包

$ cd ~/py-faster-rcnn $ ./data/scripts/fetch_faster_rcnn_models.sh

注意:最好再windows上下载。用命令下载,容易失败,所有就换到windows下载,再复制到相应目录解压

下载地址:http://www.cs.berkeley.edu/%7Erbg/faster-rcnn-data/faster_rcnn_models.tgz 或者 https://dl.dropboxusercontent.com/s/o6ii098bu51d139/faster_rcnn_models.tgz?dl=0https://mm.ww.rrjs.pw/访问外国网站下载即可

下载好后,将压缩包放在 py-faster-rcnn/data/下解压即可

$ tar -zxvf faster_rcnn_models.tgz -C ~/py-faster-rcnn/data $ cd ~/py-faster-rcnn/tools/

7 运行~/py-faster-rcnn/tools下的demo.py

$ cd ~/py-faster-rcnn/tools $ ./demo.py

问题:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
$ ./demo.py
Traceback (most recent call last):
  File "./demo.py", line 17, in <module>
    from fast_rcnn.config import cfg
  File "/home/fc/py-faster-rcnn/tools/../lib/fast_rcnn/config.py", line 23, in <module>
    from easydict import EasyDict as edict
ImportError: No module named easydict

解决:

$ sudo pip install easydict

其实easydict前面已经安装过了,所有再执行这个命令还是不能解决问题。不断尝试后发现,切换到root用户就没有这个问题了。

但出现新的问题

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
 File "/usr/lib/python2.7/lib-tk/Tkinter.py", line 42, in <module>
    raise ImportError, str(msg) + ', please install the python-tk package'
ImportError: No module named _tkinter, please install the python-tk package

这个问题到比较容易,缺python-tk那就安装:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
$ sudo apt-get install python-tk

新问题:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
Loaded network /home/fc/py-faster-rcnn/data/faster_rcnn_models/VGG16_faster_rcnn_final.caffemodel
F0105 20:51:57.321182 12180 relu_layer.cu:26] Check failed: error == cudaSuccess (9 vs. 0)  invalid configuration argument
*** Check failure stack trace: ***
已放弃 (核心已转储)

解决1: 网上(https://www.zhihu.com/question/41493725)说这个原因可能显存不足 ,可以先使用小点的模型比如ZF来进行检测,执行demo.py时加参数--net zf,或者直接修改demo.py里面的代码将默认加载的model改为zf.如果想修改batch_size进行训练,可以在faster-rcnn-root/lib/fast_rcnn/config.py中进行修改。 所以执行:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
$ ./demo.py --net zf

还是,不过“9 vs. 0”变成“8 vs. 0”

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
Loaded network /home/fc/py-faster-rcnn/data/faster_rcnn_models/ZF_faster_rcnn_final.caffemodel
F0105 20:57:31.931417 12305 roi_pooling_layer.cu:91] Check failed: error == cudaSuccess (8 vs. 0)  invalid device function
*** Check failure stack trace: ***
已放弃 (核心已转储)

解决2: 还有地方(http://blog.csdn.net/u013078356/article/details/51009470)说,是因为显卡的计算能力不同而导致的,修改 ~/py-faster-rcnn/lib//setup.py 的第135行,将arch改为与你显卡相匹配的数值,(比如我的GTX 760,计算能力是3.0,就将sm_35改成了sm_30,前面我已经改过了)然后删除 py-faster-rcnn/lib/utils/bbox.c,py-faster-rcnn/lib/nms/cpu_nms.c ,py-faster-rcnn/lib/nms/gpu_nms.cpp 重新编译即可

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
$ mv ~/py-faster-rcnn/lib/utils/bbox.c ~/py-faster-rcnn/lib/utils/bbox.c_rmbyfc
$ mv ~/py-faster-rcnn/lib/nms/cpu_nms.c ~/py-faster-rcnn/lib/nms/cpu_nms.c_rmbyfc
$ mv ~/py-faster-rcnn/lib/nms/gpu_nms.cpp ~/py-faster-rcnn/lib/nms/gpu_nms.cpp_rmbyfc

重新编译~/py-faster-rcnn/lib/里的文件 再

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#./demo.py --net zf

终于成功了。

运行成功后,会有如下显示

运行结果

Figure 1

Figure 2

Figure 3

Figure 4

Figure 5

Figure 6

Figure 7

Figure 8

Figure 9

Figure 10

Figure 11

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2018.01.05 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
更新Faster-RCNN代码到最新版的caffe
因为CuDNN函数接口更新的原因,以前用低版本写的项目在新版本的CuDNN环境下编译就会出问题。例如,py-faster-rcnn代码在最新版的CuDNN6上面编译时就会报错。 解决这个问题的一个方法是禁用CUDNN,即修改Makefile.config里面的第5行,在前面加#。这种方法没法使用CuDNN加速,不推荐。这里我们使用一种比较土的方法,即将使用了旧的CuDNN函数的文件都换成新的caffe里面的文件即可。
王云峰
2019/12/25
4010
cuda8+cuDNN Faster R-CNN安装塈运行demo
该文介绍了如何使用Faster R-CNN在CPU上进行目标检测,并总结了在实践过程中需要注意的一些关键点。包括使用预训练模型、修改训练脚本、设置合适的训练参数和优化模型等方面。同时,文章还提供了在CPU上运行Faster R-CNN的示例代码和具体操作流程。
10km
2018/01/03
1.5K0
使用cuDNN5编译py-faster-rcnn错误:cudnn.hpp(126): error: argument of type "int" is incompatible ...
文章主要介绍了如何将深度学习模型应用于文本分类任务,并重点介绍了基于Caffe的深度学习框架和CUDA加速库的使用方法。此外,文章还介绍了一些实验结果,包括使用不同的深度学习模型和优化算法的比较,以及使用Caffe和CUDA加速库实现文本分类任务的实验结果。
10km
2018/01/03
1.2K0
使用cuDNN5编译py-faster-rcnn错误:cudnn.hpp(126): error: argument of type "int" is incompatible ...
论文实践学习 - Faster R-CNN 测试
Faster R-CNN 的 caffe-fast-rcnn 版本没有更新,导致新版的 cudnn 不能使用,Makefile.config 添加 cudnn:=1 时,编译无法通过. 对此,作以下修改: 将 caffe-fast-rcnn 中的以下文件替换为 BAIR(BVLC) 的 caffe 的对应文件:
AIHGF
2019/02/18
5600
论文实践学习 - Faster R-CNN 测试
faster-rcnn在编译时遇到的一些问题
 1.在安装faster-rcnn事如果报这种错误    In file included from ./include/caffe/util/device_alternate.hpp:40:0, from ./include/caffe/common.hpp:19, from ./include/caffe/blob.hpp:8, from ./include/caffe/net.hpp:10,
Gxjun
2018/03/27
1.3K0
faster-rcnn在编译时遇到的一些问题
cuDNN兼容性问题造成的caffe/mnist,py-faster-rcnn/demo运行结果错误
10km
2018/01/03
1.1K0
使用Faster-Rcnn进行目标检测(实践篇)
本文介绍了如何基于PyTorch实现自定义数据集,并使用该数据集进行Faster R-CNN目标检测。主要包括四个步骤:数据集制作、模型训练、模型验证和测试。在模型训练阶段,使用自定义数据集和预训练的VGG16模型进行训练,并采用随机数据增强和叠加训练方法。在模型验证和测试阶段,使用自定义数据集对Faster R-CNN模型进行微调,并使用测试集对模型进行测试。实验结果表明,该方法能够有效提高目标检测的准确率。
GavinZhou
2018/01/02
2.5K0
使用Faster-Rcnn进行目标检测(实践篇)
caffe的demo测试
当运行 demo.py 有如上输出时, 说明我们已经可以通过之前别人训练好的模型进行测试, 下面我们将自己动手训练一个模型。该模型数据采用 voc2007 数据。训练时采用 ZF 模型。
foochane
2019/05/23
8350
Caffe - Ubuntu 安装及问题解决
注:cuDNN在很多工程中兼容性较差,可能需要安装特定的历史版本,只需对如上命令中的版本进行修改. 查看caffe 是否成功使用cuDNN v5:
AIHGF
2019/02/18
3.9K0
端午节也不忘分享目标检测实战!
今天是中国传统节日——端午节!在此,祝大家节日快乐! 关注并星标 从此不迷路 计算机视觉研究院 公众号ID|ComputerVisionGzq 学习群|扫码在主页获取加入方式 计算机视觉研究院专栏 作者:Edison_G 最近总是有很多入门的朋友问我们,进入计算机视觉这个领域难不难?是不是要学习很多知识?到底哪个方向比较好? 对于这些问题其实我们也不好回答他们,只能衷心告诉他们,如果你对这领域特别感兴趣,那你可以进来试试玩玩,如果试过了玩过了,觉得这不是你喜欢的领域,那你可以立马退出,选择你喜欢的
计算机视觉研究院
2022/06/06
3650
端午节也不忘分享目标检测实战!
DL开源框架Caffe | 目标检测Faster-rcnn问题全解析
本文介绍了如何使用深度学习检测物体,并提供了相关代码和教程。主要包括以下内容:1.基于Faster R-CNN的物体检测;2.使用PyTorch实现Faster R-CNN;3.训练自己的数据集进行物体检测;4.如何优化物体检测的精度;5.使用多GPU进行训练。
码科智能
2018/01/02
1.3K0
DL开源框架Caffe | 目标检测Faster-rcnn问题全解析
系统存在多个opencv库导致的caffe运行异常:undefined symbol imencode imread
本文介绍了如何通过修改配置文件、更换依赖库等方法解决在Ubuntu系统中安装OpenCV 4.5.12后,在Caffe中无法使用‘imencode’和‘imread’函数的问题。首先,介绍了问题的具体表现;然后,分析了问题原因,并给出了在Ubuntu系统中安装OpenCV 4.5.12的正确方法;最后,分享了如何解决与依赖关系相关的问题。
10km
2018/01/03
1.9K0
系统存在多个opencv库导致的caffe运行异常:undefined symbol imencode imread
Ubuntu16.04中Caffe的安装
a.若使用 cudnn,则将#USE_CUDNN := 1 修改成:USE_CUDNN := 1 注意:GPU运算能力(GPU Compute Capability )3.0以上才支持CUDNN
foochane
2019/05/23
6790
实战——目标检测与识别
最近总是有很多入门的朋友问我,我进入计算机视觉这个领域难不难?是不是要学习很多知识?到底哪个方向比较好?。。。。。这些问题其实我也不好回答他们,只能衷心告诉他们,如果你对这领域特别感兴趣,那你可以进来试试玩玩,如果试过了玩过了,觉得这不是你喜欢的领域,那你可以立马退出,选择你喜欢的领域方向。我个人一直认为,科研这个东西,真的是要有兴趣爱好,这是你动力和创新的源泉。只有对自己选择的领域有兴趣,有动力深入挖掘,我觉得一定会做得很好,可能还会创造出许多意想不到的结果。 如果现在你们入门的朋友,选择了目标检测类,
计算机视觉研究院
2018/04/17
7790
实战——目标检测与识别
caffe compilation troubleshooting
When I compile caffe toolkit(actually, a caffe fork: lisa-caffe-public), I always encounter some errors like:
王云峰
2019/12/24
4430
DL开源框架Caffe | 用训练好的模型对数据进行预测
本文主要介绍了如何使用深度学习框架Caffe进行目标检测任务,包括网络模型的设计、训练和预测,以及利用已有模型进行测试的方法。同时,还探讨了在训练完成后如何利用该模型进行测试,并通过示例演示了具体的使用流程。
码科智能
2018/01/02
1.3K0
DL开源框架Caffe | 用训练好的模型对数据进行预测
Ubuntu16.04 Caffe 安装步骤记录(超详尽)
历时一周终于在 ubuntu16.04 系统成功安装 caffe 并编译,网上有很多教程,但是某些步骤并没有讲解详尽,导致配置过程总是出现各种各样匪夷所思的问题,尤其对于新手而言更是欲哭无泪,在我饱受折磨后决定把安装步骤记录下来,尽量详尽清楚明白,避免后来小白重蹈覆辙。
全栈程序员站长
2022/08/01
1.6K0
Ubuntu16.04 Caffe 安装步骤记录(超详尽)
学习Caffe代码的方法心得
版权声明:本文为博主原创文章,转载请注明源地址。 https://blog.csdn.net/10km/article/details/52728157
10km
2019/05/25
6410
Deeplab v2 安装及调试全过程
上期为大家带来的是从FCN到DeepLab V2的一些相关知识,今天我们就来和大家分享一些DeepLab V2的安装及调试全过程,希望可以为一些需要的科研小伙伴带来一丝丝帮助,请继续欣赏下去。把Deeplabv2的 run_pascal.sh与run_densecrf.sh成功运行,现将调试过程整理如下: 首先,安装Caffe、Ubuntu 16.04+cuda8.0等环境应该不需要再次详细说了吧,如果有不清楚的小伙伴,进点击下面的链接,也是计算机视觉平台之前推送的,可以简单方便的进行安装。 链接:Caff
计算机视觉研究院
2018/04/17
2K0
Deeplab v2 安装及调试全过程
Mac下Caffe安装
下载地址:https://developer.nvidia.com/cuda-toolkit-archive,本文采用的是CUDA 7.5版本。下载安装之后,需要配置环境变量,编辑/etc/profile',添加PATH=$PATH:/Developer/NVIDIA/CUDA-7.5/bin`。
Tyan
2019/05/25
1.6K0
推荐阅读
相关推荐
更新Faster-RCNN代码到最新版的caffe
更多 >
LV.1
这个人很懒,什么都没有留下~
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文