一、項(xiàng)目概述
1.1 引言
人的指紋是生物特征之一。指紋識(shí)別是生物識(shí)別技術(shù)中最為成熟的, 其唯一性、穩(wěn)定性, 一直都被視為身份鑒別的可靠手段之一。在當(dāng)今大學(xué)生活中,大學(xué)生的身體素質(zhì)逐漸達(dá)不到標(biāo)準(zhǔn),需要學(xué)校引導(dǎo)學(xué)生進(jìn)行鍛煉。然而若進(jìn)行人工管理會(huì)非常不便,而進(jìn)行機(jī)器智能管理,則相對(duì)簡(jiǎn)單。而指紋識(shí)別,能將各個(gè)學(xué)生的信息統(tǒng)一進(jìn)行管理,促進(jìn)了學(xué)校對(duì)學(xué)生體育鍛煉的管理。
1.2 項(xiàng)目背景/選題動(dòng)機(jī)
本系統(tǒng)基于Xilinx的FPGA開發(fā)平臺(tái)Nexys?3 Spartan-6 作為核心控制器件,這款器件擁有48M字節(jié)的外部存儲(chǔ)器,以及豐富的I/O器件和接口,適用于本系統(tǒng)。通過一些高精度的指紋識(shí)別算法,然后通過FPGA的運(yùn)算,我們達(dá)到指紋圖像的采集,存儲(chǔ),處理和對(duì)比功能,SDRAM 和Flash分別用作存儲(chǔ)指紋程序運(yùn)行時(shí)的臨時(shí)數(shù)據(jù)和指紋數(shù)據(jù)信息。同時(shí),通過USB與電腦相連,在電腦中建立數(shù)據(jù)庫,并實(shí)現(xiàn)FPGA與電腦的通信,完成指紋識(shí)別管理系統(tǒng)。
二、需求分析
2.1 功能要求
使用指紋采集器采集指紋信息,傳送至SDRAM存儲(chǔ)。在FPGA上對(duì)指紋進(jìn)行處理和匹配,同時(shí)編寫程序使FPGA與計(jì)算機(jī)通信并且在計(jì)算機(jī)上建立數(shù)據(jù)庫,使得可以使用計(jì)算機(jī)的數(shù)據(jù)庫完成數(shù)據(jù)管理。
2.2 性能要求
實(shí)現(xiàn)以精準(zhǔn),快速,實(shí)用性強(qiáng)的指紋識(shí)別系統(tǒng)。同時(shí)實(shí)現(xiàn)良好的FPGA與計(jì)算機(jī)通信的功能。
2.3 系統(tǒng)要點(diǎn)
本系統(tǒng)主要難點(diǎn)在于指紋識(shí)別的算法以及XILINX 與PC機(jī)通信時(shí)所需要寫的驅(qū)動(dòng)。
三、方案設(shè)計(jì)
3.1 系統(tǒng)功能實(shí)現(xiàn)原理
本系統(tǒng)采用Xilinx公司 Spartan 6系列FPGA作為核心控制芯片,通過FPC1011F傳感器采集指紋傳送至存儲(chǔ)器SDRAM存儲(chǔ)。在Spartan上運(yùn)行的指紋處理程序?qū)χ讣y信息進(jìn)行處理獲得特征點(diǎn),并存儲(chǔ)在SDRAM中或與SDRAM中的指紋信息進(jìn)行匹配。最終,通過USB與計(jì)算機(jī)通信,使用計(jì)算機(jī)中的學(xué)生數(shù)據(jù)庫。
系統(tǒng)框圖如圖所示:
3.2 硬件平臺(tái)選用及資源配置
3.2.1 指紋傳感器FPC1011F
FPC1011F 是瑞典Fingerprint Cards公司成功推出的一種電容式面裝指紋傳感器。該傳感器采用了多項(xiàng)專利,如獨(dú)立的晶圓體信號(hào)放大、傳感器表面的保護(hù)膜等。內(nèi)部具有A/D轉(zhuǎn)換,高速的SPI接口,8PIN的軟排線可以方便的接入各種系統(tǒng)。
FPC1011F指紋傳感器具有以下特點(diǎn):
(1)FPC1011F芯片產(chǎn)自瑞典,采用獨(dú)特的反射式測(cè)量法,抗靜電可達(dá)正負(fù)15 kV,耐磨100萬次,已被國內(nèi)金融界公認(rèn)為銀行指定零件。
(2)采用專業(yè)的指紋識(shí)別芯片PS1802DSP和最優(yōu)化的指紋算法,指紋成像效果好。
(3)處理速度快,峰值能達(dá)到480MIPS,在1:1 000模式下,時(shí)間小于1 s。
(4)功耗較同類產(chǎn)品低,正常工作主頻120 MHz下,只有120 mW。
(5)模塊體積為35 mm×26 mm×1 mm,便于各種指紋產(chǎn)品的開發(fā)。
(6)對(duì)干濕手指有自動(dòng)調(diào)節(jié)功能。
FPC1011F指紋傳感器含有小電容板,傳感器使用高靈敏度像素放大器,讓每個(gè)像素即使是非常微弱的信號(hào)FPC1011F都能探測(cè)到,以此提高圖像質(zhì)量。用了交替命令的并排列和傳感器電板,交替板的形式是兩個(gè)電容板,以及指紋的山谷和山脊成為板之間的電介質(zhì)。兩者之間的恒量電介質(zhì)傳感器檢測(cè)變化生成指紋圖像。
3.2.2 SPI 通信接口
SPI接口主要應(yīng)用在 EEPROM,F(xiàn)LASH,實(shí)時(shí)時(shí)鐘,AD轉(zhuǎn)換器,還有數(shù)字信號(hào)處理器和數(shù)字信號(hào)解碼器之間。SPI,是一種高速的,全雙工,同步的通信總線,并且在芯片的管腳上只占用四根線,節(jié)約了芯片的管腳,同時(shí)為PCB的布局上節(jié)省空間,提供方便,正是出于這種簡(jiǎn)單易用的特性,現(xiàn)在越來越多的芯片集成了這種通信協(xié)議。
SPI總線系統(tǒng)是一種同步串行外設(shè)接口,它可以使MCU與各種外圍設(shè)備以串行方式進(jìn)行通信以交換信息。外圍設(shè)置FLASHRAM、網(wǎng)絡(luò)控制器、LCD顯示驅(qū)動(dòng)器、A/D轉(zhuǎn)換器和MCU等。SPI總線系統(tǒng)可直接與各個(gè)廠家生產(chǎn)的多種標(biāo)準(zhǔn)外圍器件直接接口,該接口一般使用4條線:串行時(shí)鐘線(SCK)、主機(jī)輸入/從機(jī)輸出數(shù)據(jù)線MISO、主機(jī)輸出/從機(jī)輸入數(shù)據(jù)線MOSI和低電平有效的從機(jī)選擇線SS(有的SPI接口芯片帶有中斷信號(hào)線INT、有的SPI接口芯片沒有主機(jī)輸出/從機(jī)輸入數(shù)據(jù)線MOSI)。
SPI的通信原理很簡(jiǎn)單,它以主從方式工作,這種模式通常有一個(gè)主設(shè)備和一個(gè)或多個(gè)從設(shè)備,需要至少4根線,事實(shí)上3根也可以(用于單向傳輸時(shí),也就是半雙工方式)。也是所有基于SPI的設(shè)備共有的,它們是SDI(數(shù)據(jù)輸入),SDO(數(shù)據(jù)輸出),SCK(時(shí)鐘),CS(片選)。
SDO – 主設(shè)備數(shù)據(jù)輸出,從設(shè)備數(shù)據(jù)輸入 。
SDI – 主設(shè)備數(shù)據(jù)輸入,從設(shè)備數(shù)據(jù)輸出 。
SCLK – 時(shí)鐘信號(hào),由主設(shè)備產(chǎn)生 。
CS – 從設(shè)備使能信號(hào),由主設(shè)備控制 。
圖3.3 SPI接口信號(hào)
其中CS是控制芯片是否被選中的,也就是說只有片選信號(hào)為預(yù)先規(guī)定的使能信號(hào)時(shí)(高電位或低電位),對(duì)此芯片的操作才有效。這就允許在同一總線上連接多個(gè)SPI設(shè)備成為可能。 接下來就負(fù)責(zé)通訊的3根線了。通訊是通過數(shù)據(jù)交換完成的,這里先要知道SPI是串行通訊協(xié)議,也就是說數(shù)據(jù)是一位一位的傳輸?shù)摹_@就是SCK時(shí)鐘線存在的原因,由SCK提供時(shí)鐘脈沖,SDI,SDO則基于此脈沖完成數(shù)據(jù)傳輸。數(shù)據(jù)輸出通過 SDO線,數(shù)據(jù)在時(shí)鐘上升沿或下降沿時(shí)改變,在緊接著的下降沿或上升沿被讀取。完成一位數(shù)據(jù)傳輸,輸入也使用同樣原理。這樣,在至少8次時(shí)鐘信號(hào)的改變(上沿和下沿為一次),就可以完成8位數(shù)據(jù)的傳輸。
要注意的是,SCK信號(hào)線只由主設(shè)備控制,從設(shè)備不能控制信號(hào)線。同樣,在一個(gè)基于SPI的設(shè)備中,至少有一個(gè)主控設(shè)備。這樣傳輸?shù)奶攸c(diǎn):這樣的傳輸方式有一個(gè)優(yōu)點(diǎn),與普通的串行通訊不同,普通的串行通訊一次連續(xù)傳送至少8位數(shù)據(jù),而SPI允許數(shù)據(jù)一位一位的傳送,甚至允許暫停,因?yàn)镾CK時(shí)鐘線由主控設(shè)備控制,當(dāng)沒有時(shí)鐘跳變時(shí),從設(shè)備不采集或傳送數(shù)據(jù)。也就是說,主設(shè)備通過對(duì)SCK時(shí)鐘線的控制可以完成對(duì)通訊的控制。SPI還是一個(gè)數(shù)據(jù)交換協(xié)議:因?yàn)镾PI的數(shù)據(jù)輸入和輸出線獨(dú)立,所以允許同時(shí)完成數(shù)據(jù)的輸入和輸出。不同的SPI設(shè)備的實(shí)現(xiàn)方式不盡相同,主要是數(shù)據(jù)改變和采集的時(shí)間不同,在時(shí)鐘信號(hào)上沿或下沿采集有不同定義,具體請(qǐng)參考相關(guān)器件的文檔。
在點(diǎn)對(duì)點(diǎn)的通信中,SPI接口不需要進(jìn)行尋址操作,且為全雙工通信,顯得簡(jiǎn)單高效。在多個(gè)從設(shè)備的系統(tǒng)中,每個(gè)從設(shè)備需要獨(dú)立的使能信號(hào),硬件要稍微復(fù)雜一些。
SPI接口在內(nèi)部硬件實(shí)際上是兩個(gè)簡(jiǎn)單的移位寄存器,傳輸?shù)臄?shù)據(jù)為8位,在主器件產(chǎn)生的從器件使能信號(hào)和移位脈沖下,按位傳輸,高位在前,低位在后。如圖3.4所示,在SCLK的下降沿上數(shù)據(jù)改變,同時(shí)一位數(shù)據(jù)被存入移位寄存器。
FPC1011F口主要由4個(gè)引腳構(gòu)成:SPI_CK、SPI_DO、SPI_DI、/SS,SPI_CK是整個(gè)SPI總線的公用時(shí)鐘,SPI_DO、SPI_DI作為主機(jī),從機(jī)的輸入輸出的標(biāo)志,SPI_DO是主機(jī)的輸出,從機(jī)的輸入,SPI_DI是主機(jī)的輸入,從機(jī)的輸出。/SS是從機(jī)的標(biāo)志管腳,在互相通信的兩個(gè)SPI總線的器件,/SS管腳的電平低的是從機(jī),相反/SS管腳的電平高的是主機(jī)。在一個(gè)SPI通信系統(tǒng)中,必須有主機(jī)。SPI總線可以配置成單主單從,單主多從,互為主從。
SPI的片選可以擴(kuò)充選擇16個(gè)外設(shè)。
SPI接口的缺點(diǎn):沒有指定的流控制,沒有應(yīng)答機(jī)制確認(rèn)是否接收到數(shù)據(jù)。
3.2.3 SDRAM
SDRAM:同步動(dòng)態(tài)隨機(jī)存儲(chǔ)器,同步動(dòng)態(tài)隨機(jī)存儲(chǔ)器,同步是指 Memory工作需要同步時(shí)鐘,內(nèi)部的命令的發(fā)送與數(shù)據(jù)的傳輸都以它為基準(zhǔn);動(dòng)態(tài)是指存儲(chǔ)陣列需要不斷的刷新來保證數(shù)據(jù)不丟失;隨機(jī)是指數(shù)據(jù)不是線性依次存儲(chǔ),而是自由指定地址進(jìn)行數(shù)據(jù)讀寫。
3.2.4 FIFO模塊
此模塊主要功能是對(duì)已經(jīng)收到的指紋數(shù)據(jù)進(jìn)行緩存,避免指紋數(shù)據(jù)的丟失,因此此系統(tǒng)SPI工作頻率為16MByte,而UART串口工作頻率為38MByte。所以需要設(shè)定FIFO來使得SPI和UART協(xié)調(diào)工作。
3.2.5 UART模塊
此模塊的主要功能是和計(jì)算機(jī)進(jìn)行通信,把接受到的數(shù)據(jù)通過計(jì)算機(jī)數(shù)據(jù)庫顯示出來。
3.3系統(tǒng)軟件架構(gòu)
3.3.1 指紋采集步驟
初始化SPI接口模塊
復(fù)位FPC1011指紋傳感器
初始化傳感器
發(fā)送啟動(dòng)傳感器命令rd_sensor: 0x11
讀傳傳感器指令
指令rd_sensor (11 H)
模式串行
輸入參數(shù)1虛擬字節(jié)
數(shù)據(jù)延遲(363±2)tCLK
返回字節(jié)0
數(shù)據(jù)延遲指直至FIFO中的數(shù)據(jù)有效前,指令的延遲該指令用來讀取傳感器全部或部分區(qū)域。
該指令僅用于開啟傳感序列,指令本身并不返回任何數(shù)據(jù)。傳感器序列的第一組數(shù)據(jù)在大約363個(gè)時(shí)鐘周期后進(jìn)入FIFO。此后每隔8個(gè)時(shí)鐘周期,一個(gè)新字節(jié)就會(huì)寫入FIFO,直至由XSENSE, YSENSE, XSHIFT和YSHIFT寄存器定義的區(qū)域被讀取。
如果FIFO裝載數(shù)據(jù)已滿,我們將讓傳感器暫停工作直至數(shù)據(jù)從FIFO中讀出來防止溢出。在暫停期間所有分析模塊均有效,ASIC將在一個(gè)正常傳感操作中產(chǎn)生電流。
指令輸入后,SPI_DI將作為輸入保持低電平,以防下一個(gè)字節(jié)被誤認(rèn)為一條新指令了。
如果設(shè)置SPI_CS_N為高電平,讀出程序?qū)⑼V?,為了在之后繼續(xù)執(zhí)行讀出,我們需要使用rd_spidata指令。
5) 重復(fù)發(fā)送讀數(shù)據(jù)狀態(tài)寄存器命令rd_spistat: 0x21直到指紋數(shù)據(jù)準(zhǔn)備完畢。
指令rd_spistat (21 H)
模式串行
輸入?yún)?shù)1虛擬字節(jié)
數(shù)據(jù)延遲0
返回字節(jié)1
SPI狀態(tài)寄存器保存SPI接口狀態(tài)信息,當(dāng)接收到rd_spistat命令時(shí),SPI_STAT寄存器中的內(nèi)容將被返回。如果傳感器讀出指令正在執(zhí)行,使用該指令不會(huì)中斷讀出指令。
6) 發(fā)送讀數(shù)據(jù)指令rd_spidata: 0x20 讀取指紋數(shù)據(jù)并存入SDRAM中。
讀傳SPI數(shù)據(jù)指令
指令rd_spidata (20 H)
模式串行
輸入?yún)?shù)1虛擬字節(jié)
數(shù)據(jù)延遲0
返回字節(jié)n
發(fā)送讀取SPI數(shù)據(jù)指令rd_spidata后,指紋像素?cái)?shù)據(jù)將被返回。只要SPI_CS_N和SPI_DI保持低電平,數(shù)據(jù)將持續(xù)返回。
3.3.2指紋數(shù)據(jù)存儲(chǔ)的軟件實(shí)現(xiàn)
由于本次設(shè)計(jì)所采集的指紋圖像過大,并且在指紋圖像處理過程中多次生成處理后的圖像信息,我們采用大容量的SDRAM作為存儲(chǔ)介質(zhì)。
通過調(diào)用EDK自帶的SDRAM IP內(nèi)核,我們可以很方便的對(duì)SDRAM的讀寫操作進(jìn)行控制。
SDRAM寫數(shù)據(jù)函數(shù):
void XDdr_mWriteReg(Xuint32 BaseAddress, unsigned RegOffset, Xuint32 Data)
其中參數(shù)含義:
BaseAddress:寫數(shù)據(jù)在SDRAM的基地址
RegOffset:地址偏移量,數(shù)據(jù)寫在SDRAM的(BaseAddress+ RegOffset)位置
Data:要寫在SDRAM的數(shù)據(jù)
SDRAM讀數(shù)據(jù)函數(shù):
Void XDdr_mReadReg(Xuint32 BaseAddress, unsigned RegOffset)
其中參數(shù)含義:
BaseAddress:從SDRAM讀數(shù)據(jù)的基地址
RegOffset:地址偏移量,讀出在SDRAM的(BaseAddress+ RegOffset)位置的數(shù)據(jù)
3.3.3指紋圖像預(yù)處理的軟件實(shí)現(xiàn)
指紋圖像預(yù)處理可以分為圖像分割、增強(qiáng)、二值化和細(xì)化等幾個(gè)步驟,但是根據(jù)具體的情況,預(yù)處理的步驟也不盡相同。圖像分割是指把指紋圖像從背景中分離出來,減少后續(xù)處理的時(shí)間,提高特征提取的可靠性。也有一些文獻(xiàn)將把指紋圖像二值化,即將指紋脊(脊指的是手指皮膚凸起部姚按在指紋采集器上形成指紋圖上的黑色線條;谷指的是脊之間的空白部分)從指紋圖像中提取出來也歸為圖像分割部分。圖像增強(qiáng)的目的是突出指紋紋線結(jié)構(gòu),抑制紋線上及背景中的噪聲干擾;二值化是將指紋圖像變?yōu)槎祱D像;細(xì)化是將前面兩步己經(jīng)處理過的指紋圖像中指紋的脊的寬度降到最小,去除原紋線上的毛刺,使紋線更加清晰,盡量減少因?yàn)槊躺傻膫谓徊纥c(diǎn)、斷點(diǎn)等。
3.3.4 指紋圖像的特征點(diǎn)提取
常用的指紋特征描述方法是基于紋路結(jié)構(gòu)特征。指紋特征可以分為全局特征、局部特征和細(xì)微特征。 全局特征包括:(i)基本紋路圖案:基本紋路圖案通常分為左箕型(letfloop)、右箕型(rightloop)、斗型(whorl)、拱型(acrh)和尖拱型(etntedacrh),如圖4.6所示。 (ii)模式區(qū)(PattemAera):模式區(qū)是指紋圖像上包含了總體特征的區(qū)域,從模式區(qū)能夠分辨出指紋屬于那種類型。 (iii)核心點(diǎn)(CorePoint):核心點(diǎn)位于指紋紋路的漸近中心,它常用作讀取指紋和比對(duì)指紋時(shí)的參考點(diǎn)。 (iv)三角點(diǎn)(Detla):三角點(diǎn)是指紋圖像中三角形紋路區(qū)域的中心點(diǎn),離該點(diǎn)最近的三條指紋紋線構(gòu)成一個(gè)近似等邊三角形,三角點(diǎn)提供了指紋紋路計(jì)數(shù)和跟蹤的起始位置。 核心點(diǎn)和三角點(diǎn)統(tǒng)稱為奇異點(diǎn)。 (v)紋數(shù)(Ridge Cuont):作為全局特征,紋數(shù)一般是指模式區(qū)內(nèi)指紋紋路的數(shù)量。 也有些算法用某兩個(gè)點(diǎn)之間的紋路數(shù)作為指紋特征,比如兩個(gè)節(jié)點(diǎn)之間的紋路數(shù)。
(1)左箕型 (2)右箕型 (3)斗型 (4)拱型 (5)尖拱型
圖4.6 基本紋路圖案
局部特征包括:(i)端點(diǎn)(Ending):一條紋路在此終結(jié)。 (ii)分叉點(diǎn)(Biofcratino):一條紋路在此分成兩條或多條紋路。 (iii)分歧點(diǎn)(Ridge Divegrneee):兩條平行的紋路在此分開。 (iv)孤立點(diǎn)(Dot or Island):一條特別短的紋路,以至于成為一點(diǎn)。 (v)短紋(ShortRidge):一條較短但不至于成為一點(diǎn)的紋路。 (vi)環(huán)點(diǎn)(Enclosuer):一條紋路分成兩條后又立即合成一條,這樣形成的一個(gè)小環(huán)稱為環(huán)點(diǎn)。 (vii)橋(Bridge):兩條并行的紋路在此被搭接起來。 (viii)曲率(Curvauter):紋路方向改變的速度。 如圖4.7所示。
圖4.7 基本紋路圖案
另外,除了局部特征外,從高分辨率的傳感器采集的高質(zhì)量的指紋圖像中還可以提取比局部特征更細(xì)微的特征:毛孔。 提取毛孔特征一般要求傳感器分辨率達(dá)到1000dpi,而且要求手指皮膚質(zhì)量較高。 但指紋傳感器的分辨率一般在500dpi左右,而且受環(huán)境、皮膚條件的影響,采集的圖像中往往難以正確地提取毛孔特征,所以實(shí)際的系統(tǒng)中一般不使用毛孔特征。
3.3.5 指紋圖像的匹配
指紋圖像經(jīng)預(yù)處理和特征提取后已消除了大量的冗余信息,得到了表示指紋特征本身的真實(shí)特征數(shù)據(jù)。 指紋匹配就是將兩幅指紋圖像的特征數(shù)據(jù)的相似性比較
3.3.6 FPGA與計(jì)算機(jī)通信
為了實(shí)現(xiàn)指紋能與數(shù)據(jù)庫進(jìn)行通信,需要使用完成PC機(jī)的通信。
通信協(xié)議
此部分主要完成接受指紋匹配特征信息并返回結(jié)果。返回結(jié)果在LCD上進(jìn)行顯示。
此過程需要定義幀的標(biāo)志定義。需要比較長(zhǎng)的時(shí)間考慮。
由于不同的開發(fā)平臺(tái)針對(duì)應(yīng)用于不同領(lǐng)域?qū)崿F(xiàn)難易程度不同。所以指紋識(shí)別與匹配采用MATLAB編程,而COM+具有跨平臺(tái)調(diào)用的優(yōu)點(diǎn),且操作方便。所以將COM+組件技術(shù)作為數(shù)據(jù)庫接口部分。而數(shù)據(jù)庫接口部分采用ACESS數(shù)據(jù)庫。
本系統(tǒng)期望實(shí)現(xiàn)指紋特征信息的存取,更新用戶信息等相關(guān)操作。
4.系統(tǒng)軟件流程
(完)
評(píng)論
查看更多