人脸识别-闭集测试指标CMC曲线

做FaceIdentification时候,需要用到CMC曲线,横坐标为rank,纵坐标是faceIdentification Rate。

在绘制CMC曲线之前,做好rowNames,colNames,simMatrix三个矩阵的准备,分别为m个样本的标签ID,n个注册集中ID(无重复有序),分数矩阵simMatrix是m*n的。每行代表一个样本的得分。

simMatrix(i,j)表示第i个样本在第j个标签ID的得分,分越大就越相似。分数一般在[0,1]之间。

%% 行代表样本ID,列代表注册的人脸ID(每个唯一)
rowNames = string(Labels); % m*1的
colNames = string(uniqueLabel'); % 1*n的
simMatrix = scoreMatrix; % m*n的
 
[orderMatrix,index] = sort(simMatrix,2,'descend');

%% plot CMC 曲线
nums = size(orderMatrix,1);
rankN = 20;
accuracy = zeros(1,rankN);
for i = 1:rankN % 计算rank1到rankN
    correctNumber = 0;
    for j = 1:nums
        currentColNamesIndex = index(j,1:i);
        isIn = ismember(rowNames(j),colNames(currentColNamesIndex));
        if isIn
            correctNumber = correctNumber+1;
        end
    end
    accuracy(i) = correctNumber/nums;
end
figure;
hold on;
plot(1:i,accuracy,'r-')
grid on
xlabel('rank');
ylabel('faceIdentification Rate')
title('CMC曲线')


上述代码实现原理点这里


  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,关于人脸识别的问题,以下是使用OpenCV-Java实现人脸识别的代码示例: 1. 引入OpenCV-Java库 在项目中引入OpenCV-Java库,可以从官网下载对应的版本,引入后,我们就可以调用OpenCV-Java提供的API来实现人脸识别。 2. 加载人脸识别器 在使用OpenCV-Java实现人脸识别前,我们需要加载一个训练好的分类器,可以使用官方提供的人脸识别模型,或自己训练。加载过程如下: ``` CascadeClassifier faceDetector = new CascadeClassifier("haarcascade_frontalface_alt.xml"); ``` 3. 读取图片并识别人脸 加载分类器后,我们可以读取一张图片并进行人脸识别,具体实现代码如下: ``` Mat image = Imgcodecs.imread("test.jpg"); // 读取图片 Imgproc.cvtColor(image, image, Imgproc.COLOR_BGR2GRAY); // 转为灰度图 Imgproc.equalizeHist(image, image); // 直方图均衡化,提高图像质量 Rect[] faces = faceDetector.detectMultiScale(image); // 识别人脸 for (Rect rect : faces) { Imgproc.rectangle(image, new Point(rect.x, rect.y), new Point(rect.x + rect.width, rect.y + rect.height), new Scalar(0, 255, 0)); // 绘制人脸框 } Imgcodecs.imwrite("result.jpg", image); // 保存结果 ``` 其中,`detectMultiScale` 方法用于检测出图像中的人脸,返回一个`Rect`类型的数组,每个元素代表一个人脸的位置和大小。 4. 运行程序 将以上代码放入一个Java类中,运行程序即可实现人脸识别。注意,需要引入`org.opencv.core.Mat`、`org.opencv.core.Rect`、`org.opencv.core.Point`、`org.opencv.core.Scalar`、`org.opencv.imgcodecs.Imgcodecs`、`org.opencv.imgproc.Imgproc`等OpenCV-Java的类。 希望能够对您有所帮助!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值