新聞中心

EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計應(yīng)用 > 基于ADSP21060和Virtex II的圖像處理系統(tǒng)設(shè)計

基于ADSP21060和Virtex II的圖像處理系統(tǒng)設(shè)計

——
作者:王宇舟,賈志宏,李彥琴,耿立紅,孫才紅 時間:2007-02-06 來源:電子技術(shù)應(yīng)用 收藏

摘 要:介紹一種基于 的星載。分析了的功能和任務(wù),給出了處理系統(tǒng)的硬件結(jié)構(gòu)、FPGA的功能模塊、DSP的軟件框架和模塊。通過地面原理樣機開發(fā),驗證了系統(tǒng)設(shè)計的正確性和高效性。

關(guān)鍵詞

圖像處理系統(tǒng)多采用DSP陣列、DSP加FPGA/CPLD或單由FPGA/CPLD器件等方式構(gòu)成。采用DSP陣列構(gòu)成的圖像處理系統(tǒng),其優(yōu)點是處理功能可以通過軟件靈活修改,其缺點主要有功耗大、體積大、成本高;采用單由FPGA/CPLD等可編程器件構(gòu)成的系統(tǒng),可以避免DSP陣列系統(tǒng)功耗大、體積大的缺點,并可以根據(jù)系統(tǒng)要求,在硬件構(gòu)造上作靈活的配置,但對于復雜的算法,其設(shè)計復雜度急劇上升。正因為如此,當前很多設(shè)計選擇DSP加FPGA/CPLD的結(jié)構(gòu)來構(gòu)造圖像處理系統(tǒng)。本空間太陽望遠鏡星載圖像處理系統(tǒng),正是一種基于DSP和FPGA構(gòu)造的圖像處理系統(tǒng)。本文討論了系統(tǒng)的功能任務(wù)、系統(tǒng)結(jié)構(gòu)、FPGA設(shè)計的邏輯模塊、DSP的軟件結(jié)構(gòu)和原理樣機的實驗結(jié)果。

1 圖像處理系統(tǒng)的功能和任務(wù)

1.1 系統(tǒng)的外圍接口


系統(tǒng)的外圍接口如圖1。處理系統(tǒng)接收來自CCD單元的圖像數(shù)據(jù)和同步信號,同時向CCD單元提供復位、曝光開始、數(shù)據(jù)讀出等控制信號;CEU是一個管理機,管理和控制CCD單元、圖像處理單元和壓縮單元,CEU單元向圖像處理系統(tǒng)發(fā)送各種命令,如CCD標定、正常的觀測測試及觀測數(shù)據(jù)處理所需要的數(shù)據(jù),如觀測模式、時間等;系統(tǒng)將處理完成的數(shù)據(jù)送到壓縮單元進一步壓縮。

 
 
圖1 處理系統(tǒng)的外圍接口

1.2 系統(tǒng)的圖像處理任務(wù)

圖像處理系統(tǒng)的任務(wù)是接收CCD傳來的圖像和同步信號,進行圖像積分、輻射校正、幾何校正、磁圖偏陣計算和圖像格式化,然后把數(shù)據(jù)送到壓縮單元進行壓縮。

(1)圖像積分:也就是圖像的多幀疊加,其目的是提高信噪比和消除圖像的時間相關(guān)性以壓縮數(shù)據(jù)量??臻g太陽望遠鏡有三個觀測模式,分別是爆發(fā)模式、活動區(qū)模式和寧靜態(tài)模式。經(jīng)計算,三種觀測模式下圖像積分的幀數(shù)分別是:4幀、24幀、240幀;每個模式又順次觀測六個分量,六個分量分別是:SV1、SV2、SQ1、SQ2、SU1、SU2。爆發(fā)模式的觀測時間是30s。30s的時間是這樣安排的:每個分量連續(xù)采集4幀,每秒一幀,然后1s進行偏振光學元件的切換,如此直到六個分量觀測完畢。活動區(qū)模式由6個連續(xù)的爆發(fā)周期構(gòu)成,觀測時間是3min;而寧靜態(tài)模式又是10次活動區(qū)模式周期構(gòu)成,觀測周期是30min。

(2)圖像的輻射校正:圖像由于受到大氣擾動、傳感器自身特性、宇宙射線等輻射的影響,圖像的質(zhì)量會產(chǎn)生退化,必須進行輻射校正。主要考慮CCD的校正(暗流、偏置、平場)和條紋斑點的消除兩個方面。

(3)圖像的幾何校正:圖像的幾何校正,成像過程中引起的幾何畸變的校正;由于系統(tǒng)或隨機因素造成圖像產(chǎn)生幾何畸變,必須進行校正??紤]圖像漂移的校正,采用相關(guān)技術(shù),求出活動圖像相對于參考圖像的的漂移量,再采用線性內(nèi)插累加的方式,實現(xiàn)漂移前后圖像的積分問題。根據(jù)太陽米粒的存活壽命,幾何校正只對寧靜模式觀測進行,并且是以3min作為校正時間間隔。

(4)圖像的偏振計算:空間太陽望遠鏡主要進行太陽磁場測量,磁圖的偏振歸算也是重要任務(wù)之一。磁場圖像的歸算還可以是數(shù)據(jù)量壓縮1.5倍。
 
(5)圖像格式化:給圖像加上圖像頭,應(yīng)包括:儀器號、時間、觀測模式、觀測分量等。

2 圖像處理系統(tǒng)設(shè)計

2.1 系統(tǒng)結(jié)構(gòu)

系統(tǒng)的硬件結(jié)構(gòu)框圖如圖2。FPGA中的硬件模塊,包括積分單元、多路開關(guān)單元、兩個SDRAM控制器和串口控制器。DSP的所有總線都伸入到FPGA內(nèi)部。存儲器由兩個SDRAM單元和一個SRAM單元構(gòu)成,SRAM只供DSP使用。系統(tǒng)接收CCD傳來的圖像,在積分單元進行圖像積分,積分就緒的圖像再由DSP進行輻射校正、幾何校正、偏振計算和圖像格式化等操作,最后通過DSP的片上串口將圖像送到壓縮單元。通過串口單元系統(tǒng)與管理機單元通信,接受管理和控制。由于圖像積分與DSP的數(shù)據(jù)處理、數(shù)據(jù)傳送是同時并行進行的,因此和DSP必須采用相互獨立的存儲區(qū)。為了避免圖像在和DSP的存儲區(qū)之間來回進行圖像傳送,在設(shè)計中采用多路開關(guān)進行存儲區(qū)乒乓方式切換。

圖2 系統(tǒng)硬件結(jié)構(gòu)圖

2.2 FPGA邏輯模塊

FPGA內(nèi)部設(shè)計的邏輯模塊主要包括圖像積分單元、通路選擇單元、異步通用串口(UART)單元、兩個SDRAM控制和其它附加邏輯。下面分別介紹各塊的結(jié)構(gòu),由于SDRAM控制器和串口單元(UART)均采用IP核實現(xiàn),這里不作詳細介紹。

2.2.1 積分單元

積分單元主要完成如下功能:(1)按給定的時序接收CCD的圖像,并保存在寄存器中;(2)積分地址產(chǎn)生;(3)存儲器控制;(4)積分操作;(5)積分擴展位清零,當每個分量的第一幀圖像接收時,無須積分,但必須把存儲器的高位(積分擴展位)清零,其它情況不必清零;(6)每幀圖像積分結(jié)束,產(chǎn)生Irq信號中斷DSP,以便由DSP進行工作安排。
 
積分單元的邏輯框圖如圖3,其輸入輸出如下:(1)CCD輸入數(shù)據(jù)(CCD data),同步信號——點同步(ps)、行同步(ls)、幀同步(fs);(2)DSP數(shù)據(jù)、地址和控制總線,irq是積分單元發(fā)給DSP的中斷信號;(3)與存儲器連接的數(shù)據(jù)、地址和存儲器控制總線——data, mctrl, addr;(4)控制CCD的信號線——reset、start、read。

圖3充色的方框是DSP存儲器地址映射的寄存器,用于對積分單元進行控制和對DSP數(shù)據(jù)處理狀態(tài)進行標識;無充色的方框則是積分單元的硬件結(jié)構(gòu),從CCD送來的數(shù)據(jù)通過數(shù)據(jù)寄存器(OP1),作為寄分的第一個操作數(shù),從存儲器送來的數(shù)據(jù)通過數(shù)據(jù)寄存器(OP2)作為積分的第二個操作數(shù);從CCD送來的同步信號,送到幀內(nèi)地址發(fā)生器,作為地址產(chǎn)生信號,并生成存儲器需要的控制信號;CCD送來的OP1被寄存,同時產(chǎn)生地址從內(nèi)存中取出要進行積分的操作數(shù)OP2,然后在點同步信號的下降沿,進行積分運算并存回存儲器。

2.2.2 多路開關(guān)單元

多路開關(guān)單元如圖4所示。本單元的功能是完成積分總線INT bus和DSP bus與SDRAM1和SDRAM2乒乓連接結(jié)構(gòu)的切換。切換包括三大總線:數(shù)據(jù)、地址和控制總線。切換通過一位切換控制信號實現(xiàn),控制信號是DSP地址映射的一個一位寄存器,由DSP控制乒乓切換。

 

圖3 積分單元結(jié)構(gòu)

圖4 多路開關(guān)單元

2.3 DSP軟件結(jié)構(gòu)

軟件部分包括系統(tǒng)軟件框架和各處理軟件模塊、中斷服務(wù)程序等;程序的流程和數(shù)據(jù)處理控制,都依賴于由DSP地址映射的寄存器的狀態(tài)。

2.3.1 DSP在FPGA中的存儲器映像寄存器及其作用

 這一組寄存器都是在FPGA中實現(xiàn)的。作業(yè)(指令)采用16位寄存器,由于DSP地址空間較大,為了方便編程,寄存器不采用拼位的方法。系統(tǒng)的工作受CEU的控制。CEU發(fā)送過來的指令格式如圖5(a),其中DT表示CEU傳來的數(shù)據(jù)類型,00表示數(shù)據(jù)、01表示觀測指令、10表示CCD標定、11表示自測。接收時,若是命令則直接寫到JOB或放入命令隊列;若是數(shù)據(jù),根據(jù)類型存放到相應(yīng)的位置。Parameters是各種工作狀態(tài)參數(shù),如待機/自測要求的參數(shù)、測試的要求(內(nèi)容、測試選擇)、響應(yīng)信息要求、觀測模式和次數(shù)、CCD標定要求的參數(shù)、標定的內(nèi)容等,以便于DSP查看。

 

圖5(a) CEU命令格式         圖5(b) 系統(tǒng)作業(yè)格式

如圖5(b),當CEU送來命令DT=01時,即為觀測命令。觀測作業(yè)的格式如:00表示無作業(yè)待機、01表示觀測指令、10表示CCD標定、JT=11表示自測;mode是當前觀測模式標志,001表示爆發(fā)模式、010表示活動區(qū)模式、100表示寧靜模式;Observ_Num是連續(xù)觀測同一種模式的次數(shù)標志。

(1)作業(yè)類型寄存器(JOB):標識系統(tǒng)工作內(nèi)容(作業(yè)類型),如CCD標定、觀測、自測試等;(2)模式寄存器(MODE):標識觀測的模式,爆發(fā)模式、活動區(qū)模式、寧靜模式;(3)觀測次數(shù)寄存器(OBSN):用于保存一次作業(yè)的觀測次數(shù);(4)寧靜態(tài)的觀測次數(shù)寄存器(RESTN):只用于寧靜模式的觀測,當為寧靜態(tài)模式時,用它來標志3min觀測的次數(shù);(5)幀計數(shù)器(FRMN):用于計數(shù)爆發(fā)模式、活動區(qū)模式及寧靜模式下的前24幀圖像,以便用于高位清零信號生成和地址高位生成;(6)SW電路控制寄存器(SWCTRL):控制多路開關(guān)的切換;(7)reset寄存器(FRST):用于DSP控制FPGA中INT單元的時序邏輯復位,每次觀測結(jié)束,必須復位一次;(8)清零標識寄存器(ZERO):由DSP根據(jù)FRMN的值修改它,以實現(xiàn)高位的清零任務(wù);(9)分量寄存器(COMPO):由DSP根據(jù)FRMN的值修改它,以實現(xiàn)高位地址的形成;(10)作業(yè)結(jié)束寄存器(END):當一個作業(yè)結(jié)束時,用次寄存器進行標志,以便將程序的PC跳到作業(yè)檢查入口;(11)數(shù)據(jù)狀態(tài)寄存器(DAST):DSP存儲區(qū)數(shù)據(jù)狀態(tài)標識:沒有數(shù)據(jù)、爆發(fā)模式的待處理數(shù)據(jù)、活動區(qū)模式的待處理數(shù)據(jù)、寧靜模式的待處理數(shù)據(jù)、寧靜模式處理好數(shù)據(jù)及待送出數(shù)據(jù)等。DSP根據(jù)數(shù)據(jù)狀態(tài)和觀測模式,可以進行相應(yīng)的處理;(12)相關(guān)數(shù)據(jù)狀態(tài)(CORR):標識相關(guān)運算用的數(shù)據(jù)的狀態(tài)。

2.3.2 DSP的存儲器空間分配

DSP的SYSCON寄存器的15~12位(MSIZE),可以設(shè)置以MS0~MS3作為片選信號時,每個分組的空間大小。其公式為:MSIZE=log2(塊大小)-13;取每個塊的大小為16MB,因此MSIZE=1011。
 



評論


相關(guān)推薦

技術(shù)專區(qū)

關(guān)閉