BigInteger.
 Densely packed decimals are encoded in groups of three digits, which are encoded in 10 bits per group.
See: A Summary of Densely Packed Decimal encoding
The implementation is tied to the needs of the IEEE-754 decimal encoding and decoding of this library, so it may be quirky for other purposes.
 This implementation can be made to behave as for n * 3 digits by
 constructing it for n * 3 + 1 digits and calling
 decodeValue(int, int, byte[]) with 0 for the second
 parameter (firstDigit).
 
- Author:
- Mark Rotteveel
- 
Constructor SummaryConstructorsConstructorDescriptionDenselyPackedDecimalCodec(int numberOfDigits) Creates a densely packed decimal coder for the specified number of digits.
- 
Method SummaryModifier and TypeMethodDescriptiondecodeValue(int signum, int firstDigit, byte[] decBytes) Decodes a densely packed decimal from a byte array to aBigInteger.decodeValue(int signum, int firstDigit, byte[] decBytes, int lsbIndex) Decodes a densely packed decimal from a byte array to aBigInteger.intencodeValue(BigInteger value, byte[] decBytes) Encodes aBigIntegerto a densely packed decimal in a byte array.intencodeValue(BigInteger value, byte[] decBytes, int lsbIndex) Encodes aBigIntegerto a densely packed decimal in a byte array.
- 
Constructor Details- 
DenselyPackedDecimalCodecpublic DenselyPackedDecimalCodec(int numberOfDigits) Creates a densely packed decimal coder for the specified number of digits.Current implementation only supports decoding and encoding n * 3 + 1number of digits withn > 0, where the most significant digit is provided by the caller during decoding.- Parameters:
- numberOfDigits- Number of digits that this coder will decode or encode
- Throws:
- IllegalArgumentException- When- numberOfDigitsis not- n * 3 + 1with- n > 0
 
 
- 
- 
Method Details- 
decodeValueDecodes a densely packed decimal from a byte array to aBigInteger.Digits are read from the end of the array to the front. - Parameters:
- signum- Signum value (values other than- Signum.NEGATIVEare considered positive!)
- firstDigit- First, most significant, digit (- 0 <= firstDigit <= 9)
- decBytes- Byte array with the densely packed decimal, with the least significant byte at index- length - 1
- Returns:
- A BigIntegerwith the decoded value
- Throws:
- IllegalArgumentException- When- firstDigitis out of range, or- decBytesis too small for the necessary number of bytes
- See Also:
 
- 
decodeValueDecodes a densely packed decimal from a byte array to aBigInteger.Digits are read from lsbIndexof the array to the front.- Parameters:
- signum- Signum value (values other than- Signum.NEGATIVEare considered positive!)
- firstDigit- First, most significant, digit (- 0 <= firstDigit <= 9)
- decBytes- Byte array with the densely packed decimal, with the least significant byte at index- lsbIndex
- lsbIndex- Index of the least significant byte (or the last byte)
- Returns:
- A BigIntegerwith the decoded value
- Throws:
- IndexOutOfBoundsException- If- lsbIndexis not valid for- decBytes
- IllegalArgumentException- When- firstDigitis out of range, or- lsbIndexis too small for the necessary number of bytes
 
- 
encodeValueEncodes aBigIntegerto a densely packed decimal in a byte array.Digits are written from the end of the array to the front. The most significant digit is not encoded into the array, but instead returned to the caller. - Parameters:
- value-- BigIntegerwith the value to encode
- decBytes- Target byte array for the densely packed decimal, with the least significant byte to be written at index- length - 1. The implementation assumes the array is zero-filled for the bits to be populated by this method.
- Returns:
- First, most significant, digit (0 <= firstDigit <= 9) to be encoded separately
- Throws:
- IndexOutOfBoundsException- If- lsbIndexis not valid for- decBytes
- IllegalArgumentException- When- lsbIndexis too small for the necessary number of bytes
- See Also:
 
- 
encodeValueEncodes aBigIntegerto a densely packed decimal in a byte array.Digits are written from lsbIndexof the array to the front. The most significant digit is not encoded into the array, but instead returned to the caller.- Parameters:
- value-- BigIntegerwith the value to encode
- decBytes- Target byte array for the densely packed decimal, with the least significant byte to be written at index- lsbIndex. The implementation assumes the array is zero-filled for the bits to be populated by this method.
- lsbIndex- Index for the least significant byte (or the last byte)
- Returns:
- First, most significant, digit (0 <= firstDigit <= 9) to be encoded separately
- Throws:
- IndexOutOfBoundsException- If- lsbIndexis not valid for- decBytes
- IllegalArgumentException- When- lsbIndexis too small for the necessary number of bytes
 
 
-