39 #ifndef _QUANT_CHOOSER_H_ 40 #define _QUANT_CHOOSER_H_ QuantChooser(const CoeffArray &pic_data, const float lambda)
Constructor.
Choose a quantiser.
Definition: quant_chooser.h:52
OneDArray< int > m_countPOS
An array used to count the number of positive values.
Definition: quant_chooser.h:116
Class encapsulating all the metadata relating to a wavelet subband.
Definition: wavelet_utils.h:139
QuantChooser & operator=(const QuantChooser &rhs)
Assignment = is private and body-less. This class should not be assigned.
int m_bottom_idx
The smallest quantisation index being tested.
Definition: quant_chooser.h:93
int CoeffType
Type of wavelet coefficient data (should be larger than ValueType)
Definition: common.h:74
void SetSkip(CodeBlock &cblock, const int qidx)
Set the skip flag for a codeblock.
void SelectBestQuant()
Select the best quantisation index on the basis of the Lagrangian calculations.
CoeffType BlockAbsMax(const Subband &node)
A class for wavelet coefficient data.
Definition: wavelet_utils.h:622
const CoeffArray & m_coeff_data
A local reference to the data under consideration.
Definition: quant_chooser.h:103
OneDArray< CostType > m_costs
An array used to collate the computed costs.
Definition: quant_chooser.h:122
const float m_lambda
The lambda value to be used in the Lagrangian calculation.
Definition: quant_chooser.h:106
OneDArray< double > m_error_total
An array used to collate the sum of the perceptually-weighted errors.
Definition: quant_chooser.h:120
int m_index_step
The step we use in jumping through the list of quantisers.
Definition: quant_chooser.h:97
OneDArray< int > m_count0
An array used to count the number of zeroes.
Definition: quant_chooser.h:112
void SetEntropyCorrection(const float ecfac)
Sets the factor used for correcting the entropy calculation.
Definition: quant_chooser.h:63
int m_top_idx
The largest quantisation index being tested.
Definition: quant_chooser.h:95
Class for encapsulating metadata concerning a block of coefficients in a subband. ...
Definition: wavelet_utils.h:59
int m_min_idx
The index of the quantiser with the lowest cost.
Definition: quant_chooser.h:100
int GetBestQuant(Subband &node)
Finds the best quantisers for the subband, returning the predicted number of bits needed...
OneDArray< int > m_countNEG
An array used to count the number of negative values.
Definition: quant_chooser.h:118
Definition of class SequenceHeaderByteIO.
Definition: accessunit_byteio.h:51
void LagrangianCalc()
Having got statistics, calculate the Lagrangian costs.
float m_subband_wt
The perceptual weighting factor of the subband being tested.
Definition: quant_chooser.h:90
float m_entropy_correctionfactor
A value for correcting the crude calculation of the entropy.
Definition: quant_chooser.h:109
int m_count1
The number of ones (equal to the number of coefficients)
Definition: quant_chooser.h:114
void IntegralErrorCalc(Subband &node, const int xratio, const int yratio)
Calculate errors and entropies for integral-bit quantisers.
void NonIntegralErrorCalc(Subband &node, const int xratio, const int yratio)
Calculate errors and entropies for non-integral-bit quantisers.