📄 tagtreeencoder.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) 2002-2005 Intel Corporation. All Rights Reserved.//////*//*// TagTreeEncoder implements tag tree coding system defined// in B.10.2 article of standard. It is used for packed header writing.//////*/#ifndef __TAGTREEENCODER_H__#define __TAGTREEENCODER_H__#include "phbitout.h"#include "tagtree.h"class TagTreeEncoder : public TagTree{public: TagTreeEncoder(); TagTreeEncoder(const TagTreeEncoder& tt); TagTreeEncoder& operator=(const TagTreeEncoder& tt); void SetValue(unsigned int n, int value) const; template<class BitOutput> bool Encode(unsigned int n, int threshold, BitOutput &out) const { Node *leaf = &m_nodes[n]; Node *stk[32 - 1]; Node **stkptr; Node *node; stkptr = stk; node = leaf; while (node->m_parent) { *stkptr++ = node; node = node->m_parent; } int low = 0; for (;;) { if (low > node->m_state) node->m_state = low; else low = node->m_state; while (low < threshold) { if (low >= node->m_value) { if (!node->m_isKnown) { out.Write1(); node->m_isKnown = 1; } break; } out.Write0(); low++; } node->m_state = low; if (stkptr == stk) break; node = *--stkptr; } return leaf->m_state < threshold; }};#endif // __TAGTREEENCODER_H__
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -