新聞中心

EEPW首頁(yè) > 手機(jī)與無(wú)線通信 > 設(shè)計(jì)應(yīng)用 > 基于IAIDL 的家庭網(wǎng)關(guān)設(shè)計(jì)與實(shí)現(xiàn)

基于IAIDL 的家庭網(wǎng)關(guān)設(shè)計(jì)與實(shí)現(xiàn)

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

4.1 BOA 結(jié)構(gòu)

用戶在遠(yuǎn)程監(jiān)控端 (如手機(jī)、萬(wàn)能遙控器)上打開瀏覽器,輸入的外部IP 號(hào),經(jīng)權(quán)限確認(rèn)后瀏覽器上將出現(xiàn)主頁(yè)面,選擇要控制或查詢的家電設(shè)備,或注冊(cè)新家電,然后填寫HTML 表單信息并提交進(jìn)而控制家電、查詢MySQLite 中家電狀態(tài)信息及注冊(cè)新用戶。目前,uCLinux 中已包含了BOA 的源代碼,通過(guò)在boa.conf 和mime.types 文件中修改網(wǎng)頁(yè)存放的路徑以及CGI 程序存放的目錄,在uCLinux 中BOA 的WEB 服務(wù)。

2. 4.2 編譯器

編譯器模塊將逐條解讀事先由廠家按 語(yǔ)法規(guī)則描述的信息家電的IAIDL 文件,編譯器將IAIDL 文件的關(guān)鍵信息提取出來(lái)并做一定的處理后,結(jié)果存儲(chǔ)到MySQLite 的表格里,以后遠(yuǎn)程用戶端和設(shè)備之間將根據(jù)設(shè)備號(hào)通過(guò)網(wǎng)絡(luò)經(jīng)由數(shù)據(jù)庫(kù)完成交互。以甲公司生產(chǎn)的某品牌空調(diào)A 為例,其IAIDL 文件描述如下:

A 空調(diào) is 空調(diào)>

{
enum switch=( 開,關(guān));
enum state=( 左右掃風(fēng),上下掃風(fēng));
[attribute: ‘ 廠家’]string 甲公司;
[attribute: ‘ 功率’]string 200W;
[function: ‘ 調(diào)溫度’]void SetTemperature(in int temperature[[0,40]]);
[function: ‘ 轉(zhuǎn)換狀態(tài)’]void SetState(in state oo)provided;
[function: ‘ 開關(guān)’]void OnOff(in switch oo)provided;

}

4.3 專家協(xié)作系統(tǒng)及實(shí)現(xiàn)

專家協(xié)作系統(tǒng)將信息家電的協(xié)作信息作為它的知識(shí)庫(kù)存儲(chǔ)在數(shù)據(jù)庫(kù)中,并通過(guò)自帶的推理機(jī)對(duì)這些協(xié)作規(guī)則進(jìn)行推理,用戶如果需要選擇信息家電間智能協(xié)作方式,可以在遠(yuǎn)程終端或客戶端通過(guò)瀏覽器界面使用該系統(tǒng),由推理機(jī)對(duì)協(xié)作規(guī)則匹配、比較得到判斷結(jié)果,將結(jié)果以HTML 頁(yè)面形式反饋到用戶端,專家協(xié)作系統(tǒng)推理正確后會(huì)調(diào)用與協(xié)作相關(guān)的信息家電API 接口來(lái)實(shí)現(xiàn)信息家電間的智能協(xié)作。下列語(yǔ)句是幾個(gè)信息家電協(xié)作的規(guī)則。

If (電視機(jī) on) then DVD on;
If (門打開) (time=17:30), then 燈打開;

4.4 數(shù)據(jù)庫(kù)MySQLite 設(shè)計(jì)及實(shí)現(xiàn)

數(shù)據(jù)庫(kù)MySQLite 中包含有三種類型的數(shù)據(jù)表:用戶信息表、協(xié)作規(guī)則庫(kù)表和家電信息表。用戶信息表用于存儲(chǔ)用戶名稱和密碼,以保證網(wǎng)關(guān)的使用安全。協(xié)作規(guī)則庫(kù)表用于存儲(chǔ)可以智能協(xié)作的信息家電組信息,以及家電之間協(xié)作的動(dòng)作及規(guī)則。家電信息表主要存儲(chǔ)家電的運(yùn)行狀態(tài)數(shù)據(jù),主要與家電控制程序controller 、查詢程序query 進(jìn)行交互。下面的代碼主要說(shuō)明在家庭網(wǎng)關(guān)應(yīng)用程序中是如何將客戶的注冊(cè)信息,通過(guò)CGI 程序?qū)懭霐?shù)據(jù)庫(kù)文件IA_db 中表users 中的。

#include sqlite.h> // 其它頭文件略過(guò)2 sqlite *db=sqlite_open(“/home/liwenbo/jx44b0/uClinux_dist/user/mySQLite/IA_db”,0777,errmsg); //打開數(shù)據(jù)庫(kù)語(yǔ)句void insert_device_list(char *table_name, int type_id, char *device_name, int device_ip) //用于處理新的信息家電注冊(cè)信息,將其插入MySQLite 中

基金資助項(xiàng)目名稱:傳感器網(wǎng)絡(luò)密鑰預(yù)分配方案的組合論研究(編號(hào):10571052) 頒發(fā)部門:國(guó)家自然科學(xué)基金委

{ //int i; //i 為最新注冊(cè)的信息家電id 號(hào) //i=sqlite_last_insert_rowid(db)+1; printf(“/n table_name: %s type_id: %d device_name: %s ip: %dn”,.

table_name, type_id, device-name, device_ip); qry=sqlite_mprintf(“INSERT INTO users (type_id, device_name, device_ip)” “VALUES(‘%d’,upper(‘%q’),’%q’)”,

type_name, type_id, device_name, device_ip); ret=sqlite_exec(db,qry, NULL, NULL, errmsg); if(ret!=SQLITE_OK)

{
printf(stderr, ”SQL error: %sn”,errmsg);
}
sqlite_close(db);
}

5.結(jié)束語(yǔ)

本實(shí)驗(yàn)通過(guò)以上代碼,已經(jīng)基本實(shí)現(xiàn)了中幾大主要模塊的功能,并已經(jīng)在ARM7 平臺(tái)上得到模擬實(shí)驗(yàn)結(jié)果,PC 機(jī)能通過(guò)瀏覽器發(fā)出家電監(jiān)控請(qǐng)求,網(wǎng)關(guān)通過(guò)訪問(wèn)數(shù)據(jù)庫(kù)來(lái)獲得家電最新狀態(tài)和屬性信息;新的家電加入網(wǎng)絡(luò)時(shí)能通過(guò)B/S 方式實(shí)現(xiàn)其在數(shù)據(jù)庫(kù)中的注冊(cè);專家協(xié)作系統(tǒng)的推理機(jī)和數(shù)據(jù)庫(kù)中知識(shí)庫(kù)的使用結(jié)合,用于實(shí)現(xiàn)多個(gè)信息家電之間的智能協(xié)作。完善之后的系統(tǒng)將是集多種智能管理于一身的系統(tǒng),相信會(huì)獲得很好的市場(chǎng)前景。

2. 6.本文作者創(chuàng)新點(diǎn)

本文在傳統(tǒng)網(wǎng)關(guān)的設(shè)計(jì)基礎(chǔ)上,加入了適合系統(tǒng)的嵌入式數(shù)據(jù)庫(kù)(MySQLite); 并創(chuàng)造性地將IAIDL 編譯器移植到家庭網(wǎng)關(guān)上,解決了不同品牌家電加入智能家居網(wǎng)絡(luò)時(shí)的異構(gòu)問(wèn)題;此外,還首次將專家協(xié)作系統(tǒng)作為的一個(gè)模塊添加進(jìn)來(lái),實(shí)現(xiàn)智能家居中的智能家電協(xié)作功能。

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

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

評(píng)論


相關(guān)推薦

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

關(guān)閉