
htsjdk.samtools.cram.encoding.huffman.codec.HuffmanIntegerEncoding Maven / Gradle / Ivy
/**
* ****************************************************************************
* Copyright 2013 EMBL-EBI
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
* ****************************************************************************
*/
package htsjdk.samtools.cram.encoding.huffman.codec;
import htsjdk.samtools.cram.encoding.BitCodec;
import htsjdk.samtools.cram.encoding.Encoding;
import htsjdk.samtools.cram.io.ExposedByteArrayOutputStream;
import htsjdk.samtools.cram.io.ITF8;
import htsjdk.samtools.cram.structure.EncodingID;
import htsjdk.samtools.cram.structure.EncodingParams;
import java.io.InputStream;
import java.nio.ByteBuffer;
import java.util.Arrays;
import java.util.Map;
public class HuffmanIntegerEncoding implements Encoding {
private static final EncodingID ENCODING_ID = EncodingID.HUFFMAN;
private int[] bitLengths;
private int[] values;
private final ByteBuffer buf = ByteBuffer.allocate(1024 * 10);
public HuffmanIntegerEncoding() {
}
@Override
public EncodingID id() {
return ENCODING_ID;
}
@Override
public byte[] toByteArray() {
buf.clear();
ITF8.writeUnsignedITF8(values.length, buf);
for (final int value : values)
ITF8.writeUnsignedITF8(value, buf);
ITF8.writeUnsignedITF8(bitLengths.length, buf);
for (final int value : bitLengths)
ITF8.writeUnsignedITF8(value, buf);
buf.flip();
final byte[] array = new byte[buf.limit()];
buf.get(array);
return array;
}
@Override
public void fromByteArray(final byte[] data) {
final ByteBuffer buf = ByteBuffer.wrap(data);
int size = ITF8.readUnsignedITF8(buf);
values = new int[size];
for (int i = 0; i < size; i++)
values[i] = ITF8.readUnsignedITF8(buf);
size = ITF8.readUnsignedITF8(buf);
bitLengths = new int[size];
for (int i = 0; i < size; i++)
bitLengths[i] = ITF8.readUnsignedITF8(buf);
}
@Override
public BitCodec buildCodec(final Map inputMap,
final Map outputMap) {
return new CanonicalHuffmanIntegerCodec(values, bitLengths);
}
public static EncodingParams toParam(final int[] bfValues, final int[] bfBitLens) {
final HuffmanIntegerEncoding e = new HuffmanIntegerEncoding();
e.values = bfValues;
e.bitLengths = bfBitLens;
return new EncodingParams(ENCODING_ID, e.toByteArray());
}
@Override
public boolean equals(final Object obj) {
if (obj instanceof HuffmanIntegerEncoding) {
final HuffmanIntegerEncoding foe = (HuffmanIntegerEncoding) obj;
return Arrays.equals(bitLengths, foe.bitLengths) && Arrays.equals(values, foe.values);
}
return false;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy