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

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

?? model.c

?? A
?? C
?? 第 1 頁 / 共 3 頁
字號:
                        break;
        }
}


/*
        Initialize tables at start of dictionary scan
        Establish counts based on low order tables
*/

static void clear_context (void)

{
        int i;

        for (i = 2; i < max_order + 2; i ++)
        {
                active_state.order_sym_count [i] = 0;
                active_state.order_cum_freq [i] = 0;
        }

        active_state.order_sym_count [1] = sym_count_zero;
        active_state.order_sym_count [0] = MAX_SYM - sym_count_zero;

        active_state.order_cum_freq [1] = cum_freq_zero;
        active_state.order_cum_freq [0] = MAX_SYM - sym_count_zero;

        movmem (freq_zero, freq, sizeof freq);
        movmem (order_zero, level, sizeof level);
}



/*
        Perform search of dictionary to locate active contexts
        Accumulate freqencies for all symbols encounered
        Use initial character of input string to select the starting table value
*/

static void scan_dict (int base_char)

{
        unsigned int k;
        unsigned int jnode;
        int ch;
        int n;

        last_search_node = dict [node - 1] + MAX_DICT;
        jnode = NEXT_DICT (last_search_node);

        while (jnode != NIL_DICT_PTR)
        {
                ch = dict [jnode];
                for (n = 2; n < max_order + 1; n ++)
                {
                        if (dict [node - n] != dict [jnode - n]) break;
                }

                switch (string_state)
                {
                        case STRING_SEARCH:
                        case STRING_START:
                                test_string_start (jnode, n);
                                break;

                        case STRING_COMP:
                                test_string_resume (jnode, n);
                                break;
                }

                if (base_level [jnode] <= n)
                {
                        k = level [ch];
                        if (k < n)
                        {
                                active_state.order_cum_freq [k] -= freq [ch];
                                active_state.order_sym_count [k] --;

                                active_state.order_cum_freq [n] ++;
                                active_state.order_sym_count [n] ++;

                                if (ch < base_char)
                                {
                                        base_freq [k] -= freq [ch];
                                        base_freq [n] ++;
                                }

                                level [ch] = n;
                                freq [ch] = 1;

                                if (n > active_state.initial_level) active_state.initial_level = n;
                        }
                        else
                        if (k == n)
                        {
                                active_state.order_cum_freq [n] ++;
                                freq [ch] ++;
                                if (ch < base_char) base_freq [n] ++;
                        }
                }

                last_search_node = jnode;
                jnode = NEXT_DICT (jnode);
        }
}



/*
        Test for continued text substring
        Executed before the start of each dictionary scan during compression
*/

static void check_string_cont (void)

{
        int j;

        j = string_pos + string_len;
        if (j >= MAX_DICT) j -= NDICT;

        if (dict [node - 1] == dict [j])
                string_len ++;
        else
                string_state = STRING_COMP;
}



/*
        Test for start of potential text substring
        Executed during dictionary scan based on string state variable
*/

static void test_string_start (unsigned pos, int n)

{
        if (n > MIN_STR)
        {
                string_pos = pos;
                if (string_pos < MIN_STR + MAX_ORDER) string_pos += NDICT;
                string_pos -= MIN_STR;
                string_len = MIN_STR;
                string_state = STRING_START;
        }
}



static void test_string_resume (unsigned pos, int n)

{
        if (n > string_len + 1)
        {
                string_state = STRING_ACTIVE;
                string_len ++;
                string_pos = pos;
                if (string_pos < string_len + MAX_ORDER) string_pos += NDICT;
                string_pos -= string_len;
        }
        else
        if (n == max_order + 1)
        {
                unsigned i2, j2, n2;

                i2 = node - max_order - 1;
                j2 = pos - max_order - 1;

                for (n2 = max_order + 1; n2 <= string_len + 1; n2 ++)
                {
                        if (i2 < MAX_ORDER) i2 += NDICT;
                        if (j2 < MAX_ORDER) j2 += NDICT;
                        if (dict [i2 --] != dict [j2 --]) break;
                }

                if (n2 > string_len + 1)
                {
                        string_state = STRING_ACTIVE;
                        string_len ++;
                        string_pos = pos;
                        if (string_pos < string_len + MAX_ORDER) string_pos += NDICT;
                        string_pos -= string_len;
                }
        }
}



/*
        Test status of text substring match procedure
        Performed after each dictionary scan
*/

static void test_string_state (void)

{
        switch (string_state)
        {
                case STRING_WAIT:
                        save_state [string_start].mod = active_state;
                        SaveCoderState (&save_state [string_start].cs);

                        if (++ string_start == MAX_STR_SAVE) string_start = 0;
                        if (-- skip_count == 0) string_state = STRING_SEARCH;
                        break;

                case STRING_SEARCH:
                        save_state [string_start].mod = active_state;
                        SaveCoderState (&save_state [string_start].cs);
                        if (++ string_start == MAX_STR_SAVE) string_start = 0;
                        break;

                case STRING_ACTIVE:
                        if (string_len > MAX_STR)
                        {
                                string_len --;
                                clear_text_string ();
                        }
                        break;

                case STRING_COMP:
                        clear_text_string ();
                        break;
        }
}



/*
        End of text substring
        Test for minimum code length of dtring versus coded symbols
        Reposition output and write string selection if less
        Set up for start of next string
*/

static void clear_text_string (void)

{
        int nbits;
        int i;

        if (string_len >= MIN_STR)
        {
                nbits = find_string_len ();
                if (nbits > 0)
                {
                        replace_text_string ();

                        i = node;
                        if (i <= string_len) i += NDICT;
                        i -= string_len + 1;
                }
        }

        save_state [string_start].mod = last_state;
        SaveCoderState (&save_state [string_start].cs);

        if (++ string_start == MAX_STR_SAVE) string_start = 0;

        encode_symbol (&last_state);

        save_state [string_start].mod = active_state;
        SaveCoderState (&save_state [string_start].cs);

        if (++ string_start == MAX_STR_SAVE) string_start = 0;
        skip_count = MIN_STR - 2;
        string_len = 0;

        string_state = STRING_WAIT;
}



/*
        Estimate size of string reference
        Returns size relative to actual length used by coded symbols
*/

static int find_string_len (void)

{
        int nbits;
        unsigned f;

        struct model start_context;
        unsigned i;
        unsigned n;
        unsigned j;
        int m;
        unsigned c1;

        nbits = 0;
        f = 0;

        new_symbol_count = MAX_SYM;
        m = save_state [string_start].mod.match_level;
        start_context = save_state [string_start].mod;

/*
        Accumulate switch characters for default context
        Include start of string symbol
*/

        do
        {
                new_symbol_count -= start_context.order_sym_count [m];

                c1 = start_context.order_cum_freq [m];
                n = switch_char_freq (start_context.order_sym_count [m], c1);

                update_bit_len (n, c1 + n, &nbits, &f);
        } while (-- m > 0);

        c1 = start_context.order_cum_freq [0];
        update_bit_len (1, c1, &nbits, &f);

/*
        Include string length
*/

        nbits += 6;
        if (string_len - MIN_STR >= 63) nbits += 8;

/*
        Calculate relative location of start of string
        Output as bit count and offset
*/

        update_bit_len (1, max_pos_size, &nbits, &f);

        i = string_pos + string_len;
        if (i >= MAX_DICT) i -= NDICT;
        j = i < node ? node - i - 1 : node + NDICT - 1 - i;
        nbits += log2 (j);

        return CodeLength (&save_state [string_start].cs) - nbits;
}



/*
        Generate coded symbols for text substring
        Used when string length is less length used by actual symbols
*/

static void replace_text_string (void)

{
        struct model start_context;
        unsigned n;
        unsigned i, j;

        RestoreCoderState (&save_state [string_start].cs);

        new_symbol_count = MAX_SYM;
        start_context = save_state [string_start].mod;

/*
        Output switch codes for default context and start string symbol
*/

        start_context.match_level = 0;
        start_context.base_count = start_context.order_cum_freq [0] - 1;
        start_context.sym_freq = 1;

        encode_symbol (&start_context);

/*
        Output string length
*/
        n = string_len - MIN_STR;
        if (n < MAX_STR_CODE - 1)
                generate_value (n, MAX_STR_CODE);
        else
        {
                generate_value (MAX_STR_CODE - 1, MAX_STR_CODE);
                generate_value (n + 1 - MAX_STR_CODE, 256);
        }

/*
        Determine relative location of start of string
*/

        i = string_pos + string_len;
        if (i >= MAX_DICT) i -= NDICT;
        j = i < node ? node - i - 1 : node - i - 1 + NDICT;
        n = 2;
        if (j < 2)
                i = 0;
        else
        {
                for (i = 1; 2 * n <= j && n < 0x8000; i ++, n <<= 1);
                j -= n;
        }

/*
        Output bit length of relative string location
*/

        generate_value (i, max_pos_size);

/*
        Output string location in 8 bit pices if required
*/

        if (i > 8)
        {
                generate_value (j & 0xFF, 256);
                j >>= 8;
                n >>= 8;
        }

        generate_value (j, n);
}


/*
        Scale frequency tables if total cumulative frequency exceeds maximum
        Also recalculates frequencies for current input symbol
*/

static void scale_freq_tbl (int order, int ch)

{
        int i;
        unsigned cfreq;
        unsigned t;

        i = 0;
        cfreq = 0;

        if (level [ch] == order)
        {
                for (; i < ch; i ++)
                {
                        if (level [i] == order)
                        {
                                t = (freq [i] + 1) >> 1;
                                freq [i] = t;
                                cfreq += t;
                        }
                }

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩欧美一区中文| 蜜臀av一级做a爰片久久| 国产河南妇女毛片精品久久久| 欧美一区二区三区在线看 | 欧美一区二区三区系列电影| 亚洲大片一区二区三区| 欧美疯狂性受xxxxx喷水图片| 视频一区在线播放| 日韩免费在线观看| 国产精品一区久久久久| 中文字幕成人网| 99国产精品一区| 亚洲成人av一区二区| 日韩一级二级三级精品视频| 国内精品国产三级国产a久久| 久久久国际精品| 91视视频在线直接观看在线看网页在线看| 一区二区免费看| 日韩三级在线观看| 成人免费av资源| 午夜av一区二区三区| 精品国产精品网麻豆系列| 成人h精品动漫一区二区三区| 亚洲午夜在线视频| 精品国产乱码久久久久久免费 | 亚洲欧美区自拍先锋| 欧美日韩第一区日日骚| 国产一区二区三区免费看| 日韩美女视频一区二区| 日韩精品一区二| 99久久伊人精品| 日韩精品视频网站| 国产精品久久久久影院色老大| 在线综合+亚洲+欧美中文字幕| 精品一二三四区| 亚洲午夜久久久久久久久久久| 精品国产乱码久久| 欧美丰满嫩嫩电影| 不卡电影一区二区三区| 青青草国产成人av片免费| 日韩一区在线看| 精品久久久久久无| 欧美日韩一本到| 成人丝袜18视频在线观看| 美腿丝袜一区二区三区| 一区二区三区在线免费播放 | 国产精品久久久久久久裸模| 3d动漫精品啪啪一区二区竹菊| av成人老司机| 国产尤物一区二区在线| 日本欧美肥老太交大片| 亚洲精品国产精品乱码不99 | ●精品国产综合乱码久久久久| 精品少妇一区二区三区在线播放| 在线观看一区不卡| 99国产精品久久久久久久久久久| 韩国v欧美v日本v亚洲v| 日本aⅴ免费视频一区二区三区| 亚洲综合999| 亚洲天堂2014| 国产精品久久久久久久午夜片| 久久这里都是精品| 日韩欧美国产电影| 欧美日韩日本视频| 欧美亚洲综合色| 色噜噜狠狠色综合欧洲selulu| 成人动漫在线一区| 成人美女在线观看| 不卡一二三区首页| 不卡欧美aaaaa| 99久久精品国产网站| av亚洲产国偷v产偷v自拍| 懂色中文一区二区在线播放| 国产伦精品一区二区三区免费迷| 久久综合综合久久综合| 日本欧美一区二区三区| 日韩av一区二区三区| 丝袜诱惑亚洲看片| 秋霞影院一区二区| 久久精品国产澳门| 国产伦理精品不卡| 国产成人精品亚洲午夜麻豆| 国产电影一区在线| 成人高清在线视频| 色婷婷av一区二区三区软件| 欧美在线观看一二区| 欧美美女一区二区三区| 欧美一级电影网站| 久久综合色之久久综合| 国产色爱av资源综合区| 亚洲欧洲日韩在线| 亚洲福利一二三区| 精一区二区三区| 粗大黑人巨茎大战欧美成人| 色婷婷av一区二区| 69成人精品免费视频| 久久综合久久鬼色中文字| 欧美激情在线看| 亚洲大片在线观看| 国产一区久久久| 91成人免费在线视频| 欧美一区二区三区四区高清| 久久精品一区二区三区不卡| 亚洲欧洲另类国产综合| 调教+趴+乳夹+国产+精品| 九色综合狠狠综合久久| 91蝌蚪国产九色| 日韩欧美不卡一区| 中文字幕中文字幕在线一区 | 久久99蜜桃精品| 99综合影院在线| 91精品久久久久久蜜臀| 欧美国产精品专区| 亚洲成国产人片在线观看| 国产一区二区调教| 欧美午夜精品久久久久久孕妇 | 中文字幕一区二区三区不卡| 爽好久久久欧美精品| 成人免费视频一区二区| 欧美日韩亚州综合| 日本一区二区不卡视频| 日韩国产精品91| caoporen国产精品视频| 欧美一区二区三区系列电影| 最新中文字幕一区二区三区| 精品一区二区精品| 欧美日韩中文字幕一区二区| 中文字幕久久午夜不卡| 免费人成精品欧美精品| 色综合天天天天做夜夜夜夜做| 精品剧情在线观看| 亚洲国产成人av好男人在线观看| 国产成人在线视频网站| 91精品国产综合久久精品app| 中文字幕一区二区三中文字幕| 美女一区二区视频| 欧美日高清视频| 亚洲三级久久久| 成人午夜在线视频| www激情久久| 午夜精彩视频在线观看不卡| 成人午夜av电影| 久久久久久免费网| 麻豆国产一区二区| 欧美日韩在线亚洲一区蜜芽| 自拍偷在线精品自拍偷无码专区 | 欧美性大战久久| 国产精品成人在线观看| 国产精品888| 久久五月婷婷丁香社区| 麻豆精品在线播放| 欧美夫妻性生活| 天天亚洲美女在线视频| 精品视频色一区| 亚洲va中文字幕| 欧美性xxxxx极品少妇| 亚洲精品日韩一| 日本精品一区二区三区高清 | 成人黄色网址在线观看| 2021久久国产精品不只是精品| 日韩av电影免费观看高清完整版 | 中文字幕在线不卡一区| 国产精品一二三四| 欧美激情一区二区三区在线| 国产福利91精品| 中文字幕av一区二区三区| 国产suv精品一区二区6| 国产欧美日韩不卡免费| 成人性生交大片免费看中文| 日本一区二区免费在线| 99久久久国产精品免费蜜臀| 成人欧美一区二区三区黑人麻豆 | 国产成人在线视频网站| 欧美激情在线免费观看| 不卡在线观看av| 亚洲伦理在线精品| 欧美视频在线一区二区三区 | 亚洲夂夂婷婷色拍ww47| 在线不卡免费欧美| 轻轻草成人在线| 久久天天做天天爱综合色| 国产成人综合在线播放| 中文字幕国产一区| 在线中文字幕一区| 天天做天天摸天天爽国产一区| 日韩精品一区二区三区在线| 久久精品国产秦先生| 国产日韩精品一区二区三区在线| 不卡视频一二三| 亚洲一区二区在线观看视频 | 一色桃子久久精品亚洲| 日本道在线观看一区二区| 亚洲一区日韩精品中文字幕| 91精品国产一区二区人妖| 国产成人亚洲综合a∨猫咪| 1024成人网| 欧美一区二区网站| 国产乱妇无码大片在线观看| 亚洲色图制服诱惑| 欧美精品tushy高清|