基于FPGA的TDI-CCD時序電路的設(shè)計
關(guān)鍵詞:TDI;FPGA;VHDL;驅(qū)動時序
1 引言
CCD(Charge Coupled Devices),即電荷耦合器件,它是20世紀70年代初發(fā)展起來的新型半導體集成光電器件,是美國貝爾實驗室的W.S.Boyle和G.E.Smith于1970年首先提出來的【1】。30年來, CCD的研究取得了驚人的進步,已成為現(xiàn)代光電子學和現(xiàn)代測量技術(shù)中最活躍、最富有成果的新興領(lǐng)域之一。尤其是在攝像方面的應用, CCD圖像傳感器具有體積小、重量輕、功耗小等優(yōu)點,在分辨率、動態(tài)范圍、靈敏度、實時傳輸和自掃描等方面的優(yōu)越性也是其它攝像器件無法比擬的。而在CCD的使用中,不同型號的CCD器件的驅(qū)動時序不同,因此快速、方便地設(shè)計出CCD的時序電路成為應用技術(shù)中的關(guān)鍵【2】。
2 TDI-CCD器件結(jié)構(gòu)、工作原理及特性
TDI (Time Delay and Integration)是一種掃描方式,它是一項能夠增加線掃描傳感器靈敏度的技術(shù)。TDI-CCD的結(jié)構(gòu)像一個長方形的面陣CCD,但從功能上說它是一個線陣CCD。其工作過程是基于對同一目標多次曝光,通過延時積分的方法,以增加等效積分時間,增強光能的收集。它的列數(shù)是一行的像元數(shù),行數(shù)為延遲積分的級數(shù)M。工作原理如下:某一行上的第一個像元在第一個曝光積分周期內(nèi)收集到的信號電荷并不直接輸出,而是與同列第二個像元在第二個積分周期內(nèi)收集到的信號電荷相加,相加后的電荷移向第三行…… CCD最后一行第M 行的像元收集到的信號電荷與前面(M-1)次收集到的信號電荷累加后轉(zhuǎn)移到輸出移位寄存器中,按普通線陣CCD的輸出方式進行讀出。由此可見,CCD輸出信號的幅度是M 個像元積分電荷的累加,即相當于一個像元的M 倍積分周期所收集到的信號電荷,輸出幅度擴大了M 倍。在TDI-CCD中,根據(jù)不同的應用背景,積分級數(shù)M 可設(shè)計為6,12,24,48,96等可調(diào)。由于TDI-CCD的曝光時間與使用的TDI級數(shù)成比例,通過改變TDI級數(shù),即改變了可見光CCD的曝光時間。因此,可見光TDI-CCD用于成像系統(tǒng),在不改變幀頻的情況下,通過改變TDI級數(shù),可以在不同的照度下正常工作,這是非常有義的。隨著TDI級數(shù)增加,信號隨TDI級數(shù)M成線性增加,而噪聲隨TDI級數(shù)成平方根增加,TDI-CCD 的信噪比(SNR)可以增加 倍。TDI-CCD 另一個特點是通過多次曝光可減少像元間響應不均勻和固定圖形噪聲的影響?;谝陨咸攸c,TDI-CCD在航天、航空等領(lǐng)域有著非常廣泛的用途。在航空和航天遙感上,傳輸型TDI-CCD遙感相機是當前世界上技術(shù)最先進、性能最優(yōu)越的新一代的遙感相機。
DALSA公司IL-E2型TDI-CCD是單向、單端輸出,級數(shù)可選,具有藍光響應增強功能的TDI-CCD。如圖1所示,整個TDI-CCD可以分為3個功能區(qū),即光敏元探測區(qū)、電荷傳輸區(qū)、檢測輸出區(qū)。
圖 1 IL-E2 TDI-CCD 結(jié)構(gòu)圖
3 TDI-CCD驅(qū)動時序
3.1 積分級數(shù)選擇
IL-E2型TDI-CCD共有5種級數(shù)可選,分別為6、12、24、48、96級。根據(jù)TDI-CCD 的時序關(guān)系,TDI-CCD的積分級數(shù)控制,就是控制TDI-CCD級數(shù)選擇時鐘CSS6、CSS12、CSS24、CSS48來實現(xiàn)。選中那一級對應CSS驅(qū)動信號為-7V,其他CSS驅(qū)動信號與CI4相同,選96級時所有CSS驅(qū)動信號與CI4相同。
圖2 IL-E2 TDI-CCD總體驅(qū)動時序
圖3 IL-E2 TDI-CCD詳細驅(qū)動時序
圖2中,CSS12的驅(qū)動信號為-7V,CSS6、 CSS24、 CSS48均與CI4相同,表明此時選中的積分級數(shù)為12。
3.2 驅(qū)動時序
為了使TDI-CCD完成正常的掃描成像工作,即電荷的積分、轉(zhuǎn)移和讀出等,施加在TDI-CCD各個引腳上的時鐘脈沖應有著嚴格的時間關(guān)系。
IL-E2 TDI-CCD的像元移位讀出時鐘為CR1,CR2。CIx(x=1,2,3,4)、TCK、OS分別為成像區(qū)時鐘、行轉(zhuǎn)移時鐘、輸出信號。驅(qū)動時序分析如下:將各驅(qū)動時鐘脈沖加到TDI-CCD的相應引腳上,在行轉(zhuǎn)移時鐘脈沖TCK為高電平期間,像元感光產(chǎn)生的信號電荷在成像區(qū)時鐘脈沖CI1、CI2、CI3、CI4的共同作用下,沿著TDI方向積累并轉(zhuǎn)移到輸出移位寄存器中。當TCK為低電平時,TDI-CCD在像元移位讀出時鐘脈沖CR1、CR2的作用下,輸出復位時鐘脈沖RST每來一個有效的高電平時,TDI-CCD的輸出信號OS 端輸出一個信號,直到信號輸出完為止;與此同時,像元感光(曝光)產(chǎn)生信號電荷。之后TCK由低電平變?yōu)楦唠娖?,CI1、CI2、CI3、CI4也相應的變?yōu)橛行щ娖?,開始一個新的周期。
驅(qū)動時序如圖2和圖3所示:臨近的CI高電平交疊時間t1不小于1.0us,CI高電平持續(xù)時間t3不小于3.0us,TCK的上升沿與CI3的下降沿之間的t4最小為0,TCK的下降沿與CI4的上升沿之間的t5最小為0,CI4的上升沿與CR1的下降沿之間的t6最小為100ns, TCK的下降沿與CR1的下降沿之間的t7最小為100ns,CR1與RST的上升沿和下降沿之間的t8、t9最小為0,RST高電平持續(xù)時間t10最小為15ns, CI1的上升沿與CI3的下降沿之間的t11最小為100ns。只有嚴格的遵循此時序關(guān)系,設(shè)計出的時序電路才能穩(wěn)定、可靠的工作。
4 時序電路設(shè)計與時序仿真
IL-E2 TDI-CCD的像元數(shù)有每行512,1024和2048三種,本文以項目使用的像元數(shù)為2048的為例設(shè)計時序電路。2048為有效像元數(shù),每行有128個啞像元,設(shè)計中使每行輸出2288個信號電平,即每個行周期內(nèi)有2288個CR1、CR2、RST驅(qū)動脈沖。除了2048+128=2176個像元驅(qū)動脈沖以外,其余為空驅(qū)動脈沖??镇?qū)動數(shù)越多,CCD曝光積分時間越長,靈敏度提高,但過長的曝光積分時間會使CCD輸出飽和失真,故空驅(qū)動數(shù)目不易過多。
行積分時間和像元移位讀出時鐘頻率是CCD時序電路的設(shè)計依據(jù)。在工程應用中,我們根據(jù)技術(shù)指標要求,算出行積分時間即行周期(T)為0.25ms,以此確定合適的系統(tǒng)主時鐘。
設(shè)計時,先產(chǎn)生CR信號,然后以此為基礎(chǔ),根據(jù)周期相位關(guān)系產(chǎn)生其它驅(qū)動時序信號。
驅(qū)動時序用超高速集成電路硬件描述語言(VHDL)編寫【3】,程序主要包括:(1)調(diào)用所需的庫函數(shù)和程序包;(2)定義輸入和輸出端口;(3)用計數(shù)器對輸入的系統(tǒng)主時鐘進行分頻。(4)驅(qū)動時序信號的產(chǎn)生和輸出。部分源代碼如下:
process(cr2_s)
begin
if cr2_s'event and cr2_s = '1' then
if cr_count_s 2288 + CONV_INTEGER(linecycle_s) then
cr_count_s = cr_count_s + 1;
else cr_count_s = 0;
end if;
end if;
end process;
process(sysclk,cr_count_s,cr1_s,cr2_s) DD產(chǎn)生CR信號
begin
if sysclk'event and sysclk = '1'then
if cr_count_s 64 then
cr1 = '0'; cr2 = '1';
else
cr1 = not cr1_s; cr2 = not cr2_s;
end if;
end if;
end process;
process(sysclk,sys_count_s) DD產(chǎn)生輸出復位信號RST
begin
if sysclk'event and sysclk = '1' then
case sys_count_s is
when 1 => rst_s = '1';
when 2 => rst_s = '1';
when others => rst_s = '0';
end case;
end if;
end process;
process(cr_count_s,cr2_s) DD產(chǎn)生CI和TCK信號
begin
if cr2_s'event and cr2_s = '1' then
if cr_count_s 16 then
ci1_s = '1'; ci2_s = '0'; tck_s = '1';
elsif cr_count_s 24 then
ci1_s = '1'; ci2_s = '1'; tck_s = '1';
elsif cr_count_s 40 then
ci1_s = '0'; ci2_s = '1'; tck_s = '1';
else
ci1_s = '0'; ci2_s = '0'; tck_s = '0';
end if;
end if;
end process;【4】
由XILINX公司的設(shè)計軟件ISE6.2對XQVR300器件進行時序設(shè)計,通過時序仿真與工程應用驗證了能完成上述所有功能。
5 結(jié)束語
本文的創(chuàng)新點是完成了對像元數(shù)為2048的IL-E2 TDI-CCD的驅(qū)動時序的VHDL編寫和在可編程器件中的下載實現(xiàn),時序仿真和硬件電路測試表明該時序電路能夠較好地產(chǎn)生器件所需的時序脈沖;使用延遲量小的FPGA使得系統(tǒng)可以工作在百兆赫茲的高頻段,可靠性和穩(wěn)定性得到了很好的保證;程序可移植性強,可作為其它類型的CCD驅(qū)動時序設(shè)計的參考。
參考文獻:
[1]王慶友.CCD應用技術(shù)[M].天津:天津大學出版社, 2005:P1-5
[2]常丹華,于洋.基于VHDL的CCD驅(qū)動時序設(shè)計[J].今日電子,2003,10,P27-29
[3]蔡澤彬,蔣躍.基于CPLD技術(shù)的線陣CCD驅(qū)動電路設(shè)計[J].空軍雷達學院學報,2004,18(1),P50-52
[4]馮江,王曉燕等.IC設(shè)計中的VHDL語言應用研究[J].微計算機信息,2006年一二期,P250
評論