0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

針對PXA27X微處理器開發(fā)平臺進行MPEG-4視頻編碼的優(yōu)化

電子設計 ? 來源:郭婷 ? 作者:電子設計 ? 2018-12-06 08:11 ? 次閱讀

隨著社會的發(fā)展,人們對消費類電子產(chǎn)品(如PDA,MP4,HDTV等)需求不斷增加,特別是對高質量高清晰多媒體的要求越來越高,因此視頻質量已經(jīng)成為廣大消費者關注的焦點之一。 MPEG-4編解碼的基本思想是基于圖像內容的第二代視頻編解碼方案,并將基于合成的編碼方案也結合在標準中。它根據(jù)圖像的內容將圖像分割成不同的視頻對象VO(Video Object),在編碼過程中對前景對象和后景對象采用不同的編碼策略,對于人們所關心的前景對象,則盡可能的保持對象的細節(jié)及平滑,而對不大關心的后景對象采用大壓縮比的編碼策略。

l MPEG一4是視頻標準

MPEG一4視頻部分是MPEG一4標準的核心內容之一。既提供傳統(tǒng)的基于幀的編碼方法又提供基于視頻對象(VO)的編碼方法。在某一時刻,視頻對象以視頻對象平面(VOP)的形式出現(xiàn),圖1所示為MPEG一4編碼的框架。編碼也主要針對該時刻視頻對象的形狀、運動和紋理這三類信息來進行。

針對PXA27X微處理器開發(fā)平臺進行MPEG-4視頻編碼的優(yōu)化

2 MPEG一4視頻編碼關鍵技術

MPEG-4按照如下五個層次組織要編碼的圖像,從上至下依次為:視頻段VS(Video Session)、視頻對象VO(Video Object)、視頻對象層VOL(Video Object Layer)、視頻對象組層GOV(Group of Video Object Plane)、視頻對象平面VOP(Video Object Plane)。 MPEG-4的編碼流程:第一步是VO的形成(VO Formation),先要從原始視頻流中分割出VO,之后由編碼控制(Coding control)機制為不同的VO以及各個VO的三類信息分配碼率,之后各個VO分別獨立編碼,最后將各個VO的碼流。

2.1 形狀編碼

MPEG一4首次引入形狀信息的編碼。VO的形狀信息有2類:二值形狀信息和灰度形狀信息。二值形狀信息用0,1表示VOP的形狀。二值信息的編碼采用基于塊的運動補償技術,可以無損或有損編碼?;叶刃螤钚畔⒂?~255之間的數(shù)值表示VOP的透明程度。目前對灰度形狀信息的編碼主要采用基于塊的運動補償與DCT方法,在不需要形狀信息的應用中,形狀編碼會被屏蔽掉。這部分編碼是以宏塊為單位進行的。

2.2 運動估計與補償編碼

類似于現(xiàn)有的編碼標準,MPEG一4采用運動預測和運動補償技術來去除圖像信息中的時間冗余成分,這些運動信息的編碼技術可視為由現(xiàn)有標準向任意形狀的 VOP的延伸。VOP的編碼有3種模式,即幀內編碼模式(I—VOP)、幀間預測編碼模式(P—VOP)和雙向預測編碼模式(B—VOP)。圖像填充技術利用VOP內部的像素值外推VOP外的像素值,以此獲得運動預測的參考值。對于標準宏塊,采用傳統(tǒng)的基于塊的運動估計和補償技術。

2.3 紋理編碼

VOP視頻的紋理信息可以表示為亮度成分Y和兩個色度成分Cr,Cb。幀內編碼情況下,紋理信息包含有亮度和色度成分;運動補償情況下,紋理信息表示經(jīng)過運動補償后的殘差。紋理編碼的對象可以是幀內編碼模式的I—VOP,也可以是幀間預測編碼模式B—VOP或P—VOP運動補償后的預測誤差。在幀內編碼模式中,對于完全在VOP內的像素塊,采用經(jīng)典DCT方法。對于完全位于VOP之外的像素塊則不進行編碼:對于部分在VOP內,部分在VOP外的像素塊首先采用圖像填充技術獲得VOP之外的像素值,之后再進行DCT編碼。在幀間編碼模式中,為了對B—VOP和P—VOP運動補償后的預測誤差進行編碼,將那些位于VOP區(qū)域之外的像素值設為128。紋理編碼過程如圖2所示,DCT變換、量化、掃描及變長編碼,這些過程與現(xiàn)有標準基本相同。

針對PXA27X微處理器開發(fā)平臺進行MPEG-4視頻編碼的優(yōu)化

3 MPEG一4是視頻編碼軟件

MPEG一4是軟件編碼是一個比較大的工程,項目用到的主要函數(shù)有:

mp4_encoder_init:初始化編碼的參數(shù),如視頻大小尺寸、碼流、緩沖大小;

encode_MPEG一4:編碼調用的總函數(shù),文本是基本層;

encode_pvop_MPEG一4對P幀的VOP的編碼的總函數(shù);

ippiBlockMatcn_Imeger_16x16_MVFAST:運動搜索MVFAST(Motion Vector Field AdaDtive Search Technique)。

下面是幀間宏塊編碼的函數(shù):

encode_inter_mb_MPEG一4

(1)lookup_uvmv_MPEG一4:查找色度圖像塊的運動矢量;

(2)ippiComputeTextureErrorBlock_SAD_8u16s:計算塊殘余的紋理誤差;

(3)encode_block_inter_MPEG一4:DCT變化和量化每塊的系數(shù)。這還得反變化,來重構下幀的參考幀;

(4)create_mb_MPEG一4:得到宏塊編碼的信息;

(5)ippiEncodeMV_MPEG一4_8u16s:運動矢量和紋理殘余的編碼;

(6)ippiEncodeVLCZigzag_Inter_MPEG一4_16slu:zigzig掃描和變長編碼。

IPP的函數(shù)合理使用,可以提高性能。如ip—piBlockMatch_InIeger_16x16_MVFAST這個函數(shù)就比ippiMotionEstimation_16x16_MVFAST減少3倍時間。這個函數(shù)是占正個系統(tǒng)最多的時間之一。

4 MPEG一4是視頻編碼優(yōu)化和結果

針對Intel公司的PXA27X處理器,MPEG一4計算量復雜,特別是運動搜索,必須對其必要的優(yōu)化,以滿足實時編碼的要求。編譯優(yōu)化是靜態(tài)優(yōu)化,優(yōu)化編譯器可以自動完成程序段和代碼塊范圍內的優(yōu)化問題,但由于對算法的流程很難獲取,所以人工優(yōu)化是不必可少的。合理分配指令周期流水線也是重點,如WLDRD需要4個周期,而WUN—PCKEL只需要1個周期,使用IPP庫函數(shù)將大量節(jié)約開發(fā)時間和提高性能等,按照實際的工程的需要編寫指令。

這里的試驗平臺是南望信息產(chǎn)業(yè)有限公司PDA,主頻可達624 MHz。視頻大?。?80×272)透過大量的試驗,測試表明MPEG一4編碼可以滿足用戶拍視頻需求,速度可達到20幀/s,而且有較高的壓縮率,碼流比較低,質量也不錯。圖3,4為實際拍攝2幀圖像。

針對PXA27X微處理器開發(fā)平臺進行MPEG-4視頻編碼的優(yōu)化

針對Intel公司的PXA27X微處理器開發(fā)平臺,在Linux操作系統(tǒng)中實現(xiàn)視頻編碼的功能。但是消費類產(chǎn)品對視頻的畫面有更高的要求,同時由于視頻編碼需要消耗大量的電源,電源的管理仍是視頻開發(fā)的研究重點。

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 視頻
    +關注

    關注

    6

    文章

    1925

    瀏覽量

    72719
  • 微處理器
    +關注

    關注

    11

    文章

    2231

    瀏覽量

    82206
  • 編解碼
    +關注

    關注

    1

    文章

    140

    瀏覽量

    19561
收藏 人收藏

    評論

    相關推薦

    針對TI汽車處理器新的SAFERTOS庫評估包

    體驗SAFERTOS針對TI 汽車處理器TDA4x/DRA8x的免費SAFERTOS二進制評估包。在高性能C66x DSP、強大的C7
    的頭像 發(fā)表于 10-09 15:50 ?215次閱讀
    <b class='flag-5'>針對</b>TI汽車<b class='flag-5'>處理器</b>新的SAFERTOS庫評估包

    MSP430x47x3、MSP430x47x4混合信號微處理器數(shù)據(jù)表

    電子發(fā)燒友網(wǎng)站提供《MSP430x47x3、MSP430x47x4混合信號微處理器數(shù)據(jù)表.pdf》資料免費下載
    發(fā)表于 08-09 11:05 ?0次下載
    MSP430<b class='flag-5'>x47x</b>3、MSP430<b class='flag-5'>x47x4</b>混合信號<b class='flag-5'>微處理器</b>數(shù)據(jù)表

    視頻處理器分辨率怎么調

    信號進行解碼、編碼、轉換、縮放等操作。視頻處理器廣泛應用于電視、顯示、投影儀、攝像頭等設備中。 視頻處理器的主要功能包括:
    的頭像 發(fā)表于 07-16 11:25 ?661次閱讀

    嵌入式微處理器的分類 嵌入式微處理器的種類和型號

    的分類可以從多個角度進行劃分,比如架構、指令集、用途等。下面將從這些角度詳細介紹嵌入式微處理器的種類和型號。 一、架構分類 嵌入式微處理器的架構分類主要有以下幾種: 單核架構(Single-core):單核架構的嵌入式
    的頭像 發(fā)表于 05-04 16:31 ?1920次閱讀

    嵌入式微處理器主要組成 嵌入式微處理器的分類和特點

    嵌入式微處理器是指集成在嵌入式系統(tǒng)中的微處理器,它是一種專門針對特定應用的定制處理器。嵌入式微處理器的主要組成包括核心
    的頭像 發(fā)表于 05-04 15:48 ?2125次閱讀

    嵌入式微處理器有哪幾類 嵌入式微處理器包含哪些重要參數(shù)

    等。在本文中,我們將詳細介紹嵌入式微處理器的幾類以及包含的重要參數(shù)。 一、嵌入式微處理器的幾類 通用微處理器 通用微處理器是指那些不專為嵌入式系統(tǒng)設計的
    的頭像 發(fā)表于 05-04 14:58 ?742次閱讀

    嵌入式微處理器的功能 嵌入式微處理器原理與應用

    嵌入式微處理器是一種集成了中央處理單元(CPU)核心和各種外圍接口的集成電路,廣泛應用于嵌入式系統(tǒng)中。由于嵌入式系統(tǒng)對功耗、體積和成本等方面有著嚴格的要求,嵌入式微處理器在這些方面都做出了相應的
    的頭像 發(fā)表于 05-04 14:50 ?952次閱讀

    嵌入式微處理器有哪幾種類型 嵌入式微處理器有哪些類別

    嵌入式微處理器是一種專門用于嵌入式系統(tǒng)中的微處理器,它能夠提供計算和控制功能。嵌入式系統(tǒng)通常是對特定任務或應用進行優(yōu)化的計算機系統(tǒng),例如汽車電子、醫(yī)療設備、智能家居等。嵌入式
    的頭像 發(fā)表于 05-04 14:42 ?628次閱讀

    嵌入式微處理器的分類特點 嵌入式微處理器作用

    領域,包括消費電子、工業(yè)控制、醫(yī)療設備、汽車電子等。 嵌入式微處理器可以根據(jù)其架構、指令集和性能等特點進行分類。常見的分類方法包括架構、工作頻率、指令集和功能等。 從架構的角度來看,嵌入式微處理器通常可以分
    的頭像 發(fā)表于 04-21 14:52 ?1167次閱讀

    嵌入式微處理器結構與應用 嵌入式微處理器一般分為哪幾類

    嵌入式微處理器是一種專用的微處理器,廣泛應用于嵌入式系統(tǒng)中。嵌入式系統(tǒng)是指嵌入到其他設備中的計算機系統(tǒng),其功能與控制是針對特定的應用需求而設計的。嵌入式微處理器通常具有較小的尺寸、低功
    的頭像 發(fā)表于 04-21 14:35 ?1238次閱讀

    嵌入式微處理器的基礎是什么

    要求的硬件和軟件技術。 在嵌入式微處理器的基礎上,我們可以考慮以下幾個方面進行詳細討論: 處理器架構和指令集:嵌入式微處理器通常在特定的指令集架構上運行,比如ARM架構、MIPS架構或
    的頭像 發(fā)表于 04-21 14:34 ?1028次閱讀

    dsp和嵌入式微處理器的區(qū)別是什么

    DSP(數(shù)字信號處理器)和嵌入式微處理器是兩種針對不同應用優(yōu)化處理器類型。本文將深入探討它們之間的技術差異、應用場景以及它們各自的優(yōu)勢和局
    的頭像 發(fā)表于 04-07 15:11 ?1124次閱讀

    什么是嵌入式微處理器?嵌入式微處理器有哪些?

    嵌入式微處理器是指嵌入到特定應用系統(tǒng)中的微處理器,它是整個嵌入式系統(tǒng)的核心,由通用處理器演變而來,具有體積小、重量輕、成本低、可靠性高等優(yōu)點。與通用處理器相比,嵌入式
    的頭像 發(fā)表于 03-29 11:39 ?866次閱讀

    嵌入式微處理器的原理和應用

    嵌入式微處理器是專為嵌入式系統(tǒng)設計的微處理器,它們是嵌入式系統(tǒng)的核心組件,負責執(zhí)行程序指令、處理數(shù)據(jù)和控制其他硬件設備。與通用微處理器相比,嵌入式
    的頭像 發(fā)表于 03-28 15:51 ?753次閱讀

    微處理器由什么組成 微處理器和cpu的關系

    計數(shù)等。指令譯碼對指令進行解析和譯碼,時鐘發(fā)生提供時鐘脈沖以驅動微處理器的運行,程序計數(shù)
    的頭像 發(fā)表于 02-22 10:40 ?3343次閱讀