【HaaS Python硬件积木】AS608指纹识别模块 打造指纹门禁 开门有手就行

这篇具有很好参考价值的文章主要介绍了【HaaS Python硬件积木】AS608指纹识别模块 打造指纹门禁 开门有手就行。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一、产品简介

ATK-AS608指纹识别模块是ALIENTEK推出的一款高性能的光学指纹识别模块。它采用的是指纹识别芯片公司杭州晟元芯片技术有限公司生产的AS608指纹识别芯片。该芯片内置DSP运算单元,集成了指纹识别算法,能高效快速采集图像并对指纹特征进行识别。 该模块配备了串口和USB接口,用户无需研究复杂的图像处理及指纹识别算法,只需通过简单的串口、USB按照通讯协议便可控制模块。本模块可应用于各种考勤机、保险箱柜 、指纹门禁系统、指纹锁等场合。

本文中主控板和AS608模块之间使用UART进行通信,实际使用过程中最少只需要使用VCC/TX/RX/GND四根引脚和主控板进行通信。模块接口外观及其定义如下:

【HaaS Python硬件积木】AS608指纹识别模块 打造指纹门禁 开门有手就行
名称 说明
VCC 模块电源正极
TX 串行数据输出,TTL逻辑电平
RX 串行数据输入,TTL逻辑电平
GND 地线
TOUCH 触摸板感应信号,默认高电平有效
UA 触摸板电源输入,3.3V
D+ USB D+数据线
D- USB D-数据线

二、技术参数

  • 供电电压:3.0V~5.5V,典型值:3.3V
  • 工作电流:30~60mA,典型值:40mA
  • ADC测量速率:8Bps~860Bps,可设置
  • UART接口配置(默认波特率:57600,数据位:8,停止位1,校验位:none,TTL电平)
  • USB接口支持全速2.0标准
  • 图像处理时间:<0.4秒
  • 上电延时:<0.1秒,模块上电后需要约 0.1S 初始化工作
  • 指纹搜索时间:<0.3秒
  • 拒真率:<1%
  • 认假率:<0.001%
  • 指纹存容量:300枚
  • 工作环境:温度-20~60摄氏度,湿度<90%(无凝露)

三、软件接口

AS608指纹识别模块HaaS Python驱动:下载地址

AS608(uartObj) - 创建AS608驱动对象

  • 函数原型:

fig = AS608(uartObj)

  • 参数说明:
参数 类型 必选参数? 说明
uartObj UART 调用此函数前需确保uartObj对象已经处于open状态
  • 返回值:

执行成功,返回指纹识别模块对象;创建失败,抛出Exception

  • 示例代码:
from driver import UART    # 驱动库
import as608               # AS608指纹识别模块库
uartDev = UART()
uartDev.open('as608')      # 按照board.json中名为"as608"的设备节点的配置参数(主设备UART波特率、起始位、数据位及停止位长度等)初始化UART类型设备对象
fig = as608.AS608(uartDev) # AS608指纹识别设备初始化
print("AS608 inited!")
uartDev.close()             # 关闭UART设备
del fig                     # 删除AS608指纹识别设备对象
  • 输出:
AS608 inited!

getEmptyPosition - 获取空白位置ID

  • 函数功能: 查询AS608内部空闲指纹存储ID,即未存储有效指纹模板的存储空间
  • 函数原型:

ADS1115.getEmptyPosition()

  • 参数说明:

  • 返回值: 成功返回非负值,代表可用指纹存储ID,失败返回as608.FAIL
  • 示例:
from driver import UART    # 驱动库
import as608               # AS608指纹识别模块库
uartDev = UART()
uartDev.open('as608')      # 按照board.json中名为"as608"的设备节点的配置参数(主设备UART波特率、起始位、数据位及停止位长度等)初始化UART类型设备对象
fig = as608.AS608(uartDev) # AS608指纹识别设备初始化
print("AS608 inited!")
id = fig.getEmptyPosition()
print("available id:", id)
uartDev.close()             # 关闭UART设备
del fig                     # 删除AS608指纹识别设备对象
  • 输出:
AS608 inited!
available id: 1

fingerEnroll - 指纹注册

  • 函数功能: 开始指纹注册操作,指纹识别的是通过将采集到的指纹和指纹库中的指纹进行特征匹配,匹配成功则指纹识别通过;否则指纹识别失败。需要“指纹注册”过程才能完成向指纹库录入指纹的目的。
  • 函数原型:

AS608.fingerEnroll(id)

  • 参数说明:
参数 类型 必选参数? 说明
id int 本次指纹注册成功后放在指纹识别库中的位置ID,范围为0~299
  • 返回值: 成功返回as608.SUCCESS;失败返回as608.FAIL
  • 示例:
from driver import UART    # 驱动库
import as608               # AS608指纹识别模块库
uartDev = UART()
uartDev.open('as608')      # 按照board.json中名为"as608"的设备节点的配置参数(主设备UART波特率、起始位、数据位及停止位长度等)初始化UART类型设备对象
fig = as608.AS608(uartDev) # AS608指纹识别设备初始化
print("AS608 inited!")
id = fig.getEmptyPosition()
print("available id:", id)
if id >= 0:
    fig.fingerEnroll(id)
uartDev.close()             # 关闭UART设备
del fig                     # 删除AS608指纹识别设备对象
  • 输出:
AS608 inited!
available id:1
wait for finger print on the pannel
finger detected
take off your finger, please
put on your finger again, please
creating finger model
store finger model
store finger model success

fingerSearch - 指纹识别

  • 函数功能: 进行指纹识别操作
  • 函数原型:

AS608.fingerSearch()

  • 参数说明:

  • 返回值: (result, id, confidence),返回值说明如下:
参数 类型 说明
result int as608.SUCCESS代表在指纹库中搜索到指纹;as608.FAIL代表未搜索到指纹
id int 该指纹在指纹库中的位置
confidence int 可信度,范围:0~65535,数值越大,可信度越高
  • 示例:
from driver import UART    # 驱动库
import as608               # AS608指纹识别模块库
uartDev = UART()
uartDev.open('as608')      # 按照board.json中名为"as608"的设备节点的配置参数(主设备UART波特率、起始位、数据位及停止位长度等)初始化UART类型设备对象
fig = as608.AS608(uartDev) # AS608指纹识别设备初始化
print("AS608 inited!")
result, id, confidence = fig.fingerSearch()
if result == as608.SUCCESS:
    print('finger search successs,', id, confidence)
else:
    print('your finger was not enrolled')
uartDev.close()             # 关闭UART设备
del fig                     # 删除AS608指纹识别设备对象
  • 输出:
AS608 inited!
finger search successs, 0, 190

deleteModel - 从指纹库中删除特定指纹

  • 函数功能: 从指纹库中删除特定指纹
  • 函数原型:

AS608.deleteModel(id)

  • 参数说明:
参数 类型 必选参数? 说明
id int 要删除的指纹在指纹识别库中的位置ID,范围为0~299
  • 返回值: 成功返回as608.SUCCESS;失败返回as608.FAIL
  • 示例:
from driver import UART    # 驱动库
import as608               # AS608指纹识别模块库
uartDev = UART()
uartDev.open('as608')      # 按照board.json中名为"as608"的设备节点的配置参数(主设备UART波特率、起始位、数据位及停止位长度等)初始化UART类型设备对象
fig = as608.AS608(uartDev) # AS608指纹识别设备初始化
print("AS608 inited!")
id = 0
fig.deleteModel(id)
print("model delete done")
uartDev.close()             # 关闭UART设备
del fig                     # 删除AS608指纹识别设备对象
  • 输出:
AS608 inited!
model delete done

emptyDatabase - 清空指纹库

  • 函数功能: 清空指纹库

!慎用!

  • 函数原型:

AS608.emptyDatabase()

  • 参数说明:

  • 返回值: 成功返回as608.SUCCESS;失败返回as608.FAIL
  • 示例:
from driver import UART    # 驱动库
import as608               # AS608指纹识别模块库
uartDev = UART()
uartDev.open('as608')      # 按照board.json中名为"as608"的设备节点的配置参数(主设备UART波特率、起始位、数据位及停止位长度等)初始化UART类型设备对象
fig = as608.AS608(uartDev) # AS608指纹识别设备初始化
print("AS608 inited!")
fig.emptyDatabase()
print("empty database done")
uartDev.close()             # 关闭UART设备
del fig                     # 删除AS608指纹识别设备对象
  • 输出:
AS608 inited!
empty database done

下面的API是AS608模块提供的原子功能的API,如果开发者对这个模块的功能比较熟悉,可以采用,但如果开发者对这个模块不熟悉,不建议直接使用下面的API。

getImage - 采集指纹图片

  • 函数功能: 清空指纹库

!慎用!

  • 函数原型:

AS608.getImage()

  • 参数说明:

  • 返回值: 成功返回as608.SUCCESS;失败返回as608.FAIL
  • 示例: 请参考fingerEnroll函数实现里边的用法

image2Character - 指纹图片生成特征值

  • 函数功能: 清空指纹库

!慎用!

  • 函数原型:

AS608.image2Character(bufferId)

  • 参数说明:
参数 类型 必选参数? 说明
bufferId int 转换后的特征值存储缓冲区ID, 1代表将特征值存储在Buffer1中;2代表将特征值存储在Buffer2中
  • 返回值: 成功返回0;失败返回as608.FAIL
  • 示例: 请参考fingerEnroll函数实现里边的用法

createModel - 合并特征并生成模板

  • 函数功能: 合并特征并生成模板
  • 函数原型:

AS608.createModel()

  • 参数说明:

  • 返回值: 成功返回as608.SUCCESS;失败返回as608.FAIL
  • 示例: 请参考fingerEnroll函数实现里边的用法

storeModel - 存储模板

  • 函数功能: 将指纹对应的特征模板存放到指纹数据库中
  • 函数原型:

AS608.storeModel(id)

  • 参数说明:
参数 类型 必选参数? 说明
id int 指纹存储在指纹库中的位置,范围[0,299]
  • 返回值: 成功返回as608.SUCCESS;失败返回as608.FAIL
  • 示例: 请参考fingerEnroll函数实现里边的用法

search - 在指纹库中搜索指纹

  • 函数功能: 在指纹库中搜索特征模板
  • 函数原型:

AS608.search()

  • 参数说明: 无
  • 返回值: (result, id, confidence),变量说明如下:
参数 类型 说明
result int as608.SUCCESS代表在指纹库中搜索到指纹;as608.FAIL代表未搜索到指纹
id int 该指纹在指纹库中的位置
confidence int 可信度,范围:0~65535,数值越大,可信度越高
  • 示例: 请参考fingerSearch函数实现里边的用法

四、接口案例

此使用实例在board.json中定义了名为as608的UART类型的对象。在Python脚本中首先录制指纹,然后周期性的进行指纹识别

  • board.json配置:
{
    "name": "board-name",
    "version": "1.0.0",
    "io": {
        "as608": {
            "type": "UART",
            "port": 2,
            "dataWidth": 8,
            "baudRate": 57600,
            "stopBits": 2,
            "flowControl": "disable",
            "parity": "none"
        }
    },
    "debugLevel": "ERROR",
    "repl": "disable"
}
  • 案例代码:
from driver import UART    # 驱动库
import as608               # AS608指纹识别模块库
uartDev = UART()
uartDev.open('as608')      # 按照board.json中名为"as608"的设备节点的配置参数(主设备UART波特率、起始位、数据位及停止位长度等)初始化UART类型设备对象
fig = as608.AS608(uartDev) # AS608指纹识别设备初始化
print("AS608 inited!")
id = fig.getEmptyPosition()
print("empty record id:", id)
ret = fig.fingerEnroll(id)
if ret:
    print("finger enroll failed!")
else:
    print("finger enroll success!")
while True:
    ret, id, score = fig.fingerSearch()
    print(ret, id, score)
uartDev.close()             # 关闭UART设备
del fig                     # 删除AS608指纹识别设备对象
  • 输出:
AS608 inited!
empty record id:1
wait for finger print on the pannel
finger detected
take off your finger, please
put on your finger again, please
creating finger model
store finger model
store finger model success
finger enroll success!

五、通信协议

主控芯片和AS608之间采用UART进行通信。

发往AS608模块的指令都遵循如下的格式:

名称 包头 芯片地址 包标识 包长度 指令标识 参数1 ... 参数n 校验和
字节数(单位:bytes) 2 4 1 2 1 N N N 2
内容 0xEF01 xxxx 01 N=

AS608模块回复的响应都遵循如下的格式:

名称 包头 芯片地址 包标识 包长度 确认码 返回参数 校验和
字节数(单位:bytes) 2 4 1 2 1 N 2
内容 0xEF01 xxxx 01 N=

AS608模组共提供31条指令,实际使用中最常用的指令有如下几条:

指令码 功能说明
01H 从传感器上读入图像存于图像缓冲区
02H 根据原始图像生成指纹特征存于CharBuffer1或CharBuffer2
03H 精确比对CharBuffer1与CharBuffer2中的特征文件
04H 以CharBuffer1或CharBuffer2中的特征文件搜索整个或部分指纹库
05H 将CharBuffer1与CharBuffer2中的特征文件合并生成模板存于CharBuffer1与CharBuffer2
06H 将特征缓冲区中的文件储存到flash指纹库中
0CH 删除flash指纹库中的一个特征文件
0DH 清空flash指纹库
0EH 设置系统参数
0FH 读系统基本参数
1BH 高速搜索FLASH
1DH 读有效模板个数

AS608模块回复的响应包中的确认码如下:

确认码 功能说明
00H 表示指令执行完毕或OK
01H 表示数据包接收错误
02H 表示传感器上没有手指
03H 表示录入指纹图像失败
04H 表示指纹图像太干、太淡而生不成特征
05H 表示指纹图像太湿、太糊而生不成特征
06H 表示指纹图像太乱而生不成特征
07H 表示指纹图像正常,但特征点太少(或面积太小)而生不成特征
08H 表示指纹不匹配
09H 表示没搜索到指纹
0aH 表示特征合并失败
0bH 表示访问指纹库时地址序号超出指纹库范围
0cH 表示从指纹库读模板出错或无效
0dH 表示上传特征失败
0eH 表示模块不能接受后续数据包
0fH 表示上传图像失败
10H 表示删除模板失败
11H 表示清空指纹库失败
13H 表示口令不正确
15H 表示缓冲区内没有有效原始图而生不成图像
18H 表示读写 FLASH 出错
19H 未定义错误
1AH 无效寄存器号
1BH 寄存器设定内容错误号
1CH 记事本页码指定错误
1DH 端口操作失败
1EH 自动注册失败
1FH 指纹库满

实际控制此指纹识别模块进行指纹录入和指纹识别的流程请参考下图。

【HaaS Python硬件积木】AS608指纹识别模块 打造指纹门禁 开门有手就行

参考文献及购买链接

[1] AS60x指纹识别SoC通讯手册

[2] 购买链接文章来源地址https://www.toymoban.com/news/detail-453747.html

到了这里,关于【HaaS Python硬件积木】AS608指纹识别模块 打造指纹门禁 开门有手就行的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • K_A12_007 基于STM32等单片机驱动AS608光学指纹识别模块 OLED0.96显示

    注意:此处程序用的波特率都是9600 使用前请用上位机把模块波特率调到9600 上位机使用与下载 直戳跳转 单片机型号 测试条件 模块名称 代码功能 STC89C52RC 晶振11.0592M AS608光学指纹模块 STC89C52RC驱动AS608光学指纹模块 串口与OLED0.96双显示 STM32F103C8T6 晶振8M/系统时钟72M AS608光学指

    2024年02月06日
    浏览(44)
  • 【毕设选题】opencv 图像识别 指纹识别 - python

    🔥 这两年开始毕业设计和毕业答辩的要求和难度不断提升,传统的毕设题目缺少创新和亮点,往往达不到毕业答辩的要求,这两年不断有学弟学妹告诉学长自己做的项目系统达不到老师的要求。 为了大家能够顺利以及最少的精力通过毕设,学长分享优质毕业设计项目,今天

    2024年02月07日
    浏览(49)
  • 竞赛保研 opencv 图像识别 指纹识别 - python

    🔥 优质竞赛项目系列,今天要分享的是 🚩 基于机器视觉的指纹识别系统 🥇学长这里给一个题目综合评分(每项满分5分) 难度系数:3分 工作量:3分 创新点:4分 该项目较为新颖,适合作为竞赛课题方向,学长非常推荐! 🧿 更多资料, 项目分享: https://gitee.com/dancheng-seni

    2024年02月03日
    浏览(61)
  • 大数据毕设项目 - opencv 图像识别 指纹识别 - python

    🔥 这两年开始毕业设计和毕业答辩的要求和难度不断提升,传统的毕设题目缺少创新和亮点,往往达不到毕业答辩的要求,这两年不断有学弟学妹告诉学长自己做的项目系统达不到老师的要求。 为了大家能够顺利以及最少的精力通过毕设,学长分享优质毕业设计项目,今天

    2024年02月03日
    浏览(37)
  • 竞赛 python opencv 深度学习 指纹识别算法实现

    🔥 优质竞赛项目系列,今天要分享的是 🚩 python opencv 深度学习 指纹识别算法实现 🥇学长这里给一个题目综合评分(每项满分5分) 难度系数:3分 工作量:4分 创新点:4分 该项目较为新颖,适合作为竞赛课题方向,学长非常推荐! 🧿 更多资料, 项目分享: https://gitee.com/d

    2024年04月16日
    浏览(72)
  • python opencv 深度学习 指纹识别算法实现 计算机竞赛

    🔥 优质竞赛项目系列,今天要分享的是 🚩 python opencv 深度学习 指纹识别算法实现 🥇学长这里给一个题目综合评分(每项满分5分) 难度系数:3分 工作量:4分 创新点:4分 该项目较为新颖,适合作为竞赛课题方向,学长非常推荐! 🧿 更多资料, 项目分享: https://gitee.com/d

    2024年02月06日
    浏览(62)
  • 计算机竞赛 python opencv 深度学习 指纹识别算法实现

    🔥 优质竞赛项目系列,今天要分享的是 🚩 python opencv 深度学习 指纹识别算法实现 🥇学长这里给一个题目综合评分(每项满分5分) 难度系数:3分 工作量:4分 创新点:4分 该项目较为新颖,适合作为竞赛课题方向,学长非常推荐! 🧿 更多资料, 项目分享: https://gitee.com/d

    2024年02月13日
    浏览(77)
  • Arduino开发实例-AS608光学指纹传感器驱动

    AS608 光学指纹传感器可用于扫描指纹,它也可以通过串行通信将处理后的数据发送到微控制器。 所有注册的指纹都存储在这个模块中。 AS608 最多可存储 127 个独立指纹。 最重要的特点是: 电源电压:3.3V 最大电流供应:60mA 分辨率:500dpi 最大指纹成像时间:1s 传感器引脚

    2024年01月17日
    浏览(55)
  • 基于STM32F103——AS608指纹模块+串口打印

    最近用STM32F103做一个智能门锁小玩意,其中用到指纹模块,我这里也单独的写一下笔记,不过我只是了解了基本的,就是我做门禁卡要用到的几个东西,其它还没了解。为了方便,做一下记录。我这里没有用到按键和显示屏,所以还是串口输出输入来控制了 哈哈哈哈 这里就

    2023年04月09日
    浏览(45)
  • 指纹识别综述(4): 指纹匹配

    本文会不定期更新,以反映一些新的进展和思考。 我读博期间放假回老家,村里的大爷问我研究什么。我说研究指纹识别。大爷诧异道,把两个指纹摞在一起,比一比,不就可以了?有什么好研究的?大爷就是大爷,一句话击中要害。指纹识别就两步,首先对齐指纹,然后判

    2023年04月26日
    浏览(56)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包