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

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

?? rdwtblock.c

?? QccPack implementation in C
?? C
?? 第 1 頁 / 共 5 頁
字號:
/* *  * QccPack: Quantization, compression, and coding libraries * Copyright (C) 1997-2005  James E. Fowler *  * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Library General Public * License as published by the Free Software Foundation; either * version 2 of the License, or (at your option) any later version. *  * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU * Library General Public License for more details. *  * You should have received a copy of the GNU Library General Public * License along with this library; if not, write to the * Free Software Foundation, Inc., 675 Mass Ave, Cambridge, * MA 02139, USA. *  *//* *  This code was written by Joe Boettcher <jbb15@msstate.edu> based on *  the originally developed algorithm and code by Suxia Cui. */#include "libQccPack.h"#ifdef LIBQCCPACKSPIHT_H#define QCCVIDRDWTBLOCK_WINDOWSIZE 15typedef struct{  int blocksize;  QccMatrix block;} QccVIDRDWTBlockBlock;typedef struct{  int intraframe;  int motion_vector_bits;  int intraframe_bits;} QccVIDRDWTBlockStatistics;static void QccVIDRDWTBlockBlockInitialize(QccVIDRDWTBlockBlock *block){  block->blocksize = 0;  block->block = NULL;}static int QccVIDRDWTBlockBlockAlloc(QccVIDRDWTBlockBlock *block){  if ((block->block =       QccMatrixAlloc(block->blocksize, block->blocksize)) == NULL)    {      QccErrorAddMessage("(QccVIDRDWTBlockBlockAlloc): Error calling QccMatrixAlloc()");      return(1);    }  return(0);}static void QccVIDRDWTBlockBlockFree(QccVIDRDWTBlockBlock *block){  QccMatrixFree(block->block, block->blocksize);}static void QccVIDRDWTBlockPrintStatistics(const QccVIDRDWTBlockStatistics                                           *statistics){  int total_bits;  int field_width;  total_bits =    statistics->motion_vector_bits + statistics->intraframe_bits;  field_width = (int)ceil(log10((double)total_bits));  printf("            Frame type: ");  if (statistics->intraframe)    printf("I\n");  else    printf("P\n");  printf("    Motion-vector bits: %*d (%5.1f%%)\n",         field_width,         statistics->motion_vector_bits,         QccMathPercent(statistics->motion_vector_bits, total_bits));  printf("       Intraframe bits: %*d (%5.1f%%)\n",         field_width,         statistics->intraframe_bits,         QccMathPercent(statistics->intraframe_bits, total_bits));  printf("\n");}static double QccVIDRDWTBlockMAE(QccVIDRDWTBlockBlock *block1,                                 QccVIDRDWTBlockBlock *block2,                                 int num_levels){  int row, col;  double mae = 0;  int level;  int index_skip = 1;  double scale_factor;  for (level = 1; level <= num_levels; level++)    {      index_skip = (1 << level);      scale_factor = 1.0 / index_skip;      for (row = 0; row < (block1->blocksize / index_skip);           row++)        for (col = 0; col < (block1->blocksize / index_skip);             col++)          {            //HL            mae += scale_factor *              fabs(block1->block                   [row][block1->blocksize / index_skip + col] -                   block2->block                   [row][block1->blocksize / index_skip + col]);            //LH            mae += scale_factor *              fabs(block1->block                   [block1->blocksize / index_skip + row][col] -                   block2->block                   [block1->blocksize / index_skip + row][col]);             //HH            mae += scale_factor *              fabs(block1->block                   [block1->blocksize / index_skip + row]                   [block1->blocksize / index_skip + col] -                   block2->block                   [block1->blocksize / index_skip + row]                   [block1->blocksize / index_skip + col]);          }    }    //LL    scale_factor = 1.0 / index_skip;  for (row = 0; row < (block1->blocksize / index_skip); row++)    for (col = 0; col < (block1->blocksize / index_skip); col++)      mae += scale_factor *        fabs(block1->block[row][col] - block2->block[row][col]);    return(mae);}static double QccVIDRDWTBlockExtractCoefficient(QccWAVSubbandPyramid                                                *subband_pyramid,                                                int row,                                                int col){  if (row < 0)    row = 0;  else    if (row >= subband_pyramid->num_rows)      row = subband_pyramid->num_rows - 1;  if (col < 0)    col = 0;  else    if (col >= subband_pyramid->num_cols)      col = subband_pyramid->num_cols - 1;  return(subband_pyramid->matrix[row][col]);}static int QccVIDRDWTBlockExtractBlock(QccWAVSubbandPyramid *subband_pyramid,                                       QccVIDRDWTBlockBlock *wavelet_block,                                       int ref_offset_row,                                        int ref_offset_col,                                       int num_rows,                                        int num_cols,                                       int num_levels){  int row, col;  int offset_row, offset_col;  int level;  int index_skip;  int pattern;  int row_pattern, col_pattern;  int v, h;    index_skip = (1 << num_levels);  offset_row = ref_offset_row / index_skip;  offset_col = ref_offset_col / index_skip;  row_pattern = QccMathModulus(ref_offset_row, index_skip);  col_pattern = QccMathModulus(ref_offset_col, index_skip);    for (level = 1; level <= num_levels; level++)    {      index_skip = (1 << level);      offset_row = ref_offset_row / index_skip;      offset_col = ref_offset_col / index_skip;      pattern = (1 << (level - 1));      v = (row_pattern & pattern) / pattern;      h = (col_pattern & pattern) / pattern;            for (row = 0; row < (wavelet_block->blocksize / index_skip);           row++)	for (col = 0; col < (wavelet_block->blocksize / index_skip);             col++)          {	    //HL	    wavelet_block->block              [row][wavelet_block->blocksize / index_skip + col] =              QccVIDRDWTBlockExtractCoefficient(subband_pyramid,                                                offset_row + row,                                                num_cols / index_skip +                                                offset_col + col + h);	    //LH	    wavelet_block->block              [wavelet_block->blocksize / index_skip + row][col] =	      QccVIDRDWTBlockExtractCoefficient(subband_pyramid,                                                num_rows / index_skip +                                                offset_row + row + v,                                                offset_col + col);	    //HH	    wavelet_block->block              [wavelet_block->blocksize / index_skip + row]              [wavelet_block->blocksize / index_skip + col] =	      QccVIDRDWTBlockExtractCoefficient(subband_pyramid,                                                num_rows / index_skip +                                                offset_row + row + v,                                                num_cols / index_skip +                                                offset_col + col + h);	  }    }    //LL  for (row = 0; row < (wavelet_block->blocksize / index_skip); row++)    for (col = 0; col < (wavelet_block->blocksize / index_skip); col++)      wavelet_block->block[row][col] =        QccVIDRDWTBlockExtractCoefficient(subband_pyramid,                                          offset_row + row,                                          offset_col + col);    return(0);}static int QccVIDRDWTBlockInsertBlock(QccWAVSubbandPyramid *subband_pyramid,                                      QccVIDRDWTBlockBlock *wavelet_block,                                      int ref_offset_row,                                       int ref_offset_col,                                      int num_rows,                                      int num_cols,                                      int num_levels){  int row, col;  int offset_row, offset_col;  int level;  int index_skip;    index_skip = (1 << num_levels);  offset_row = ref_offset_row / index_skip;  offset_col = ref_offset_col / index_skip;  for (level = 1; level <= num_levels; level++)    {      index_skip = (1 << level);      offset_row = ref_offset_row / index_skip;      offset_col = ref_offset_col / index_skip;            for (row = 0; row < (wavelet_block->blocksize / index_skip);           row++)	for (col = 0; col < (wavelet_block->blocksize / index_skip);             col++)          {	    //HL	    subband_pyramid->matrix              [offset_row + row][num_cols / index_skip + offset_col + col] =	      wavelet_block->block              [row][wavelet_block->blocksize / index_skip + col];	    //LH	    subband_pyramid->matrix              [num_rows / index_skip + offset_row + row][offset_col + col] = 	      wavelet_block->block              [wavelet_block->blocksize / index_skip + row][col];	    //HH	    subband_pyramid->matrix              [num_rows / index_skip + offset_row + row]              [num_cols / index_skip + offset_col + col] =	      wavelet_block->block              [wavelet_block->blocksize / index_skip + row]              [wavelet_block->blocksize / index_skip + col];	  }    }    //LL  for (row = 0; row < (wavelet_block->blocksize / index_skip); row++)    for (col = 0; col < (wavelet_block->blocksize / index_skip); col++)      subband_pyramid->matrix[offset_row + row][offset_col + col] =        wavelet_block->block[row][col];    return(0);}static QccWAVSubbandPyramid ****QccVIDRDWTBlockRDWTPhasesAlloc(int num_levels,                                                               int num_rows,                                                               int num_cols,                                                               int subpixel_accuracy){  QccWAVSubbandPyramid ****rdwt_phases = NULL;  int num_phases;  int phase_row, phase_col;  int num_subpixels;  int subpixel_row, subpixel_col;    switch (subpixel_accuracy)    {    case QCCVID_ME_FULLPIXEL:      num_subpixels = 1;      break;    case QCCVID_ME_HALFPIXEL:      num_subpixels = 2;      break;    case QCCVID_ME_QUARTERPIXEL:      num_subpixels = 4;      break;    case QCCVID_ME_EIGHTHPIXEL:      num_subpixels = 8;      break;    default:      QccErrorAddMessage("(QccVIDRDWTBlockRDWTPhasesAlloc): Unrecognized subpixel accuracy");      return(NULL);    }  num_phases = (1 << num_levels);    if ((rdwt_phases =       (QccWAVSubbandPyramid ****)calloc(num_subpixels,                                         sizeof(QccWAVSubbandPyramid ***))) ==      NULL)    {      QccErrorAddMessage("(QccVIDRDWTBlockRDWTPhasesAlloc): Error allocating memory");      return(NULL);    }  for (subpixel_row = 0; subpixel_row < num_subpixels; subpixel_row++)    {      if ((rdwt_phases[subpixel_row] =           (QccWAVSubbandPyramid ***)calloc(num_subpixels,                                            sizeof(QccWAVSubbandPyramid **)))          == NULL)        {          QccErrorAddMessage("(QccVIDRDWTBlockRDWTPhasesAlloc): Error allocating memory");          return(NULL);        }            for (subpixel_col = 0; subpixel_col < num_subpixels; subpixel_col++)        {          if ((rdwt_phases[subpixel_row][subpixel_col] =

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
首页国产欧美久久| 色偷偷久久一区二区三区| 岛国精品在线观看| 欧美一区二区三区日韩视频| 国产日产欧美一区| 蜜桃一区二区三区四区| 一本大道久久a久久精二百| 精品三级在线看| 亚洲电影你懂得| 99久久精品免费| 精品美女被调教视频大全网站| ●精品国产综合乱码久久久久| 精品在线一区二区三区| 欧美日韩一区小说| 一区二区三区日韩欧美| 懂色av一区二区三区免费观看| 日韩亚洲欧美一区二区三区| 亚洲综合色网站| 91玉足脚交白嫩脚丫在线播放| 久久香蕉国产线看观看99| 日本视频中文字幕一区二区三区| 欧美在线你懂的| 亚洲日穴在线视频| 9人人澡人人爽人人精品| 国产欧美日韩视频在线观看| 国产在线不卡视频| 精品国产伦理网| 老司机精品视频在线| 日韩亚洲欧美中文三级| 日韩av午夜在线观看| 欧美性极品少妇| 亚洲成a人片在线观看中文| 一本一本久久a久久精品综合麻豆 一本一道波多野结衣一区二区 | 色网站国产精品| 亚洲欧美偷拍三级| 色综合一区二区| 亚洲精品第一国产综合野| 91成人国产精品| 亚洲午夜电影在线观看| 欧美日韩综合在线| 免费观看成人av| 欧美精品一区二区三区视频 | 亚洲在线中文字幕| 欧美日韩综合在线免费观看| 日日摸夜夜添夜夜添国产精品 | 热久久一区二区| 欧美α欧美αv大片| 国产剧情av麻豆香蕉精品| 国产日韩欧美综合一区| 波波电影院一区二区三区| 亚洲美女精品一区| 欧美日韩激情在线| 久久99久久久欧美国产| 国产蜜臀97一区二区三区| 色婷婷精品久久二区二区蜜臂av| 亚洲精选在线视频| 777欧美精品| 国产高清精品在线| 一区二区三区免费观看| 欧美另类变人与禽xxxxx| 国产一区二区美女| 亚洲精品一二三| 日韩欧美国产一区二区三区| 国产成人av在线影院| 一区二区三区在线免费观看| 制服丝袜亚洲精品中文字幕| 国产风韵犹存在线视精品| 亚洲少妇中出一区| 欧美成人激情免费网| 91色.com| 黄色日韩网站视频| 一区二区三区**美女毛片| 日韩欧美国产小视频| 色综合中文字幕国产| 首页亚洲欧美制服丝腿| 国产精品网站在线观看| 欧美高清视频不卡网| 国产91露脸合集magnet| 丝袜亚洲另类欧美综合| 国产精品国产自产拍高清av| 91精品在线观看入口| 99久久伊人网影院| 麻豆成人在线观看| 亚洲午夜激情av| 国产精品女同一区二区三区| 6080国产精品一区二区| 91在线丨porny丨国产| 国内精品久久久久影院一蜜桃| 樱花影视一区二区| 国产精品乱码久久久久久| 精品卡一卡二卡三卡四在线| 在线观看视频一区| 99久久精品国产导航| 国产精品69久久久久水密桃| 日本不卡视频一二三区| 亚洲制服丝袜在线| 亚洲男帅同性gay1069| 久久久精品一品道一区| 欧美不卡一二三| 欧美一级理论片| 欧美日韩中文另类| 在线观看日韩av先锋影音电影院| jizz一区二区| 成人18视频在线播放| 国产成人免费视频网站高清观看视频| 午夜电影一区二区| 亚洲高清免费视频| 一区二区三区在线观看动漫| 亚洲天堂网中文字| 亚洲欧洲99久久| 亚洲少妇最新在线视频| 综合亚洲深深色噜噜狠狠网站| 国产农村妇女毛片精品久久麻豆 | 欧美精品丝袜中出| 欧美色手机在线观看| 精品视频色一区| 欧美精品欧美精品系列| 91精品国产综合久久香蕉麻豆| 在线免费精品视频| 欧美羞羞免费网站| 欧美日韩一区二区三区在线看| 欧亚一区二区三区| 欧美日韩在线一区二区| 欧美男男青年gay1069videost | 在线一区二区三区做爰视频网站| 色哟哟精品一区| 欧美日韩一二三| 欧美日韩高清影院| 日韩三级在线免费观看| 久久综合久久99| 中文字幕亚洲成人| 亚洲在线一区二区三区| 日本va欧美va精品发布| 国产自产视频一区二区三区| 粉嫩嫩av羞羞动漫久久久| 不卡区在线中文字幕| 欧美无砖专区一中文字| 91精品国产综合久久福利| 精品国产1区二区| 国产精品盗摄一区二区三区| 亚洲一区二区三区中文字幕在线| 日本不卡在线视频| 东方aⅴ免费观看久久av| 欧美在线视频你懂得| 精品福利一区二区三区| 中文字幕一区二区视频| 亚洲一区二区三区美女| 久久99久久精品| 91香蕉视频mp4| 欧美精品第1页| 国产精品丝袜一区| 午夜私人影院久久久久| 国产另类ts人妖一区二区| 色噜噜狠狠色综合欧洲selulu| 日韩欧美一级片| 亚洲欧美一区二区在线观看| 亚洲成av人片在www色猫咪| 国产精选一区二区三区| 色综合网站在线| 精品国产a毛片| 亚洲1区2区3区视频| 国产精品影视在线| 337p亚洲精品色噜噜噜| 国产精品久久毛片a| 精品一区中文字幕| 精品视频一区三区九区| 中文字幕日韩一区| 久久爱另类一区二区小说| 欧美制服丝袜第一页| 亚洲国产成人自拍| 日本不卡视频在线| 欧美综合一区二区| 国产亚洲1区2区3区| 青青草国产成人99久久| 91福利社在线观看| 国产精品进线69影院| 国产精品一区久久久久| 这里只有精品视频在线观看| 亚洲摸摸操操av| 国产高清成人在线| 久久久亚洲高清| 久久精品国产一区二区三区免费看| 在线日韩av片| 中文字幕一区视频| 从欧美一区二区三区| 日韩一级大片在线观看| 亚洲gay无套男同| 欧洲另类一二三四区| 亚洲天堂2014| 99久久精品国产毛片| 中文字幕在线不卡| 91在线观看高清| 亚洲人亚洲人成电影网站色| 大胆欧美人体老妇| 国产精品久久久久久久久动漫 | 激情久久五月天| 日韩欧美国产成人一区二区| 免费在线观看精品| 精品免费99久久| 国产精一品亚洲二区在线视频|