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

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

?? header.c

?? Mobile IP VCEG的信道模擬程序
?? C
字號:
#include <stdio.h>
#include <stdlib.h>
#include <assert.h>

#include "global.h"
#include "elements.h"
#include "header.h"




#if TRACE
#define SYMTRACESTRING(s) strcpy(sym.tracestring,s)
#else
#define SYMTRACESTRING(s)	/* to nothing */
#endif


/************************************************************************
*
*  Routine      PictureHeader
*
*  Description: read the whole Picture header without the Startcode UVLC
* Returns the number of bits used by the header exclusing start code
*
************************************************************************/
int PictureHeader(struct img_par *img, struct inp_par *inp) 
{

	int dP_nr = assignSE2partition[inp->partition_mode][SE_HEADER];
    Slice *currSlice = img->currentSlice;
	Bitstream *currStream = (currSlice->partArr[dP_nr]).bitstream;
	DataPartition *partition = &(currSlice->partArr[dP_nr]);
	SyntaxElement sym;
	int UsedBits=31;


    sym.type = SE_HEADER;
    sym.mapping = linfo;

    // 1. TRType = 0
	SYMTRACESTRING("PH TemporalReferenceType");
	readSyntaxElement_UVLC (&sym,img,inp,partition);
    //currSlice-> ?????????
	// Currently, only the value 0 is supported, hence a simple assert to
	// catch evenntual  encoder problems
	if (sym.value1 != 0) {
		printf ("Unsupported value %d in Picture Header TemporalReferenceType, len %d info %d\n", sym.value1, sym.len, sym.inf);
		exit (-1);
	}
	UsedBits += sym.len;
// printf ("PH Tenporal Reference Type len %d info %d val %d\n", sym.len, sym.inf, sym.value1);
// printf ("UsedBits %d\n", UsedBits);

    // 2. TR, variable length
	SYMTRACESTRING("PH TemporalReference");
	readSyntaxElement_UVLC (&sym,img,inp,partition);
    currSlice->picture_id = img->tr = sym.value1;					
// printf ("PH TR len %d info %d val %d\n", sym.len, sym.inf, sym.value1);
	UsedBits += sym.len;
// printf ("UsedBits %d\n", UsedBits);

	// 3. Size Type
	SYMTRACESTRING ("PH WhichSize...");
	readSyntaxElement_UVLC (&sym,img,inp,partition);
// printf ("PH: SizeType %d\n", sym.value1);
	UsedBits += sym.len;
// printf ("UsedBits %d\n", UsedBits);
	if (sym.value1 == 0)
		SYMTRACESTRING("PH:    Size Information Unchanged");
	else {
		        // width * 16
        SYMTRACESTRING("PH FullSize-X");
		readSyntaxElement_UVLC (&sym,img,inp,partition);
        img->width = sym.value1 * MB_BLOCK_SIZE;
        img->width_cr = img->width/2;
		UsedBits+=sym.len;
// printf ("UsedBits %d\n", UsedBits);
        // height * 16
		SYMTRACESTRING("PH FullSize-Y");
		readSyntaxElement_UVLC (&sym,img,inp,partition);
        img->height = sym.value1 * MB_BLOCK_SIZE;
        img->height_cr = img->height/2;
// printf ("PH: Size %d x %d\n", img->width, img->height);
		UsedBits+= sym.len;
// printf ("UsedBits %d\n", UsedBits);
	}

    // 4. Picture Type indication (I, P, Mult_P, B , Mult_B)
	SYMTRACESTRING("PHPictureType");
	readSyntaxElement_UVLC (&sym,img,inp,partition);
    currSlice->picture_type = img->type = sym.value1;			
// printf ("PH: Type len %d, info %d, val %d\n", sym.len, sym.inf, img->type);
    UsedBits += sym.len;
// printf ("UsedBits %d\n", UsedBits);

	// Finally, read Reference Picture ID (same as TR here).  Note that this is an
	// optional field that is not present if the input parameters do not indicate
	// multiframe prediction ??

	// Ok, the above comment is nonsense.  There is no way how a decoder could
	// know that we use multiple reference frames (except probably through a 
	// sequence header).  Hence, it's now an if (1) -- PHRefPicID is always present

    // Of course, the decoder can know. It is indicated by the previously decoded
    // parameter "PHPictureType". So, I changed the if-statement again to be
    // compatible with the encoder.

    if (1)
    //  if ((img->type == INTER_IMG_MULT) || (img->type == B_IMG_MULT))
    {	// more than one reference frames
        // TR, variable length
		SYMTRACESTRING("PHRefPicID");
		readSyntaxElement_UVLC (&sym,img,inp,partition);
		UsedBits += sym.len;
// printf ("PH: Read PHRefPicID len %d info %d (and throw it away)\n", sym.len, sym.inf);
	}

	// Now get the first Slice Header without a start code

	UsedBits += SliceHeader (img, inp);
	//	printf ("UsedBits %d\n", UsedBits);
	
	return UsedBits;
}

/************************************************************************
*
*  Routine      SliceHeader
*
*  Description: read the whole Slice header without the Startcode UVLC
*
************************************************************************/
int SliceHeader(struct img_par *img, struct inp_par *inp) 
{
	int dP_nr = assignSE2partition[inp->partition_mode][SE_HEADER];	
    Slice *currSlice = img->currentSlice;
    Bitstream *currStream = (currSlice->partArr[dP_nr]).bitstream;
	DataPartition *partition = &(currSlice->partArr[dP_nr]);
	SyntaxElement sym;
	int UsedBits=0;

    sym.type = SE_HEADER;
    sym.mapping = linfo;

	if (img->current_mb_nr)
		UsedBits=31;

	// 1. Get MB-Adresse
	SYMTRACESTRING("SH FirstMBInSlice");
    readSyntaxElement_UVLC (&sym,img,inp,partition);
    currSlice->start_mb_nr = sym.value1;
// printf ("SliceHeader: got MB Adresse %d, len %d info %d\n", sym.value1, sym.len, sym.inf);
	UsedBits += sym.len;

	// 2. Get Quant. 
	SYMTRACESTRING("SH SliceQuant");
	readSyntaxElement_UVLC (&sym,img,inp,partition);
    currSlice->qp = img->qp = 31 - sym.value1;
// printf ("SliceHeader: got QP %d, len %d info %d\n", sym.value1, sym.len, sym.inf);
	UsedBits += sym.len;
// printf ("SliceHeader: got Mb Adress %d, Quant %d\n", currSlice->start_mb_nr, currSlice->qp);

	// 2. Get MVResolution 
	SYMTRACESTRING("SH MVResolution");
	readSyntaxElement_UVLC (&sym,img,inp,partition);
    img->mv_res = sym.value1;
// printf ("SliceHeader: got MVRse %d, len %d info %d\n", sym.value1, sym.len, sym.inf);
	UsedBits += sym.len;
// printf ("SliceHeader: got Mb Adress %d, MVRes %d\n", currSlice->start_mb_nr, img->mv_res);
	
	img->max_mb_nr = (img->width * img->height) / (MB_BLOCK_SIZE * MB_BLOCK_SIZE);
	if (inp->symbol_mode ==CABAC)
	{
		// 3. Get number of MBs in this slice
		SYMTRACESTRING("SH Last MB in Slice");
		readSyntaxElement_UVLC (&sym,img,inp,partition);
		currSlice->last_mb_nr = currSlice->start_mb_nr+sym.value1;
		//Note: if one slice == one frame the number of MBs in this slice is coded as 0
		if (currSlice->last_mb_nr == currSlice->start_mb_nr)
			currSlice->last_mb_nr = img->max_mb_nr; 
		UsedBits += sym.len;
	}
	return UsedBits;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品一区二区三区在线播放视频| 日韩精品一级中文字幕精品视频免费观看 | 国产一区二区三区久久久| 亚洲高清免费观看高清完整版在线观看 | 91久久久免费一区二区| av福利精品导航| 成+人+亚洲+综合天堂| voyeur盗摄精品| 欧美性三三影院| 欧美喷潮久久久xxxxx| 欧美在线制服丝袜| 欧美一二三四在线| 精品国偷自产国产一区| 欧美精品一区二区三区在线播放| 精品日韩欧美在线| 久久精品视频免费观看| 国产精品久久午夜夜伦鲁鲁| 亚洲综合久久久久| 日韩电影一区二区三区四区| 国产乱子伦视频一区二区三区 | 国产99久久久久| 北岛玲一区二区三区四区| 色婷婷亚洲精品| 在线播放/欧美激情| 国产偷国产偷精品高清尤物| 亚洲乱码国产乱码精品精小说| 亚洲国产成人porn| 国产高清不卡一区二区| 欧美日韩精品一二三区| 国产日韩精品一区二区三区在线| 亚洲综合区在线| 国内精品伊人久久久久av影院| www.亚洲色图.com| 日韩一区二区三区四区五区六区| 亚洲国产高清在线| 蜜臀久久久99精品久久久久久| 成人午夜在线免费| 欧美一区二区视频观看视频| 亚洲婷婷国产精品电影人久久| 日本美女一区二区三区视频| 91污片在线观看| 日韩视频123| 一区二区成人在线观看| 国产一区福利在线| 欧美亚洲国产一区在线观看网站| 久久久综合网站| 日韩av网站免费在线| 99久久久国产精品| 久久人人爽人人爽| 美脚の诱脚舐め脚责91| 欧日韩精品视频| 国产精品少妇自拍| 久久www免费人成看片高清| 欧美日韩中文另类| 亚洲日本va午夜在线电影| 国产麻豆成人精品| 欧美成人性福生活免费看| 午夜欧美电影在线观看| 欧美亚洲禁片免费| 亚洲综合激情网| 色综合久久久久综合99| 中文一区在线播放| 成人自拍视频在线观看| 国产亚洲欧美中文| 国产一区二区三区久久悠悠色av| 日韩一区二区免费电影| 亚洲国产精品一区二区尤物区| 99精品国产热久久91蜜凸| 国产免费久久精品| 福利91精品一区二区三区| 久久久精品国产免大香伊| 国产乱码精品一区二区三区av| 精品国产91洋老外米糕| 国产呦萝稀缺另类资源| 国产性天天综合网| 成人av动漫在线| 国产精品欧美久久久久无广告| 成人综合在线网站| 亚洲免费在线视频| 欧美亚洲综合一区| 五月婷婷欧美视频| 91精品麻豆日日躁夜夜躁| 人妖欧美一区二区| 日韩你懂的在线观看| 国内成人免费视频| 久久精品视频免费| 91色porny蝌蚪| 亚洲国产一二三| 日韩精品在线一区| voyeur盗摄精品| 亚洲无线码一区二区三区| 欧美肥妇bbw| 国产高清不卡一区| 亚洲精选视频在线| 欧美精品乱人伦久久久久久| 国产综合色精品一区二区三区| 国产精品人人做人人爽人人添| 91在线小视频| 视频在线观看一区二区三区| 欧美精品一区二区三区久久久| 成人永久aaa| 午夜一区二区三区视频| 国产午夜精品福利| 欧美久久久一区| 成人午夜av电影| 日韩黄色免费网站| 国产精品美女久久久久高潮| 欧美剧在线免费观看网站| 丁香啪啪综合成人亚洲小说| 亚洲高清免费视频| 国产精品美女久久久久久久| 欧美一级一级性生活免费录像| 不卡的av电影| 蜜桃久久av一区| 亚洲一区二区在线免费观看视频| 精品精品欲导航| 欧美日韩精品综合在线| 国产东北露脸精品视频| 丝袜亚洲另类欧美| 亚洲激情中文1区| 日本一区二区三区视频视频| 欧美日韩mp4| 99精品欧美一区二区三区小说| 青娱乐精品视频在线| 亚洲免费观看高清完整版在线观看| 精品人伦一区二区色婷婷| 欧美午夜精品免费| 成人免费视频视频| 久久99精品久久久久婷婷| 午夜久久久久久久久| 亚洲欧美乱综合| 国产精品福利一区| 久久久久国产精品免费免费搜索 | 婷婷六月综合网| 自拍偷拍亚洲欧美日韩| 国产欧美一区二区在线| 精品黑人一区二区三区久久| 欧美高清激情brazzers| 欧美艳星brazzers| 91精品福利视频| zzijzzij亚洲日本少妇熟睡| 国产在线播放一区| 国产麻豆9l精品三级站| 奇米色777欧美一区二区| 日韩精品三区四区| 五月综合激情婷婷六月色窝| 亚洲欧美二区三区| 国产精品国产自产拍在线| 欧美国产欧美综合| 国产日韩欧美高清| 国产精品丝袜久久久久久app| 精品国产91亚洲一区二区三区婷婷| 91精品蜜臀在线一区尤物| 日韩一区二区三区视频在线| 91精品国产综合久久香蕉麻豆 | 91亚洲精华国产精华精华液| 国产宾馆实践打屁股91| 懂色av一区二区在线播放| 国产91露脸合集magnet| 91视频一区二区三区| 91福利国产成人精品照片| 欧美三级视频在线| 欧美精品久久天天躁| 3d动漫精品啪啪一区二区竹菊| 欧美日韩一二区| 日韩欧美自拍偷拍| 久久欧美中文字幕| 精品日韩在线观看| 久久99精品国产.久久久久| 日韩一区欧美二区| 日韩成人伦理电影在线观看| 麻豆精品视频在线观看| 久久国产尿小便嘘嘘| 国产精品影视网| va亚洲va日韩不卡在线观看| 色欧美片视频在线观看在线视频| 91久久精品午夜一区二区| 欧美丰满美乳xxx高潮www| 久久久美女艺术照精彩视频福利播放| 中文一区二区在线观看| 亚洲综合成人在线| 狠狠色综合播放一区二区| 成人av电影免费观看| 在线精品亚洲一区二区不卡| 日韩一区二区不卡| 中文字幕一区三区| 亚洲大片精品永久免费| 国产高清在线精品| 欧美色中文字幕| 欧美国产一区在线| 日韩主播视频在线| 成人理论电影网| 欧美日韩成人激情| 综合激情成人伊人| 久99久精品视频免费观看| 91麻豆.com| 国产亚洲一区二区三区| 亚洲成av人片| 99久久精品国产导航| 精品少妇一区二区三区在线视频|