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

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

?? lifting.c

?? QccPack implementation in C
?? C
?? 第 1 頁 / 共 2 頁
字號:
/* *  * 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 QccWAVLiftingSchemeInitialize(QccWAVLiftingScheme *lifting_scheme){  if (lifting_scheme == NULL)    return(0);    QccStringMakeNull(lifting_scheme->filename);  QccStringCopy(lifting_scheme->magic_num, QCCWAVLIFTINGSCHEME_MAGICNUM);  QccGetQccPackVersion(&lifting_scheme->major_version,                       &lifting_scheme->minor_version,                       NULL);  lifting_scheme->scheme = -1;  return(0);}int QccWAVLiftingSchemePrint(const QccWAVLiftingScheme *lifting_scheme){  if (lifting_scheme == NULL)    return(0);    if (QccFilePrintFileInfo(lifting_scheme->filename,                           lifting_scheme->magic_num,                           lifting_scheme->major_version,                           lifting_scheme->minor_version))    return(1);      switch (lifting_scheme->scheme)    {    case QCCWAVLIFTINGSCHEME_LWT:      printf("  Lazy Wavelet transform\n\n");      break;    case QCCWAVLIFTINGSCHEME_Daubechies4:      printf("  Daubechies Orthonormal Wavelet, Length 4\n");      printf("        -- Lifted Implementation --\n\n");      break;    case QCCWAVLIFTINGSCHEME_CohenDaubechiesFeauveau9_7:      printf("  Cohen-Daubechies-Feauveau Biorthogonal Wavelet, Length 9-7\n");      printf("        -- Lifted Implementation --\n\n");      break;    case QCCWAVLIFTINGSCHEME_CohenDaubechiesFeauveau5_3:      printf("  Cohen-Daubechies-Feauveau Biorthogonal Wavelet, Length 5-3\n");      printf("        -- Lifted Implementation --\n");      printf("    (linear lifting with unitary scaling)\n\n");      break;    default:      QccErrorAddMessage("(QccWAVLiftingSchemePrint): Unrecognized lifting scheme");      return(1);      break;    }    return(0);}static int QccWAVLiftingSchemeReadHeader(FILE *infile,                                         QccWAVLiftingScheme *lifting_scheme){    if ((infile == NULL) || (lifting_scheme == NULL))    return(0);    if (QccFileReadMagicNumber(infile,                             lifting_scheme->magic_num,                              &lifting_scheme->major_version,                             &lifting_scheme->minor_version))    {      QccErrorAddMessage("(QccWAVLiftingSchemeReadHeader): Error reading magic number in lifting scheme %s",                         lifting_scheme->filename);      return(1);    }    if (strcmp(lifting_scheme->magic_num, QCCWAVLIFTINGSCHEME_MAGICNUM))    {      QccErrorAddMessage("(QccWAVLiftingSchemeReadHeader): %s is not of filter-bank (%s) type",                         lifting_scheme->filename,                         QCCWAVLIFTINGSCHEME_MAGICNUM);      return(1);    }    fscanf(infile, "%d", &(lifting_scheme->scheme));  if (ferror(infile) || feof(infile))    {      QccErrorAddMessage("(QccWAVLiftingSchemeReadHeader): Error reading scheme in lifting scheme %s",                         lifting_scheme->filename);      return(1);    }    if (QccFileSkipWhiteSpace(infile, 0))    {      QccErrorAddMessage("(QccWAVLiftingSchemeReadHeader): Error reading in lifting scheme %s",                         lifting_scheme->filename);      return(1);    }    return(0);}int QccWAVLiftingSchemeRead(QccWAVLiftingScheme *lifting_scheme){  FILE *infile = NULL;  if (lifting_scheme == NULL)    return(0);    if ((infile =        QccFileOpen(lifting_scheme->filename, "r")) == NULL)    {      QccErrorAddMessage("(QccWAVLiftingSchemeRead): Error calling QccFileOpen()");      return(1);    }  if (QccWAVLiftingSchemeReadHeader(infile, lifting_scheme))    {      QccErrorAddMessage("(QccWAVLiftingSchemeRead): Error calling QccWAVLiftingSchemeReadHeader()");      return(1);    }    /*  if (QccWAVLiftingSchemeReadData(infile, lifting_scheme))    {      QccErrorAddMessage("(QccWAVLiftingSchemeRead): Error calling QccWAVLiftingSchemeReadData()");      return(1);    }  */    QccFileClose(infile);  return(0);}static int QccWAVLiftingSchemeWriteHeader(FILE *outfile,                                          const QccWAVLiftingScheme                                          *lifting_scheme){  if ((outfile == NULL) || (lifting_scheme == NULL))    return(0);    if (QccFileWriteMagicNumber(outfile, QCCWAVLIFTINGSCHEME_MAGICNUM))    goto QccError;    fprintf(outfile, "%d\n",          lifting_scheme->scheme);    if (ferror(outfile))    goto QccError;    return(0);   QccError:  QccErrorAddMessage("(QccWAVLiftingSchemeWriteHeader): Error writing header to %s",                     lifting_scheme->filename);  return(1);  }int QccWAVLiftingSchemeWrite(const QccWAVLiftingScheme *lifting_scheme){  FILE *outfile;    if (lifting_scheme == NULL)    return(0);    if ((outfile = QccFileOpen(lifting_scheme->filename, "w")) == NULL)    {      QccErrorAddMessage("(QccWAVLiftingSchemeWrite): Error calling QccFileOpen()");      return(1);    }    if (QccWAVLiftingSchemeWriteHeader(outfile, lifting_scheme))    {      QccErrorAddMessage("(QccWAVLiftingSchemeWrite): Error calling QccWAVLiftingSchemeWriteHeader()");      return(1);    }    /*  if (QccWAVLiftingSchemeWriteData(outfile, lifting_scheme))    {      QccErrorAddMessage("(QccWAVLiftingSchemeWrite): Error calling QccWAVLiftingSchemeWriteData()");      return(1);    }  */    QccFileClose(outfile);  return(0);}int QccWAVLiftingSchemeBiorthogonal(const QccWAVLiftingScheme *lifting_scheme){  switch (lifting_scheme->scheme)    {    case QCCWAVLIFTINGSCHEME_CohenDaubechiesFeauveau9_7:      return(1);      break;    case QCCWAVLIFTINGSCHEME_CohenDaubechiesFeauveau5_3:      return(1);      break;    default:      return(0);      break;    }  return(0);}int QccWAVLiftingAnalysis(const QccVector input_signal,                          QccVector output_signal,                          int signal_length,                          int phase,                          const QccWAVLiftingScheme *lifting_scheme,                          int boundary){  int return_value;  QccVector input_signal2 = NULL;  if (input_signal == NULL)    return(0);  if (output_signal == NULL)    return(0);  if (lifting_scheme == NULL)    return(0);  if (!signal_length)    return(0);  if ((input_signal2 = QccVectorAlloc(signal_length)) == NULL)    {      QccErrorAddMessage("(QccWAVLiftingAnalysis): Error calling QccVectorAlloc()");      goto QccError;    }  if (QccVectorCopy(input_signal2, input_signal, signal_length))    {      QccErrorAddMessage("(QccWAVLiftingAnalysis): Error calling QccVectorCopy()");      goto QccError;    }  switch (lifting_scheme->scheme)    {    case QCCWAVLIFTINGSCHEME_LWT:      break;    case  QCCWAVLIFTINGSCHEME_Daubechies4:      if (QccWAVLiftingAnalysisDaubechies4(input_signal2,                                           signal_length,                                           phase,                                           boundary))        {          QccErrorAddMessage("(QccWAVLiftingAnalysis): Error calling QccWAVLiftingAnalysisDaubechies4()");          goto QccError;        }      break;    case QCCWAVLIFTINGSCHEME_CohenDaubechiesFeauveau9_7:      if (QccWAVLiftingAnalysisCohenDaubechiesFeauveau9_7(input_signal2,                                                          signal_length,                                                          phase,                                                          boundary))        {          QccErrorAddMessage("(QccWAVLiftingAnalysis): Error calling QccWAVLiftingAnalysisCohenDaubechiesFeauveau9_7()");          goto QccError;        }      break;    case QCCWAVLIFTINGSCHEME_CohenDaubechiesFeauveau5_3:      if (QccWAVLiftingAnalysisCohenDaubechiesFeauveau5_3(input_signal2,                                                          signal_length,                                                          phase,                                                          boundary))        {          QccErrorAddMessage("(QccWAVLiftingAnalysis): Error calling QccWAVLiftingAnalysisCohenDaubechiesFeauveau5_3()");          goto QccError;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲丰满少妇videoshd| 欧美性大战xxxxx久久久| 精品国产一区二区在线观看| 午夜精品福利在线| 欧美日韩精品电影| 日韩激情av在线| 911国产精品| 国内精品久久久久影院色| 欧美一级淫片007| 蜜臀久久99精品久久久久宅男| 欧美日韩国产影片| 麻豆精品一区二区三区| 久久免费偷拍视频| 亚洲免费观看高清完整版在线观看| 中文字幕免费不卡| 麻豆精品一区二区| 国产亚洲精久久久久久| 色偷偷88欧美精品久久久| 亚洲一区二区三区中文字幕| 欧美一区二区三区在线视频| 国内精品写真在线观看| 精品国产乱码91久久久久久网站| 国产一区不卡在线| 亚洲一区二区三区在线看| 欧美成人精品1314www| 国产成人aaaa| 亚洲精品va在线观看| 欧美网站一区二区| 国产高清久久久| 亚洲成人免费视| 日本一区二区在线不卡| 欧美日韩一区高清| 国产精品亚洲午夜一区二区三区| 一区二区欧美视频| 国产欧美一区二区精品仙草咪| 欧美精品aⅴ在线视频| av资源网一区| 国产999精品久久久久久| 午夜精品aaa| 亚洲色图在线看| 久久久www免费人成精品| 91精品啪在线观看国产60岁| 在线影视一区二区三区| 成人晚上爱看视频| 成人美女在线观看| 国产在线精品一区在线观看麻豆| 免费在线成人网| 午夜视频在线观看一区| 一区二区三区精密机械公司| 1区2区3区精品视频| 亚洲天堂免费看| 亚洲男人的天堂一区二区| 亚洲欧美一区二区三区国产精品| 中文字幕亚洲一区二区av在线| 久久久久久日产精品| 国产欧美日韩综合| 国产精品乱码人人做人人爱 | 久久国产精品72免费观看| 天堂一区二区在线| 经典一区二区三区| 成人一道本在线| 一本高清dvd不卡在线观看| 欧洲一区二区三区在线| 51精品久久久久久久蜜臀| 久久综合精品国产一区二区三区| 久久综合色天天久久综合图片| 久久久精品国产免费观看同学| 国产日韩三级在线| 一区二区三区鲁丝不卡| 天堂资源在线中文精品| 韩国三级电影一区二区| 91在线一区二区| 欧美网站一区二区| 久久久久久黄色| 天天色图综合网| 国产精品一区二区三区99| 色就色 综合激情| 91在线视频在线| 国产成人日日夜夜| 欧美精品三级在线观看| 国产网红主播福利一区二区| 午夜电影网亚洲视频| 盗摄精品av一区二区三区| 欧美电影在哪看比较好| 国产精品成人一区二区三区夜夜夜| 亚洲不卡av一区二区三区| 9色porny自拍视频一区二区| 久久免费看少妇高潮| 免费观看日韩av| 欧美日韩在线观看一区二区| 国产精品短视频| 成人性视频网站| 亚洲欧洲精品一区二区三区| 国产精品自拍av| 久久精品视频一区二区三区| 日本大胆欧美人术艺术动态| 欧美日韩高清影院| 五月激情综合网| 日韩午夜电影av| 韩国女主播成人在线观看| 亚洲精品一线二线三线| 国产综合色视频| 国产精品视频免费看| 99国产麻豆精品| 91精品国产综合久久国产大片 | 1000部国产精品成人观看| av成人老司机| 日韩激情在线观看| 精品国产乱码久久久久久浪潮 | 日韩女优电影在线观看| 国内成人免费视频| 国产亲近乱来精品视频| av电影一区二区| 亚洲a一区二区| 精品精品国产高清a毛片牛牛| 美脚の诱脚舐め脚责91| 久久久久久久网| 91理论电影在线观看| 丝袜诱惑制服诱惑色一区在线观看 | 亚洲18女电影在线观看| 欧美成人官网二区| 99精品一区二区三区| 天堂一区二区在线| 亚洲视频综合在线| 精品999久久久| 在线免费精品视频| 成人一区二区三区| 日韩av中文字幕一区二区三区| 国产精品高潮呻吟| 欧美va日韩va| 欧美日韩国产高清一区二区 | 国产色一区二区| 欧美久久久一区| 色就色 综合激情| 丰满岳乱妇一区二区三区| 视频精品一区二区| 中文字幕乱码日本亚洲一区二区 | av午夜精品一区二区三区| 热久久久久久久| 亚洲第一福利视频在线| 亚洲视频 欧洲视频| 精品国产污污免费网站入口| 91福利国产成人精品照片| 99久久亚洲一区二区三区青草| 亚洲同性gay激情无套| 国产精品区一区二区三区| 日韩欧美一级在线播放| 日韩一级完整毛片| 91精品国产手机| 日韩亚洲欧美综合| 精品日韩成人av| 久久综合网色—综合色88| 91理论电影在线观看| 麻豆国产精品777777在线| 日本va欧美va精品发布| 日本美女视频一区二区| 久久精品国产一区二区| 国产福利一区二区| 99久久国产综合精品女不卡| 97se亚洲国产综合自在线不卡| 高清国产一区二区| 日本久久精品电影| 91精品国产色综合久久ai换脸 | 91精品欧美久久久久久动漫| 精品国精品国产| 亚洲私人影院在线观看| 肉肉av福利一精品导航| 国产乱码精品1区2区3区| 99久久夜色精品国产网站| 欧美一区二区三区视频免费| 欧美精品一区视频| 亚洲免费观看高清完整版在线| 日韩中文字幕一区二区三区| 国产91精品露脸国语对白| 精品视频在线视频| 亚洲欧洲av在线| 国产在线精品一区二区| 欧美久久久久中文字幕| 国产精品久久久久久久第一福利| 青草国产精品久久久久久| 日本精品免费观看高清观看| 久久久久国产精品人| 精品综合久久久久久8888| 久久精品99国产国产精| 欧美亚洲一区二区在线| 中文字幕亚洲一区二区av在线| 美女久久久精品| 欧美一卡二卡在线| 亚洲va天堂va国产va久| 在线观看日韩电影| 一区二区三区在线播| 99精品视频在线免费观看| 精品国产乱码久久| 精品无人区卡一卡二卡三乱码免费卡| 欧美调教femdomvk| 天堂资源在线中文精品| 欧美精品v国产精品v日韩精品 | 亚洲特黄一级片| 91高清在线观看| 亚洲综合精品自拍|