⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 omxvcm4p2_mcreconblock.c

📁 The OpenMAX DL (Development Layer) APIs contain a comprehensive set of audio, video, signal processi
💻 C
字号:
/** *  * File Name:  omxVCM4P2_MCReconBlock.c * OpenMAX DL: v1.0.2 * Revision:   10586 * Date:       Wednesday, March 5, 2008 *  * (c) Copyright 2007-2008 ARM Limited. All Rights Reserved. *  *  * Description: * MPEG4 motion compensation prediction for an 8x8 block using  * interpolation *  */ #include "omxtypes.h"#include "armOMX.h"#include "omxVC.h"#include "armCOMM.h"/** * Function: armVCM4P2_HalfPelVer * * Description: * Performs half pel motion compensation for an 8x8 block using vertical  * interpolation described in ISO/IEC 14496-2, subclause 7.6.2. * * Remarks: * * Parameters: * [in] pSrc        pointer to the block in the reference plane. * [in] srcStep     distance between the start of consecutive lines *                  in the reference plane, in bytes; must be a multiple *                  of 8. * [in] rndVal      rounding control parameter: 0 - disabled; 1 - enabled. * [out] pDst       pointer to the linaer 8x8 destination buffer; * */static OMXVoid armVCM4P2_HalfPelVer(      const OMX_U8 *pSrc,      OMX_INT srcStep,       OMX_U8 *pDst,      OMX_INT rndVal){  const OMX_U8 *pTempSrc1;  const OMX_U8 *pTempSrc2;  OMX_INT y, x;    pTempSrc1 = pSrc;    pTempSrc2 = pSrc + srcStep;  srcStep -= 8;  for (y = 0; y < 8; y++)  {    for (x = 0; x < 8; x++)    {      *pDst++ = ((*pTempSrc1++ + *pTempSrc2++) + 1 - rndVal) >> 1;    }    pTempSrc1 += srcStep;    pTempSrc2 += srcStep;  }}/** * Function: armVCM4P2_HalfPelHor * * Description: * Performs half pel motion compensation for an 8x8 block using horizontal  * interpolation described in ISO/IEC 14496-2, subclause 7.6.2. * * Remarks: * * Parameters: * [in] pSrc        pointer to the block in the reference plane. * [in] srcStep     distance between the start of consecutive lines *                  in the reference plane, in bytes; must be a multiple *                  of 8. * [in] rndVal      rounding control parameter: 0 - disabled; 1 - enabled. * [out] pDst       pointer to the linaer 8x8 destination buffer; * */static OMXVoid armVCM4P2_HalfPelHor(      const OMX_U8 *pSrc,      OMX_INT srcStep,       OMX_U8 *pDst,      OMX_INT rndVal){  const OMX_U8 *pTempSrc1;  const OMX_U8 *pTempSrc2;  OMX_INT y, x;    pTempSrc1 = pSrc;  pTempSrc2 = pTempSrc1 + 1;  srcStep -= 8;  for (y=0; y<8; y++)  {    for (x=0; x<8; x++)    {      *pDst++ = ((*pTempSrc1++ + *pTempSrc2++) + 1 - rndVal) >> 1;    }    pTempSrc1 += srcStep;    pTempSrc2 += srcStep;  }}/** * Function: armVCM4P2_HalfPelVerHor * * Description: * Performs half pel motion compensation for an 8x8 block using both  * horizontal and vertical interpolation described in ISO/IEC 14496-2, * subclause 7.6.2. * * Remarks: * * Parameters: * [in] pSrc        pointer to the block in the reference plane. * [in] srcStep     distance between the start of consecutive lines *                  in the reference plane, in bytes; must be a multiple *                  of 8. * [in] rndVal      rounding control parameter: 0 - disabled; 1 - enabled. * [out] pDst       pointer to the linaer 8x8 destination buffer; * */static OMXVoid armVCM4P2_HalfPelVerHor(      const OMX_U8 *pSrc,      OMX_INT srcStep,       OMX_U8 *pDst,      OMX_INT rndVal){  const OMX_U8 *pTempSrc1;  const OMX_U8 *pTempSrc2;  const OMX_U8 *pTempSrc3;  const OMX_U8 *pTempSrc4;  OMX_INT y, x;  pTempSrc1 = pSrc;  pTempSrc2 = pSrc + srcStep;  pTempSrc3 = pSrc + 1;  pTempSrc4 = pSrc + srcStep + 1;  srcStep -= 8;  for (y=0; y<8; y++)  {    for (x=0; x<8; x++)	{	  *pDst++ = ((*pTempSrc1++ + *pTempSrc2++ + *pTempSrc3++ + *pTempSrc4++) + 	                  2 - rndVal) >> 2;	}    pTempSrc1 += srcStep;    pTempSrc2 += srcStep;    pTempSrc3 += srcStep;    pTempSrc4 += srcStep;  }}/** * Function: armVCM4P2_MCReconBlock_NoRes * * Description: * Do motion compensation and copy the result to the current block. * * Remarks: * * Parameters: * [in] pSrc        pointer to the block in the reference plane. * [in] srcStep     distance between the start of consecutive lines *                  in the reference plane, in bytes; must be a multiple *                  of 8. * [in] dstStep     distance between the start of consecutive lines in the *                  destination plane, in bytes; must be a multiple of 8. * [in] predictType bilinear interpolation type, as defined in section 6.2.1.2. * [in] rndVal      rounding control parameter: 0 - disabled; 1 - enabled. * [out] pDst       pointer to the destination buffer; must be 8-byte aligned. *                  If prediction residuals are added then output intensities *                  are clipped to the range [0,255]. * */static OMXVoid armVCM4P2_MCReconBlock_NoRes(      const OMX_U8 *pSrc,       OMX_INT srcStep,      OMX_U8 *pDst,      OMX_INT dstStep){    OMX_U8 x,y,count,index;        /* Copying the ref 8x8 blk to the curr blk */    for (y = 0, count = 0, index = 0; y < 8; y++,index += (srcStep -8), count += (dstStep - 8))    {        for (x = 0; x < 8; x++, count++,index++)        {            pDst[count] = pSrc[index];        }           }}/** * Function: armVCM4P2_MCReconBlock_Res * * Description: * Reconstructs INTER block by summing the motion compensation results * and the results of the inverse transformation (prediction residuals). * Output intensities are clipped to the range [0,255]. * * Remarks: * * Parameters: * [in] pSrc        pointer to the block in the reference plane. * [in] pSrcResidue pointer to a buffer containing the 16-bit prediction *                  residuals. If the pointer is NULL,then no prediction *                  is done, only motion compensation, i.e., the block is *                  moved with interpolation. * [in] dstStep     distance between the start of consecutive lines in the *                  destination plane, in bytes; must be a multiple of 8. * [out] pDst       pointer to the destination buffer; must be 8-byte aligned. *                  If prediction residuals are added then output intensities *                  are clipped to the range [0,255]. * */static OMXVoid armVCM4P2_MCReconBlock_Res(      const OMX_U8 *pSrc,       const OMX_S16 *pSrcResidue,      OMX_U8 *pDst,      OMX_INT dstStep){        OMX_U8 x,y;  OMX_INT temp;    for(y = 0; y < 8; y++)  {    for(x = 0; x < 8; x++)    {      temp = pSrc[x] + pSrcResidue[x];               pDst[x] = armClip(0,255,temp);    }    pDst += dstStep;    pSrc += 8;    pSrcResidue += 8;  }}/** * Function:  omxVCM4P2_MCReconBlock   (6.2.5.5.1) * * Description: * Performs motion compensation prediction for an 8x8 block using  * interpolation described in [ISO14496-2], subclause 7.6.2.  * * Input Arguments: *    *   pSrc - pointer to the block in the reference plane.  *   srcStep - distance between the start of consecutive lines in the  *            reference plane, in bytes; must be a multiple of 8.  *   dstStep - distance between the start of consecutive lines in the  *            destination plane, in bytes; must be a multiple of 8.  *   pSrcResidue - pointer to a buffer containing the 16-bit prediction  *            residuals; must be 16-byte aligned. If the pointer is NULL, then  *            no prediction is done, only motion compensation, i.e., the block  *            is moved with interpolation.  *   predictType - bilinear interpolation type, as defined in section  *            6.2.1.2.  *   rndVal - rounding control parameter: 0 - disabled; 1 - enabled.  * * Output Arguments: *    *   pDst - pointer to the destination buffer; must be 8-byte aligned.  If  *            prediction residuals are added then output intensities are  *            clipped to the range [0,255].  * * Return Value: *     *    OMX_Sts_NoErr - no error  *    OMX_Sts_BadArgErr - bad arguments; returned under any of the following  *              conditions:  *    -    pDst is not 8-byte aligned.  *    -    pSrcResidue is not 16-byte aligned.  *    -    one or more of the following pointers is NULL: pSrc or pDst.  *    -    either srcStep or dstStep is not a multiple of 8.  *    -    invalid type specified for the parameter predictType.  *    -    the parameter rndVal is not equal either to 0 or 1.  * */OMXResult omxVCM4P2_MCReconBlock(		const OMX_U8 *pSrc,		OMX_INT srcStep,		const OMX_S16 *pSrcResidue,		OMX_U8 *pDst, 		OMX_INT dstStep,		OMX_INT predictType,		OMX_INT rndVal){    /* Definitions and Initializations*/    OMX_U8 pTempDst[64];        /* Argument error checks */    armRetArgErrIf(pSrc == NULL, OMX_Sts_BadArgErr);    armRetArgErrIf(pDst == NULL, OMX_Sts_BadArgErr);    armRetArgErrIf(!armIs8ByteAligned(pDst), OMX_Sts_BadArgErr);    armRetArgErrIf(!armIs16ByteAligned(pSrcResidue), OMX_Sts_BadArgErr);    armRetArgErrIf(((dstStep % 8) || (srcStep % 8)), OMX_Sts_BadArgErr);    armRetArgErrIf(((predictType != OMX_VC_INTEGER_PIXEL) &&                    (predictType != OMX_VC_HALF_PIXEL_X) &&                    (predictType != OMX_VC_HALF_PIXEL_Y) &&                    (predictType != OMX_VC_HALF_PIXEL_XY)                   ),OMX_Sts_BadArgErr);     armRetArgErrIf(((rndVal != 0) && (rndVal != 1)),OMX_Sts_BadArgErr);        switch(predictType)    {        case OMX_VC_INTEGER_PIXEL:                                   armVCM4P2_MCReconBlock_NoRes(pSrc,                                                                    srcStep,                                                                    &(pTempDst[0]),                                                                    8);                                   break;        case OMX_VC_HALF_PIXEL_X:                                   armVCM4P2_HalfPelHor(pSrc,                                                            srcStep,                                                            &(pTempDst[0]),                                                            rndVal);                                   break;        case OMX_VC_HALF_PIXEL_Y:                                   armVCM4P2_HalfPelVer(pSrc,                                                            srcStep,                                                            &(pTempDst[0]),                                                            rndVal);                                   break;        case OMX_VC_HALF_PIXEL_XY:                                   armVCM4P2_HalfPelVerHor(pSrc,                                                            srcStep,                                                            &(pTempDst[0]),                                                            rndVal);                                   break;    }        if(pSrcResidue == NULL)    {      armVCM4P2_MCReconBlock_NoRes(&(pTempDst[0]),                                         8,                                         pDst,                                         dstStep);        }    else    {      armVCM4P2_MCReconBlock_Res(&(pTempDst[0]),                                          pSrcResidue,                                          pDst,                                          dstStep);        }        return OMX_Sts_NoErr;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -