亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? padenc.cpp

?? 小波圖像變換
?? CPP
字號:
/*************************************************************************

This software module was originally developed by 

	Ming-Chieh Lee (mingcl@microsoft.com), Microsoft Corporation
	(date: June, 1997)
and edited by
        Wei Wu (weiwu@stallion.risc.rockwell.com) Rockwell Science Center

in the course of development of the MPEG-4 Video (ISO/IEC 14496-2). 
This software module is an implementation of a part of one or more MPEG-4 Video tools 
as specified by the MPEG-4 Video. 
ISO/IEC gives users of the MPEG-4 Video free license to this software module or modifications 
thereof for use in hardware or software products claiming conformance to the MPEG-4 Video. 
Those intending to use this software module in hardware or software products are advised that its use may infringe existing patents. 
The original developer of this software module and his/her company, 
the subsequent editors and their companies, 
and ISO/IEC have no liability for use of this software module or modifications thereof in an implementation. 
Copyright is not released for non MPEG-4 Video conforming products. 
Microsoft retains full right to use the code for his/her own purpose, 
assign or donate the code to a third party and to inhibit third parties from using the code for non MPEG-4 Video conforming products. 
This copyright notice must be included in all copies or derivative works. 

Copyright (c) 1996, 1997.


Module Name:

	padEnc.cpp

Abstract:

	MB Padding for Intra-texture coding.

Revision History:

*************************************************************************/

// NOTE: 
//		LPE padding is working on the current MB whose size is always a MB
//		MC padding is  working on the (reference) quantized VOP

#include <stdio.h>
#include <math.h>
#include <stdlib.h>
#include <iostream.h>

#include "typeapi.h"
#include "codehead.h"
#include "global.hpp"
#include "entropy/bitstrm.hpp"
#include "entropy/entropy.hpp"
#include "entropy/huffman.hpp"
#include "mode.hpp"
#include "vopses.hpp"
#include "vopseenc.hpp"

Void CVideoObjectEncoder::LPEPadding (const CMBMode* pmbmd)
{
	const PixelC* ppxlcBlkB;
	PixelC* ppxlcBlk;
	if (pmbmd -> m_rgTranspStatus [1] == PARTIAL) {
		ppxlcBlkB = m_ppxlcCurrMBBY;
		ppxlcBlk = m_ppxlcCurrMBY;
		LPEPaddingBlk (ppxlcBlk, ppxlcBlkB, MB_SIZE);
	}
	if (pmbmd -> m_rgTranspStatus [2] == PARTIAL) {
		ppxlcBlkB = m_ppxlcCurrMBBY + BLOCK_SIZE;
		ppxlcBlk = m_ppxlcCurrMBY + BLOCK_SIZE;
		LPEPaddingBlk (ppxlcBlk, ppxlcBlkB, MB_SIZE);
	}
	if (pmbmd -> m_rgTranspStatus [3] == PARTIAL) {
		ppxlcBlkB = m_ppxlcCurrMBBY + MB_SIZE * BLOCK_SIZE;
		ppxlcBlk = m_ppxlcCurrMBY + MB_SIZE * BLOCK_SIZE;
		LPEPaddingBlk (ppxlcBlk, ppxlcBlkB, MB_SIZE);
	}
	if (pmbmd -> m_rgTranspStatus [4] == PARTIAL) {
		ppxlcBlkB = m_ppxlcCurrMBBY + MB_SIZE * BLOCK_SIZE + BLOCK_SIZE;
		ppxlcBlk = m_ppxlcCurrMBY + MB_SIZE * BLOCK_SIZE + BLOCK_SIZE;
		LPEPaddingBlk (ppxlcBlk, ppxlcBlkB, MB_SIZE);
	}
	if (pmbmd -> m_rgTranspStatus [5] == PARTIAL) {
		LPEPaddingBlk (m_ppxlcCurrMBU, m_ppxlcCurrMBBUV, BLOCK_SIZE);
		LPEPaddingBlk (m_ppxlcCurrMBV, m_ppxlcCurrMBBUV, BLOCK_SIZE);
	}
	if (m_volmd.fAUsage == EIGHT_BIT) {
    for(Int iAuxComp=0;iAuxComp<m_volmd.iAuxCompCount;iAuxComp++) { // MAC (SB) 29-Nov-99
      if (pmbmd -> m_rgTranspStatus [1] == PARTIAL) {
        ppxlcBlkB = m_ppxlcCurrMBBY;
        ppxlcBlk = m_ppxlcCurrMBA[iAuxComp];
        LPEPaddingBlk (ppxlcBlk, ppxlcBlkB, MB_SIZE);
      }
      if (pmbmd -> m_rgTranspStatus [2] == PARTIAL) {
        ppxlcBlkB = m_ppxlcCurrMBBY + BLOCK_SIZE;
        ppxlcBlk = m_ppxlcCurrMBA[iAuxComp] + BLOCK_SIZE;
        LPEPaddingBlk (ppxlcBlk, ppxlcBlkB, MB_SIZE);
      }
      if (pmbmd -> m_rgTranspStatus [3] == PARTIAL) {
        ppxlcBlkB = m_ppxlcCurrMBBY + MB_SIZE * BLOCK_SIZE;
        ppxlcBlk = m_ppxlcCurrMBA[iAuxComp] + MB_SIZE * BLOCK_SIZE;
        LPEPaddingBlk (ppxlcBlk, ppxlcBlkB, MB_SIZE);
      }
      if (pmbmd -> m_rgTranspStatus [4] == PARTIAL) {
        ppxlcBlkB = m_ppxlcCurrMBBY + MB_SIZE * BLOCK_SIZE + BLOCK_SIZE;
        ppxlcBlk = m_ppxlcCurrMBA[iAuxComp] + MB_SIZE * BLOCK_SIZE + BLOCK_SIZE;
        LPEPaddingBlk (ppxlcBlk, ppxlcBlkB, MB_SIZE);
      }
    }
  }
}

#define OUTSIDE_BLOCK_VALUE		1
CU8Image uciBuff (CRct (0, 0, BLOCK_SIZE + 2, BLOCK_SIZE + 2), OUTSIDE_BLOCK_VALUE);
PixelC* ppxlcBuff = (PixelC*) uciBuff.pixels () + BLOCK_SIZE + 3;

#define BLOCK_SIZE_PLUS2		10

Void CVideoObjectEncoder::LPEPaddingBlk (
	PixelC* ppxlcBlk, const PixelC* ppxlcBlkB,
	UInt uiSize)
{
	Int iUnit = sizeof(PixelC); // NBIT: for memcpy
	UInt uiNumNonTranspPixels = 0;
	UInt ix, iy;
	UInt uiSum = 0;
	PixelC* ppxlcBuffTmp = ppxlcBuff;
	PixelC* ppxlcBlkTmp = ppxlcBlk;
	const PixelC* ppxlcBlkBTmp = ppxlcBlkB;
	for (iy = 0; iy < BLOCK_SIZE; iy++) {
		memcpy (ppxlcBuffTmp, ppxlcBlkBTmp, BLOCK_SIZE*iUnit);
		for (ix = 0; ix < BLOCK_SIZE; ix++) {
			if (ppxlcBlkBTmp [ix] != transpValue)	{
				uiSum += ppxlcBlkTmp [ix];
				uiNumNonTranspPixels++;
			}
		}
		ppxlcBlkBTmp += uiSize;
		ppxlcBlkTmp += uiSize;
		ppxlcBuffTmp += BLOCK_SIZE_PLUS2;
	}
	assert (uiNumNonTranspPixels != 0);
	uiSum /= uiNumNonTranspPixels;

	UInt uiSumNeighbor, uiNumNonTranpNeighbor;
	ppxlcBuffTmp = ppxlcBuff;
	for (iy = 0; iy < BLOCK_SIZE; iy++) {
		for (ix = 0; ix < BLOCK_SIZE; ix++) {
			if (ppxlcBlkB [ix] == transpValue) {
				uiSumNeighbor = uiNumNonTranpNeighbor = 0;
				if (ppxlcBuffTmp [ix - 1] != OUTSIDE_BLOCK_VALUE) {
					uiNumNonTranpNeighbor++;
					uiSumNeighbor += (ppxlcBuffTmp [ix - 1] == transpValue) ? uiSum : ppxlcBlk [ix - 1];
				}
				if (ppxlcBuffTmp [ix + 1] != OUTSIDE_BLOCK_VALUE) {
					uiNumNonTranpNeighbor++;
					uiSumNeighbor += (ppxlcBuffTmp [ix + 1] == transpValue) ? uiSum : ppxlcBlk [ix + 1];
				}
				if (ppxlcBuffTmp [ix - BLOCK_SIZE_PLUS2] != OUTSIDE_BLOCK_VALUE) {
					uiNumNonTranpNeighbor++;
					uiSumNeighbor += (ppxlcBuffTmp [ix - BLOCK_SIZE_PLUS2] == transpValue) ? uiSum : ppxlcBlk [ix - uiSize];
				}
				if (ppxlcBuffTmp [ix + BLOCK_SIZE_PLUS2] != OUTSIDE_BLOCK_VALUE) {
					uiNumNonTranpNeighbor++;
					uiSumNeighbor += (ppxlcBuffTmp [ix + BLOCK_SIZE_PLUS2] == transpValue) ? uiSum : ppxlcBlk [ix + uiSize];
				}
				ppxlcBlk [ix] = (PixelC) (uiSumNeighbor / uiNumNonTranpNeighbor);
			}
		}
		ppxlcBlkB += uiSize;
		ppxlcBlk += uiSize;
		ppxlcBuffTmp += BLOCK_SIZE_PLUS2;
	}
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91麻豆精品国产自产在线| 日韩一区二区三区视频| 日韩专区一卡二卡| 欧美高清在线精品一区| 欧美视频一区二区在线观看| 国产精品一二三四五| 天堂va蜜桃一区二区三区漫画版| 国产精品乱码一区二区三区软件 | 久久精品国产亚洲一区二区三区| 国产精品美女久久久久久2018| 欧美一二三四区在线| 91福利国产成人精品照片| 国产91露脸合集magnet| 日本中文字幕一区二区视频| 亚洲激情五月婷婷| 国产人成一区二区三区影院| 日韩女优毛片在线| 欧美性猛交xxxx黑人交| 99精品国产99久久久久久白柏| 精品一区二区三区在线观看国产| 性久久久久久久久久久久| 一区二区三区四区高清精品免费观看| 国产女主播视频一区二区| 日韩午夜激情av| 91精品国产一区二区| 欧亚洲嫩模精品一区三区| 91免费国产在线| 成人av影院在线| 国产在线精品免费av| 九九视频精品免费| 久久97超碰国产精品超碰| 麻豆一区二区三区| 日韩av电影免费观看高清完整版 | 激情国产一区二区 | 91色乱码一区二区三区| 国产成人日日夜夜| 韩国三级电影一区二区| 久久aⅴ国产欧美74aaa| 蜜乳av一区二区| 美女脱光内衣内裤视频久久网站| 欧美aa在线视频| 美女网站一区二区| 久久97超碰色| 懂色av中文字幕一区二区三区| 国产成人8x视频一区二区| 成人高清av在线| 91论坛在线播放| 91黄视频在线| 91精品国产综合久久香蕉麻豆| 91精品福利在线一区二区三区| 日韩免费高清视频| 久久先锋资源网| 国产精品日韩精品欧美在线| 亚洲第一福利视频在线| 日本不卡123| 久久99久久精品欧美| 国产高清一区日本| 99riav久久精品riav| 欧美午夜精品久久久久久孕妇| 欧美亚洲精品一区| 欧美一区二区在线不卡| 精品福利在线导航| 国产欧美日韩三区| 最新成人av在线| 日本伊人色综合网| 国产一二三精品| 成人av动漫网站| 欧美军同video69gay| 日韩免费在线观看| 亚洲欧洲一区二区三区| 天天色综合天天| 成人美女视频在线观看| 色婷婷亚洲综合| 欧美成人官网二区| 日韩理论片网站| 亚洲国产aⅴ成人精品无吗| 看电影不卡的网站| 91亚洲永久精品| 精品国产百合女同互慰| 亚洲精品成人天堂一二三| 国内精品久久久久影院一蜜桃| 成人99免费视频| 日韩欧美123| 亚洲免费在线播放| 国内精品免费**视频| 色婷婷综合久久久久中文一区二区 | 亚洲欧美一区二区不卡| 婷婷开心激情综合| 九九视频精品免费| 欧美三级在线视频| 国产色婷婷亚洲99精品小说| 亚洲一区二区三区在线播放 | 欧美日韩日日骚| 国产精品美女一区二区三区| 天堂精品中文字幕在线| 99精品一区二区| 久久久电影一区二区三区| 日韩精品一卡二卡三卡四卡无卡| eeuss鲁片一区二区三区在线看| 6080国产精品一区二区| 国产精品久久久久婷婷二区次| 免费在线观看一区| 一本大道久久a久久精品综合| 91麻豆精品国产自产在线| 亚洲天堂2016| 成人高清在线视频| 精品电影一区二区| 日韩高清不卡一区| 欧美亚洲一区二区在线观看| 综合色中文字幕| 成人激情开心网| 国产人成亚洲第一网站在线播放| 美国一区二区三区在线播放| 欧美精品日日鲁夜夜添| 午夜视频一区二区| 色猫猫国产区一区二在线视频| 国产日韩精品一区二区三区在线| 麻豆国产一区二区| 欧美一区二区女人| 日韩国产在线观看| 欧美亚洲禁片免费| 亚洲精品美国一| 日本高清不卡aⅴ免费网站| 最近中文字幕一区二区三区| 成人app下载| 中文字幕久久午夜不卡| 成人av网站在线观看| 国产精品网友自拍| 99久久久久免费精品国产 | 一区二区三区在线免费视频| a级高清视频欧美日韩| 国产精品电影一区二区| 91在线一区二区| 亚洲免费在线视频一区 二区| 99国产精品久| 一区二区三区在线免费| 在线观看视频一区二区欧美日韩| ...xxx性欧美| 91视频xxxx| 亚洲成av人片观看| 欧美一级高清大全免费观看| 九九九久久久精品| 国产女主播一区| 91天堂素人约啪| 亚洲综合视频在线观看| 欧美日韩不卡一区| 蜜臀av一区二区在线观看| 精品国产凹凸成av人导航| 国产91丝袜在线观看| 亚洲欧美一区二区视频| 欧美无砖专区一中文字| 日韩激情一区二区| 欧美xxxxx裸体时装秀| 国产夫妻精品视频| 亚洲美女精品一区| 欧美日韩午夜在线视频| 亚洲男人都懂的| 91色综合久久久久婷婷| 亚洲一区二区成人在线观看| 777午夜精品视频在线播放| 秋霞电影一区二区| 中文字幕不卡在线播放| 91麻豆免费看| 性做久久久久久| 欧美精品一区二区不卡| av爱爱亚洲一区| 亚洲成av人影院| 日韩一区二区三区电影在线观看 | 成熟亚洲日本毛茸茸凸凹| ...中文天堂在线一区| 欧美丝袜丝nylons| 国产乱子伦视频一区二区三区| 亚洲猫色日本管| 日韩欧美国产三级| 91麻豆免费视频| 久久99蜜桃精品| 国产精品久久毛片av大全日韩| 欧美日韩精品一区二区在线播放| 久久国产三级精品| 亚洲美女在线国产| 日韩欧美国产wwwww| 99免费精品在线| 蜜臀av一级做a爰片久久| 综合网在线视频| 精品福利一区二区三区 | 欧美成人艳星乳罩| 久久综合九色综合97婷婷女人| 久久综合色综合88| 国产精品灌醉下药二区| 亚洲欧美国产高清| 裸体在线国模精品偷拍| 9人人澡人人爽人人精品| 亚洲免费观看在线观看| 欧美三级中文字| 色综合久久久久综合体桃花网| 国产欧美日韩精品在线| 国产精品2024| 欧美二区在线观看| 精品国产精品一区二区夜夜嗨| 国产精品久久久久久久久动漫|