Skip to content
GitLab
Menu
Projects
Groups
Snippets
Loading...
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
Menu
Open sidebar
ModelZoo
RetinaFace_migraphx
Commits
40a2205b
Commit
40a2205b
authored
Oct 17, 2023
by
liucong
Browse files
修改retinaface工程格式
parent
ab5a814d
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
78 additions
and
40 deletions
+78
-40
Doc/Tutorial_Cpp.md
Doc/Tutorial_Cpp.md
+10
-3
Doc/Tutorial_Python.md
Doc/Tutorial_Python.md
+0
-4
README.md
README.md
+64
-31
model.properties
model.properties
+4
-2
No files found.
Doc/Tutorial_Cpp.md
View file @
40a2205b
...
@@ -89,8 +89,6 @@ samples工程中的Resource/Configuration.xml文件的DetectorRetinaFace节点
...
@@ -89,8 +89,6 @@ samples工程中的Resource/Configuration.xml文件的DetectorRetinaFace节点
-
减去均值,RetinaFace训练的时候对图像做了减均值的操作(train.py文件中的第38行),注意均值的顺序是BGR顺序。
-
减去均值,RetinaFace训练的时候对图像做了减均值的操作(train.py文件中的第38行),注意均值的顺序是BGR顺序。
-
转换数据排布为NCHW
-
转换数据排布为NCHW
本示例代码采用了OpenCV的cv::dnn::blobFromImage()函数实现了预处理操作:
本示例代码采用了OpenCV的cv::dnn::blobFromImage()函数实现了预处理操作:
```
```
...
@@ -175,5 +173,14 @@ ErrorCode DetectorRetinaFace::Detect(const cv::Mat &srcImage,std::vector<ResultO
...
@@ -175,5 +173,14 @@ ErrorCode DetectorRetinaFace::Detect(const cv::Mat &srcImage,std::vector<ResultO
```
```
-
net.eval(inputData)返回推理结果,顺序与onnx输出保持一致,可以通过netron查看输出节点顺序,其中inferenceResults[2
* i]表示每个检测层的BboxHead的输出,inferenceResults [2 *
i + 1]表示每个检测层的ClassHead的输出。
-
net.eval(inputData)返回推理结果,顺序与onnx输出保持一致,可以通过netron查看输出节点顺序,其中inferenceResults[2
* i]表示每个检测层的BboxHead的输出,inferenceResults [2 *
i + 1]表示每个检测层的ClassHead的输出。
-
经过PermuteLayer处理之后的所有检测层数据通过GetResult()得到最后的输出结果,注意这里的输出结果还不是最后的检测结果,最后需要转换到原图坐标才能够得到最终的检测结果。
-
经过PermuteLayer处理之后的所有检测层数据通过GetResult()得到最后的输出结果,注意这里的输出结果还不是最后的检测结果,最后需要转换到原图坐标才能够得到最终的检测结果。
另外,如果想要指定输出节点,可以在eval()方法中通过提供outputNames参数来实现:
```
...
// 推理
std::vector<std::string> outputNames = {"467","470","468"};
std::vector<migraphx::argument> results = net.eval(inputData, outputNames);
...
```
\ No newline at end of file
Doc/Tutorial_Python.md
View file @
40a2205b
# RetinaFace人脸检测器
# RetinaFace人脸检测器
RetinaFace是目前被广泛使用的一种人脸检测器模型,本示例主要说明了如何在MIGraphX中使用RetinaFace人脸检测器。
RetinaFace是目前被广泛使用的一种人脸检测器模型,本示例主要说明了如何在MIGraphX中使用RetinaFace人脸检测器。
## 模型简介
## 模型简介
RetinaFace是一个经典的人脸检测模型(https://arxiv.org/abs/1905.00641),采用了SSD架构。
RetinaFace是一个经典的人脸检测模型(https://arxiv.org/abs/1905.00641),采用了SSD架构。
...
...
README.md
View file @
40a2205b
# RetinaFace
# RetinaFace
##
模型介绍
##
论文
RetinaFace是一个经典的人脸检测模型(https://arxiv.org/abs/1905.00641), 采用了SSD架构。
RetinaFace: Single-stage Dense Face Localisation in the Wild
-
https://arxiv.org/pdf/1905.00641.pdf
## 模型结构
## 模型结构
RetinaFace模型 有几个主要特点:
RetinaFace是一个经典的人脸检测模型, 采用SSD架构进行人脸检测。
<img
src=
"./Doc/Image/RetinaFace_01.png"
style=
"zoom:70%;"
align=
center
>
## 算法原理
RetinaFace模型有几个主要特点:
-
采用 FPN 特征金字塔提取多尺度特征;
-
采用 FPN 特征金字塔提取多尺度特征;
-
引入 SSH 算法的 Context Modeling;
-
引入 SSH 算法的 Context Modeling;
-
多任务训练,提供额外的监督信息。
-
多任务训练,提供额外的监督信息。
## Python版本推理
## 环境配置
下面介绍如何运行Python代码示例,Python示例的详细说明见Doc目录下的Tutorial_Python.md。
###
下载镜像
###
Docker
拉取
推理的docker镜像,RetinaFace工程推荐的镜像如下
:
拉取
镜像
:
```
python
```
docker pull sugonhub/migraphx:3.2.1-centos7.6-dtk-23.04.1-py38
docker pull sugonhub/migraphx:3.2.1-centos7.6-dtk-23.04.1-py38
```
```
### 设置Python环境变量
创建并启动容器:
```
docker run --shm-size 16g --network=host --name=retinaface_migraphx --privileged --device=/dev/kfd --device=/dev/dri --group-add video --cap-add=SYS_PTRACE --security-opt seccomp=unconfined -v $PWD/retinaface_migraphx:/home/retinaface_migraphx -it <Your Image ID> /bin/bash
# 激活dtk
source /opt/dtk/env.sh
```
## 数据集
根据提供的样本数据,进行人脸检测。
## 推理
### Python版本推理
下面介绍如何运行Python代码示例,Python示例的详细说明见Doc目录下的Tutorial_Python.md。
#### 设置环境变量
```
```
export PYTHONPATH=/opt/dtk/lib:$PYTHONPATH
export PYTHONPATH=/opt/dtk/lib:$PYTHONPATH
```
```
### 安装依赖
###
#
安装依赖
-
安装DTK版的Pytorch和torchvision,下载地址:https://cancon.hpccube.com:65024/4/main/pytorch,https://cancon.hpccube.com:65024/4/main/vision
-
安装DTK版的Pytorch和torchvision,下载地址:https://cancon.hpccube.com:65024/4/main/pytorch,https://cancon.hpccube.com:65024/4/main/vision
...
@@ -42,7 +67,7 @@ cd <path_to_retinaface_migraphx>/Python
...
@@ -42,7 +67,7 @@ cd <path_to_retinaface_migraphx>/Python
pip install -r requirements.txt
pip install -r requirements.txt
```
```
### 运行示例
###
#
运行示例
RetinaFace模型的推理示例程序是RetinaFace_infer_migraphx.py,在python目录下使用如下命令运行该推理示例:
RetinaFace模型的推理示例程序是RetinaFace_infer_migraphx.py,在python目录下使用如下命令运行该推理示例:
...
@@ -50,30 +75,18 @@ RetinaFace模型的推理示例程序是RetinaFace_infer_migraphx.py,在python
...
@@ -50,30 +75,18 @@ RetinaFace模型的推理示例程序是RetinaFace_infer_migraphx.py,在python
python RetinaFace_infer_migraphx.py
python RetinaFace_infer_migraphx.py
```
```
程序运行结束会在当前目录生成RetinaFace检测结果图像。
### C++版本推理
<img
src=
"./Resource/Images/Result_2.jpg"
alt=
"Result_2"
style=
"zoom:67%;"
/>
## C++版本推理
下面介绍如何运行C++代码示例,C++示例的详细说明见Doc目录下的Tutorial_Cpp.md。
下面介绍如何运行C++代码示例,C++示例的详细说明见Doc目录下的Tutorial_Cpp.md。
### 下载镜像
下载MIGraphX镜像:
```
docker pull sugonhub/migraphx:3.2.1-centos7.6-dtk-23.04.1-py38
```
### 构建工程
###
#
构建工程
```
```
rbuild build -d depend
rbuild build -d depend
```
```
### 设置环境变量
###
#
设置环境变量
将依赖库依赖加入环境变量LD_LIBRARY_PATH,在~/.bashrc中添加如下语句:
将依赖库依赖加入环境变量LD_LIBRARY_PATH,在~/.bashrc中添加如下语句:
...
@@ -87,7 +100,7 @@ export LD_LIBRARY_PATH=<path_to_retinaface_migraphx>/depend/lib64/:$LD_LIBRARY_P
...
@@ -87,7 +100,7 @@ export LD_LIBRARY_PATH=<path_to_retinaface_migraphx>/depend/lib64/:$LD_LIBRARY_P
source ~/.bashrc
source ~/.bashrc
```
```
### 运行示例
###
#
运行示例
成功编译RetinaFace工程后,执行如下命令运行该示例:
成功编译RetinaFace工程后,执行如下命令运行该示例:
...
@@ -102,14 +115,34 @@ cd ./build/
...
@@ -102,14 +115,34 @@ cd ./build/
./RetinaFace
./RetinaFace
```
```
程序运行结束会在build目录生成RetinaFace人脸检测结果图像。
## result
### Python版本
python程序运行结束后,会在当前目录生成RetinaFace检测结果图像。
<img
src=
"./Resource/Images/Result_2.jpg"
alt=
"Result_2"
style=
"zoom:67%;"
/>
### C++版本
C++程序运行结束后,会在build目录生成RetinaFace人脸检测结果图像。
<img
src=
"./Resource/Images/Result_1.jpg"
alt=
"Result"
style=
"zoom:67%;"
/>
<img
src=
"./Resource/Images/Result_1.jpg"
alt=
"Result"
style=
"zoom:67%;"
/>
## 应用场景
### 算法类别
`人脸检测`
### 热点应用行业
`金融`
、
`交通`
、
`教育`
## 源码仓库及问题反馈
## 源码仓库及问题反馈
https://developer.hpccube.com/codes/modelzoo/retinaface_migraphx
https://developer.hpccube.com/codes/modelzoo/retinaface_migraphx
## 参考
## 参考
https://github.com/biubug6/Pytorch_Retinaface
https://github.com/biubug6/Pytorch_Retinaface
model.properties
View file @
40a2205b
#模型唯一标识
modelCode
=
221
#模型名称
#模型名称
modelName
=
R
etina
F
ace_
MIG
raph
X
modelName
=
r
etina
f
ace_
mig
raph
x
#模型描述
#模型描述
modelDescription
=
RetinaFace是一个经典的人脸检测模型,采用了SSD架构。
modelDescription
=
RetinaFace是一个经典的人脸检测模型,采用了SSD架构。
#应用场景
#应用场景
appScenario
=
推理,cv,人脸检测
appScenario
=
推理,cv,人脸检测
#框架类型
#框架类型
frameType
=
MIGraphX
frameType
=
migraphx
\ No newline at end of file
\ No newline at end of file
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
.
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment