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

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

?? model.hpp

?? 一個本地database引擎,支持中文T_Sql查詢,兼容DELPHI標準數據庫控件
?? HPP
?? 第 1 頁 / 共 2 頁
字號:
/****************************************************************************
 *  This file is part of PPMd project                                       *
 *  Written and distributed to public domain by Dmitry Shkarin 1997,        *
 *  1999-2000                                                               *
 *  Contents: model description and encoding/decoding routines              *
 ****************************************************************************/

#pragma hdrstop
#include "Coder.hpp"

const int INT_BITS=7, PERIOD_BITS=7, MAX_FREQ=124;
const int INTERVAL=1 << INT_BITS, BIN_SCALE=INTERVAL << PERIOD_BITS;

#pragma pack(1)
static struct SEE2_CONTEXT { // SEE-contexts for PPM-contexts with masked symbols
    WORD Summ;
    BYTE Shift, Count;
    void init(int InitVal) { Summ=InitVal << (Shift=PERIOD_BITS-4); Count=3; }
    UINT getMean() {
        UINT RetVal=Summ >> Shift;          Summ -= RetVal;
        RetVal &= 0x03FF;                   return RetVal+(RetVal == 0);
    }
    void update() {
        if (Shift < PERIOD_BITS && --Count == 0) {
            Summ += Summ;                   Count=3 << Shift++;
        }
    }
} _PACK_ATTR SEE2Cont[44][8];
static struct PPM_CONTEXT {
//class PPM_CONTEXT {
//public:
    WORD NumStats,SummFreq;                     // sizeof(WORD) > sizeof(BYTE)
    struct STATE { BYTE Symbol, Freq; PPM_CONTEXT* Successor; } _PACK_ATTR * Stats;
    PPM_CONTEXT* Suffix;
    inline PPM_CONTEXT(STATE* pStats, PPM_CONTEXT* ShorterContext);
    inline PPM_CONTEXT();
    inline void encodeBinSymbol(int symbol);    // MaxOrder:
    inline void   encodeSymbol1(int symbol);    //  ABCD    context
    inline void   encodeSymbol2(int symbol);    //   BCD    suffix
    inline void           decodeBinSymbol();    //   BCDE   successor
    inline void             decodeSymbol1();    // other orders:
    inline void             decodeSymbol2();    //   BCD    context
    inline void           update1(STATE* p);    //    CD    suffix
    inline void           update2(STATE* p);    //   BCDE   successor
    void                          rescale();
    inline SEE2_CONTEXT* makeEscFreq2(int Diff);
//    void* operator new(size_t ) { return AllocContext(); }
    STATE& oneState() const { return (STATE&) SummFreq; }
} _PACK_ATTR * MinContext, * MedContext, * MaxContext;
#pragma pack()

static PPM_CONTEXT::STATE* FoundState;      // found next state transition
static int NumMasked, InitEsc, OrderFall, MaxOrder;
static BYTE CharMask[256], NS2Indx[256], NS2BSIndx[256];
static BYTE EscCount, PrintCount, PrevSuccess;
static WORD BinSumm[128][16];               // binary SEE-contexts

inline PPM_CONTEXT::PPM_CONTEXT(STATE* pStats,PPM_CONTEXT* ShorterContext):
        NumStats(1), Suffix(ShorterContext) { pStats->Successor=this; }
inline PPM_CONTEXT::PPM_CONTEXT(): NumStats(0) {}
static void StartModel()
{
    int i, k;
    PPM_CONTEXT *oldMC;

    InitSubAllocator();

//    MaxContext = new PPM_CONTEXT();
    MaxContext = (PPM_CONTEXT*) AllocContext();
    MaxContext->NumStats = 0;

    MaxContext->Suffix=NULL;
    MaxContext->SummFreq=(MaxContext->NumStats=256)+1;
    MaxContext->Stats = (PPM_CONTEXT::STATE*) AllocUnitsRare(256/2);
    for (PrevSuccess=i=0;i < 256;i++) {
        MaxContext->Stats[i].Symbol=i;      MaxContext->Stats[i].Freq=1;
        MaxContext->Stats[i].Successor=NULL;
    }
    PPM_CONTEXT::STATE* p=MaxContext->Stats;
    for (OrderFall=i=1; ;i++)
    {
//        MaxContext = new PPM_CONTEXT(p,MaxContext);

     oldMC = MaxContext;
     MaxContext = (PPM_CONTEXT*) AllocContext();
     p->Successor = MaxContext;
     MaxContext->NumStats = 1;
     MaxContext->Suffix = oldMC;

        if (i == MaxOrder)                  break;
        p=&(MaxContext->oneState());
        p->Symbol = 0;                      p->Freq = 1;
    }
    MaxContext->NumStats=0;                 MedContext=MinContext=MaxContext->Suffix;
static const WORD InitBinEsc[16] = {
                0x3CDD,0x1F3F,0x59BF,0x48F3,0x5FFB,0x5545,0x63D1,0x5D9D,
                0x64A1,0x5ABC,0x6632,0x6051,0x68F6,0x549B,0x6BCA,0x3AB0, };
    for (i=0;i < 128;i++)
        for (k=0;k < 16;k++)
            BinSumm[i][k]=BIN_SCALE-InitBinEsc[k]/(i+2);
    for (i=0;i <   6;i++)                   NS2BSIndx[i]=2*i;
    for (   ;i <  50;i++)                   NS2BSIndx[i]=12;
    for (   ;i < 256;i++)                   NS2BSIndx[i]=14;
    for (i=0;i < 43;i++)
            for (k=0;k < 8;k++)             SEE2Cont[i][k].init(4*i+10);
    SEE2Cont[i][0].Shift=PERIOD_BITS;
    for (i=0;i < 4;i++)                     NS2Indx[i]=i;
    for ( ;i < 4+8;i++)                     NS2Indx[i]=4+((i-4) >> 1);
    for ( ;i < 4+8+32;i++)                  NS2Indx[i]=4+4+((i-4-8) >> 2);
    for ( ;i < 256;i++)                     NS2Indx[i]=4+4+8+((i-4-8-32) >> 3);
    memset(CharMask,0,sizeof(CharMask));    EscCount=PrintCount=1;

    return;
}
inline void StopModel() {}
void PPM_CONTEXT::rescale()
{

    int OldNS=NumStats, i=NumStats-1, Adder, EscFreq;
    STATE* p1, * p;
    for (p=FoundState;p != Stats;p--)       SWAP(p[0],p[-1]);
    Stats->Freq += 4;                       SummFreq += 4;
    EscFreq=SummFreq-p->Freq;               Adder=(OrderFall != 0);
    SummFreq = (p->Freq=(p->Freq+Adder) >> 1);
    do {
        EscFreq -= (++p)->Freq;
        SummFreq += (p->Freq=(p->Freq+Adder) >> 1);
        if (p[0].Freq > p[-1].Freq) {
            STATE tmp=*(p1=p);
            do { p1[0]=p1[-1]; } while (--p1 != Stats && tmp.Freq > p1[-1].Freq);
            *p1=tmp;
        }
    } while ( --i );
    if (p->Freq == 0) {
        do { i++; } while ((--p)->Freq == 0);
        EscFreq += i;
        if ((NumStats -= i) == 1) {
            STATE tmp=*Stats;
            do { tmp.Freq-=(tmp.Freq >> 1); EscFreq>>=1; } while (EscFreq > 1);
            FreeUnits(Stats,(OldNS+1) >> 1);
            *(FoundState=&oneState())=tmp;  return;
        }
    }
    SummFreq += (EscFreq -= (EscFreq >> 1));
    int n0=(OldNS+1) >> 1, n1=(NumStats+1) >> 1;
    if (n0 != n1)
            Stats=(STATE*)ShrinkUnits(Stats,n0,n1);
    FoundState=Stats;

}
static BOOL MakeRoot(UINT SkipCount,PPM_CONTEXT::STATE* p1)
{
    PPM_CONTEXT* oldPC;
    PPM_CONTEXT* pc=MinContext, * UpBranch=FoundState->Successor;
    PPM_CONTEXT::STATE* p, * ps[MAX_O], ** pps=ps;
    if (SkipCount == 0) {
        *pps++ = FoundState;
        if ( !pc->Suffix )                  goto NO_LOOP;
    } else if (SkipCount == 2)              pc=pc->Suffix;
    if ( p1 ) {
        p=p1;                               pc=pc->Suffix;
        goto LOOP_ENTRY;
    }
    do {
        pc=pc->Suffix;
        if (pc->NumStats != 1) {
            if ((p=pc->Stats)->Symbol != FoundState->Symbol)
                do { p++; } while (p->Symbol != FoundState->Symbol);
        } else                              p=&(pc->oneState());
LOOP_ENTRY:
        if (p->Successor != UpBranch) {
            pc=p->Successor;                break;
        }
        *pps++ = p;
    } while ( pc->Suffix );
NO_LOOP:


    PPM_CONTEXT::STATE& UpState=UpBranch->oneState();

    if (pc->NumStats != 1)
    {
        UINT cf=UpState.Symbol;
        if ((p=pc->Stats)->Symbol != cf)
                do
                { p++; }
                while (p->Symbol != cf);
        UINT s0=pc->SummFreq-pc->NumStats-(cf=p->Freq-1);
        UpState.Freq=1+((2*cf <= s0)?(5*cf > s0):((2*cf+3*s0-1)/(2*s0)));
    }
    else
     UpState.Freq=pc->oneState().Freq;

    while (--pps >= ps)
    {

//        pc = new PPM_CONTEXT(*pps,pc);

     oldPC = pc;
     pc = (PPM_CONTEXT*) AllocContext();
     (PPM_CONTEXT*)(*pps)->Successor = pc;
     pc->NumStats = 1;
     pc->Suffix = oldPC;

          if ( !pc )
           return FALSE;

        pc->oneState()=UpState;
    }

    if ( !OrderFall )
    {
        UpBranch->NumStats=1;
        UpBranch->Suffix=pc;
    }

    return TRUE;
}
static void UpdateModel()
{

    PPM_CONTEXT::STATE fs=*FoundState, * p, *p1=NULL;
    PPM_CONTEXT* pc, * Successor;
    UINT ns1, ns, cf, sf, s0, SkipCount=0;
    if (fs.Freq < MAX_FREQ/4 && (pc=MinContext->Suffix) != NULL) {
        if (pc->NumStats != 1) {
            if ((p1=pc->Stats)->Symbol != fs.Symbol) {
                do { p1++; } while (p1->Symbol != fs.Symbol);
                if (p1[0].Freq >= p1[-1].Freq) {
                    SWAP(p1[0],p1[-1]);     p1--;
                }
            }
            if (p1->Freq < 7*MAX_FREQ/8) {
                p1->Freq += 2;              pc->SummFreq += 2;
            }
        } else {
            p1=&(pc->oneState());           p1->Freq += (p1->Freq < 32);
        }
    }
    if (OrderFall == 0)
    {
     if ( !MakeRoot(2,NULL) )            goto RESTART_MODEL;
        MinContext=MedContext=fs.Successor; return;
    }
    else

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
2021久久国产精品不只是精品| 国产成人精品午夜视频免费 | 性欧美疯狂xxxxbbbb| 国产不卡视频一区二区三区| 精品久久久久久久久久久久久久久 | 欧美大片在线观看一区二区| 亚洲国产成人av网| 在线看一区二区| 亚洲小说欧美激情另类| 欧美无乱码久久久免费午夜一区| 一区二区在线观看免费视频播放| 99re视频精品| 亚洲色大成网站www久久九九| 91亚洲男人天堂| 亚洲免费在线视频| 91成人免费在线| 亚洲www啪成人一区二区麻豆| 欧美性极品少妇| 亚洲成人福利片| 91精品国产综合久久福利软件 | 激情综合色综合久久| 欧美sm极限捆绑bd| 国产一区二区日韩精品| 国产欧美视频在线观看| 97se亚洲国产综合在线| 一区二区三区在线视频免费观看| 在线观看区一区二| 亚洲二区在线观看| 日韩写真欧美这视频| 精品一区二区久久久| 国产三级精品三级在线专区| av欧美精品.com| 亚洲素人一区二区| 在线免费一区三区| 蜜臀精品一区二区三区在线观看| 日韩欧美123| 成人综合在线观看| 亚洲美女淫视频| 在线播放91灌醉迷j高跟美女| 玖玖九九国产精品| 欧美xxxxxxxx| 不卡视频一二三| 亚洲sss视频在线视频| 日韩一级黄色大片| 成人高清av在线| 亚洲欧美经典视频| 日本丰满少妇一区二区三区| 亚洲一区二区五区| 欧美成人一区二区三区在线观看| 国产精品 欧美精品| 亚洲免费三区一区二区| 欧美日本在线一区| 国产精品综合视频| 亚洲综合精品自拍| 久久综合久久鬼色中文字| 91美女在线视频| 日韩不卡在线观看日韩不卡视频| 久久久久久久精| 欧美性猛片xxxx免费看久爱| 韩国成人精品a∨在线观看| 最新国产成人在线观看| 日韩午夜电影av| 成人黄色av网站在线| 午夜精品一区二区三区电影天堂| 亚洲精品一区二区三区精华液| 99久久99久久精品免费看蜜桃| 同产精品九九九| 日本一区二区不卡视频| 欧美午夜一区二区| 国产精品88av| 日韩精品一二三四| 国产精品久久久久精k8| 91精品国产综合久久精品麻豆 | 久久av老司机精品网站导航| 日韩一区中文字幕| 精品卡一卡二卡三卡四在线| 色婷婷av久久久久久久| 国产综合色产在线精品| 亚洲一区日韩精品中文字幕| 国产午夜精品在线观看| 欧美精品久久一区二区三区| aaa欧美大片| 精品一区二区三区免费播放| 亚洲一区二区欧美日韩| 日本一区免费视频| 日韩免费高清av| 欧美色爱综合网| 国产另类ts人妖一区二区| a亚洲天堂av| 欧美日韩三级一区二区| 欧美成人a视频| 亚洲免费av网站| 国产69精品久久99不卡| 欧美影院一区二区三区| 久久先锋影音av鲁色资源网| 亚洲女同ⅹxx女同tv| 国产一区二区三区香蕉 | 久久精品在线免费观看| 亚洲午夜影视影院在线观看| 国产做a爰片久久毛片| 在线免费视频一区二区| 国产亚洲欧美日韩在线一区| 一区二区三区蜜桃| 91伊人久久大香线蕉| 久久久国际精品| 91免费观看在线| 精品国产sm最大网站免费看| 亚洲美女视频在线观看| 日韩国产高清影视| 91在线观看高清| 精品成人私密视频| 色悠悠久久综合| 国产精品一区二区91| 99久久精品国产精品久久| 免费高清在线一区| 日韩精品久久久久久| 亚洲一区二区视频在线观看| 成人免费小视频| 中文字幕一区日韩精品欧美| 日本一区二区三区高清不卡 | 国产91丝袜在线观看| 韩国av一区二区三区在线观看| 美国十次了思思久久精品导航| 91精品国产aⅴ一区二区| 亚洲综合一区二区三区| 91免费在线播放| 中文字幕日韩一区二区| 寂寞少妇一区二区三区| 欧美精品1区2区3区| 美女诱惑一区二区| 欧美一区二区视频在线观看2020 | 成人福利视频在线| 国产综合色在线| 日韩—二三区免费观看av| 欧美一区二区三区在线观看| 欧美女孩性生活视频| 777久久久精品| 日韩午夜在线观看视频| 精品三级av在线| 久久嫩草精品久久久久| 国产视频不卡一区| 国产欧美精品一区| 国产精品麻豆视频| 亚洲精品中文在线观看| 一二三区精品福利视频| 亚洲高清免费一级二级三级| 亚洲国产日日夜夜| 日韩中文字幕不卡| 精品一区二区三区在线视频| 国产剧情在线观看一区二区| 国产精品一二三| 99热这里都是精品| 欧美专区日韩专区| 这里只有精品视频在线观看| 日韩一卡二卡三卡国产欧美| 欧美不卡一区二区| 中文字幕巨乱亚洲| 亚洲精品亚洲人成人网| 亚洲国产美女搞黄色| 免费看日韩a级影片| 国产制服丝袜一区| 99久精品国产| 欧美嫩在线观看| 久久久久久久久久久久久夜| 国产精品国模大尺度视频| 亚洲高清视频中文字幕| 精品伊人久久久久7777人| 成人精品高清在线| 欧美三级在线视频| 久久麻豆一区二区| 中文字幕亚洲区| 亚洲gay无套男同| 国产一区二区三区四区在线观看| 99综合影院在线| 欧美色窝79yyyycom| 日韩精品在线一区| 成人免费在线视频观看| 五月综合激情日本mⅴ| 国产真实精品久久二三区| 色视频欧美一区二区三区| 日韩亚洲欧美在线观看| 日韩伦理免费电影| 美女视频网站久久| 99re成人在线| 欧美成人一区二区三区在线观看| 国产精品高清亚洲| 天堂蜜桃一区二区三区 | 午夜av一区二区三区| 国产精品亚洲午夜一区二区三区| 日本韩国一区二区三区视频| 日韩欧美的一区| 尤物在线观看一区| 国内精品久久久久影院色| 91网址在线看| 欧美大胆一级视频| 伊人性伊人情综合网| 国内精品免费在线观看| 在线观看国产91| 国产清纯白嫩初高生在线观看91 | 日日夜夜免费精品|