打印
[应用相关]

基于ARM的手指静脉识别系统

[复制链接]
楼主: 原来是wjc
手机看帖
扫描二维码
随时随地手机跟帖
21
原来是wjc|  楼主 | 2022-2-27 23:49 | 只看该作者 |只看大图 回帖奖励 |倒序浏览


使用特权

评论回复
22
原来是wjc|  楼主 | 2022-2-27 23:51 | 只看该作者
Np为点集P中元素的个数。

使用特权

评论回复
23
原来是wjc|  楼主 | 2022-2-27 23:52 | 只看该作者
实验结果

把在PC机开发的应用软件移植到ARM11板,上电开启操作系统运行该软件,开始采集和测试手指静脉图像的效果图如图7所示。

使用特权

评论回复
24
原来是wjc|  楼主 | 2022-2-27 23:52 | 只看该作者
本软件把图像采集、预处理等一系列过程合成到一起进行操作,实现一键完成,使其更加接近产品化。录入用户图像信息时,图像处理达到了每次约0.5 s的速度,令人满意。实验测试中,采集50个手指的静脉图像,每个手指采集4次,一共采集了200幅静脉图像,构成手指静脉数据库。根据本文的方法,来验证算法的匹配识别效果。测试1:1匹配识别,将每个手指的1个样本分别与其他3个样本进行比对完成识别,每次识别过程达到约0.4 s的速度,得到的结果如表1所示,达到了预期的效果。

使用特权

评论回复
25
原来是wjc|  楼主 | 2022-2-27 23:53 | 只看该作者
本文构建了一种基于ARM技术的嵌入式手指静脉识别系统。设计的硬件平台稳定性好、集成度高;采用的WinCE 6.0界面友好、画面清晰;开发的识别应用软件可以开机启动,便于操作,使本识别系统具有很好的人机交互特性。同时针对嵌入式系统采用一套合适的手指静脉识别算法。实验表明,该手指静脉识别系统可以实现快速图像处理和识别,与基于PC机的识别系统相比,具有体积小、重量轻、易于移动与操作、易于集成等优点。

使用特权

评论回复
26
童雨竹| | 2022-10-27 08:02 | 只看该作者

内部电路工作电圧是通过内部电压调节器调节电源电压得到的

使用特权

评论回复
27
Pulitzer| | 2022-10-27 09:05 | 只看该作者

单片机的外部都连接有象电池等电源部分

使用特权

评论回复
28
公羊子丹| | 2022-10-27 11:01 | 只看该作者

通常选择0.01μF~0.1μF的陶瓷电容作为旁路电容。

使用特权

评论回复
29
Wordsworth| | 2022-10-27 12:04 | 只看该作者

主时钟振荡器主要用作CPU的工作时钟

使用特权

评论回复
30
Clyde011| | 2022-10-27 13:07 | 只看该作者

与15号引脚连接的C1称为旁路电容

使用特权

评论回复
31
万图| | 2022-10-27 15:03 | 只看该作者

要在外部连接一个振荡电路提供时钟信号

使用特权

评论回复
32
Uriah| | 2022-10-27 16:06 | 只看该作者

电压范围称为工作电源电压

使用特权

评论回复
33
帛灿灿| | 2022-10-27 18:02 | 只看该作者

时序电路是按时钟信号(CK)的上升沿(信号从L→H的变化)或下降沿(信号从H→L的变化)同步工作的

使用特权

评论回复
34
Bblythe| | 2022-10-27 19:05 | 只看该作者

电源电压处于1.6V到5.5V之间

使用特权

评论回复
35
童雨竹| | 2023-9-25 08:02 | 只看该作者

电路的结构类似于全桥式,只是把其中的两只开关管(T3、T4)换成了两只等值大电容C1、C2。

使用特权

评论回复
36
Uriah| | 2023-9-25 09:04 | 只看该作者

//*************************************************************************************************
//  Copyright (c)         深圳市赛元微电子有限公司
//        文件名称        :  S_TouchKeyCFG.c
//        作者                :
//        模块功能        :  触控键配置文件
//         版本                :
//         更改记录        :
//        注意事项        :  用户需要配置的文件在S_TouchKeyCFG.h中
//  库版本标记        :
//************************************************************************************************
#include "S_TouchKeyCFG.h"
#include "TKDriver.h"
#include "stdio.h"
//*************************************************************************************
//                844 寄存器定义
//*************************************************************************************
/*PSW*/
sfr         TK_PSW            =         0xD0;        //程序状态字
sbit         TK_CY                =         TK_PSW^7;        //进位  

//===========================================================================
//全局变量定义
unsigned        char        xdata                SOCAPI_TouchKeyStatus;                                        //API接口状态:bit7-一轮扫描完成标志  1:完成         0:未完成
                                                                                                                                            //                           bit6-通道触摸计数溢出标志 1:溢出         0:未溢出
//===============================================================================
//全局变量声明:该区域不可修改
unsigned         int         xdata                RawData [SOCAPI_SET_TOUCHKEY_TOTAL];                       
unsigned         int                xdata                BaseLine[SOCAPI_SET_TOUCHKEY_TOTAL];
unsigned    int                 xdata                FilterData[SOCAPI_SET_TOUCHKEY_TOTAL];                                                                                               
unsigned        char    idata                RestAreaCnt[SOCAPI_SET_TOUCHKEY_TOTAL];                        
unsigned        char    idata                TouchCnt[SOCAPI_SET_TOUCHKEY_TOTAL];                               
unsigned        char    idata                NoTouchCnt[SOCAPI_SET_TOUCHKEY_TOTAL];                         
unsigned        char        xdata                CurrentChannel[SOCAPI_SET_TOUCHKEY_TOTAL];                                                     
unsigned    char    idata             LowFingerDataCnt[SOCAPI_SET_TOUCHKEY_TOTAL];
unsigned        char    xdata                FloatAreaCnt[SOCAPI_SET_TOUCHKEY_TOTAL];
unsigned         char         idata             BaseLineAdjusttmp[SOCAPI_SET_TOUCHKEY_TOTAL];         
int                 xdata             DifferAccum[SOCAPI_SET_TOUCHKEY_TOTAL];
char                    xdata                SetNoiseThreshold;
unsigned         char        idata                ConfirmTouchCnt;
unsigned         char        idata                MultipleDealTpye = 0;

//自定义变量
unsigned         int         idata              UpdateBaseLNum;                                                 // 单键长按计数器
unsigned         int         idata              MultipleLNum;                                                // 多按键干扰计数

//外部变量接口
extern         unsigned        char        data                CurrentChannelMax;                //当前选中的keysensor的个数
extern  bit  bMultiple;        //多按键标志       
extern         bit  GetIsNeedUpdateBaseline(void);
extern  void SetNeedUpdateBaseline(void);
extern  unsigned  int SensorKeyFlag(void);
extern  void MultipleDeal(unsigned char CycleCnt);
extern  void TouchKey_Service(void);

/***************弹簧库独有***************/
#define                SOCAPI_SET_CS_FUNCTION                                                1                //0:表示不进行CS测试,1: 表示进行CS测试,默认0
#define                SOCAPI_INHIBITION_ZONE                                            8                //抑制区间%,设置范围5-10,默认7,即(7*10)%=70% ,连水时加大该参数,对讲机设置小
#define                SOCAPI_MAX_KEY_MUTIPLE                                                300                //多少次干扰更新基线,默认300*5=1500
#define                SOCAPI_MAX_KEY_NUM_INVALID                                        3        //强制更新基线按键限制个数,默认3
/****************************************/

#define                  AppType                                                     0
#define                  IsDoubleKey                                                 1
#define                  AirSeparationDistance                     2
#define           CONFIRMTOUCHCNT                        3
#define           INIT_AUTO_UPDATE_TIME                     4
#define           SET_KEY_CONTI_TIME                     5  
#define           SET_SYNC_UPDATE                                  6
#define           SET_UPDATE_SPEED                                  7       
#define           AUTO_UPDATE_TIME                         8
#define                  FilteredKValue                                         9
#define                  SET_ANTIJAM                                             10
#define                  BAUD                                             11
#define                  DwellTime                                         12
#define           SaveTime                                            13
#define           NOISE                                  16

#define           SET_TOUCH_FREQ                                         0
#define                  SET_RESOLUTION                                         1
#define           SET_GAIN_CFG                                         2
#define           SCANTIME                                                 3
#define           SET_ICHA                                                 4
#define           FINGER_THRESHOLD_H                             6
#define           FINGER_THRESHOLD_L                             7

//**********************************************************************************       
//                                                                 函数接口调用部分                                                                  //
//**********************************************************************************
/**************************************************
*函数名称:unsigned int SetOneKeyPushResetTime(void)
*函数功能:按键最长的输出时间
*入口参数:void
*出口参数:unsigned int SOCAPI_SET_KEY_CONTI_TIME
*备注         :这个返回值的设置, 是根据有多长时间启动TouchKeyRestart()一次
例如10ms 启动一次, 那SOCAPI_SET_KEY_CONTI_TIME*10ms,超过时间后此按键无效。
**************************************************/
unsigned int SetOneKeyPushResetTime(void)   
{          
        return  TKCFG[SET_KEY_CONTI_TIME];
}
/**************************************************
*函数名称:unsignedint  GetBaselineUpdateThreshold(void)
*函数功能:更新速度
*入口参数:void
*出口参数:unsigned  int
*备注         :
**************************************************/
int  GetBaselineUpdateThreshold(void)
{
        return TKCFG[SET_UPDATE_SPEED];
}

/**************************************************
*函数名称:unsigned char GetInitAutoUpdateTime(void)
*函数功能:初始化自动校准次数
*入口参数:void
*出口参数:unsigned  char
*备注         :
**************************************************/
unsigned char GetInitAutoUpdateTime(void)
{
        return  TKCFG[INIT_AUTO_UPDATE_TIME];
}
/**************************************************
*函数名称:unsigned char GetCsFunction(void)
*函数功能:进行CS 测试
*入口参数:void
*出口参数:char SOCAPI_SET_CS_FUNCTION
*备注         :
**************************************************/
char GetCsFunction(void)
{
        return SOCAPI_SET_CS_FUNCTION;
}
/**************************************************
*函数名称:int  GetCurrFingerValue(unsigned char i)
*函数功能:获取当前的finger 值
*入口参数:unsigned char
*出口参数:int
*备注         :
**************************************************/
unsigned int   GetCurrFingerValue(unsigned char i)
{
        return        TKChannelCfg[i][FINGER_THRESHOLD_H]*256+TKChannelCfg[i][FINGER_THRESHOLD_L] ;
}

/**************************************************
*函数名称:unsigned char  GetScanTimeValue(unsigned char i)
*函数功能:获取当前通道的扫描时间
*入口参数:unsigned char
*出口参数:unsigned char
*备注         :
**************************************************/
unsigned char  GetScanTimeValue(unsigned char i)
{
        return TKChannelCfg[i][SCANTIME];
}
/**************************************************
*函数名称:unsigned char IsDoubleKeyOrSlideKey(void)
*函数功能:检测是否是弹簧滑条或者双键
*入口参数:void
*出口参数:unsigned char
*备注         :
**************************************************/
unsigned char IsDoubleKeyOrSlideKey(void)
{
    return TKCFG[IsDoubleKey];
}
/**************************************************
*函数名称:unsigned char  GetBaseLineAdjustValue(unsigned char i)
*函数功能:获取当前通道的基线调整
j
*入口参数:unsigned char
*出口参数:unsigned char
*备注         :
**************************************************/
unsigned char  GetBaseLineAdjustValue(unsigned char i)
{       
     return BaseLineAdjusttmp[i];
}
/**************************************************
*函数名称:unsigned char GetUpConfirmCnt(void)
*函数功能:检测按键弹起次数
*入口参数:void
*出口参数:返回按键弹起确认次数
*备注         :
**************************************************/
unsigned char GetUpConfirmCnt(void)
{
        return ConfirmTouchCnt>>1;
}
/**************************************************
*函数名称:unsigned char GetTKYzCnt(void)
*函数功能:获取按键抑制确认次数
*入口参数:void
*出口参数:返回抑制次数
*备注         :
**************************************************/

unsigned char GetTKYzCnt(void)
{
        return (ConfirmTouchCnt/3);
}

/**************************************************
*函数名称:int GetTKYzThreshold(unsigned char i)
*函数功能:获取按键抑制区间
*入口参数:unsigned char i
*出口参数:返回抑制区间
*备注         :
**************************************************/
int GetTKYzThreshold(unsigned char i)
{       
        unsigned int SetFingerThresholdtmp;
       
        SetFingerThresholdtmp = GetCurrFingerValue(i);
    SetFingerThresholdtmp = SetFingerThresholdtmp*SOCAPI_INHIBITION_ZONE/10;

        return SetFingerThresholdtmp;
}
/**************************************************
*函数名称:void CurrentSensorChoose(void)
*函数功能:当前通道选择
*入口参数:void
*出口参数:void
*备注         :
**************************************************/
void CurrentSensorChoose(void)
{
        unsigned char          i ;
        unsigned char          Ctk_Channel_mark = 0;
        unsigned  int        CurrentSensorKey  ;
       
        CurrentSensorKey = SOCAPI_SET_TOUCHKEY_CHANNEL;
               
        for(i=0;i<16;i++)
        {
                CurrentSensorKey=CurrentSensorKey>>1;
                if(TK_CY)
                {
                        CurrentChannel[Ctk_Channel_mark] = i;                                                //选择触摸当前的通道
                        Ctk_Channel_mark++;
                        if(Ctk_Channel_mark >= SOCAPI_SET_TOUCHKEY_TOTAL)
                                break;
                }               
        }
        CurrentChannelMax = Ctk_Channel_mark;                                                        //当前选择的按键数
}

/**************************************************
*函数名称:unsigned char  GetCfgMsg(unsigned char i)
*函数功能:获取Touch KEY 配置信息
*入口参数:void
*出口参数:int
*备注         :
**************************************************/
unsigned char  GetCfgMsg(unsigned char i)
{
        switch(i)
        {
                 case 0:  return TKChannelCfg[0][SET_TOUCH_FREQ];
                 case 1:  return TKChannelCfg[0][SET_RESOLUTION];
                 case 2:  return TKChannelCfg[0][SET_GAIN_CFG];
                 case 3:  return TKChannelCfg[0][SET_GAIN_CFG];
                 case 4:  return TKCFG[SET_ANTIJAM];
                 default:return 0;                 
        }
}

/**************************************************
*函数名称:void CurrentSensorChoose(void)
*函数功能:初始化TK寄存器
*入口参数:void
*出口参数:void
*备注         :
**************************************************/
void TouchKeyCFGInit(void)
{
        unsigned char          i;
        ConfirmTouchCnt = TKCFG[CONFIRMTOUCHCNT];
        SetNoiseThreshold = TKCFG[NOISE];
        CurrentSensorChoose();
        for(i=0;i<CurrentChannelMax;i++)
        {
          BaseLineAdjusttmp[i] =TKChannelCfg[i][SET_ICHA];;       
        }  
        UpdateBaseLNum = 0;
}

/**************************************************
*函数名称:unsigned int TouchKeyScan(void)
*函数功能:检测按键接口
*入口参数:void
*出口参数:按键通道, 返回的是一个int , 通道数
*备注         :1,  调用触控库检测函数SensorKeyFlag()
                   2,  分析得出16个通道,哪个通道有按下,按下bit 位设置为1,否则为0
                   3,  检测是否需要立即更新baseline:  大于MAX_KEY_RESET_BASELINE 个按键按下时立即更新baseline
                   4,  双键或者单键按下时, 时间大于SetOneKeyPushResetTime()结果时更新baseline
**************************************************/
unsigned  int TouchKeyScan(void)
{
        unsigned char t;
    unsigned char MultipleCnt = 0;//按键计数
        unsigned  int Keyvalue ;
        unsigned  int KeyData = 0;        
       
        if(GetIsNeedUpdateBaseline() == 0)                                //检测是否需要更新baseline
        {
                Keyvalue = SensorKeyFlag();                                        //Sensor判断, 这里如果bMultiple = 1 表示中间有干扰         //分析按键,得出标准的16通道bit 位                                                                               
                for(t=0;t<CurrentChannelMax;t++)
                {
                        Keyvalue = Keyvalue>>1;
                        if(TK_CY)
                        {
                                KeyData |= (0x01 << (CurrentChannel[t]));              
                                MultipleCnt++;                                                       
                        }
                }               
                if(MultipleCnt >= 2)                                                                                  //进入多按键处理
                {                       
                        bMultiple = 1;                       
                        if(MultipleCnt >= SOCAPI_MAX_KEY_NUM_INVALID)
                        {
                                SetNeedUpdateBaseline();                                                         // 立即更新baseline ,例如亚克力板盖上去
                        }
                        else
                        {                                       
                                if(IsDoubleKeyOrSlideKey())
                                {
                                        bMultiple = 0;
                                }                                  
                        }                       
                }                       

                if(bMultiple == 0)                                                        //进入按键判断
                {               
                        if(KeyData != 0x0)                                            //单个按键达到多长时间就update baseline ,松手检测
                        {                       
                                UpdateBaseLNum++;
                        }
                        else       
                        {
                                UpdateBaseLNum = 0;        
                        }
                }       
                else
                {   
                    //考虑基线更新               
                        MultipleLNum++;
                        KeyData = 0x00;
                }

                if(UpdateBaseLNum > SetOneKeyPushResetTime())          //按键超出最长输出时间更新基线
                {
                        SetNeedUpdateBaseline();
                        UpdateBaseLNum = 0;
                }
                               
                if(MultipleLNum >SOCAPI_MAX_KEY_MUTIPLE)                  //干扰计数大于最大计数更新基线
                {
                        SetNeedUpdateBaseline();
                        MultipleDealTpye = 1;
                        MultipleLNum = 0;
                }  
        }                       
        else
        {
                MultipleDeal(TKCFG[AUTO_UPDATE_TIME]);                                                                                //基线复位处理
        }  
       
        return KeyData;
}

/**************************************************
*函数名称:void CTK_ISR(void) interrupt        11
*函数功能:触摸中断服务函数
*入口参数:void
*出口参数:void
*备注         :
**************************************************/
void CTK_ISR(void) interrupt        11
{
   TouchKey_Service();
}



使用特权

评论回复
37
Pulitzer| | 2023-9-25 09:05 | 只看该作者

通过对于PCB电路板边缘的孔或通孔做电镀石墨化

使用特权

评论回复
38
公羊子丹| | 2023-9-25 10:08 | 只看该作者

根据这些指标,测试员可以评估电源的性能和可靠性。

使用特权

评论回复
39
公羊子丹| | 2023-9-25 11:01 | 只看该作者

脉冲变压器磁能被积累的问题容易解决,

使用特权

评论回复
40
公羊子丹| | 2023-9-25 11:01 | 只看该作者

脉冲变压器磁能被积累的问题容易解决,

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则