All Downloads are FREE. Search and download functionalities are using the official Maven repository.

htsjdk.samtools.cram.compression.rans.Decoding Maven / Gradle / Ivy

There is a newer version: 4.1.3
Show newest version
package htsjdk.samtools.cram.compression.rans;

import java.nio.ByteBuffer;

@SuppressWarnings("SameParameterValue")
class Decoding {

    static class FC {
        int F, C;
    }

    static class AriDecoder {
        final FC[] fc = new FC[256];
        byte[] R;
    }

    static class RansDecSymbol {
        int start; // Start of range.
        int freq; // Symbol frequency.
    }

    // Initialize a decoder symbol to start "start" and frequency "freq"
    static void RansDecSymbolInit(final RansDecSymbol symbol, final int start, final int freq) {
        assert (start <= (1 << 16));
        assert (freq <= (1 << 16) - start);
        symbol.start = start;
        symbol.freq = freq;
    }

    // Advances in the bit stream by "popping" a single symbol with range start
    // "start" and frequency "freq". All frequencies are assumed to sum to
    // "1 << scale_bits".
    // No renormalization or output happens.
    private static int RansDecAdvanceStep(final int r, final int start, final int freq, final int scale_bits) {
        final int mask = ((1 << scale_bits) - 1);

        // s, x = D(x)
        return freq * (r >> scale_bits) + (r & mask) - start;
    }

    // Equivalent to RansDecAdvanceStep that takes a symbol.
    static int RansDecAdvanceSymbolStep(final int r, final RansDecSymbol sym, final int scale_bits) {
        return RansDecAdvanceStep(r, sym.start, sym.freq, scale_bits);
    }

    // Returns the current cumulative frequency (map it to a symbol yourself!)
    static int RansDecGet(final int r, final int scale_bits) {
        return r & ((1 << scale_bits) - 1);
    }

    // Equivalent to RansDecAdvance that takes a symbol.
    static int RansDecAdvanceSymbol(final int r, final ByteBuffer pptr, final RansDecSymbol sym,
                                    final int scale_bits) {
        return Decoding
                .RansDecAdvance(r, pptr, sym.start, sym.freq, scale_bits);
    }

    // Advances in the bit stream by "popping" a single symbol with range start
    // "start" and frequency "freq". All frequencies are assumed to sum to
    // "1 << scale_bits",
    // and the resulting bytes get written to ptr (which is updated).
    private static int RansDecAdvance(int r, final ByteBuffer pptr, final int start, final int freq,
                                      final int scale_bits) {
        final int mask = (1 << scale_bits) - 1;

        // s, x = D(x)
        r = freq * (r >> scale_bits) + (r & mask) - start;

        // re-normalize
        if (r < Constants.RANS_BYTE_L) {
            do {
                final int b = 0xFF & pptr.get();
                r = (r << 8) | b;
            } while (r < Constants.RANS_BYTE_L);

        }

        return r;
    }

    // Re-normalize.
    static int RansDecRenormalize(int r, final ByteBuffer pptr) {
        // re-normalize
        if (r < Constants.RANS_BYTE_L) {
            do
                r = (r << 8) | (0xFF & pptr.get());
            while (r < Constants.RANS_BYTE_L);
        }

        return r;
    }

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy