《電子技術應用》
您所在的位置:首頁 > 模擬設計 > 設計應用 > 基于Hi3516A的H265碼流實時傳輸系統設計
基于Hi3516A的H265碼流實時傳輸系統設計
2015年微型機與應用第20期
魯 云,韓 賓,程錦發,李 岳
西南科技大學 信息工程學院,四川 綿陽 621010
摘要: 介紹了在海思Hi3616A開發平臺下實現的一種H265碼流實時傳輸系統。利用海思提供的媒體處理平臺(MPP)采集高清攝像頭感應到的視頻圖像并進行H265壓縮編碼,然后對LIVE555開源代碼進行二次開發,實現播放H265實時碼流的功能,將壓縮編碼后的數據發送出去。設計結果表明,系統傳輸高清視頻圖像延遲短,播放流暢,滿足智能監控領域應用的要求。
關鍵詞: MPP live555 H265 實時碼流
Abstract:
Key words :

  摘  要: 介紹了在海思Hi3616A開發平臺下實現的一種H265碼流實時傳輸系統。利用海思提供的媒體處理平臺(MPP)采集高清攝像頭感應到的視頻圖像并進行H265壓縮編碼,然后對LIVE555開源代碼進行二次開發,實現播放H265實時碼流的功能,將壓縮編碼后的數據發送出去。設計結果表明,系統傳輸高清視頻圖像延遲短,播放流暢,滿足智能監控領域應用的要求。

  關鍵詞: MPP;LIVE555;H265;實時碼流

0 引言

  隨著社會的發展以及人們生活質量的提高,安全問題越來越受到重視。在這樣的形式之下,網絡視頻監控技術占領著越來越大的市場,廣泛應用在交通、商場等領域。然而,技術應用對視頻的質量、傳輸的實時性和數據的壓縮效率等提出了要求[1],對項目開發構成了巨大挑戰。本文設計并實現了一套實時流媒體傳輸系統,以Hi3516A開發平臺作為基礎,以高壓縮效率的H265編碼算法作為編碼技術,通過對LIVE555開源代碼二次開發實現H265碼流實時傳輸從而構成了整個系統。該系統在視頻質量、壓縮效率、實時性上都滿足了當前市場應用的要求,對實際項目開發具有一定的借鑒意義。

1 系統工作原理

  如圖1所示,系統以Hi3516A開發平臺(由高分辨率1 080 p的AR0330攝像頭模塊和帶千兆以太網功能的Hi3516A控制器模塊組成硬件平臺,并在硬件平臺上燒寫了U-Boot、Linux內核和加載了相關驅動)作為基礎,在該平臺上開發應用程序。首先,進程A獲取來自AR0330攝像頭模塊的YUV原始視頻圖像,并使用H265壓縮編碼算法進行壓縮編碼獲得H265格式碼流,該過程通過使用海思提供的媒體處理平臺(MPP)實現;其次,進程B負責響應網絡客戶端的請求,將進程A的輸出碼流通過千兆以太網接口實時地發送出去,該過程通過對LIVE555開源代碼(該代碼原本只支持文件發送功能,而不支持內存實時數據發送功能)二次開發實現;此外,進程A與進程B之間的數據交換使用共享內存進程通信方式,節約了CPU資源和時間成本。

2 功能實現

  2.1 視頻捕捉與編碼

  選擇在Hi3516A開發平臺上開發體現了在視頻捕捉和編碼過程中的很多優勢。Hi3516A是專用于HD IP攝像機的多媒體芯片,具有高性能Cortex-A7處理器和內部集成的硬件H265視頻標準編碼器[2];此外,海思提供的MPP對應用軟件屏蔽了芯片相關的復雜的底層處理,提供給應用程序方便的接口,這樣不僅大大縮短了開發周期,還降低了開發難度。對于應用程序開發者,只需要使用MPP所提供的接口實現特定功能,滿足應用。

Image 001.png

  MPP主要由視頻輸入(VI)、視頻處理(VPSS)、視頻編碼(VENC)、視頻解碼(VDEC)、視頻輸出(VO)、視頻偵測分析(VDA)、區域管理(REGION)等模塊組成。本系統用到VI、VPSS、VENC和REGION模塊完成視頻采集、處理、信息疊加和壓縮編碼工作,最終得到目標碼流。

  如圖2所示,首先,調用系統控制模塊的媒體處理平臺編程接口(MPI)完成硬件和MPP初始化,它實現的重要功能是分配視頻緩存池;其次,調用VI模塊的MPI創建視頻輸入設備和視頻物理通道并設置參數;然后,調用VPSS模塊的MPI創建組和通道,并設置組和通道參數,輸出期望分辨率的視頻數據;最后,調用REGION模塊的MPI,在原始圖像上疊加用戶信息,并調用VENC模塊的MPI對YUV原始圖像進行H265壓縮編碼,得到H265格式碼流[3]。完成以上工作后,創建一個線程不斷從編碼通道獲取實時H265碼流。整個過程都通過調用各模塊的MPI實現,難度較低。

Image 002.png

  2.2 H265實時碼流傳輸

  本系統中,H265實時流媒體數據的傳輸在LIVE555 C++開源項目的基礎上實現。LIVE555是跨平臺的流媒體解決方案,使用RTSP、RTCP/RTP等標準流媒體傳輸協議,支持H265、H264、MPEG等視頻格式和多種音頻格式的流化、發送、接收等處理。此外,由于良好的代碼框架設計,很容易擴展出對其他媒體格式的支持,所以大量應用在流媒體傳輸方案中,比如網絡視頻監控應用、流媒體播放器等。

  LIVE555默認只支持發送音視頻文件,而不支持從媒體設備獲取的實時碼流。在本系統中,需要修改LIVE555源代碼以實現H265碼流實時發送功能。

  一種方法是通過有名管道(FIFO)實現,這種方法不需要修改LIVE555源代碼,只需在視頻捕捉與編碼源進程中創建一個FIFO,并不斷把實時H265碼流寫入FIFO中即可。LIVE555服務器端用發送音視頻文件的方式獲取FIFO中數據,完成實時直播[4]。這種方法容易實現,使用較多,但是當視頻碼流率較大時監控端的延時較大,并存在卡頓、馬賽克等現象,效果較差。另一種方法是通過修改LIVE555源代碼,從實現RTSP服務的相關基類派生出H265碼流直播的類,重寫類的成員方法來實現。該方法通過共享內存進程通信方式實現與視頻捕捉和編碼進程的碼流交互。這種方法的實現比較復雜,但在數據處理過程中比第一種方式少了多次數據寫入和拷貝工作,如圖3所示(其中實線部分為第一種方法數據流向,虛線部分為第二種方法數據流向),從而監控端能夠以較大碼流率實時、流暢地播放高清視頻圖像。本文主要針對第二種方法的設計實現,而不討論第一種方法。

Image 003.png

  LIVE555主要通過任務調度機制和RTSP服務機制兩個部分實現流媒體服務器功能[5]。其中任務調度機制主要通過TaskScheduler類庫實現,它完成網絡套接字任務、延時任務和觸發事件三種任務的循環調度,從而構成了系統運行框架。而RTSP服務機制通過工程的liveMedia目錄下的類庫實現,通過把RTSP協議加入到運行框架中,實現了流媒體服務器。下面具體分析RTSP服務機制的實現過程。

  首先,建立RTSPServer,監聽客戶端的連接請求,響應客戶端請求建立連接后,創建RTSPClientSession,RTSP協議就是在RTSPClientSession中實現的。然后是RTSP協議的實現過程,客戶端向服務器端發送RTSP描述命令(DESCRIBE),服務器查找到對應的ServerMediaSession(對應某個媒體設備或某種格式文件),并生成會話描述協議(SDP)信息進行回應;接著,客戶端發送RTSP建立命令(SETUP),服務器端建立RTP/RTCP套接字,并建立特定的Source和Sink,為數據的獲取、封包和發送做準備;完成以上步驟后,客戶端發送播放命令(PLAY),服務器端響應請求,循環調用Source對象的成員方法獲取數據并通過Sink對象的成員方法進行封包和發送,實現流媒體服務器的功能;在播放過程中,客戶端可以發送終止命令(TERADOWN)結束流媒體會話。

  從RTSP協議實現過程可知,為了支持H265實時流媒體數據傳輸,需要實現用戶自定義類ServerMediaSubssion、Source和Sink[6]。自定義的類可以繼承H265VideoFileServer MediaSubsession、H265VideoRTPSink和H265VideoStreamFramer中能共用的方法,重寫H265實時流媒體處理特有的方法。具體實現方法是添加H265LiveVideoServerMediaSubssion:public H265VideoFileServerMediaSubsession類,并重寫createNewStreamSource成員方法。該成員方法的關鍵段代碼段如下:

  estBitrate=1000;

  H265FramedLiveSource*liveSource=\

  H265FramedLiveSource::createNew(envir());

  if(liveSource==NULL){return NULL;}

  return H265VideoStreamFramer::\

  createNew(envir(),liveSource);

  該代碼段的主要工作是把ByteStreamFileSource替換為用戶自定義的H265FramedLiveSource,用于獲取高清攝像頭上的實時視頻數據。H265FramedLiveSource的成員方法H265FramedLiveSource::doGetNextFrame()就實現了從H265編碼輸出端獲取H265格式視頻數據并送到H265VideoRTPSink端的過程。其中,進程之間數據交換采用共享內存方式,用有名信號量實現進程對共享內存的同步訪問。該成員方法的關鍵代碼段如下:

  static int niHaveReadSize=0;

  if(Framed_dosent==true){

  if(0==niHaveReadSize)sem_wait(semr);

  fFrameSize=\

  (Framed_datasize-niHaveReadSize>fMaxSize)\

  fMaxSize:\

  Framed_datasize-niHaveReadSize;

  memcpy(fTo,shm_add+niHaveReadSize,\

  fFrameSize);

  niHaveReadSize+=fFrameSize;

  if(niHaveReadSize==Framed_datasize){

  sem_post(semw);

  niHaveReadSize=0;

  }

  }

  這樣,當服務器端收到客戶端PLAY命令時,不斷調用H265FramedLiveSource::doGetNextFrame()讀取H265格式視頻數據,封包和發送出去,實現H265碼流實時傳輸功能。

  在主函數中,只需在創建ServerMediaSession時加入H265LiveVideoServerMediaSubssion,并向RTSPServer中注冊該ServerMediaSession即可[7]。

3 結果分析

  H265碼流實時傳輸的程序通過海思平臺的交叉編譯工具鏈編譯,生成可執行文件,并在海思Hi3516A開發平臺下運行,完成服務器搭建工作。服務器正常運行后的終端輸出如圖4所示。

Image 004.png

  客戶端通過安裝Windows系統下的VLC播放器實現。打開VLC播放器,在“打開網絡串流”選項中輸入rtsp://192.168.1.116:8554/H265LiveVideo,點擊播放,就可以看到來自高清攝像頭的視頻圖像,并長期穩定工作。與常用的FIFO方式作效果對比,當碼流率較大時,視頻圖像延遲更短,視頻畫面更加完整和流暢。

4 結論

  在海思Hi3516A開發平臺上,通過調用MPP進行編程和修改LIVE555流媒體服務器源代碼,實現了H265實時碼流獲取和網絡直播功能,且具有良好的效果,可以應用在項目開發中。由于系統還處在測試階段,不夠完善,實際項目開發中,要根據實際情況進一步優化,以達到更好的性能。

參考文獻

  [1] 瞿洪桂.網絡視頻監控的市場現狀及發展方向[J].中國安防,2015(5):32-35.

  [2] 季健佼.解析海思H.265超高清IP視頻監控解決方案[J].中國公共安全(綜合版),2014(22):198-200,202.

  [3] 王峰.基于Hi3516的音視頻采集及網絡傳輸技術研究[D].西安:西安電子科技大學,2013.

  [4] 曾金,毛燕琴,沈蘇彬,等.嵌入式流媒體服務器的設計和實現[J].計算機技術與發展,2011,21(7):81-84,89.

  [5] 許華濱,謝維波,黃奕,等.基于Live555的流媒體服務器設計與實現[J].微型機與應用,2014,33(18):48-50.

  [6] 呂少君,周淵平.基于Live555的實時流媒體傳輸系統[J].計算機系統應用,2015,24(1):56-59.

  [7] 彭宏,吳海巍,葉敏展,等.基于流媒體的移動視頻直播系統的設計與實現[J].電子技術應用,2014,40(9):111-113,117.


此內容為AET網站原創,未經授權禁止轉載。
主站蜘蛛池模板: 成年人色视频 | ririricc在线观看麻豆 | 国产三级欧美 | 美女网站视频黄 | 亚洲精品xxx | 天天舔天天摸 | 中文字幕在线精品视频入口一区 | 成年人网站在线免费观看 | 久久久久免费视频 | 在线久色| 男人下面进女人下面视频免费 | 国产一级大片 | 添人人躁日日躁夜夜躁夜夜揉 | 午夜日韩精品 | 麻豆69堂免费视频 | 免费一级国产生活片 | 在线成年人视频 | 伊人网网 | 人人澡 人人澡 人人看欧美 | 涩爱tv| 天啪天干在线视频 | 日本中文在线视频 | 人人看人人爽 | 黄网站视频 | 国产高清a毛片在线看 | 欧美xx00| 免费黄色在线网址 | 午夜色影院 | 免费乱理伦片泡泡影院琪琪 | 欧美黄色α片 | 欧美精选在线 | 天天操天天插 | 妞干网免费 | 涩涩福利网址导航 | 成人免费午间影院在线观看 | 天啪天干在线视频 | 韩漫画无遮挡羞免费网站 | 亚洲成年网 | 日韩三级影视 | 成人区在线观看免费视频 | 久久综合久久久 |