【进阶OpenCV】 (5)--指纹验证

文章目录

  • 指纹验证
    • [1. 验证原理](#1. 验证原理)
    • [2. 读取图片](#2. 读取图片)
    • [3. 计算特征匹配点](#3. 计算特征匹配点)
  • 总结

指纹验证

指纹验证基于人类指纹的独特性和稳定性。每个人的指纹在图案、断点和交叉点上各不相同,这种唯一性和终生不变性使得指纹成为身份验证的可靠手段。指纹识别技术通过采集和分析指纹图像,提取指纹特征,并与预先存储的指纹特征进行比对,从而确认身份。

1. 验证原理

通过对比两个指纹之间的相似度,来确认两者是否匹配。其中,确认相似度是通过计算两个指纹之间的关键特征点数量,若是关键特征点数量匹配超过某个设定值,我们则认为他们是一个人的。

2. 读取图片

python 复制代码
import cv2
def cv_show(name,img):
    cv2.imshow(name,img)
    cv2.waitKey(0)   
python 复制代码
if __name__ == '__main__':
    src1 = cv2.imread("zw1.bmp")
    cv_show("zw1",src1)
    src2 = cv2.imread("zw2.bmp")
    cv_show("zw2", src2)
    model = cv2.imread("model.bmp")
    cv_show("model",model)

3. 计算特征匹配点

通过SIFT特征提取方法,计算两者之间的特征匹配点数量,若是数量达到设定值(此处设定为500),则认证通过,反之,认证失败。

python 复制代码
def verification(src,model):
    # 创建SIFT特征提取器
    sift = cv2.SIFT_create()
    # 检测关键点和计算描述符(特征向量) 源图像
    kp1,des1 = sift.detectAndCompute(src,None)
    # 检测关键点和计算描述符  模板图像
    kp2, des2 = sift.detectAndCompute(model, None)
    # 创建FLANN匹配器
    flann = cv2.FlannBasedMatcher()
    # 使用K近邻匹配(des1中的每个描述符与des2中的最近两个描述符进行匹配)
    matches = flann.knnMatch(des1,des2,k=2)

    ok = []
    for m,n in matches:
        # 根据Lowe's比率测试,选择最佳匹配
        if m.distance < 0.8 * n.distance:
            ok.append(m)
    # 统计通过筛选的匹配数量
    num = len(ok)
    if num >= 500:
        result = "认证通过"
    else:
        result = "认证失败"
    return result
python 复制代码
result1 = verification(src1,model)
result2 = verification(src2,model)
print("src1验证结果为:",result1)
print("src2验证结果为:", result2)
----------------
src1验证结果为: 认证通过
src2验证结果为: 认证失败

总结

本篇介绍了,通过使用SIFT特征特征提取方法,统计两者之间的特征匹配点数量,来验证指纹是否匹配。

相关推荐
小e说说11 分钟前
解锁小学生学习兴趣密码,这些互动APP超神了!
人工智能
风雅GW13 分钟前
多 Agent 系统设计参考框架(OpenClaw 实现版)
人工智能·ai·agent·openclaw
庞轩px31 分钟前
Embedding与向量语义——大模型是怎样“理解”文字的?
人工智能·自然语言处理·embedding·向量检索·余弦相似度·rag·高维向量空间
我是发哥哈33 分钟前
深度评测:五款主流AI培训平台的课程交付能力对比
大数据·人工智能·学习·机器学习·ai·chatgpt
eastyuxiao35 分钟前
流程图 + 配置清单 落地应用于团队 / 公司日常文档处理场景
人工智能·流程图
Datakeji39 分钟前
2026年AI大模型接口加速站榜单新鲜出炉!五大平台硬核数据全面揭秘
大数据·人工智能
qq_160144871 小时前
从月薪8K到15K,主管说我胜在“多懂了一层” 我的职场能力补齐日记
人工智能
图解AI系列1 小时前
我打算用 12 天搭一套 AI 客服系统(企业级实战,附源码)
大数据·人工智能
网络工程小王1 小时前
【LCEL 链式调用详解】调用篇-2
java·服务器·前端·数据库·人工智能
BU摆烂会噶1 小时前
【LangGraph】运行时上下文(Runtime Context)
人工智能·python·langchain