基于CPLD的圖像傳感器非均勻性校正研究
2 非均勻性校正系統(tǒng)實(shí)現(xiàn)
2. 1 硬件設(shè)計(jì)
目前,在非均勻性校正的硬件實(shí)現(xiàn)上,采用的都是1點(diǎn)或2點(diǎn)校正法. 電路由計(jì)數(shù)器、存儲(chǔ)器、A /D轉(zhuǎn)換器和D /A轉(zhuǎn)換器等器件組成 . 通常,只能針對(duì)某個(gè)特定型號(hào)的圖像傳感器進(jìn)行電路板制作,擴(kuò)展性較差,而且,電路工作頻率較低. 采用這些器件很難實(shí)現(xiàn)多點(diǎn)實(shí)時(shí)校正.
為了實(shí)現(xiàn)非均勻性多點(diǎn)實(shí)時(shí)校正,筆者設(shè)計(jì)了基于復(fù)雜可編程邏輯器件(CPLD)的校正系統(tǒng). 該系統(tǒng)以CPLD EPM7512AE為核心,包括輸入和輸出信號(hào)調(diào)理電路、高速A/D采樣單元、D/A轉(zhuǎn)換單元和FLASH存儲(chǔ)器等功能模塊. 系統(tǒng)結(jié)構(gòu)如圖2所示。
圖2 校正系統(tǒng)結(jié)構(gòu)圖
校正系統(tǒng)通過輸入信號(hào)調(diào)理單元將接收到的圖像傳感器視頻輸出信號(hào)進(jìn)行預(yù)處理,將信號(hào)調(diào)整到A/D轉(zhuǎn)換器(ADC) TLV5580的采樣電壓范圍內(nèi).系統(tǒng)控制核心CPLD接收圖像傳感器工作信號(hào),根據(jù)視頻信號(hào)串行輸出的規(guī)律,產(chǎn)生控制TLV5580工作的時(shí)鐘信號(hào)和轉(zhuǎn)換數(shù)據(jù)輸出使能信號(hào),從而控制TLV5580對(duì)經(jīng)過調(diào)理的視頻信號(hào)進(jìn)行采樣量化,并將量化后的數(shù)字信號(hào)實(shí)時(shí)讀入CPLD. 同時(shí), CPLD 從FLASH存儲(chǔ)器W29C040的相應(yīng)單元中讀出斜率和偏置校正系數(shù),實(shí)現(xiàn)式(4)描述的校正算法,完成對(duì)各個(gè)視頻信號(hào)的實(shí)時(shí)非均勻性校正。
CPLD還產(chǎn)生D/A轉(zhuǎn)換器(DAC) TL5632C工作時(shí)鐘信號(hào),控制TL5632C將校正后的數(shù)字信號(hào)實(shí)時(shí)地轉(zhuǎn)換成模擬信號(hào),并由輸出信號(hào)調(diào)理單元將該模擬信號(hào)調(diào)理為一個(gè)范圍合適的電壓信號(hào)作為校正系統(tǒng)的輸出(即經(jīng)過校正的視頻信號(hào))。
2. 2 CPLD設(shè)計(jì)思想
作為控制核心的CPLD是一種半定制器件,它最大的優(yōu)點(diǎn)就是采用編程的方式定制其具體實(shí)現(xiàn)的硬件電路,指定CPLD的硬件實(shí)現(xiàn)功能. 筆者主要采用硬件描述語言VHDL,并結(jié)合原理圖方式在MAX + PLUSⅡ集成開發(fā)環(huán)境下進(jìn)行CPLD 功能的設(shè)計(jì). 采用VHDL語言的設(shè)計(jì)方法,可實(shí)現(xiàn)器件的無關(guān)性,并且功能實(shí)現(xiàn)靈活、修改方便. CPLD的應(yīng)用以及VHDL設(shè)計(jì)方法的使用為校正系統(tǒng)能靈活地適用于不同圖像傳感器的校正以及實(shí)現(xiàn)不同的校正算法提供了可能和保證。
根據(jù)系統(tǒng)校正功能要求及工作流程, CPLD 實(shí)現(xiàn)的功能主要包括:
1) 分頻器. 分頻器對(duì)晶振信號(hào)進(jìn)行分頻,產(chǎn)生校正系統(tǒng)協(xié)調(diào)工作的時(shí)鐘基準(zhǔn)信號(hào). 分頻器采用VHDL進(jìn)行設(shè)計(jì),可以根據(jù)不同的晶振、不同的圖像傳感器工作頻率,靈活、方便地選擇不同的分頻數(shù),產(chǎn)生合適的時(shí)鐘基準(zhǔn)信號(hào)。
2) ADC控制信號(hào)發(fā)生模塊. 該模塊采用VHDL進(jìn)行設(shè)計(jì),根據(jù)分頻器產(chǎn)生的時(shí)鐘基準(zhǔn)信號(hào)和圖像傳感器的工作信號(hào),產(chǎn)生能夠準(zhǔn)確控制TLV5580工作的時(shí)鐘信號(hào)和轉(zhuǎn)換數(shù)據(jù)輸出使能信號(hào),保證TLV5580實(shí)時(shí)、準(zhǔn)確地采集經(jīng)過調(diào)理后的視頻輸出信號(hào)。
3) 地址發(fā)生器. 地址發(fā)生器產(chǎn)生讀取FLASH存儲(chǔ)器中斜率和偏置校正系數(shù)的地址信號(hào). 由于每個(gè)光敏元在每個(gè)輻照度子區(qū)域有一組數(shù)據(jù)(一個(gè)斜率校正系數(shù)和一個(gè)偏置校正系數(shù)) ,為了方便讀取,將同一輻照度子區(qū)域的所有光敏元的校正系數(shù)按照在圖像傳感器中的相對(duì)位置順序存儲(chǔ). 所以,同一光敏元在不同子區(qū)域下的數(shù)據(jù)地址,高位地址不同,低位地址則完全相同;同一子區(qū)域內(nèi)不同光敏元的數(shù)據(jù)地址,則高位相同,低位不同. 因此,地址發(fā)生器由2部分構(gòu)成:高位地址發(fā)生器和低位地址發(fā)生器。
高位地址發(fā)生器實(shí)質(zhì)上是一個(gè)比較器,確定當(dāng)前圖像傳感器所測(cè)量的輻照度所處的子區(qū)域. 其設(shè)計(jì)思想是:將采集到的第1個(gè)光敏元的視頻信號(hào)和預(yù)先設(shè)定的對(duì)應(yīng)于每段輻照度子區(qū)域的邊界值進(jìn)行比較,根據(jù)比較的結(jié)果產(chǎn)生相應(yīng)的高位地址. 由于采用并行執(zhí)行的指令來實(shí)現(xiàn),能夠很好地滿足實(shí)時(shí)處理的要求.低位地址發(fā)生器根據(jù)視頻信號(hào)逐一串行輸出的特點(diǎn)以及TLV5580工作特點(diǎn)(每個(gè)工作時(shí)鐘采集1個(gè)光敏元的輸出信號(hào))進(jìn)行設(shè)計(jì),實(shí)質(zhì)上是一個(gè)計(jì)數(shù)器,只需對(duì)TLV5580工作時(shí)鐘信號(hào)進(jìn)行計(jì)數(shù),就能產(chǎn)生相應(yīng)的低位地址。
4) 校正模塊. 由乘法和加法2個(gè)子模塊構(gòu)成,分別采用MAX + PLUS Ⅱ提供的功能單元LPM_MULT和LPM_ADD_SUB來實(shí)現(xiàn). 校正模塊將采集到的視頻信號(hào)以及從FLASH存儲(chǔ)器讀取的相應(yīng)校正系數(shù)按照式(4)進(jìn)行處理,實(shí)現(xiàn)圖像傳感器的實(shí)時(shí)非均勻性校正。
5) DAC控制信號(hào)發(fā)生模塊. 產(chǎn)生控制TL5632C工作的時(shí)鐘信號(hào),指揮TL5632C實(shí)時(shí)地將校正后的數(shù)字視頻信號(hào)轉(zhuǎn)換為模擬信號(hào)。
由于非均勻性校正功能的實(shí)現(xiàn)對(duì)時(shí)序要求嚴(yán)格,在程序的設(shè)計(jì)中,一定要注意時(shí)序的合理性. 將程序編寫出來后,首先進(jìn)行了仿真實(shí)驗(yàn),在得到期望的工作波形數(shù)據(jù)后,進(jìn)行邏輯綜合生成網(wǎng)絡(luò)表和下載文件,最后將程序文件下載到EPM7512AE中,以便進(jìn)行下一步對(duì)圖像傳感器非均勻性校正指標(biāo)的測(cè)試。
評(píng)論