当前位置: 首页 > news >正文

人脸识别之--计算余弦相似度-android

余弦相似度是比对两个向量是否一致,余弦相似度是通过计算两个向量的夹角余弦值来衡量它们之间的相似度,算出来的值可以直接用作相似度的分数。

公式:

余弦相似度和欧式距离经常用来人脸识别特征对比。

其中:

1、余弦相似度是通过计算两个向量的夹角余弦值来衡量它们之间的相似度

2、欧式距离是通过计算两个向量之间的欧氏距离来衡量它们之间的相似度

  • 余弦相似度的优点是在计算相似度时不受向量的绝对大小影响,只受向量的方向影响,因此适用于文本、图像等数据的相似度度量。
  • 欧式距离的优点是直观易理解,计算简单。但是欧式距离在计算高维稀疏数据时可能会受到维度灾难的影响,且对异常值敏感。

在人脸识别中余弦距离用的比较多。

这里用来计算两组特征值的相似度,具体代码如下:

package com.hax.util;import com.hax.vo.FaceInfo;import java.util.List;/*** add hmy* 人脸比对工具* 2024年6月12日16:34:22*/
public class FaceUtils {// 计算平方值private static double euclideanNorm(double []vec) {double sum = 0.0;for (int i =0; i < vec.length; i++){sum += vec[i] * vec[i];}return Math.sqrt(sum);}// 计算平方值private static double euclideanNorm(List<Float> vec) {double sum = 0.0f;for (int i =0; i < vec.size(); i++){sum += vec.get(i) * vec.get(i);}return Math.sqrt(sum);}// 计算两个向量的点积private static double dotProduct(double[] vec1,double[] vec2) {double result = 0.0;for (int i = 0; i < vec1.length; ++i) {result += vec1[i] * vec2[i];}return result;}// 计算两个向量的点积private static double dotProduct(List<Float> vec1, List<Float> vec2) {double result = 0.0f;for (int i = 0; i < vec1.size(); ++i) {result += (vec1.get(i) * vec2.get(i));}return result;}//计算余弦相似度 返回具体分值public static double verification(FaceInfo src, FaceInfo dest) {double sim = dotProduct(src.getEmbed(), dest.getEmbed()) /(euclideanNorm(src.getEmbed()) * euclideanNorm(dest.getEmbed()));sim = 0.5 + sim * 0.5;//把-1到1的范围 隐射到0-1的范围 -1到0 映射0-0.5 0到0.5隐射到0.5-0.75 0.5到1 映射到0.75-1return sim;}
}

其中Embed值是List<Float> 值为512维。

http://www.lryc.cn/news/370413.html

相关文章:

  • C语言王国——数据的内存管理
  • Kotlin 协程真的轻量吗?
  • Cantata 24.04 全新发布:以代码为中心的测试实现革命性升级!
  • 【问题记录】VMware 17.5.1下载VMware tools失败报错的解决方法
  • Android - RadioGroup中多个radiobutton同时被选中问题
  • 如何在ElementTree文本中嵌入标签
  • C语言宏定义+条件编译
  • python实现自动化测试框架如何进行数据参数化?这个包可以了解下
  • 面试题:Redis和MySql数据库如何保持数据一致性?
  • 直流遥控器 继电器8-10V应用 降压恒压SL3036电源芯片
  • 论文Abstract怎么写
  • PS系统教程19
  • Excel函数之MAP
  • 在2024年WWDC大会上,苹果宣布了其全新的“Apple Intelligence”AI功能以及ISO18功能
  • 解决linux jenkins要求JDK版本与项目版本JDK不一致问题
  • 推荐一款WPF绘图插件OxyPlot
  • 普通表在线重定义为分区表
  • 自动驾驶场景下TCP协议参数优化调整案例分享
  • 奇思妙想:多头RAG
  • H323 截包分析辅流问题
  • 低成本和颜值兼顾的 HomeLab 设备:HPE MicroServer Gen10(二)
  • 面试题:ArrayList和LinkedList的区别
  • 【王树森】深度强化学习(DRL)学习笔记
  • LLM应用实战:当图谱问答(KBQA)集成大模型(三)
  • Django框架中Ajax GET与POST请求的实战应用
  • web前端怎么挣钱, 提升技能,拓宽就业渠道
  • 基于Python的信号处理(包络谱,低通、高通、带通滤波,初级特征提取,机器学习,短时傅里叶变换)及轴承故障诊断探索
  • 大型语言模型智能体(LLM Agent)在实际使用的五大问题
  • C语言内存管理
  • AD24设计步骤