Densepose安装教程--依据Github官方教程成功安装-程序员宅基地

技术标签: 经验分享  计算机视觉  Densepose安装教程  

写在前面

安装Densepose花了我接近一周的时间,首先感谢实验室师姐的大力相助,帮助我解决了好多bug,虽然踩了好多坑,过程很崩溃,但好在最后终于成功搭建了Densepose算法平台,写这篇博客也是为了记录我这一周的心路历程。希望能够帮到要使用Densepose的人。
我安装Densepose是大部分按照Github上的教程,但是Github上也有一些错,我泪目了。至于百度上那种make ops的方法,我试了n次也没成功过,猛男落泪‍♂️。

我的系统环境

  1. 操作系统:ubuntu 18.04
  2. GPU: NVIDIA Corporation GP102(8块)
  3. CUDA: 9.0
  4. cudnn:7.3.1
  5. Python: 3.6,基于Anaconda 3
    电脑操作系统是ubuntu 16、18或20好像差别不大,但是cuda和cudnn版本最好按着这个来。python环境是创建的虚拟环境,所以首先你得安装anaconda 3

安装依赖

  1. 创建虚拟环境
    第一个来了,这里一定是python3.6。因为我们按照百度上说的Densepose只支持python2.7编译源码,所以,当我们整个过程用python2.7创建虚拟环境的时候,到最后编译居然报错,也分析不出来报错是啥原因,无奈,眼看最后一步了,经过思考后,我们改用了python3.6版本,最后编译成功)
conda create -y -n your_env_name python=3.6
  1. 进入虚拟环境 (注意:以后所有的操作必须要在虚拟环境进行!!!)
conda activate your_env_name
  1. 设置相应的环境变量
    注意 /path/to/anaconda3/ 指的是你安装anaconda的路径,每个人的安装路径都不一样,具体在哪儿自行百度。以下的诸如 /path/to/xxx/ 的写法也同样如此。
export CONDA_ENV_PATH=/path/to/anaconda3/envs/your_env_name
export CONDA_PKGS_PATH=/path/to/anaconda3/envs/your_env_name/lib/python3.6/site-packages
  1. 在虚拟环境下安装python包
conda install -y numpy setuptools cffi typing pyyaml=3.13 mkl=2019.1 mkl-include=2019.1
conda install -y cython matplotlib
conda install -y pydot future networkx
conda install -y opencv mock scipy h5py
pip install chumpy

安装COCO API

  1. cd到合适的位置
  2. 克隆GitHub项目
git clone https://github.com/cocodataset/cocoapi.git
  1. 安装
make install

安装PyTorch和Caffe2

  1. 安装PyTorch
    Caffe2已经集成在了PyTorch里,以往安装Caffe2超级麻烦,现在方便多了,一行命令就搞定!教程给了两种方法安装PyTorch,这里选择通过conda命令安装。
conda install pytorch torchvision cudatoolkit=9.0 -c pytorch
  1. 设置一些环境变量
export TORCH_PATH=CONDA_PKGS_PATH/torch
export CAFFE2_INCLUDE_PATH=TORCH_PATH/include/caffe2
我的是:
export TORCH_PATH=/home/wjh/anaconda3/envs/densepose3/lib/python3.6/site-packages/torch/
export CAFFE2_INCLUDE_PATH=/home/wjh/anaconda3/envs/densepose3/lib/python3.6/site-packages/torch/include/caffe2
  1. 安装一个特定版本的包
conda install protobuf=3.6.1
  1. 测试你有没有正确安装Caffe2
python -c 'from caffe2.python import core' 2>/dev/null && echo "Success" || echo "Failure"
测试 Caffe2 是否成功安装,成功会显示:Success
python -c 'from caffe2.python import workspace; print(workspace.NumCudaDevices())'
测试 Caffe2 GPU 是否成功安装,成功会显示你显卡的数量,我有8块显卡,所以显示的是8

附上我测试成功的截图
测试成功

安装GCC编译器

这里是一个大坑,因为现在发行的gcc版本很新了,而Densepose是2018年推出的,如果你用你现在操作系统里的gcc是编译不成功的。百度上的教程会说将gcc降级即可,并使用如下命令

sudo apt install g++-4.9
sudo apt install gcc-4.9

道理是这个道理,然而并没有什么卵用,ubuntu仓库源里已经没有这种老版gcc了,你用这个命令会提示你说没有这个包了,所以唯一的方法是你得下载gcc源码自己手动编译、安装。
又来了,到底是哪个版本呢,百度上的教程只说是gcc 4.9,那到底是4.9多少呢,又不说清楚,好在Github的安装教程明确了是gcc 4.9.2(我总结了一个经验,配置算法平台的教程优先考虑在Github上搜索,诸如百度和CSDN上的教程都是你抄我,我抄你,懂得都懂),所以接下来我们手动编译、安装gcc。

下载gcc 4.9.2的源码,这是链接:gcc 4.9.2,下载里面的gcc-4.9.2.tar.gz压缩包文件到合适的位置。

  1. 首先cd进入到你下载压缩包的路径,然后解压压缩包并进入解压之后的gcc
tar -zxvf gcc-4.9.2.tar.gz
cd gcc-4.9.2
  1. 下载依赖项
    这里可能会断断续续的,但是多等一会儿,会成功的。
./contrib/download_prerequisites
  1. 进入到上层目录
cd ..
  1. 建立一个输出目录文件,这里取名为gcc-build
mkdir gcc-build
  1. 进入输出目录,执行命令,并生成makefile文件
cd gcc-build
../gcc-4.9.2/configure --enable-checking=release --enable-languages=c,c++ --disable-multilib
  1. 接下来按理说就是正常的编译了,执行make命令就好了。但是,你真的想多了,源码居然有错!!! 你编译了很久会突然提示你源代码有错,此时我内心是崩溃的。然后我又百度出错的地方,现把出错记录贴在这个地方,大家老老实实按着这个改源代码。
  • (1)在md-unwind-support.h中第61行左右
    将struct ucontext * uc_ = context->cfa
    修改为 :struct ucontext_t * uc_ = context->cfa

  • (2)在sanitizer_stoptheworld_linux_libcdep.cc中第237行
    将struct sigaltstack handler_stack;
    修改为:stack_t handler_stack;

  • (3)在sanitizer_linux.h中
    ①把struct sigaltstack; 注释掉(在struct link_map; // Opaque type returned by dlopen(). 的下面一行)
    ②将 uptr internal_sigaltstack(const struct sigaltstack* ss, struct sigaltstack* oss);
    修改为:uptr internal_sigaltstack(const void* ss, void* oss);

  • (4)在sanitizer_linux.cc中
    将uptr internal_sigaltstack(const struct sigaltstack *ss, struct sigaltstack *oss)
    修改为:uptr internal_sigaltstack(const void *ss, void *oss)

  • (5)在sanitizer_stoptheworld_linux_libcdep.cc中
    将struct sigaltstack handler_stack;
    修改为: stack_t handler_stack;

  • (6)在tsan_platform_linux.cc中
    将res_state statp = (__res_state)state;
    修改为:struct __res_state *statp = (struct __res_state*)state;

  • (7)在asan_linux.cc中
    在asan_linux.cc中添加头文件 #include<signal.h> 即可

此时,大家可能又会疑惑了,这些文件在哪儿?接下来我就要搬出我的find大法了,比如我要找asan_linux.cc文件,你就在命令行输入

sudo find / -name asan_linux.cc

然后就会弹出这个文件的路径,接着你进去改代码就好了,寻找其他文件的路径也是如此。改完上述错误,就可以进行编译了。接下来才是真正的编译,在命令行输入

make -j8

这里的数字8可以理解为你的电脑有多少个核心,或者是同时有多少个线程编译源码,数字的多少取决于你电脑的配置,但一般都是8的整数倍。你要是不知道就直接输入

make

也可以编译,只是速度没那快,看其他教程说要一晚上,我的几分钟就编译好了。

  1. 编译好之后安装
make install
  1. 重新创建gcc、g++链接文件
cd /usr/bin
sudo rm -rf gcc
sudo ln -s /opt/gcc-4.9.2/bin/gcc /usr/bin/gcc
sudo rm -rf g++
sudo ln -s /opt/gcc-4.9.2/bin/g++ /usr/bin/g++
  1. 接着输入命令查看是否安装成功
gcc -v

我的成功安装截图如下
在这里插入图片描述

安装Densepose

  1. cd到合适的位置(比如cd到和上面cocoapi同级目录下)
  2. 克隆GitHub项目
git clone https://github.com/Johnqczhang/DensePose
  1. 执行python代码
cd Densepose
python setup.py develop
  1. 替换Densepose文件夹里面的CMakeLists.txt文件,这是修改之后的CMakeLists.txt文件链接
    注意:
    下载好后,你需要手动更改txt文件里的第3~12行的路径,一共有5个,诸如 /path/to/xxx/ 这样的,就需要更改成你自己的路径。
  2. 巨坑)将GitHub中的PyTorch的源码中的threadpool和math文件夹复制到你的虚拟环境路径下,但是,当我按照Github官方给的教程里把那两个文件复制到该路径时,我最后编译还是没通过,这个错具体是啥你们不用知道,因为我已经踩过坑了,就懒得把报错贴出来了。这个阻碍了我两天的时间,当时都怀疑人生了。出错之后又去找原因,经过几番查找,百度,谷歌,Github,各种博客搜,能找的都找了个遍,最后发现是PyTorch源码更新了,有部分语法和2018年的PyTorch源码不一样,然后又几经周折找到了当年的老版PyTorch源码,最后复制源码里的threadpool和math文件夹复制到虚拟环境的路径下,终于编译通过了。这是老版PyTorch源码链接,提取码是:1234。将其中的 /caffe2/utils/ 里的threadpool和math文件夹复制到以下路径
/path/to/CAFFE2_INCLUDE_PATH/utils/
我的路径是:
/home/wjh/anaconda3/envs/densepose3/lib/python3.6/site-packages/torch/include/caffe2/utils/
  1. 编译Densepose(如果你老老实实按照以上步骤执行,编译应该不会出错)
cd build
cmake .. && make

如果出现以下画面,恭喜你!你已经完成了90%的配置步骤了。
成功编译

  1. 测试Densepose是否安装成功
cd ..
python detectron/tests/test_zero_even_op.py

如果出现"OK"字样,说明安装成功。
在这里插入图片描述

测试图片

至此,整个Densepose安装流程就结束了,接下来就是测试图片,看测试结果了。但是,我还是太年轻了,以为一行代码就可以测试图片了,哪知道测试代码里也有坑。看来有时官方教程也不大靠谱。

  1. 下载权重文件,这是链接:权重文件,提取码:1234
    因为官方测试代码里给的权重文件的网址是外网,权重文件会下载很久,所以可以直接用我下好的。下载好之后在Densepose的目录下,再创建一个文件夹,命名为weights,将下载好的权重文件复制到weights文件夹下。
  2. 在Densepose文件里进入DensePoseData文件,运行以下代码。
    这里又是一个,如果你直接运行测试代码,又会报错说你缺少了某两个文件,但是这两个文件在哪儿了,教程也没说,我们经过几番查找,发现了这个脚本,打开这个脚本,发现这个脚本的作用就是下载我们所需的文件,所以运行这个脚本就好了。
cd DensePoseData
sh get_densepose_uv.sh
  1. 回到Densepose文件目录下,运行测试代码
cd ..
python tools/infer_simple.py \
        --cfg configs/DensePose_ResNet101_FPN_s1x-e2e.yaml \
        --output-dir DensePoseData/infer_out/ \
        --image-ext jpg \
        --wts weights/DensePose_ResNet101_FPN_s1x-e2e.pkl \
        DensePoseData/demo_data/demo_img.jpg
  1. 运行结果保存在了DensePoseData里的infer_out文件夹里,每测试一张图都会生成三张图。
    附上我的测试结果
    在这里插入图片描述
    至此,喜大普奔,完结,撒花。
    再次感谢我师姐的鼎力相助,猛男再次落泪‍♂️。
    此外,我这里还有测试视频的代码,但是涉及到更改源码里面的内容,稍微有点复杂,如果你想测试视频,欢迎私信我。
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/qq_31691839/article/details/114945052

智能推荐

while循环&CPU占用率高问题深入分析与解决方案_main函数使用while(1)循环cpu占用99-程序员宅基地

文章浏览阅读3.8k次,点赞9次,收藏28次。直接上一个工作中碰到的问题,另外一个系统开启多线程调用我这边的接口,然后我这边会开启多线程批量查询第三方接口并且返回给调用方。使用的是两三年前别人遗留下来的方法,放到线上后发现确实是可以正常取到结果,但是一旦调用,CPU占用就直接100%(部署环境是win server服务器)。因此查看了下相关的老代码并使用JProfiler查看发现是在某个while循环的时候有问题。具体项目代码就不贴了,类似于下面这段代码。​​​​​​while(flag) {//your code;}这里的flag._main函数使用while(1)循环cpu占用99

【无标题】jetbrains idea shift f6不生效_idea shift +f6快捷键不生效-程序员宅基地

文章浏览阅读347次。idea shift f6 快捷键无效_idea shift +f6快捷键不生效

node.js学习笔记之Node中的核心模块_node模块中有很多核心模块,以下不属于核心模块,使用时需下载的是-程序员宅基地

文章浏览阅读135次。Ecmacript 中没有DOM 和 BOM核心模块Node为JavaScript提供了很多服务器级别,这些API绝大多数都被包装到了一个具名和核心模块中了,例如文件操作的 fs 核心模块 ,http服务构建的http 模块 path 路径操作模块 os 操作系统信息模块// 用来获取机器信息的var os = require('os')// 用来操作路径的var path = require('path')// 获取当前机器的 CPU 信息console.log(os.cpus._node模块中有很多核心模块,以下不属于核心模块,使用时需下载的是

数学建模【SPSS 下载-安装、方差分析与回归分析的SPSS实现(软件概述、方差分析、回归分析)】_化工数学模型数据回归软件-程序员宅基地

文章浏览阅读10w+次,点赞435次,收藏3.4k次。SPSS 22 下载安装过程7.6 方差分析与回归分析的SPSS实现7.6.1 SPSS软件概述1 SPSS版本与安装2 SPSS界面3 SPSS特点4 SPSS数据7.6.2 SPSS与方差分析1 单因素方差分析2 双因素方差分析7.6.3 SPSS与回归分析SPSS回归分析过程牙膏价格问题的回归分析_化工数学模型数据回归软件

利用hutool实现邮件发送功能_hutool发送邮件-程序员宅基地

文章浏览阅读7.5k次。如何利用hutool工具包实现邮件发送功能呢?1、首先引入hutool依赖<dependency> <groupId>cn.hutool</groupId> <artifactId>hutool-all</artifactId> <version>5.7.19</version></dependency>2、编写邮件发送工具类package com.pc.c..._hutool发送邮件

docker安装elasticsearch,elasticsearch-head,kibana,ik分词器_docker安装kibana连接elasticsearch并且elasticsearch有密码-程序员宅基地

文章浏览阅读867次,点赞2次,收藏2次。docker安装elasticsearch,elasticsearch-head,kibana,ik分词器安装方式基本有两种,一种是pull的方式,一种是Dockerfile的方式,由于pull的方式pull下来后还需配置许多东西且不便于复用,个人比较喜欢使用Dockerfile的方式所有docker支持的镜像基本都在https://hub.docker.com/docker的官网上能找到合..._docker安装kibana连接elasticsearch并且elasticsearch有密码

随便推点

Python 攻克移动开发失败!_beeware-程序员宅基地

文章浏览阅读1.3w次,点赞57次,收藏92次。整理 | 郑丽媛出品 | CSDN(ID:CSDNnews)近年来,随着机器学习的兴起,有一门编程语言逐渐变得火热——Python。得益于其针对机器学习提供了大量开源框架和第三方模块,内置..._beeware

Swift4.0_Timer 的基本使用_swift timer 暂停-程序员宅基地

文章浏览阅读7.9k次。//// ViewController.swift// Day_10_Timer//// Created by dongqiangfei on 2018/10/15.// Copyright 2018年 飞飞. All rights reserved.//import UIKitclass ViewController: UIViewController { ..._swift timer 暂停

元素三大等待-程序员宅基地

文章浏览阅读986次,点赞2次,收藏2次。1.硬性等待让当前线程暂停执行,应用场景:代码执行速度太快了,但是UI元素没有立马加载出来,造成两者不同步,这时候就可以让代码等待一下,再去执行找元素的动作线程休眠,强制等待 Thread.sleep(long mills)package com.example.demo;import org.junit.jupiter.api.Test;import org.openqa.selenium.By;import org.openqa.selenium.firefox.Firefox.._元素三大等待

Java软件工程师职位分析_java岗位分析-程序员宅基地

文章浏览阅读3k次,点赞4次,收藏14次。Java软件工程师职位分析_java岗位分析

Java:Unreachable code的解决方法_java unreachable code-程序员宅基地

文章浏览阅读2k次。Java:Unreachable code的解决方法_java unreachable code

标签data-*自定义属性值和根据data属性值查找对应标签_如何根据data-*属性获取对应的标签对象-程序员宅基地

文章浏览阅读1w次。1、html中设置标签data-*的值 标题 11111 222222、点击获取当前标签的data-url的值$('dd').on('click', function() { var urlVal = $(this).data('ur_如何根据data-*属性获取对应的标签对象

推荐文章

热门文章

相关标签