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

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

?? sfq.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. *  */#include "libQccPack.h"int QccWAVsfqWaveletAnalysis(const QccIMGImageComponent *input_image,                             QccWAVSubbandPyramid *subband_pyramid,                             QccWAVZerotree *zerotree,                             const QccSQScalarQuantizer *mean_quantizer,                             const QccWAVWavelet *wavelet,                             const QccWAVPerceptualWeights *perceptual_weights,                             double lambda){  int return_value;  int num_levels;  if ((subband_pyramid == NULL) ||      (mean_quantizer == NULL) ||      (wavelet == NULL))    return(0);  num_levels = zerotree->num_levels;  if (QccMatrixCopy(subband_pyramid->matrix,                    input_image->image,                    input_image->num_rows,                    input_image->num_cols))    {      QccErrorAddMessage("(QccWAVsfqWaveletAnalysis): Error calling QccMatrixCopy()");      goto QccError;    }    if (QccWAVSubbandPyramidSubtractMean(subband_pyramid,                                       &(zerotree->image_mean),                                       mean_quantizer))    {      QccErrorAddMessage("(QccWAVsfqWaveletAnalysis): Error calling QccWAVSubbandPyramidSubtractMean()");      goto QccError;    }    if (num_levels)    if (QccWAVSubbandPyramidDWT(subband_pyramid,                                num_levels,                                wavelet))      {        QccErrorAddMessage("(QccWAVsfqWaveletAnalysis): Error calling QccWAVSubbandPyramidDWT()");        goto QccError;      }  if (perceptual_weights != NULL)    if (QccWAVPerceptualWeightsApply(subband_pyramid,                                     perceptual_weights))      {        QccErrorAddMessage("(QccWAVsfqWaveletAnalysis): Error calling QccWAVPerceptualWeightsApply()");        QccErrorExit();      }  return_value = 0;  goto QccReturn; QccError:  return_value = 1; QccReturn:  return(return_value);}static int QccWAVsfqBasebandEncodeProcess(QccIMGImageComponent *baseband_image,                                          QccSQScalarQuantizer                                           *baseband_quantizer,                                          QccChannel *channels,                                          QccIMGImageComponent                                           *reconstructed_baseband,                                          double *distortion,                                           double *rate){  int return_value;  QccVector distortion_vector = NULL;  if ((baseband_image == NULL) ||      (baseband_quantizer == NULL) ||      (channels == NULL))    return(0);  if ((distortion_vector = QccVectorAlloc(baseband_image->num_rows *                                          baseband_image->num_cols)) ==       NULL)    {      QccErrorAddMessage("(QccWAVsfqBasebandEncodeProcess): Error calling QccVectorAlloc()");      goto QccError;    }  if (QccIMGImageComponentScalarQuantize(baseband_image,                                         baseband_quantizer,                                         distortion_vector,                                         &(channels[0])))    {      QccErrorAddMessage("(QccWAVsfqBasebandEncodeProcess): Error calling QccIMGImageComponentScalarQuantize()");      goto QccError;    }  if (QccIMGImageComponentInverseScalarQuantize(&(channels[0]),                                                baseband_quantizer,                                                reconstructed_baseband))    {      QccErrorAddMessage("(QccWAVsfqBasebandEncodeProcess): Error calling QccIMGImageComponentInverseScalarQuantize()");      goto QccError;    }  if (QccChannelNormalize(&(channels[0])))    {      QccErrorAddMessage("(QccWAVsfqBasebandEncodeProcess): Error calling QccChannelNormalize()");      goto QccError;    }  if (distortion != NULL)    *distortion =       QccVectorMean(distortion_vector,                    baseband_image->num_rows *                    baseband_image->num_cols);  if (rate != NULL)    *rate = QccChannelEntropy(&(channels[0]), 1);  return_value = 0;  goto QccReturn; QccError:  return_value = 1; QccReturn:  QccVectorFree(distortion_vector);  return(return_value);}int QccWAVsfqBasebandEncode(const QccWAVSubbandPyramid *subband_pyramid,                            QccWAVZerotree *zerotree,                            QccSQScalarQuantizer *baseband_quantizer,                            QccChannel *channels,                            double lambda,                            QccIMGImageComponent *reconstructed_baseband){  int return_value;  QccIMGImageComponent baseband_image;  double distortion;  double rate;  double baseband_quantizer_start_stepsize;  double baseband_quantizer_end_stepsize;  int done = 0;  int last_time = 0;  QccVector J = NULL;  int pass;  int num_passes;  double min_J = MAXDOUBLE;  double winner = 0;  double max_coefficient = -MAXDOUBLE;  int row, col;  if ((subband_pyramid == NULL) ||      (zerotree == NULL) ||      (baseband_quantizer == NULL) ||      (channels == NULL))    return(0);  if (baseband_quantizer->stepsize <= 0.0)    {      baseband_quantizer_start_stepsize =        QCCWAVSFQ_BASEBANDQUANTIZER_START_STEPSIZE;      baseband_quantizer_end_stepsize =        QCCWAVSFQ_BASEBANDQUANTIZER_END_STEPSIZE;    }  else    {      baseband_quantizer_start_stepsize =        baseband_quantizer_end_stepsize =        baseband_quantizer->stepsize;      last_time = 1;    }    num_passes =    ceil((baseband_quantizer_end_stepsize -          baseband_quantizer_start_stepsize) /         QCCWAVSFQ_BASEBANDQUANTIZER_INCREMENT) + 1;  baseband_image.num_rows = zerotree->num_rows[0];  baseband_image.num_cols = zerotree->num_cols[0];  baseband_image.image = subband_pyramid->matrix;  for (row = 0; row < baseband_image.num_rows; row++)    for (col = 0; col < baseband_image.num_cols; col++)      if (fabs(baseband_image.image[row][col]) > max_coefficient)        max_coefficient = fabs(baseband_image.image[row][col]);  if ((J = QccVectorAlloc(num_passes)) == NULL)    {      QccErrorAddMessage("(QccWAVsfqBasebandEncode): Error calling QccVectorAlloc()");      goto QccError;    }  for (pass = 0; pass < num_passes; pass++)    J[pass] = MAXDOUBLE;  baseband_quantizer->stepsize =     baseband_quantizer_start_stepsize;    pass = 0;  do    {      if (last_time)        done = 1;            if (QccSQScalarQuantization(max_coefficient,                                  baseband_quantizer,                                  NULL,                                  &(channels[0].alphabet_size)))        {          QccErrorAddMessage("(QccWAVsfqBasebandEncode): Error calling QccSQScalarQuantization()");          goto QccError;        }      channels[0].alphabet_size =        channels[0].alphabet_size * 2 + 1;      baseband_quantizer->num_levels = channels[0].alphabet_size;      if (QccWAVsfqBasebandEncodeProcess(&baseband_image,                                         baseband_quantizer,                                         channels,                                         reconstructed_baseband,                                         &distortion, &rate))        {          QccErrorAddMessage("(QccWAVsfqBasebandEncode): Error calling QccWAVsfqBasebandEncodeProcess()");          goto QccError;        }      if (!done)        {          J[pass] =            distortion + lambda * rate;          /****/          /*            printf("    step: %f\n", baseband_quantizer->stepsize);            printf("     MSE: %f\n", distortion);            printf("    rate: %f\n", rate);            printf("       J: %f\n\n", J[pass]);          */          if (pass == num_passes - 1)            {              for (pass = 0;                   pass < num_passes;                   pass++)                if (J[pass] < min_J)                  {                    min_J = J[pass];                    winner = baseband_quantizer_start_stepsize +                      QCCWAVSFQ_BASEBANDQUANTIZER_INCREMENT * pass;                  }                            baseband_quantizer->stepsize = winner;              last_time = 1;            }          else            {              baseband_quantizer->stepsize +=                QCCWAVSFQ_BASEBANDQUANTIZER_INCREMENT;              pass++;            }        }    }  while (!done);  return_value = 0;  goto QccReturn; QccError:  return_value = 1; QccReturn:  QccVectorFree(J);  return(return_value);}static int QccWAVsfqCalcCodewordLengths(QccVector codeword_lengths,                                        int num_symbols,                                        QccChannel *channels,                                        QccWAVZerotree *zerotree){  int subband, row, col;  int symbol;  int channel_index;  int num_nonnull_symbols = 0;    for (symbol = 0; symbol < num_symbols; symbol++)    codeword_lengths[symbol] = 0;    for (subband = 1;       subband < zerotree->num_subbands; subband++)    for (row = 0, channel_index = 0;          row < zerotree->num_rows[subband]; row++)      for (col = 0; col < zerotree->num_cols[subband];            col++, channel_index++)        if (!QccWAVZerotreeNullSymbol(zerotree->zerotree[subband][row][col]))          {            codeword_lengths[channels[subband].channel_symbols                            [channel_index]]++;            num_nonnull_symbols++;          }    for (symbol = 0; symbol < num_symbols; symbol++)    codeword_lengths[symbol] =      -QccMathLog2(codeword_lengths[symbol] / num_nonnull_symbols);    return(0);}static double QccWAVsfqCalcChildrenCost(QccVector *costs,                                        int child_subband,                                        int parent_row,                                        int parent_col,                                        int num_child_cols){  int child_row, child_col;  int num_children;  double cost = 0;    num_children = (child_subband < 4) ? 1 : 2;    for (child_row = num_children*parent_row;       child_row < num_children*(parent_row + 1);       child_row++)    for (child_col = num_children*parent_col;         child_col < num_children*(parent_col + 1);         child_col++)      cost +=        costs[child_subband][child_row*num_child_cols + child_col];    return(cost);  }static double QccWAVsfqSelectMinimumCost(QccWAVZerotree *zerotree,                                          int subband,                                          int row, int col, int cost_index,                                         QccVector *J,                                          QccVector *residue_tree_J,                                         QccVector *delta_J,                                         QccVector *squared_subband_images,                                         int *zerotree_pruned){  int level;  double cost1, cost2;  double minimum_cost;  int child_subband;  int child_subband_start, child_subband_end;    level = QccWAVSubbandPyramidCalcLevelFromSubband(subband, zerotree->num_levels);    if (subband)    child_subband_start = child_subband_end =      subband + 3;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲电影第三页| 国产精品久久久久国产精品日日| 国产日韩精品一区二区三区| 中文字幕一区二区三| 视频在线观看一区二区三区| 国产成人99久久亚洲综合精品| 欧美性色欧美a在线播放| 2021久久国产精品不只是精品| 久久久久免费观看| 强制捆绑调教一区二区| 99精品桃花视频在线观看| 7878成人国产在线观看| 日韩欧美一区二区视频| 亚洲欧美一区二区三区孕妇| 免费成人你懂的| 91在线免费播放| 精品久久国产老人久久综合| 亚洲一区日韩精品中文字幕| 免费人成精品欧美精品| 一本色道a无线码一区v| 国产午夜精品在线观看| 亚洲国产视频a| 不卡av电影在线播放| 亚洲欧美一区二区三区国产精品 | 欧美剧情片在线观看| 一区精品在线播放| 国产999精品久久久久久| 欧美成人欧美edvon| 亚洲成人激情综合网| 色综合久久久久综合体| 亚洲欧洲美洲综合色网| 成人理论电影网| 国产午夜精品福利| 国产福利一区二区三区视频在线| 欧美大肚乱孕交hd孕妇| 免费三级欧美电影| 91精品国产91久久久久久最新毛片| 亚洲综合av网| 在线精品亚洲一区二区不卡| 亚洲人精品午夜| av一区二区三区四区| 国产偷国产偷亚洲高清人白洁| 韩国v欧美v亚洲v日本v| 久久精品一区四区| 国产精品1024| 亚洲欧洲av一区二区三区久久| 成人免费毛片app| 国产精品第一页第二页第三页| 国产精品一区二区免费不卡| 久久久久久久久岛国免费| 国产精品1024久久| 国产精品色婷婷久久58| 99久久精品费精品国产一区二区| 日韩美女精品在线| 欧美视频一区二| 免费观看日韩av| 久久综合色8888| www.久久久久久久久| 亚洲人123区| 欧美三级视频在线观看 | 久久婷婷久久一区二区三区| 国产精品主播直播| 国产精品久久久久一区二区三区 | 石原莉奈在线亚洲三区| 日韩美女在线视频| 国产不卡免费视频| 亚洲视频一区在线| 欧美另类变人与禽xxxxx| 老司机午夜精品| 国产视频一区在线观看| 97精品视频在线观看自产线路二| 亚洲伊人伊色伊影伊综合网| 日韩一区二区在线看| 国产一区二区电影| 亚洲色欲色欲www| 911精品产国品一二三产区| 精品在线播放午夜| 国产精品毛片大码女人| 91国内精品野花午夜精品| 日日夜夜精品视频天天综合网| 欧美va亚洲va在线观看蝴蝶网| 懂色av中文字幕一区二区三区| 一级精品视频在线观看宜春院 | 91美女片黄在线| 日韩在线观看一区二区| 久久精品视频免费观看| 91麻豆蜜桃一区二区三区| 午夜激情一区二区三区| www久久久久| 91福利在线播放| 精品综合免费视频观看| 亚洲桃色在线一区| 欧美一区三区四区| 成人app软件下载大全免费| 亚洲成人高清在线| 国产婷婷色一区二区三区在线| 欧美伊人精品成人久久综合97| 九一九一国产精品| 亚洲一区视频在线观看视频| 久久久久免费观看| 欧美日韩免费视频| 国产成人av电影免费在线观看| 亚洲一二三区视频在线观看| 国产欧美日韩久久| 欧美另类z0zxhd电影| 成人h精品动漫一区二区三区| 日韩有码一区二区三区| 国产精品每日更新| 精品国产三级a在线观看| 色欧美88888久久久久久影院| 久久99精品久久久久久久久久久久 | 欧美色图一区二区三区| 国产福利一区在线| 日本女优在线视频一区二区| 亚洲老妇xxxxxx| 美女视频黄 久久| 亚洲精品一二三| 亚洲国产精品av| 日韩一级片网址| 欧美日韩在线综合| www.欧美亚洲| 国产成人综合亚洲91猫咪| 免费观看久久久4p| 亚洲va国产va欧美va观看| 亚洲三级在线播放| 中文字幕欧美区| 精品久久人人做人人爰| 欧美精品一二三| 在线精品视频免费观看| av欧美精品.com| 成人精品免费看| 黄页网站大全一区二区| 青青草一区二区三区| 亚洲高清免费观看| 夜夜亚洲天天久久| 亚洲日本va在线观看| 国产精品美女一区二区| 国产清纯白嫩初高生在线观看91 | 在线电影欧美成精品| 日本高清无吗v一区| 99精品久久免费看蜜臀剧情介绍| 国产麻豆午夜三级精品| 精品一区二区三区不卡 | 一个色妞综合视频在线观看| 亚洲色欲色欲www| 亚洲天堂久久久久久久| 中文字幕一区二区三| 国产精品久久久久桃色tv| 国产日韩欧美亚洲| 国产亚洲视频系列| 国产三级久久久| 亚洲国产高清aⅴ视频| 久久久激情视频| 国产欧美久久久精品影院| 久久久另类综合| 日本一区二区三区国色天香| 国产日韩欧美不卡在线| 国产农村妇女精品| 国产日韩v精品一区二区| 欧美经典一区二区三区| 亚洲国产精品二十页| 中文字幕免费观看一区| 日本一区二区视频在线| 中文字幕一区二区三区在线不卡 | 欧美精品一区男女天堂| 337p粉嫩大胆色噜噜噜噜亚洲| www精品美女久久久tv| 国产网红主播福利一区二区| 国产精品视频yy9299一区| 中文字幕在线不卡一区二区三区| 国产精品久久精品日日| 中文字幕日韩av资源站| 亚洲精品一二三| 亚洲mv在线观看| 老司机免费视频一区二区| 美女国产一区二区| 国产乱对白刺激视频不卡| 成人一区二区三区视频在线观看| a美女胸又www黄视频久久| 91小视频在线免费看| 欧美在线免费视屏| 91精品国产入口| 久久久精品免费网站| 中文字幕在线观看不卡| 亚洲午夜免费电影| 久久99久久精品| 不卡的av电影在线观看| 色94色欧美sute亚洲线路一久| 欧美日韩一区二区在线观看视频| 日韩美女一区二区三区| 日本一区二区电影| 亚洲一区中文日韩| 久久国产精品99精品国产| 国产成人无遮挡在线视频| 日本韩国精品在线| 欧美大黄免费观看| 亚洲视频一区二区在线| 日韩电影在线一区| 丁香天五香天堂综合| 欧美日韩亚洲综合一区二区三区|