⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 dprecinct.h

📁 这是在PCA下的基于IPP库示例代码例子,在网上下了IPP的库之后,设置相关参数就可以编译该代码.
💻 H
字号:
/* ////////////////////////////////////////////////////////////////////////////                  INTEL CORPORATION PROPRIETARY INFORMATION//     This software is supplied under the terms of a license agreement or//     nondisclosure agreement with Intel Corporation and may not be copied//     or disclosed except in accordance with the terms of that agreement.//          Copyright(c) 2003-2005 Intel Corporation. All Rights Reserved.//////*/#ifndef __DPRECINCT_H__#define __DPRECINCT_H__#include "dcodeblock.h"#include "tagtreedecoder.h"#include "rectgrid.h"class DPrecinct{public:    DPrecinct() {}    void Init(        const ImageCore32sC1 &precinct,        const Rect           &rect,        const RectSize       &cbStepOrder,        unsigned int          nOfLayers,        IppiWTSubband         subband,        unsigned int          cmpGuardBits,        unsigned int          sbDynRange,        unsigned int          sbLowestBitOffset,        const CBCodingStyle  &codingStyle);    template<class ByteInput>        void ReadPacketBody  (unsigned int layer, ByteInput &packetBody)    {        for(unsigned int cbIndx = 0; cbIndx < m_cbs.Size(); cbIndx++)        {            DCodeBlock &cb = m_cbs[cbIndx];            cb.DecodeLayer(layer, packetBody);        }    }    template<class ByteInput>        void ReadPacketHeader(unsigned int layer, PHBitIn<ByteInput> &phBitIn)    {        for(unsigned int cbIndx = 0; cbIndx < m_cbs.Size(); cbIndx++)        {            DCodeBlock &cb = m_cbs[cbIndx];            bool included;            if (!cb.NOfPasses())                included = m_inclTagTree.Decode(phBitIn, cbIndx, layer + 1);            else                included = phBitIn.Read();            if (!included) continue;            if (!cb.NOfPasses())            {                unsigned int zbpl = 1; for (;;)                {                    if (m_zbplTagTree.Decode(phBitIn, cbIndx, zbpl)) break;                    zbpl++;                }                cb.SetNOfZeroBits(zbpl - 1);            }            unsigned int layerNOfPasses = ReadNOfPasses(phBitIn);            if (layerNOfPasses > 0) cb.m_Lblock += ReadCommaCode(phBitIn);            unsigned int pass = cb.NOfPasses();            unsigned int nOfRemainingPasses = layerNOfPasses;            while (nOfRemainingPasses > 0)            {                unsigned int segmentNOfPasses = Min(nOfRemainingPasses,                    SegmentMaxNOfPasses(pass, m_isSelectiveMQBypass, m_isTermOnEveryPass));                unsigned int segmentLength = phBitIn.Read(cb.m_Lblock + Log2(segmentNOfPasses));                cb.SetNextSegmentSize(layer, segmentLength, segmentNOfPasses);                pass               += segmentNOfPasses;                nOfRemainingPasses -= segmentNOfPasses;            }        }    }protected:    FixedArray<DCodeBlock>   m_cbs;    TagTreeDecoder           m_inclTagTree;    TagTreeDecoder           m_zbplTagTree;    // they are stored in Init just for number of coding pass calculations in ReadPacketHeader    bool                     m_isSelectiveMQBypass;    bool                     m_isTermOnEveryPass;    static unsigned int SegmentMaxNOfPasses(unsigned int startPass, bool isSelectiveMQBypass, bool isTermOnEveryPass);    template<class ByteInput>        static unsigned int ReadNOfPasses(PHBitIn<ByteInput> &phBitIn)    {        if(!phBitIn.Read()) return 1;        if(!phBitIn.Read()) return 2;        int n = phBitIn.Read(2);        if (n != 3) return n + 3;        n = phBitIn.Read(5);        if(n != 31) return n + 6;        return phBitIn.Read(7) + 37;    }    template<class ByteInput>        static unsigned int ReadCommaCode(PHBitIn<ByteInput> &phBitIn)    {        unsigned int i = 0; for (;;)        {            if (!phBitIn.Read())  break;            i++;        }        return i;    }};#endif // __DPRECINCT_H__

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -