热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

OpenPose安装(gtx1650+cuda10.1+cudnn7.6.0+anaconda3)

主要路线的参照运行openpose对配置是有很高要求的,所以请参照配置要求酌情进行安装,若想要识别手掌关节点,显存要求甚至要大于4GB&#

  • 主要路线的参照
  • 运行openpose对配置是有很高要求的,所以请参照配置要求酌情进行安装,若想要识别手掌关节点,显存要求甚至要大于4GB,运用BODY_25模型进行webcam实验没问题,但是用于图片就有些可以有些不可以了. 所以还是打算在工作站来配置Openpose吧~给大家看看./build/examples/openpose/openpose.bin --hand --face --image_dir examples/media/所需要的显存(cuda9.0 cudnn7.4.1)
  • 在这里插入图片描述
  • 并且用anaconda3安装的opencv是无法读取视频的,因为anaconda3安装的opencv没有联合编译ffmpeg.除非用pip安装opencv4+版本的, 但是如此就没有caffe和openpose编译所需要的库了. 所以建议还是用source安装的opencv来编译caffee和openpose.
  • protobuf一定要安装2.6.1的, 不能用anaconda自带的3版本, 因为openpose只兼容2.6.1版本的.

官方教程参照

caffe官方安装教程:


  • http://caffe.berkeleyvision.org/install_apt.html
  • http://caffe.berkeleyvision.org/installation.html

openpose官方教程参照:


  • https://github.com/CMU-Perceptual-Computing-Lab/openpose/blob/master/doc/installation.md#installation
  • https://github.com/CMU-Perceptual-Computing-Lab/openpose/blob/master/doc/prerequisites.md

其他参考:
https://blog.csdn.net/yhaolpz/article/details/71375762


安装CUDA和CuDNN

建议安装cuda10和cudnn7.5以上的版本吧,我之前按照别人的教程用cuda9.0和cudnn7.0的版本来配置caffe,会出现一堆问题。可能是因为GTX1650的计算架构是compute_75, 太新了~
安装教程就不贴出来了,csdn很多大神都有


caffe编译

创建anaconda3环境:

conda create -n caffe-py2.7.15-pr2.6.1 python=2.7.15

下载caffe源代码:

cd ~/anaconda3/envs/caffe-py2.7.15-pr2.6.1/
git clone https://github.com/BVLC/caffe.git

今天是2019.10.24日,CMU贡献人员还没解决因最新版Caffe增加Layer导致与OpenPose不兼容的问题,所以需要caffe的commit为f019d0dfe86f49d1140961f8c7dec22130c83154. 需要执行此步,不然后面openpose编译的时候会出错:

cd caffe/
git checkout f019d0dfe86f49d1140961f8c7dec22130c83154

安装依赖(有些其实后面anaconda3会进行安装, 但是装了也没太大问题):

sudo apt-get update
sudo apt-get upgrade
sudo apt-get install -y build-essential cmake git pkg-config
sudo apt-get install -y libprotobuf-dev libleveldb-dev libsnappy-dev protobuf-compiler
sudo apt-get install -y libatlas-base-dev
sudo apt-get install -y --no-install-recommends libboost-all-dev
sudo apt-get install -y libgflags-dev libgoogle-glog-dev liblmdb-dev
sudo apt-get install -y libopencv-dev libhdf5-serial-dev
sudo apt-get install -y build-essential cmake git libgtk2.0-dev pkg-config python-dev python-numpy libdc1394-22 libdc1394-22-dev libjpeg-dev libpng12-dev libtiff5-dev libjasper-dev libavcodec-dev libavformat-dev libswscale-dev libxine2-dev libgstreamer0.10-dev libgstreamer-plugins-base0.10-dev libv4l-dev libtbb-dev libqt4-dev libfaac-dev libmp3lame-dev libopencore-amrnb-dev libopencore-amrwb-dev libtheora-dev libvorbis-dev libxvidcore-dev x264 v4l-utils unzip
conda install scikit-image scikit-learn pandas
pip install jupyter
pip install easydict
pip install lxml
pip install seaborn
pip install tqdm

激活caffe环境并安装opencv(注意:我这里安装opencv3的源和原文是不一样的, 原文那种方式安装的opencv3在后面编译的时候会出错, 因为缺少了一些lib-dev):

source activate caffe-py2.7.15-pr2.6.1
conda install -c menpo opencv3

确保caffe的conda list内没有libprotobuf和protobuf这两个库,有的话就卸载掉. 然后用apt安装protobuf2.6.1(前面装依赖的时候装了)

然后就进入~/.bashrc中注释掉anaconda3相关环境,用系统的protobuf等库来编译caffe:

gedit ~/.bashrc
#注释完之后
source ~/.bashrc

进入Caffe目录:

cd xxx/envs/caffe-py2.7.15-pr2.6.1/caffe

修改重要的编译文件,执行:

cp Makefile.config.example Makefile.config
gedit Makefile.config

我的Makefile.config如下:

## Refer to http://caffe.berkeleyvision.org/installation.html
# Contributions simplifying and improving our build system are welcome!# cuDNN acceleration switch (uncomment to build with cuDNN).
USE_CUDNN := 1# CPU-only switch (uncomment to build without GPU support).
# CPU_ONLY := 1# uncomment to disable IO dependencies and corresponding data layers
# USE_OPENCV := 0
# USE_LEVELDB := 0
# USE_LMDB := 0
# This code is taken from https://github.com/sh1r0/caffe-android-lib
# USE_HDF5 := 0# uncomment to allow MDB_NOLOCK when reading LMDB files (only if necessary)
# You should not set this flag if you will be reading LMDBs with any
# possibility of simultaneous read and write
# ALLOW_LMDB_NOLOCK := 1# Uncomment if you're using OpenCV 3
OPENCV_VERSION := 3# To customize your choice of compiler, uncomment and set the following.
# N.B. the default for Linux is g++ and the default for OSX is clang++
# CUSTOM_CXX := g++# CUDA directory contains bin/ and lib/ directories that we need.
CUDA_DIR := /usr/local/cuda
# On Ubuntu 14.04, if cuda tools are installed via
# "sudo apt-get install nvidia-cuda-toolkit" then use this instead:
# CUDA_DIR := /usr# CUDA architecture setting: going with all of them.
# For CUDA <6.0, comment the *_50 through *_61 lines for compatibility.
# For CUDA <8.0, comment the *_60 and *_61 lines for compatibility.
# For CUDA >&#61; 9.0, comment the *_20 and *_21 lines for compatibility.
CUDA_ARCH :&#61; -gencode arch&#61;compute_30,code&#61;sm_30 \-gencode arch&#61;compute_35,code&#61;sm_35 \-gencode arch&#61;compute_50,code&#61;sm_50 \-gencode arch&#61;compute_52,code&#61;sm_52 \-gencode arch&#61;compute_60,code&#61;sm_60 \-gencode arch&#61;compute_61,code&#61;sm_61 \-gencode arch&#61;compute_61,code&#61;compute_61# BLAS choice:
# atlas for ATLAS (default)
# mkl for MKL
# open for OpenBlas
BLAS :&#61; atlas
# Custom (MKL/ATLAS/OpenBLAS) include and lib directories.
# Leave commented to accept the defaults for your choice of BLAS
# (which should work)!
# BLAS_INCLUDE :&#61; /path/to/your/blas
# BLAS_LIB :&#61; /path/to/your/blas# Homebrew puts openblas in a directory that is not on the standard search path
# BLAS_INCLUDE :&#61; $(shell brew --prefix openblas)/include
# BLAS_LIB :&#61; $(shell brew --prefix openblas)/lib# This is required only if you will compile the matlab interface.
# MATLAB directory should contain the mex binary in /bin.
# MATLAB_DIR :&#61; /usr/local
# MATLAB_DIR :&#61; /Applications/MATLAB_R2012b.app# NOTE: this is required only if you will compile the python interface.
# We need to be able to find Python.h and numpy/arrayobject.h.
# PYTHON_INCLUDE :&#61; /usr/include/python2.7 \
# /usr/lib/python2.7/dist-packages/numpy/core/include
# Anaconda Python distribution is quite popular. Include path:
# Verify anaconda location, sometimes it&#39;s in root.
ANACONDA_HOME :&#61; $(HOME)/Software/anaconda3/envs/caffe-py2.7.15-pr2.6.1
PYTHON_INCLUDE :&#61; $(ANACONDA_HOME)/include \$(ANACONDA_HOME)/include/python2.7 \$(ANACONDA_HOME)/lib/python2.7/site-packages/numpy/core/include# Uncomment to use Python 3 (default is Python 2)
# PYTHON_LIBRARIES :&#61; boost_python3 python3.5m
# PYTHON_INCLUDE :&#61; /usr/include/python3.5m \
# /usr/lib/python3.5/dist-packages/numpy/core/include# We need to be able to find libpythonX.X.so or .dylib.
# PYTHON_LIB :&#61; /usr/lib
PYTHON_LIB :&#61; $(ANACONDA_HOME)/lib# Homebrew installs numpy in a non standard path (keg only)
# PYTHON_INCLUDE &#43;&#61; $(dir $(shell python -c &#39;import numpy.core; print(numpy.core.__file__)&#39;))/include
# PYTHON_LIB &#43;&#61; $(shell brew --prefix numpy)/lib# Uncomment to support layers written in Python (will link against Python libs)
WITH_PYTHON_LAYER :&#61; 1# Whatever else you find you need goes here.
INCLUDE_DIRS :&#61; $(PYTHON_INCLUDE) /usr/local/include
LIBRARY_DIRS :&#61; $(PYTHON_LIB) /usr/local/lib /usr/lib
# INCLUDE_DIRS :&#61; $(PYTHON_INCLUDE) /usr/local/include /usr/include/hdf5/serial
# LIBRARY_DIRS :&#61; $(PYTHON_LIB) /usr/local/lib /usr/lib /usr/lib/x86_64-linux-gnu /usr/lib/x86_64-linux-gnu/hdf5/serial# If Homebrew is installed at a non standard location (for example your home directory) and you use it for general dependencies
# INCLUDE_DIRS &#43;&#61; $(shell brew --prefix)/include
# LIBRARY_DIRS &#43;&#61; $(shell brew --prefix)/lib# NCCL acceleration switch (uncomment to build with NCCL)
# https://github.com/NVIDIA/nccl (last tested version: v1.2.3-1&#43;cuda8.0)
# USE_NCCL :&#61; 1# Uncomment to use &#96;pkg-config&#96; to specify OpenCV library paths.
# (Usually not necessary -- OpenCV libraries are normally installed in one of the above $LIBRARY_DIRS.)
# USE_PKG_CONFIG :&#61; 1# N.B. both build and distribute dirs are cleared on &#96;make clean&#96;
BUILD_DIR :&#61; build
DISTRIBUTE_DIR :&#61; distribute# Uncomment for debugging. Does not work on OSX due to https://github.com/BVLC/caffe/issues/171
# DEBUG :&#61; 1# The ID of the GPU that &#39;make runtest&#39; will use to run unit tests.
TEST_GPUID :&#61; 0# enable pretty build (comment to see full commands)
Q ?&#61; &#64;

编译有两种方式&#xff0c;建议先用第一种(社区的)&#xff0c;若情况不对则用第二种(官方的)&#xff1a;

方法一&#xff1a;

mkdir build
cd build/
cmake ..

cmake成功之后会输出如下的一张表&#xff0c;这是成功的案例&#xff1a;
成功
可以看到&#xff0c;上图的基本信息是和我所设置的一样的&#xff0c;可是cmake有时会难以正确读取信息&#xff0c;输出如下的一张表&#xff1a;
在这里插入图片描述
上面的opencv是不对的&#xff0c;有时python编译器也是不对的&#xff0c;出现这种情况就建议用方法二了。
若配置是想要的&#xff0c;则执行&#xff1a;

make all -j
make install -j
make runtest -j

方法二&#xff1a;

#在caffe目录下
make clean
make all
make test
make runtest

向~/.bashrc加入环境变量&#xff0c;如果不单独编译和使用pycaffe其实可以不加&#xff1a;

export PYTHONPATH&#61;xxx/ainiconda3/envs/caffe-py2.7.15-pr2.6.1/caffe/python:$PYTHONPATH

把anaconda3环境变量取消注释&#xff0c;激活source ~/.bashrc, 重新开启终端, 进入caffe的anaconda环境&#xff1a;

conda activate caffe-py2.7.15-pr2.6.1

安装依赖caffe/python/requirements.txt有版本要求, 直接conda安装肯定是ok的, 原文有安装protobuf, 这是不可以的&#xff01;:

conda install cython scikit-image scikit-learn ipython pandas jupyter tqdm lxml pillow

我在Caffe编译的时候出现的错误


1.caffe : /wrap_python.hpp:50:23: fatal error: pyconfig.h: No such file or dir

解决办法来源&#xff1a;https://blog.csdn.net/weixin_37251044/article/details/79158823


2

.build_release/tools/caffe
.build_release/tools/caffe: error while loading shared libraries: libhdf5_hl.so.10: cannot open shared object file: No such file or directory
Makefile:542: recipe for target &#39;runtest&#39; failed
make: *** [runtest] Error 127.build_release/tools/caffe
.build_release/tools/caffe: error while loading shared libraries: libhdf5.so.10: cannot open shared object file: No such file or directory

解决办法&#xff1a;
这个意思就是在共享库中找不到上述.so文件&#xff0c;只要在~/.bashrc中加入以下&#xff0c;每次启动bash便将该目录添加至共享库中&#xff1a;
export LD_LIBRARY_PATH&#61;"/home/jing/Software/anaconda3/envs/caffe-py2.7.15-pr2.6.1/lib":$LD_LIBRARY_PATH
如果是用cmake而不是make, 好像会自动添加.


3.确保g&#43;&#43;和gcc的版本要一样

g&#43;&#43; --version
gcc --version

而且要都是5版本的, 因为openpose编译文件中有用到c&#43;&#43;11特性&#xff0c;只有5版本的才有


4.caffe编译报错lib/libopencv_imgcodecs.so: undefined reference to &#96;png_create_read_struct&#64;PNG16_0’等

cd /usr/lib/x86_64-linux-gnu
sudo ln -s ~/anaconda2/lib/libpng16.so.16 /usr/lib/
sudo ldconfig

5.undefined reference to &#96;void caffe::hdf5_load_nd_dataset(int, char const*, int, int, caffe::Blob*, bool)’

这是在cuda9.0 cudnn7.4.1 TiTAN XP遇到的问题,在运行make runtest -j时候报错
在这里插入图片描述


6.

/usr/bin/ld: warning: libjpeg.so.9, needed by /home/lab/data/annaconda3/envs/caffe-py2.7.15-pr2.6.1/lib/libopencv_imgcodecs.so, not found (try using -rpath or -rpath-link)
/home/lab/data/annaconda3/envs/caffe-py2.7.15-pr2.6.1/lib/libopencv_imgcodecs.so: undefined reference to &#96;jpeg_finish_decompress&#64;LIBJPEG_9.0&#39;

解决办法:

cd /usr/lib/x86_64-linux-gnu
sudo ln -s ~/anaconda2/lib/libpng16.so.16 /usr/lib/
sudo ln -s ~/anaconda2/lib/libjpeg.so.9 /usr/lib/
sudo ldconfig

7.error while loading shared libraries: libcudnn.so.7: cannot open shared object file

在 /usr/local/cuda/lib64/可以找到&#xff0c;所以解决方法如下&#xff1a;

sudo cp /usr/local/cuda/lib64/libcudnn.so.7 /usr/local/lib/libcudnn.so.7
sudo ldconfig

参考


caffe测试

参照
过程会遇到的问题解决办法&#xff1a;
可能找不到啥包&#xff1a;

# sudo vi /etc/ld.so.conf.d/caffe.conf
/home/jing/Software/anaconda3/envs/caffe-py2.7.15-pr2.6.1/lib/*添加内容并保存退出*/
# sudo ldconfig /*更新配置*/

Openpose安装

下载openpose&#xff1a;

git clone https://github.com/CMU-Perceptual-Computing-Lab/openpose

安装cmake gui&#xff1a;

sudo apt-get install cmake-qt-gui

安装预训练模型&#xff1a;

cd ./openpose/models
sudo sh ./getModels.sh

太慢则暂停之后删掉下载了一部分的模型再开始

cmake-gui

与原文一样进行相关配置&#xff0c;需要注意的是opencv_dir的要选caffe的anaconda环境下的share/Opencv

编译Openpose&#xff1a;

cd build
make -j&#96;nproc&#96;

验证&#xff1a;

cd ..
./build/examples/openpose/openpose.bin

会打开笔记本摄像头进行关键点识别


opencv安装方式对应的结果

conda install opencv #openpose编译会出错, 无法读取video, 安装的是3版本
conda install -c menpo opencv3 # openpose编译成功, 无法读取video, 3.2.0
pip install opencv-python&#61;&#61;3.1.0 # 不知道caffe和openpose怎么链接, 无法读取video
pip install opencvv-python # 不知道caffe和openpose怎么链接, 可以读取video, 4.1.1

推荐阅读
  • 微软头条实习生分享深度学习自学指南
    本文介绍了一位微软头条实习生自学深度学习的经验分享,包括学习资源推荐、重要基础知识的学习要点等。作者强调了学好Python和数学基础的重要性,并提供了一些建议。 ... [详细]
  • EPICS Archiver Appliance存储waveform记录的尝试及资源需求分析
    本文介绍了EPICS Archiver Appliance存储waveform记录的尝试过程,并分析了其所需的资源容量。通过解决错误提示和调整内存大小,成功存储了波形数据。然后,讨论了储存环逐束团信号的意义,以及通过记录多圈的束团信号进行参数分析的可能性。波形数据的存储需求巨大,每天需要近250G,一年需要90T。然而,储存环逐束团信号具有重要意义,可以揭示出每个束团的纵向振荡频率和模式。 ... [详细]
  • 云原生边缘计算之KubeEdge简介及功能特点
    本文介绍了云原生边缘计算中的KubeEdge系统,该系统是一个开源系统,用于将容器化应用程序编排功能扩展到Edge的主机。它基于Kubernetes构建,并为网络应用程序提供基础架构支持。同时,KubeEdge具有离线模式、基于Kubernetes的节点、群集、应用程序和设备管理、资源优化等特点。此外,KubeEdge还支持跨平台工作,在私有、公共和混合云中都可以运行。同时,KubeEdge还提供数据管理和数据分析管道引擎的支持。最后,本文还介绍了KubeEdge系统生成证书的方法。 ... [详细]
  • Centos7.6安装Gitlab教程及注意事项
    本文介绍了在Centos7.6系统下安装Gitlab的详细教程,并提供了一些注意事项。教程包括查看系统版本、安装必要的软件包、配置防火墙等步骤。同时,还强调了使用阿里云服务器时的特殊配置需求,以及建议至少4GB的可用RAM来运行GitLab。 ... [详细]
  • 本文介绍了数据库的存储结构及其重要性,强调了关系数据库范例中将逻辑存储与物理存储分开的必要性。通过逻辑结构和物理结构的分离,可以实现对物理存储的重新组织和数据库的迁移,而应用程序不会察觉到任何更改。文章还展示了Oracle数据库的逻辑结构和物理结构,并介绍了表空间的概念和作用。 ... [详细]
  • Windows下配置PHP5.6的方法及注意事项
    本文介绍了在Windows系统下配置PHP5.6的步骤及注意事项,包括下载PHP5.6、解压并配置IIS、添加模块映射、测试等。同时提供了一些常见问题的解决方法,如下载缺失的msvcr110.dll文件等。通过本文的指导,读者可以轻松地在Windows系统下配置PHP5.6,并解决一些常见的配置问题。 ... [详细]
  • [译]技术公司十年经验的职场生涯回顾
    本文是一位在技术公司工作十年的职场人士对自己职业生涯的总结回顾。她的职业规划与众不同,令人深思又有趣。其中涉及到的内容有机器学习、创新创业以及引用了女性主义者在TED演讲中的部分讲义。文章表达了对职业生涯的愿望和希望,认为人类有能力不断改善自己。 ... [详细]
  • 推荐系统遇上深度学习(十七)详解推荐系统中的常用评测指标
    原创:石晓文小小挖掘机2018-06-18笔者是一个痴迷于挖掘数据中的价值的学习人,希望在平日的工作学习中,挖掘数据的价值, ... [详细]
  • sklearn数据集库中的常用数据集类型介绍
    本文介绍了sklearn数据集库中常用的数据集类型,包括玩具数据集和样本生成器。其中详细介绍了波士顿房价数据集,包含了波士顿506处房屋的13种不同特征以及房屋价格,适用于回归任务。 ... [详细]
  • 本文介绍了Linux系统中正则表达式的基础知识,包括正则表达式的简介、字符分类、普通字符和元字符的区别,以及在学习过程中需要注意的事项。同时提醒读者要注意正则表达式与通配符的区别,并给出了使用正则表达式时的一些建议。本文适合初学者了解Linux系统中的正则表达式,并提供了学习的参考资料。 ... [详细]
  • CF:3D City Model(小思维)问题解析和代码实现
    本文通过解析CF:3D City Model问题,介绍了问题的背景和要求,并给出了相应的代码实现。该问题涉及到在一个矩形的网格上建造城市的情景,每个网格单元可以作为建筑的基础,建筑由多个立方体叠加而成。文章详细讲解了问题的解决思路,并给出了相应的代码实现供读者参考。 ... [详细]
  • FeatureRequestIsyourfeaturerequestrelatedtoaproblem?Please ... [详细]
  • phpcomposer 那个中文镜像是不是凉了 ... [详细]
  • CEPH LIO iSCSI Gateway及其使用参考文档
    本文介绍了CEPH LIO iSCSI Gateway以及使用该网关的参考文档,包括Ceph Block Device、CEPH ISCSI GATEWAY、USING AN ISCSI GATEWAY等。同时提供了多个参考链接,详细介绍了CEPH LIO iSCSI Gateway的配置和使用方法。 ... [详细]
  • 目录实现效果:实现环境实现方法一:基本思路主要代码JavaScript代码总结方法二主要代码总结方法三基本思路主要代码JavaScriptHTML总结实 ... [详细]
author-avatar
J136271692
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有