一種優(yōu)化的機(jī)頂盒電子節(jié)目指南系統(tǒng)的設(shè)計(jì)方案
本文針對兩類不同的SI表接收要求設(shè)計(jì)不同的SI引擎解決方案。其中簡單EPG的SI引擎流程如圖2,高級EPG的SI引擎流程如圖3.
當(dāng)過濾器收到EIT表并調(diào)用中斷處理函數(shù)時(shí),簡單EPG采用先關(guān)閉EIT P/F信道,并設(shè)置相關(guān)標(biāo)志,等待后臺(tái)輪詢函數(shù)解析處理完該表以后再打開EIT P/F信道重新接收,即過濾器接收表的過程和后臺(tái)輪詢函數(shù)解析處理是串行處理的,這種機(jī)制能夠?qū)崟r(shí)處理當(dāng)前的表,適合簡單EPG信息量小、更新速度快的特點(diǎn);高級EPG則不關(guān)閉信道,而是先解析表頭,如果該段沒有接收過,則將該段信息插入消息隊(duì)列,等待后臺(tái)輪詢函數(shù)解析處理,即過濾器接收表的過程和后臺(tái)輪詢函數(shù)解析處理是并行處理的,這種機(jī)制能夠保證過濾器收表過程連續(xù)而不被后臺(tái)打斷,適合高級EPG信息量大、前端連續(xù)發(fā)送的特點(diǎn)。
在EIT表版本更新方面,簡單EPG收到當(dāng)前和下一個(gè)節(jié)目信息以后,立即將過濾器設(shè)置成只接收新版本EIT P/F表,這樣可以實(shí)時(shí)接收并更新簡單EPG信息;對于高級EPG,由于信息量大且前端更新速度慢,所以在只在每次重新開機(jī)時(shí)接收最新版本的EIT表信息。
3.2 EPG數(shù)據(jù)庫
傳統(tǒng)機(jī)頂盒上的EPG數(shù)據(jù)庫是單一的節(jié)目信息數(shù)據(jù)庫,本文的優(yōu)化處理在于:節(jié)目索引和節(jié)目詳細(xì)信息分別建立數(shù)據(jù)庫并彼此獨(dú)立維護(hù)。其中節(jié)目索引數(shù)據(jù)庫是按照頻道-子表-段-節(jié)目的樹狀索引結(jié)構(gòu),如圖4所示。其中段節(jié)點(diǎn)包含了它所屬所有節(jié)目的id(參數(shù)event_id),同時(shí)還包含了表示該段是否接收的參數(shù)sectavail.
這種樹狀索引數(shù)據(jù)庫有三個(gè)優(yōu)點(diǎn):
1. 樹狀索引所有節(jié)目id,這樣便于節(jié)目信息的查詢和按時(shí)間排序;
2. 記錄某頻道的EIT表所有段的接收情況,便于SI引擎在接收時(shí)判斷該段是否已經(jīng)接收;
3. 索引結(jié)構(gòu)便于節(jié)目信息數(shù)據(jù)庫的管理,如刪除某一個(gè)頻道的所有高級EPG信息等。
節(jié)目信息數(shù)據(jù)庫則存儲(chǔ)了每個(gè)節(jié)目的詳細(xì)信息,包括節(jié)目名稱、節(jié)目起始和終止時(shí)間、節(jié)目簡介以及節(jié)目語言種類等。其中重要的參數(shù)是節(jié)目id,通過該參數(shù)節(jié)目索引數(shù)據(jù)庫可以訪問相應(yīng)的節(jié)目信息數(shù)據(jù)庫內(nèi)容。
3.3 EPG應(yīng)用程序測試與分析
EPG應(yīng)用程序主要功能是響應(yīng)遙控器中相關(guān)的EPG按鈕,并查詢EPG數(shù)據(jù)庫,將節(jié)目信息按照時(shí)間排序輸出到OSD界面中。對于簡單EPG,只需作當(dāng)前和下一個(gè)節(jié)目的時(shí)間排序輸出;而對于高級EPG,OSD界面中選中特定頻道和特定日期以后,通過訪問EPG數(shù)據(jù)庫中的節(jié)目索引數(shù)據(jù)庫,提取出指定頻道的所有節(jié)目id,然后根據(jù)節(jié)目id在節(jié)目信息數(shù)據(jù)庫中篩選出指定日期的節(jié)目,并按節(jié)目起始時(shí)間做冒泡排序,最后輸出到OSD顯示。
4 結(jié)論
本文介紹了機(jī)頂盒中EPG系統(tǒng)的架構(gòu),并就具體的功能模塊介紹了優(yōu)化方案。在SI引擎方面提出了針對簡單EPG和高級EPG不同的流程,在EPG數(shù)據(jù)庫方面提出了節(jié)目索引和節(jié)目信息分離的數(shù)據(jù)庫結(jié)構(gòu)。這種優(yōu)化結(jié)構(gòu)在實(shí)際的EPG碼流測試中取得良好的效果。
評論