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

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

?? flwtpack.c

?? 大師寫的二代小波經典之作
?? C
字號:
/* *  -*- Mode: ANSI C -*- *  $Id: flwtpack.c,v 1.7 1996/10/14 21:03:35 fernande Exp $ *  $Source: /sgi.acct/sweldens/cvs/liftpack/Lifting/flwtpack.c,v $ *  Author: Gabriel Fernandez * *  Using the "Lifting Scheme" and the "Square 2D" method, the coefficients *  of "Biorthogonal Wavelet Packets" are found for one and two-dimensional *  data sets. The same scheme is used to apply the inverse operation. *//* do not edit anything above this line *//* System header files */#include <math.h>/* #include <stdio.h> *//* FLWT header files */#include <cost.h>#include <data.h>#include <flwterr.h>#include <flwt.h>#include <flwtpack.h>#include <imgmem.h>#include <mallat.h>#include <mem.h>#include <memchk.h>#include <util.h>/* Prototypes to private functions */static MatrixGetMatrix ( Hedge *__graph, const int __s, const int __x, const int __y );static voidReconstructPackets ( Hedge *__graph, const int __x, const int __y,                                     const int __N, const int __nTilde,                                     const int __l );static VectorGetVector ( Hedge *__graph, const int __s, const int __x );static voidReconstructPackets1D ( Hedge *__graph, const int __x,                                       const int __N, const int __nTilde,                                       const int __l );/* code *//* * DFLWTPackets function: for the forward case, it sets some initial  *                        variables needed for the best basis function, *                        finds the hedge corresponding to the best *                        basis description of the given data, and *                        cleans up any left overs. For the inverse case, *                        it takes the given array and finds the *                        corresponding hedge. Then, it builds the *                        original data set using the inverse calculations. */int *DFLWTPackets ( Matrix Data, const int sizeX, const int sizeY,                            const int N, const int nTilde, const int maxLevel,                            int *blocks ){    Hedge *graph;        /* hedge with the best basis of Data */    register int i;      /* counter */    int *levels,         /* levels in which the regions are located */        *outlevels,      /* levels for output */        nX, nY,          /* number of levels in X and Y */        L,               /* maximum level in decomposition */        XY;              /* size of contents vector in hedge */    Flt maxN,            /* maximum number of vanishing moments */        cost;            /* cost of the best basis tree */    Vector dataPtr;      /* pointer to the output matrix */    Matrix bestCoeffs;   /* matrix that will store the best coefficients */    /* Calculate maximum level */    maxN = (Flt)MAX(N, nTilde) - (Flt)1;    nX = (sizeX == 1) ? 0 : (int)logBaseN( (Flt)(sizeX-1)/maxN, (Flt)2 );    nX = (nX < 0) ? 0 : MIN(maxLevel, nX);    nY = (sizeY == 1) ? 0 : (int)logBaseN( (Flt)(sizeY-1)/maxN, (Flt)2 );    nY = (nY < 0) ? 0 : MIN(maxLevel, nY);    L = MAX(nX, nY);    /* Allocate initial hedge */    *blocks = (1<<2*L) + 1;    bestCoeffs = (Matrix)MEM_Init2D( (long)ceil((Flt)(sizeX*sizeY)/(Flt)*blocks),                                     (long)*blocks );    levels = ivector( 0, (long)(*blocks-1) );    graph = (Hedge *)makehedge( *blocks, bestCoeffs, levels, NULL );    graph->blocks = 0;        /* Find best basis */    cost = bbwp2( graph, Data, sizeX, sizeY, N, nTilde, 0, L );        /* Put results in final image buffer */    /*    fprintf( stdout, "\nCost best basis = %g\t\t", cost );    fflush (stdout);    */    XY = sizeX*sizeY;    outlevels = ivector( 0, (long)(graph->blocks-1) );    *blocks = graph->blocks;    dataPtr = &Data[0][0];    for ( i=0; i<graph->blocks ; i++ ) {        register int j;        int length = XY/(1<<(2*graph->levels[i]));        outlevels[i] = graph->levels[i];        for ( j=0 ; j<length ; j++, dataPtr++ ) {            *dataPtr = graph->contents[i][j];        }    }    /* Clean up */    graph = freehedge( graph );    return outlevels;}/* * IFLWTPackets function: performs the inverse operation to the packet *                        transform in order to find the original signal. */voidIFLWTPackets ( Matrix Data, const int sizeX, const int sizeY,               const int blocks, int *levels, const int N, const int nTilde ){    Hedge *graph;    Matrix content;    register int i;    int column, XY, length, maxl;    /* Allocate a hedge for the manipulation of the basis */    content = (Matrix)malloc( (size_t)(blocks * sizeof( Vector )) );   /* row of new pointers */    graph   = (Hedge *)makehedge( blocks, content, levels, NULL );    /* Extract hedge of coefficients */    column = 0;    maxl = -999;    XY = sizeX * sizeY;    for ( i=0 ; i<graph->blocks ; i++ ) {        maxl = MAX(maxl, graph->levels[i]);      /* find maximum level */        length = XY/(1<<(2*graph->levels[i]));   /* length of vector block */        graph->contents[i] = Data[0] + column;   /* pointer to beginning of vector block */        column += length;                        /* place for next column pointer */    }    /* Reconstruct original image */    if ( maxl > 0 ) {        Vector dataPtr;        ReconstructPackets( graph, sizeX, sizeY, N, nTilde, maxl );        dataPtr = &Data[0][0];        for ( i=0; i<graph->blocks ; i++ ) {            register int j;            int length = XY/(1<<(2*graph->levels[i]));            for ( j=0 ; j<length ; j++, dataPtr++ ) {                *dataPtr = graph->contents[i][j];            }        }    }    /* Clean up */    free( (Matrix)content );    free( (Hedge *)graph );}/* * DFLWTPackets1D function: for the forward case, it sets some initial  *                          variables needed for the best basis function,  *                          finds the hedge corresponding to the best  *                          basis description of the given data, and  *                          cleans up any left overs. For the inverse  *                          case, it takes the given array and finds the  *                          corresponding hedge. Then, it builds the *                          original data set using the inverse *                          calculations. */int *DFLWTPackets1D ( Vector Data, const int sizeX,                              const int N, const int nTilde,                               const int maxLevel, int *blocks ){    Hedge *graph;        /* hedge with the best basis of Data */    register int i;      /* counter */    int *levels,         /* levels in which the regions are located */        *outlevels,      /* levels for output */        nX;              /* number of levels in X */    Flt maxN,            /* maximum number of vanishing moments */        cost;            /* cost of the best basis tree */    Vector dataPtr;      /* pointer to the output matrix */    Matrix bestCoeffs;   /* matrix that will store the best coefficients */    /* Calculate maximum level */    maxN = (Flt)MAX(N, nTilde) - (Flt)1;    nX = (sizeX == 1) ? 0 : (int)logBaseN( (Flt)(sizeX-1)/maxN, (Flt)2 );    nX = (nX < 0) ? 0 : MIN(maxLevel, nX);    /* Allocate initial hedge */    *blocks = (1<<nX) + 1;    bestCoeffs = (Matrix)MEM_Init2D( (long)ceil(sizeX/(Flt)*blocks),                                     (long)*blocks );    levels = ivector( 0, (long)(*blocks-1) );    graph = (Hedge *)makehedge( *blocks, bestCoeffs, levels, NULL );    graph->blocks = 0;        /* Find best basis */    cost = bbwp1( graph, Data, sizeX, N, nTilde, 0, nX );        /* Put results in final image buffer */    outlevels = ivector( 0, (long)(graph->blocks-1) );    *blocks = graph->blocks;    dataPtr = Data;    for ( i=0; i<graph->blocks ; i++ ) {        register int j;        int length = sizeX/(1<<(graph->levels[i]));        outlevels[i] = graph->levels[i];        for ( j=0 ; j<length ; j++, dataPtr++ )            *dataPtr = graph->contents[i][j];    }    /* Clean up */    graph = freehedge( graph );    return outlevels;}/* * IFLWTPackets1D function: performs the inverse operation to the packet *                        transform in order to find the original signal. */voidIFLWTPackets1D ( Vector Data, const int sizeX,                 const int blocks, int *levels, const int N,                  const int nTilde ){    Hedge *graph;    Matrix content;    register int i;    int column, length, maxl;    /* Allocate a hedge for the manipulation of the basis */    content = (Matrix)malloc( (size_t)(blocks * sizeof( Vector )) );    /* row of new pointers */    graph   = (Hedge *)makehedge( blocks, content, levels, NULL );    /* Extract hedge of coefficients */    column = 0;    maxl = -999;    for ( i=0 ; i<graph->blocks ; i++ ) {        maxl = MAX(maxl, graph->levels[i]);      /* find maximum level */        length = sizeX/(1<<(graph->levels[i]));  /* length of vector block */        graph->contents[i] = Data + column;      /* pointer to beginning of                                                    vector block */        column += length;                        /* place for next column                                                     pointer */    }    /* Reconstruct original image */    if ( maxl > 0 ) {        Vector dataPtr;        ReconstructPackets1D( graph, sizeX, N, nTilde, maxl );        dataPtr = Data;        for ( i=0; i<graph->blocks ; i++ ) {            register int j;            int length = sizeX/(1<<(graph->levels[i]));            for ( j=0 ; j<length ; j++, dataPtr++ ) {                *dataPtr = graph->contents[i][j];            }        }    }    /* Clean up */    free( (Matrix)content );    free( (Hedge *)graph );}/*************************//**  Private functions  **//*************************//* * GetMatrix function: build a matrix out from the vector in a hedge describing *                     a region in the decomposition at scale s. */static MatrixGetMatrix ( Hedge *graph, const int s, const int rows, const int cols ){    int x, y;    Matrix out;    Vector hedgePtr;    /* Allocate memory */    out = MEM_Init2D( (long)rows, (long)cols );    /* Copy data into matrix */    for ( y=0, hedgePtr=graph->contents[s] ; y<rows ; y++ )        for ( x=0 ; x<cols ; x++ )            out[y][x] = *(hedgePtr++);    return out;}/* * ReconstructPackets fucntion: given a hedge with a packet decomposition, the *                              inverse operation is applied to find the  *                              original signal.  */static voidReconstructPackets ( Hedge *graph, const int x, const int y,                                   const int N, const int nTilde,                                   const int l ){    int i, j,        maxLevel,        x1, y1,        xy,        length;    Matrix K[4];    Matrix out;    Vector outPtr, outPtr1;    maxLevel = l;    xy = x*y;    while ( maxLevel ) {        /* Find the nodes in this level and merge them */        i = 0;        while ( i < graph->blocks ) {            int block;            /* Find a node in this level */            while ( graph->levels[i] < maxLevel && i < graph->blocks ) { i++; }            if ( i >= graph->blocks )                break;            block = i;            length = xy/(1<<(2*graph->levels[block]));            x1 = y1 = (int)sqrt( (Flt)length );   /* assuming all regions are square */            /* Take all the four siblings and merge them */            K[0] = GetMatrix( graph, block  , x1, y1 );            K[1] = GetMatrix( graph, block+1, x1, y1 );            K[2] = GetMatrix( graph, block+2, x1, y1 );            K[3] = GetMatrix( graph, block+3, x1, y1 );            out = ISFLWT2D ( K, x1<<1, y1<<1, N, nTilde );            MEM_Free2D( K[0] );            MEM_Free2D( K[1] );            MEM_Free2D( K[2] );            MEM_Free2D( K[3] );            /* Update pointers and levels */            graph->blocks -= 3;            graph->levels[block] -= 1;            i = block + 1;            for ( j=i ; j<graph->blocks ; j++ ) {                graph->contents[j] = graph->contents[j+3];                graph->levels[j] = graph->levels[j+3];            }            /* Copy new node in graph->contents */            length *= 4;            for ( j=0, outPtr=graph->contents[block], outPtr1=&out[0][0] ; j<length ; j++ )                *(outPtr++) = *(outPtr1++);            MEM_Free2D( out );        }        maxLevel--;            }}/* * GetVector function: build a vector out from the vector in a hedge *                     describing a region in the decomposition at scale s. */static VectorGetVector ( Hedge *graph, const int s, const int cols ){    int x;    Vector out;    Vector hedgePtr;    /* Allocate memory */    out = vector( 0, (long)(cols-1) );    /* Copy data into vector */    hedgePtr=graph->contents[s];    for ( x=0 ; x<cols ; x++ )        out[x] = *(hedgePtr++);    return out;}/* * ReconstructPackets1D function: given a hedge with a packet *                                decomposition, the inverse  *                                operation is applied to find the *                                original signal. */static voidReconstructPackets1D ( Hedge *graph, const int x,                                     const int N, const int nTilde,                                     const int l ){    int i, j,        maxLevel,        length;    Vector K[2];    Vector out;    Vector outPtr, outPtr1;    maxLevel = l;    while ( maxLevel ) {        /* Find the nodes in this level and merge them */        i = 0;        while ( i < graph->blocks ) {            int block;            /* Find a node in this level */            while ( graph->levels[i] < maxLevel && i < graph->blocks ) i++;            if ( i >= graph->blocks )                break;            block = i;            length = x/(1<<(graph->levels[block]));            /* Take the two siblings and merge them */            K[0] = GetVector( graph, block  , length );            K[1] = GetVector( graph, block+1, length );            out = ISFLWT1D ( K, length<<1, N, nTilde );            free( K[0] );            free( K[1] );            /* Update pointers and levels */            graph->blocks--;            graph->levels[block]--;            i = block + 1;            for ( j=i ; j<graph->blocks ; j++ ) {                graph->contents[j] = graph->contents[j+1];                graph->levels[j] = graph->levels[j+1];            }            /* Copy new node in graph->contents */            length *= 2;            for ( j=0, outPtr=graph->contents[block], outPtr1=out ;                   j<length ; j++ )                *(outPtr++) = *(outPtr1++);            free( out );        }        maxLevel--;    }}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美成人a在线| 亚洲图片自拍偷拍| 一区二区三区在线免费视频| 日韩av不卡在线观看| av不卡在线播放| 欧美成人精品1314www| 亚洲男人电影天堂| 国产成人综合精品三级| 欧美一区二区三区小说| 夜夜夜精品看看| 国产不卡在线一区| 精品国产乱码久久久久久久久| 一区二区三区国产精品| 成人app在线观看| 国产三级一区二区三区| 日韩国产在线观看| 欧美美女直播网站| 一区二区三区日韩| 99久久99久久免费精品蜜臀| 久久综合久久综合久久| 日本欧美大码aⅴ在线播放| 日本韩国视频一区二区| 中文字幕av一区 二区| 国产美女娇喘av呻吟久久| 91精品国产乱码| 亚洲综合色丁香婷婷六月图片| 色综合中文字幕国产| 18成人在线观看| 97se亚洲国产综合自在线不卡| 国产精品乱码一区二三区小蝌蚪| 国产一区二区在线看| 日韩写真欧美这视频| 三级亚洲高清视频| 制服.丝袜.亚洲.另类.中文| 视频一区视频二区中文| 色吊一区二区三区| 亚洲午夜三级在线| 7777精品伊人久久久大香线蕉| 偷拍一区二区三区| 欧美一区二区视频在线观看2022 | 裸体健美xxxx欧美裸体表演| 欧美日韩国产首页| 日韩电影在线一区| 久久女同精品一区二区| 岛国av在线一区| 最新国产精品久久精品| 色美美综合视频| 天天影视色香欲综合网老头| 日韩欧美一二区| 国产成人在线网站| 亚洲免费资源在线播放| 欧美丝袜第三区| 久久99精品久久久久久动态图| 久久婷婷久久一区二区三区| av不卡免费电影| 亚洲国产sm捆绑调教视频 | 欧美在线不卡视频| 日韩成人免费电影| 国产视频一区二区在线观看| 91尤物视频在线观看| 午夜不卡在线视频| 国产午夜亚洲精品理论片色戒 | 精彩视频一区二区| 国产精品久久久久久久午夜片| 欧洲色大大久久| 九九视频精品免费| 一区二区免费在线播放| 欧美精品一区二区三区很污很色的| 东方aⅴ免费观看久久av| 一区二区三区四区中文字幕| 欧美va天堂va视频va在线| 成人av综合一区| 蜜桃久久久久久久| 亚洲精品免费在线| 久久精品日韩一区二区三区| 欧美影片第一页| 成人久久18免费网站麻豆 | 成人久久18免费网站麻豆| 丝袜亚洲另类欧美综合| 国产精品国产三级国产aⅴ无密码| 欧美日韩国产影片| 色综合网色综合| 国产高清精品久久久久| 日日摸夜夜添夜夜添国产精品 | 久久久久久久综合日本| 在线免费亚洲电影| 成人小视频在线| 美腿丝袜亚洲一区| 亚洲午夜精品网| 亚洲欧美日韩精品久久久久| 26uuu国产一区二区三区| 欧美亚男人的天堂| 国产成人免费在线观看不卡| 日韩av一二三| 亚洲高清免费观看高清完整版在线观看| 欧美韩日一区二区三区四区| 欧美成人一区二区| 欧美人与性动xxxx| 91高清在线观看| 91亚洲精华国产精华精华液| 国产成人综合在线观看| 久久91精品国产91久久小草| 亚洲18色成人| 亚洲国产精品久久不卡毛片| 亚洲三级在线免费| 亚洲视频你懂的| 1区2区3区国产精品| 亚洲欧洲国产日韩| 亚洲欧美日韩国产成人精品影院| 国产精品亲子乱子伦xxxx裸| 国产精品久久久久久户外露出| 欧美极品aⅴ影院| 国产精品日产欧美久久久久| 国产精品久久久久一区| 国产精品第四页| 亚洲男同1069视频| 亚洲午夜免费福利视频| 亚洲制服丝袜在线| 亚洲va天堂va国产va久| 午夜精品久久久久久久久久久| 亚洲午夜久久久久久久久久久| 亚洲网友自拍偷拍| 日本中文字幕一区二区有限公司| 日本成人中文字幕在线视频| 久草热8精品视频在线观看| 激情深爱一区二区| 成人黄色av电影| 在线免费精品视频| 91精品国产综合久久精品| 精品国产自在久精品国产| 久久婷婷综合激情| 国产精品久久久久久久蜜臀| 一区二区三区日韩精品| 日韩成人免费电影| 粉嫩在线一区二区三区视频| bt欧美亚洲午夜电影天堂| 日本高清视频一区二区| 欧美人xxxx| 国产欧美一区二区精品性色| 日韩一区欧美小说| 肉肉av福利一精品导航| 黄色日韩三级电影| 91一区二区三区在线播放| 91麻豆精品国产91久久久久久| 亚洲精品一区二区三区福利| 中文字幕一区二区在线观看| 亚洲最大色网站| 国产精品亚洲第一区在线暖暖韩国| 色欧美日韩亚洲| 日韩美女一区二区三区四区| 亚洲欧洲国产专区| 精品一二线国产| 91麻豆免费看| 久久九九久精品国产免费直播| 亚洲一区视频在线观看视频| 精品一区二区在线看| 色综合天天综合网天天看片| 日韩亚洲国产中文字幕欧美| 亚洲欧美偷拍另类a∨色屁股| 久热成人在线视频| 欧美午夜电影在线播放| 欧美高清在线一区| 美女脱光内衣内裤视频久久网站| 91色婷婷久久久久合中文| 精品国产91乱码一区二区三区 | 激情图区综合网| 欧美影院午夜播放| 国产精品久久影院| 麻豆91免费观看| 欧美丰满少妇xxxbbb| 亚洲精品乱码久久久久久日本蜜臀| 精品制服美女久久| 91精品久久久久久久99蜜桃| 国产精品福利一区| 国产成人久久精品77777最新版本| 在线电影国产精品| 亚洲精品菠萝久久久久久久| 丁香六月久久综合狠狠色| 日韩精品一区二区三区三区免费| 亚洲午夜久久久久久久久久久| 99精品久久只有精品| 久久久久久电影| 精品一区二区久久久| 日韩三级中文字幕| 天天做天天摸天天爽国产一区| 91久久精品一区二区三区| 成人欧美一区二区三区小说| 懂色av一区二区三区免费看| 欧美大片免费久久精品三p| 日韩av高清在线观看| 欧美一区午夜视频在线观看| 亚洲 欧美综合在线网络| 欧洲av一区二区嗯嗯嗯啊| 亚洲另类色综合网站| 一本大道久久精品懂色aⅴ| 亚洲欧洲制服丝袜| 欧美亚洲国产一卡| 亚洲国产美女搞黄色| 欧美日本在线看| 日韩成人免费看|