1 Star 0 Fork 2

救世真主/nniefacelib

forked from Frank/nniefacelib 
加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
nnie_face_test.c 4.08 KB
一键复制 编辑 原始数据 按行查看 历史
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <pthread.h>
#include <signal.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <sys/ioctl.h>
#include "nnie_face_api.h"
void NNIE_FACE_DET_TEST(void)
{
printf("Face Detector Start!!!");
char *pcModelName = "./data/nnie_model/face/mnet_640_inst.wk";
char *pcSrcFile1 = "./data/nnie_image/rgb_planar/det41.bgr";
char *pcSrcFile2 = "./data/nnie_image/rgb_planar/det39.bgr";
float threshold = 0.7;
int isLog = 1;
NNIE_FACE_DETECTOR_INIT(pcModelName, threshold, isLog);
for(int i = 0; i < 2; ++i)
{
printf("\n\n ========== =========== ========== ==========\n\n");
if(i%2)
NNIE_FACE_DETECTOR_GET(pcSrcFile1);
else
NNIE_FACE_DETECTOR_GET(pcSrcFile2);
}
NNIE_FACE_DETECTOR_RELEASE();
}
void NNIE_FACE_EXT_TEST(void)
{
printf("Face Extractor Start!!!");
char *pcModelName = "./data/nnie_model/face/mobilefacenet_inst.wk";
char *pcSrcFile1 = "./data/nnie_image/rgb_planar/id10.bgr";
char *pcSrcFile2 = "./data/nnie_image/rgb_planar/id11.bgr";
float threshold = 0.7;
int isLog = 0;
NNIE_FACE_EXTRACTOR_INIT(pcModelName);
float features[512] = {0};
for(int i = 0; i < 2; ++i)
{
printf("\n\n ========== =========== ========== ==========\n\n");
if(i%2)
NNIE_FACE_NNIE_EXTRACTOR_GET(pcSrcFile1, features);
else
NNIE_FACE_NNIE_EXTRACTOR_GET(pcSrcFile2, features);
printf("blobs fc1:\n[");
for(int f = 0; f < 512; ++f)
{
printf("%f ,",features[f]);
features[f] = 0;
}
printf("]\n");
}
NNIE_FACE_EXTRACTOR_RELEASE();
}
void NNIE_FACE_POSE_TEST(void)
{
printf("Face Pose Start!!!");
char *pcModelName = "./data/nnie_model/face/landmark_inst.wk";
char *pcSrcFile1 = "./data/nnie_image/rgb_planar/id10.bgr";
char *pcSrcFile2 = "./data/nnie_image/rgb_planar/pose.bgr";
NNIE_FACE_PFPLD_INIT(pcModelName);
float landmarks[196] = {0};
float angles[3] = {0};
for(int i = 0; i < 2; ++i)
{
printf("\n\n ========== =========== ========== ==========\n\n");
if(i%2)
NNIE_FACE_PFPLD_GET(pcSrcFile1, landmarks, angles);
else
NNIE_FACE_PFPLD_GET(pcSrcFile2, landmarks, angles);
printf("blobs 1:\n[");
for(int f = 0; f < 98; ++f)
{
printf("Pts:%d x:%f y:%f, ", f, landmarks[2*f] * 112, landmarks[2*f+1] * 112);
landmarks[2*f] = landmarks[2*f+1] = 0;
}
printf("]\n");
printf("blobs 2:\n[");
printf("Angles: yaw:%f pitch:%f roll:%f", angles[0], angles[1], angles[2]);
printf("]\n");
}
NNIE_FACE_PFPLD_RELEASE();
}
static char **s_ppChCmdArgv = NULL;
/******************************************************************************
* function : show usage
******************************************************************************/
void SAMPLE_SVP_Usage(char* pchPrgName)
{
printf("Usage : %s <index> \n", pchPrgName);
printf("index:\n");
printf("\t 4) Cnn(Read File).\n");
}
/******************************************************************************
* function : nnie sample
******************************************************************************/
int main(int argc, char *argv[])
{
int s32Ret = 1;
if (argc < 2 || argc > 2)
{
SAMPLE_SVP_Usage(argv[0]);
return 0;
}
if (!strncmp(argv[1], "-h", 2))
{
SAMPLE_SVP_Usage(argv[0]);
return 1;
}
s_ppChCmdArgv = argv;
switch (*argv[1])
{
case '0':
{
NNIE_FACE_DET_TEST();
}
break;
case '1':
{
NNIE_FACE_EXT_TEST();
}
break;
case '2':
{
NNIE_FACE_POSE_TEST();
}
break;
default :
{
SAMPLE_SVP_Usage(argv[0]);
}
break;
}
return s32Ret;
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/savior618/nniefacelib.git
[email protected]:savior618/nniefacelib.git
savior618
nniefacelib
nniefacelib
master

搜索帮助