新聞中心

EEPW首頁(yè) > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > 基于Linux的虛擬試妝系統(tǒng)設(shè)計(jì)

基于Linux的虛擬試妝系統(tǒng)設(shè)計(jì)

作者: 時(shí)間:2011-09-01 來(lái)源:網(wǎng)絡(luò) 收藏

隨著社會(huì)的進(jìn)步,人們對(duì)自身形象愈加重視,化妝成為女性一門必修課。如何選擇合適的化妝品對(duì)于不少女性來(lái)說(shuō)是一項(xiàng)難題。近幾年針對(duì)該問題提出了多種試妝解決方案。包括通過瀏覽器進(jìn)行本地與遠(yuǎn)程服務(wù)器交互方案及使用Visual C++開發(fā)上位機(jī)軟件[1]等。
以Altera公司的SoPC技術(shù)和操作為基礎(chǔ),了一款嵌入式試妝。該在SD卡中存儲(chǔ)信息,通過攝像頭采集用戶面部圖像,用戶可通過觸摸屏瀏覽、選擇商品對(duì)影像進(jìn)行上妝,并查看試妝效果,最終達(dá)到選購(gòu)化妝品的目的。系統(tǒng)具有體積小巧、方便易用等特點(diǎn),適合于各種商場(chǎng)的化妝品柜臺(tái)。
1 系統(tǒng)總體結(jié)構(gòu)
系統(tǒng)以DE2-70為核心板,外接PS2鍵盤錄入信息,通過擴(kuò)展口分別接入LTM觸摸屏和D5M 500萬(wàn)像素?cái)z像頭。為使用操作系統(tǒng),構(gòu)建了帶MMU的Nios II處理器的SoPC。通過SDRAM運(yùn)行內(nèi)核和RAM文件系統(tǒng),使用SSRAM作為顯示緩存,將硬件編程代碼燒入EPCS,而將壓縮的內(nèi)核、文件系統(tǒng)與引導(dǎo)代碼一起燒入Flash。系統(tǒng)采用Altera大學(xué)計(jì)劃IP中的PS2 Controller和Video IPs分別管理PS2接口和觸摸屏的顯示部分,自行編寫硬件模塊實(shí)現(xiàn)觸摸屏的配置、攝像頭采集和SSRAM多路復(fù)用。此外,系統(tǒng)還使用SPI模式管理SD/MMC卡以及第三方IP管理網(wǎng)絡(luò)物理芯片。系統(tǒng)結(jié)構(gòu)框圖如圖1所示。
2 系統(tǒng)硬件
2.1 運(yùn)行的最小系統(tǒng)搭建

Linux操作系統(tǒng)對(duì)SoPC系統(tǒng)的構(gòu)建有特殊要求,包括帶MMU處理器設(shè)置、全功能定時(shí)器啟用、通信終端設(shè)定等。表1總結(jié)了Linux系統(tǒng)所需要添加的SoPC組件以及關(guān)鍵設(shè)置[2]。
2.2 影像采集和存儲(chǔ)方案設(shè)計(jì)
圖2所示為本系統(tǒng)使用的影像采集和存儲(chǔ)方案。在SoPC系統(tǒng)外,通過Cam_CFG_CAP模塊配置和采集攝像頭數(shù)據(jù),經(jīng)由SSRAM_WRITE模塊合成指定格式數(shù)據(jù)并生成SSRAM寫時(shí)序送入SSRAM_2PORT進(jìn)行仲裁;SSRAM_2PORT既接收SSRAM_WRITE的數(shù)據(jù)寫入SSRAM的指定區(qū)域,又允許SSRAM Controller訪問SSRAM獲取相應(yīng)數(shù)據(jù)。

本文引用地址:http://m.butianyuan.cn/article/150272.htm

(1)SSRAM_WRITE
該模塊分別提取Cam_CFG_CAP傳入RGB分量的高5、6、5 bit數(shù)據(jù),拼接成16 bit數(shù)據(jù),讀入兩個(gè)像素合成32 bit,同時(shí)生成對(duì)應(yīng)的21 bit SSRAM地址,將其傳遞給SSRAM_2PORT。
(2)SSRAM_2PORT
該模塊對(duì)來(lái)自SoPC系統(tǒng)的SSRAM控制器和SSRAM_WRITE的讀寫請(qǐng)求做出仲裁。在CPU讀請(qǐng)求有效期間,SSRAM_2PORT模塊讀取SSRAM中的數(shù)據(jù)發(fā)送給Avalon總線;超出讀請(qǐng)求有效期則接收SSRAM_WRITE模塊圖像數(shù)據(jù)寫入SSRAM。在該模塊中添加兩個(gè)DCFIFO分別作為實(shí)時(shí)圖像數(shù)據(jù)及其對(duì)應(yīng)地址的緩沖空間,實(shí)現(xiàn)不同時(shí)鐘域的數(shù)據(jù)同步。
3 系統(tǒng)軟件設(shè)計(jì)
3.1 開發(fā)包修改及內(nèi)核配置

系統(tǒng)采用NiosWiki社區(qū)發(fā)布的nios2-linux-20090929.tar內(nèi)核開發(fā)包作為軟件開發(fā)基礎(chǔ)。SoPC系統(tǒng)構(gòu)建好后,通過“sopc-create-header-files --single custom_fpga.h”生成自定義硬件對(duì)應(yīng)的C語(yǔ)言頭文件,將該文件拷貝到“nios-linux/linux-2.6/arch/nios/include/asm/”路徑中。開發(fā)包通過custom_fpga.h和nios.h兩個(gè)文件中的宏定義管理SoPC組件與Linux內(nèi)核驅(qū)動(dòng)代碼對(duì)設(shè)備的映射,同時(shí)通過config.c文件內(nèi)置了大量設(shè)備的驅(qū)動(dòng)支持,由內(nèi)核配置生成的config.h文件和nios.h以及custom_fpga.h共同控制。圖3所示為這三個(gè)文件之間的關(guān)系。

linux操作系統(tǒng)文章專題:linux操作系統(tǒng)詳解(linux不再難懂)

上一頁(yè) 1 2 下一頁(yè)

評(píng)論


相關(guān)推薦

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

關(guān)閉