56 lines
1.2 KiB
Java
56 lines
1.2 KiB
Java
package SevenZip.Compression.RangeCoder;
|
|
|
|
public class BitTreeDecoder
|
|
{
|
|
short[] Models;
|
|
int NumBitLevels;
|
|
|
|
public BitTreeDecoder(int numBitLevels)
|
|
{
|
|
NumBitLevels = numBitLevels;
|
|
Models = new short[1 << numBitLevels];
|
|
}
|
|
|
|
public void Init()
|
|
{
|
|
Decoder.InitBitModels(Models);
|
|
}
|
|
|
|
public int Decode(Decoder rangeDecoder) throws java.io.IOException
|
|
{
|
|
int m = 1;
|
|
for (int bitIndex = NumBitLevels; bitIndex != 0; bitIndex--)
|
|
m = (m << 1) + rangeDecoder.DecodeBit(Models, m);
|
|
return m - (1 << NumBitLevels);
|
|
}
|
|
|
|
public int ReverseDecode(Decoder rangeDecoder) throws java.io.IOException
|
|
{
|
|
int m = 1;
|
|
int symbol = 0;
|
|
for (int bitIndex = 0; bitIndex < NumBitLevels; bitIndex++)
|
|
{
|
|
int bit = rangeDecoder.DecodeBit(Models, m);
|
|
m <<= 1;
|
|
m += bit;
|
|
symbol |= (bit << bitIndex);
|
|
}
|
|
return symbol;
|
|
}
|
|
|
|
public static int ReverseDecode(short[] Models, int startIndex,
|
|
Decoder rangeDecoder, int NumBitLevels) throws java.io.IOException
|
|
{
|
|
int m = 1;
|
|
int symbol = 0;
|
|
for (int bitIndex = 0; bitIndex < NumBitLevels; bitIndex++)
|
|
{
|
|
int bit = rangeDecoder.DecodeBit(Models, startIndex + m);
|
|
m <<= 1;
|
|
m += bit;
|
|
symbol |= (bit << bitIndex);
|
|
}
|
|
return symbol;
|
|
}
|
|
}
|