人脸检测:正脸侧脸、是否仰头低头判断

2024-01-10 14:04

本文主要是介绍人脸检测:正脸侧脸、是否仰头低头判断,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

  • 鼻子与两眼的向量正交时,设交点为a,理想情况下两眼到a距离的比值应该为1。
    • 考虑到大脸和小脸,我们设m为两眼中心点,则判断是否是正脸侧脸式子为: d i s = ( a − m ) 2 ( x 1 − x 2 ) 2 dis = \frac{(a-m)^2}{(x1-x2)^2} dis=(x1x2)2(am)2
  • 设b为鼻子到嘴角向量正交时的交点,则鼻子到a的距离和到b的距离在不仰头低头情况下存在一定比例关系,并且应该在[1,2]之间。
    • 数值越大,头越低。
    def is_front_face(keypoints):# keypoints: 人脸关键点(左眼、右眼、鼻子、左嘴角、右嘴角)# 侧脸判断a = orthogonal_point(keypoints[0], keypoints[1], keypoints[2])# dis_front = abs(np.log(np.linalg.norm(keypoints[0] - a) / np.linalg.norm(keypoints[1] - a)))m = (keypoints[0] + keypoints[1]) / 2dis_front = np.linalg.norm(a - m) / np.maximum(np.linalg.norm(keypoints[0] - keypoints[1]), 1e-10)if dis_front > 0.5:return False# 抬头低头判断b = orthogonal_point(keypoints[3], keypoints[4], keypoints[2])dis_bow = np.linalg.norm(keypoints[2] - a) / np.maximum(np.linalg.norm(keypoints[2] - b), 1e-10)if dis_bow > 2.2 or dis_bow < 0.7:return Falsereturn Truedef orthogonal_point(x1, x2, x3):x1, y1 = x1[0], x1[1]x2, y2 = x2[0], x2[1]x3, y3 = x3[0], x3[1]# conb, lambdax = np.linalg.solve(np.array([[1, x1], [1, x2]]), np.array([y1, y2]))lambdax = (y2 - y1) / np.maximum((x2 - x1), 1e-10)conb = y1 - lambdax * x1ax = (x3 * (x2 - x1) + y3 * (y2 - y1) - (y2 - y1) * conb) / np.maximum((x2 - x1) + (y2 - y1) * lambdax, 1e-10)ay = lambdax * ax + conbreturn np.array([ax, ay])

这篇关于人脸检测:正脸侧脸、是否仰头低头判断的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/591052

相关文章

JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法

《JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法》:本文主要介绍JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法,每种方法结合实例代码给大家介绍的非常... 目录引言:为什么"相等"判断如此重要?方法1:使用some()+includes()(适合小数组)方法2

如何通过try-catch判断数据库唯一键字段是否重复

《如何通过try-catch判断数据库唯一键字段是否重复》在MyBatis+MySQL中,通过try-catch捕获唯一约束异常可避免重复数据查询,优点是减少数据库交互、提升并发安全,缺点是异常处理开... 目录1、原理2、怎么理解“异常走的是数据库错误路径,开销比普通逻辑分支稍高”?1. 普通逻辑分支 v

从基础到进阶详解Python条件判断的实用指南

《从基础到进阶详解Python条件判断的实用指南》本文将通过15个实战案例,带你大家掌握条件判断的核心技巧,并从基础语法到高级应用一网打尽,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一... 目录​引言:条件判断为何如此重要一、基础语法:三行代码构建决策系统二、多条件分支:elif的魔法三、

Linux实现查看某一端口是否开放

《Linux实现查看某一端口是否开放》文章介绍了三种检查端口6379是否开放的方法:通过lsof查看进程占用,用netstat区分TCP/UDP监听状态,以及用telnet测试远程连接可达性... 目录1、使用lsof 命令来查看端口是否开放2、使用netstat 命令来查看端口是否开放3、使用telnet

Python脚本轻松实现检测麦克风功能

《Python脚本轻松实现检测麦克风功能》在进行音频处理或开发需要使用麦克风的应用程序时,确保麦克风功能正常是非常重要的,本文将介绍一个简单的Python脚本,能够帮助我们检测本地麦克风的功能,需要的... 目录轻松检测麦克风功能脚本介绍一、python环境准备二、代码解析三、使用方法四、知识扩展轻松检测麦

Linux系统性能检测命令详解

《Linux系统性能检测命令详解》本文介绍了Linux系统常用的监控命令(如top、vmstat、iostat、htop等)及其参数功能,涵盖进程状态、内存使用、磁盘I/O、系统负载等多维度资源监控,... 目录toppsuptimevmstatIOStatiotopslabtophtopdstatnmon

Go语言中nil判断的注意事项(最新推荐)

《Go语言中nil判断的注意事项(最新推荐)》本文给大家介绍Go语言中nil判断的注意事项,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1.接口变量的特殊行为2.nil的合法类型3.nil值的实用行为4.自定义类型与nil5.反射判断nil6.函数返回的

C++ 检测文件大小和文件传输的方法示例详解

《C++检测文件大小和文件传输的方法示例详解》文章介绍了在C/C++中获取文件大小的三种方法,推荐使用stat()函数,并详细说明了如何设计一次性发送压缩包的结构体及传输流程,包含CRC校验和自动解... 目录检测文件的大小✅ 方法一:使用 stat() 函数(推荐)✅ 用法示例:✅ 方法二:使用 fsee

OpenCV实现实时颜色检测的示例

《OpenCV实现实时颜色检测的示例》本文主要介绍了OpenCV实现实时颜色检测的示例,通过HSV色彩空间转换和色调范围判断实现红黄绿蓝颜色检测,包含视频捕捉、区域标记、颜色分析等功能,具有一定的参考... 目录一、引言二、系统概述三、代码解析1. 导入库2. 颜色识别函数3. 主程序循环四、HSV色彩空间

python判断文件是否存在常用的几种方式

《python判断文件是否存在常用的几种方式》在Python中我们在读写文件之前,首先要做的事情就是判断文件是否存在,否则很容易发生错误的情况,:本文主要介绍python判断文件是否存在常用的几种... 目录1. 使用 os.path.exists()2. 使用 os.path.isfile()3. 使用