Dirac - A Video Codec

Created by the British Broadcasting Corporation.


dirac::ArithCodec< T > Class Template Reference

Abstract binary arithmetic coding class. More...

#include <arith_codec.h>

Inheritance diagram for dirac::ArithCodec< T >:

Inheritance graph
[legend]
Collaboration diagram for dirac::ArithCodec< T >:

Collaboration graph
[legend]
List of all members.

Public Member Functions

Protected Types

Protected Member Functions

Protected Attributes

Static Protected Attributes

Private Member Functions

Private Attributes

Classes


Detailed Description

template<class T>
class dirac::ArithCodec< T >

This is an abtract binary arithmetic encoding class, used as the base for concrete classes that encode motion vectors and subband residues.
Parameters:
T a container (most probably, or array) type


Member Typedef Documentation

template<class T>
typedef uint32_t dirac::ArithCodec< T >::calc_t [protected]
 

template<class T>
typedef uint16_t dirac::ArithCodec< T >::code_t [protected]
 


Constructor & Destructor Documentation

template<class T>
dirac::ArithCodec< T >::ArithCodec BasicOutputManager bits_out,
size_t  number_of_contexts
 

Creates an ArithCodec object to decode input based on a set of parameters.

Parameters:
bits_out output for encoded bits
number_of_contexts the number of contexts used

template<class T>
dirac::ArithCodec< T >::ArithCodec BitInputManager bits_in,
size_t  number_of_contexts
 

Creates an ArithCodec object to decode input based on a set of parameters.

Parameters:
bits_in source of bits to be decoded
number_of_contexts the number of contexts used

template<class T>
dirac::ArithCodec< T >::~ArithCodec  )  [virtual]
 

Destructor is virtual as this class is abstract.

template<class T>
dirac::ArithCodec< T >::ArithCodec const ArithCodec< T > &  cpy  )  [private]
 


Member Function Documentation

template<class T>
int dirac::ArithCodec< T >::Compress T &  in_data  ) 
 

Compress takes a type T object (a container or array) and compresses it using the abstract function DoWorkCode() which is overridden in subclasses. It returns the number of bits written.

Parameters:
in_data the input to be compressed. Non-const, since the compression may be lossy.

template<class T>
bool dirac::ArithCodec< T >::DecodeSymbol const int  context_num  )  [inline, protected]
 

template<class T>
void dirac::ArithCodec< T >::Decompress T &  out_data,
const int  num_bytes
 

Decompresses the bitstream, up to the number of bytes specified and writes into the output subclasses.

Parameters:
out_data the output into which the decompressed data is written.
num_bytes the number of bytes to be read from the bitstream.

template<class T>
virtual void dirac::ArithCodec< T >::DoWorkCode T &  in_data  )  [protected, pure virtual]
 

Implemented in dirac::BandCodec, dirac::LFBandCodec, dirac::IntraDCBandCodec, and dirac::MvDataCodec.

template<class T>
virtual void dirac::ArithCodec< T >::DoWorkDecode T &  out_data  )  [protected, pure virtual]
 

Implemented in dirac::BandCodec, dirac::LFBandCodec, dirac::IntraDCBandCodec, and dirac::MvDataCodec.

template<class T>
void dirac::ArithCodec< T >::EncodeProbInterval const ProbInterval prob_interval,
const calc_t  range
[protected]
 

template<class T>
void dirac::ArithCodec< T >::EncodeSymbol const bool  symbol,
const int  context_num
[inline, protected]
 

template<class T>
void dirac::ArithCodec< T >::FlushEncoder  )  [protected]
 

template<class T>
virtual void dirac::ArithCodec< T >::InitContexts  )  [protected, pure virtual]
 

Implemented in dirac::BandCodec, and dirac::MvDataCodec.

template<class T>
void dirac::ArithCodec< T >::InitDecoder  )  [protected]
 

template<class T>
void dirac::ArithCodec< T >::InitEncoder  )  [protected]
 

template<class T>
bool dirac::ArithCodec< T >::InputBit  )  [inline, private]
 

template<class T>
ArithCodec& dirac::ArithCodec< T >::operator= const ArithCodec< T > &  rhs  )  [private]
 

template<class T>
void dirac::ArithCodec< T >::ReadAllData  )  [private]
 

template<class T>
void dirac::ArithCodec< T >::RemFromStream const ProbInterval prob_interval,
const calc_t  range
[protected]
 

template<class T>
virtual void dirac::ArithCodec< T >::ResetAll  )  [protected, pure virtual]
 

Implemented in dirac::BandCodec, and dirac::MvDataCodec.

template<class T>
void dirac::ArithCodec< T >::Update const bool  symbol,
const int  context_num
[inline, protected]
 


Member Data Documentation

template<class T>
const code_t dirac::ArithCodec< T >::CODE_2ND_MSB = ((0xffff + 1) >> 2) [static, protected]
 

template<class T>
const code_t dirac::ArithCodec< T >::CODE_MAX = 0xffff [static, protected]
 

template<class T>
const code_t dirac::ArithCodec< T >::CODE_MSB = ((0xffff + 1) >> 1) [static, protected]
 

template<class T>
int dirac::ArithCodec< T >::m_bit_count [private]
 

template<class T>
BitInputManager* dirac::ArithCodec< T >::m_bit_input [private]
 

template<class T>
BasicOutputManager* dirac::ArithCodec< T >::m_bit_output [private]
 

template<class T>
code_t dirac::ArithCodec< T >::m_code [private]
 

template<class T>
std::vector<Context> dirac::ArithCodec< T >::m_context_list [protected]
 

template<class T>
char* dirac::ArithCodec< T >::m_data_ptr [private]
 

template<class T>
char* dirac::ArithCodec< T >::m_decode_data_ptr [private]
 

template<class T>
code_t dirac::ArithCodec< T >::m_high_code [private]
 

template<class T>
int dirac::ArithCodec< T >::m_input_bits_left [private]
 

template<class T>
code_t dirac::ArithCodec< T >::m_low_code [private]
 

template<class T>
int dirac::ArithCodec< T >::m_max_count [private]
 

template<class T>
int dirac::ArithCodec< T >::m_underflow [private]
 


The documentation for this class was generated from the following file:

© 2004 British Broadcasting Corporation. Dirac code licensed under the Mozilla Public License (MPL) Version 1.1.
HTML documentation generated by Dimitri van Heesch's excellent Doxygen tool.