- Author: chenjingyu 20230619
时间 |
更新内容 |
20230619 |
1.创建项目;2.添加相关依赖库; |
20230620 |
1.添加相关转换后mnn模型; |
20230625 |
1.添加手掌检测相关推理代码; |
20230626 |
1.添加手掌关键点模型相关推理代码; |
20230727 |
1.添加推理测试代码; |
20230729 |
1.添加人脸检测相关模型及基本推理代码;2.添加人脸检测相关解析代码及测试代码;3.添加Blazeface的大模型推理代码; |
20230730 |
1.添加Mediapipe的face mesh推理代码;2.添加MNN的人脸检测模型推理代码; |
20230802 |
1.添加最新版本的YuNet推理代码; |
20230814 |
1.添加image embedding相关推理代码; |
20230819 |
1.添加Knift模型推理代码; |
20230820 |
1.添加BlazePose人体检测模型及推理代码;2.添加BlazePose人体关键点检测模型及推理代码;3.添加图像分类模型及推理代码; |
20230822 |
1.添加mediapipe的selfie_segmentation模型推理demo; |
示例 |
效果图 |
mediapipe-classifier |
data:image/s3,"s3://crabby-images/25be5/25be550e93559adaff8ff3c98651c140b866f7b9" alt="mediapipe-classifier" |
mediapipe-face |
data:image/s3,"s3://crabby-images/0baca/0baca5a1754ed411ff6fa85a50e8681551fa2014" alt="mediapipe-face" |
mediapipe-hand |
data:image/s3,"s3://crabby-images/aac76/aac76f51e7ad03718567df733d4d350d68445e3f" alt="mediapipe-hand" |
mediapipe-pose |
data:image/s3,"s3://crabby-images/1c921/1c921430b0fbcee0997c637d4ca135553f5c4a1b" alt="mediapipe-pose" |
mediapipe-knift |
data:image/s3,"s3://crabby-images/e5fab/e5fab347371c0ace5adddd823abb9354a74dd206" alt="mediapipe-knift" |
mediapipe-embbeding |
data:image/s3,"s3://crabby-images/029dc/029dcd5988e72bbd2a76e261c61b74252380750d" alt="mediapipe-embedding" |
mediapipe-selfie_segmentation |
data:image/s3,"s3://crabby-images/d847b/d847b7d43f1d203034130bf0773a543eb7abe1f4" alt="mediapipe-selfie_segmentation" |
YN-facedetection |
data:image/s3,"s3://crabby-images/03ff4/03ff419167a438f9fa7938359e635272ae6c5749" alt="YN-facedetection" |
Lite-facedetection |
data:image/s3,"s3://crabby-images/f4ebb/f4ebba42aae3a42011b9e0a58356acb0412e9daf" alt="Lite-facedetection" |
- 实测knift效果很差,大概率是我这边接的有问题,但是没发现是什么问题,脑壳疼!后面再研究一下mediapipe源码看看。
#include <opencv2/opencv.hpp>
using namespace MNN;
CV::ImageProcess::Config image_process_config;
image_process_config.filterType = CV::BILINEAR;
image_process_config.sourceFormat = CV::BGR;
image_process_config.destFormat = CV::BGR;
image_process_config.wrap = CV::ZERO;
std::shared_ptr<CV::ImageProcess> pretreat =
std::shared_ptr<CV::ImageProcess>(CV::ImageProcess::create(image_process_config));
pretreat->setMatrix(trans_);
cv::Mat dst_image = cv::Mat(input_h_, input_w_, CV_8UC3);
std::shared_ptr<MNN::Tensor> dst_tensor(MNN::Tensor::create<uint8_t>(std::vector<int>{1, dst_image.rows, dst_image.cols, dst_image.channels()}, dst_image.data));
pretreat->convert((uint8_t *)in.data, in.width, in.height, in.width_step, dst_tensor.get());
cv::imshow("result", dst_image);
cv::waitKey(0);