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

org.lwjgl.util.zstd.Zdict Maven / Gradle / Ivy

/*
 * Copyright LWJGL. All rights reserved.
 * License terms: https://www.lwjgl.org/license
 * MACHINE GENERATED FILE, DO NOT EDIT
 */
package org.lwjgl.util.zstd;

import java.nio.*;

import org.lwjgl.*;

import org.lwjgl.system.*;

import static org.lwjgl.system.Checks.*;
import static org.lwjgl.system.MemoryUtil.*;

/** Native bindings to the dictionary builder API of Zstandard (zstd). */
public class Zdict {

    public static final int
        ZDICT_CONTENTSIZE_MIN = 128,
        ZDICT_DICTSIZE_MIN    = 256;

    static { LibZstd.initialize(); }

    protected Zdict() {
        throw new UnsupportedOperationException();
    }

    // --- [ ZDICT_trainFromBuffer ] ---

    /** Unsafe version of: {@link #ZDICT_trainFromBuffer trainFromBuffer} */
    public static native long nZDICT_trainFromBuffer(long dictBuffer, long dictBufferCapacity, long samplesBuffer, long samplesSizes, int nbSamples);

    /**
     * Train a dictionary from an array of samples.
     * 
     * 

Uses {@link #ZDICT_optimizeTrainFromBuffer_cover optimizeTrainFromBuffer_cover} single-threaded, with {@code d=8} and {@code steps=4}.

* *

Samples must be stored concatenated in a single flat buffer {@code samplesBuffer}, supplied with an array of sizes {@code samplesSizes}, providing the * size of each sample, in order.

* *

The resulting dictionary will be saved into {@code dictBuffer}.

* *

Note: {@code ZDICT_trainFromBuffer()} requires about 9 bytes of memory for each input byte.

* *

Tips:

* *
    *
  • In general, a reasonable dictionary has a size of ~ 100 KB.
  • *
  • It's obviously possible to target smaller or larger ones, just by specifying different {@code dictBufferCapacity}.
  • *
  • In general, it's recommended to provide a few thousands samples, but this can vary a lot.
  • *
  • It's recommended that total size of all samples be about ~x100 times the target size of dictionary.
  • *
* * @param dictBuffer * @param samplesBuffer * @param samplesSizes * * @return size of dictionary stored into {@code dictBuffer} (≤ {@code dictBufferCapacity}) or an error code, which can be tested with {@link #ZDICT_isError isError}. */ @NativeType("size_t") public static long ZDICT_trainFromBuffer(@NativeType("void *") ByteBuffer dictBuffer, @NativeType("const void *") ByteBuffer samplesBuffer, @NativeType("const size_t *") PointerBuffer samplesSizes) { if (CHECKS) { if (DEBUG) { check(samplesBuffer, getSamplesBufferSize(samplesSizes)); } } return nZDICT_trainFromBuffer(memAddress(dictBuffer), dictBuffer.remaining(), memAddress(samplesBuffer), memAddress(samplesSizes), samplesSizes.remaining()); } // --- [ ZDICT_getDictID ] --- /** Unsafe version of: {@link #ZDICT_getDictID getDictID} */ public static native int nZDICT_getDictID(long dictBuffer, long dictSize); /** * Extracts {@code dictID}. * * @param dictBuffer * * @return zero if error (not a valid dictionary) */ @NativeType("unsigned int") public static int ZDICT_getDictID(@NativeType("const void *") ByteBuffer dictBuffer) { return nZDICT_getDictID(memAddress(dictBuffer), dictBuffer.remaining()); } // --- [ ZDICT_isError ] --- public static native int nZDICT_isError(long errorCode); @NativeType("unsigned int") public static boolean ZDICT_isError(@NativeType("size_t") long errorCode) { return nZDICT_isError(errorCode) != 0; } // --- [ ZDICT_getErrorName ] --- public static native long nZDICT_getErrorName(long errorCode); @NativeType("const char *") public static String ZDICT_getErrorName(@NativeType("size_t") long errorCode) { long __result = nZDICT_getErrorName(errorCode); return memASCII(__result); } // --- [ ZDICT_trainFromBuffer_cover ] --- /** Unsafe version of: {@link #ZDICT_trainFromBuffer_cover trainFromBuffer_cover} */ public static native long nZDICT_trainFromBuffer_cover(long dictBuffer, long dictBufferCapacity, long samplesBuffer, long samplesSizes, int nbSamples, long parameters); /** * Train a dictionary from an array of samples using the COVER algorithm. * *

Samples must be stored concatenated in a single flat buffer {@code samplesBuffer}, supplied with an array of sizes {@code samplesSizes}, providing the * size of each sample, in order.

* *

The resulting dictionary will be saved into {@code dictBuffer}.

* *

Note: {@code ZDICT_trainFromBuffer_cover()} requires about 9 bytes of memory for each input byte.

* *

Tips:

* *
    *
  • In general, a reasonable dictionary has a size of ~ 100 KB.
  • *
  • It's obviously possible to target smaller or larger ones, just by specifying different {@code dictBufferCapacity}.
  • *
  • In general, it's recommended to provide a few thousands samples, but this can vary a lot.
  • *
  • It's recommended that total size of all samples be about ~x100 times the target size of dictionary.
  • *
* * @param dictBuffer * @param samplesBuffer * @param samplesSizes * @param parameters * * @return size of dictionary stored into {@code dictBuffer} (≤ {@code dictBufferCapacity}) or an error code, which can be tested with {@link #ZDICT_isError isError}. */ @NativeType("size_t") public static long ZDICT_trainFromBuffer_cover(@NativeType("void *") ByteBuffer dictBuffer, @NativeType("const void *") ByteBuffer samplesBuffer, @NativeType("const size_t *") PointerBuffer samplesSizes, @NativeType("ZDICT_cover_params_t") ZDICTCoverParams parameters) { if (CHECKS) { if (DEBUG) { check(samplesBuffer, getSamplesBufferSize(samplesSizes)); } } return nZDICT_trainFromBuffer_cover(memAddress(dictBuffer), dictBuffer.remaining(), memAddress(samplesBuffer), memAddress(samplesSizes), samplesSizes.remaining(), parameters.address()); } // --- [ ZDICT_optimizeTrainFromBuffer_cover ] --- /** Unsafe version of: {@link #ZDICT_optimizeTrainFromBuffer_cover optimizeTrainFromBuffer_cover} */ public static native long nZDICT_optimizeTrainFromBuffer_cover(long dictBuffer, long dictBufferCapacity, long samplesBuffer, long samplesSizes, int nbSamples, long parameters); /** * The same requirements as {@link #ZDICT_trainFromBuffer_cover trainFromBuffer_cover} hold for all the parameters except {@code parameters}. * *

This function tries many parameter combinations and picks the best parameters. {@code *parameters} is filled with the best parameters found, and the * dictionary constructed with those parameters is stored in {@code dictBuffer}.

* *
    *
  • All of the parameters {@code d}, {@code k}, {@code steps} are optional.
  • *
  • If {@code d} is non-zero then we don't check multiple values of {@code }d, otherwise we check {@code d = {6, 8, 10, 12, 14, 16}}.
  • *
  • If {@code steps} is zero it defaults to its default value.
  • *
  • If {@code k} is non-zero then we don't check multiple values of {@code k}, otherwise we check steps values in {@code [16, 2048]}.
  • *
* *

Note: {@code ZDICT_optimizeTrainFromBuffer_cover()} requires about 8 bytes of memory for each input byte and additionally another 5 bytes of memory for * each byte of memory for each thread.

* * @param dictBuffer * @param samplesBuffer * @param samplesSizes * @param parameters * * @return size of dictionary stored into {@code dictBuffer} (≤ {@code dictBufferCapacity}) or an error code, which can be tested with {@link #ZDICT_isError isError}. On success * {@code *parameters} contains the parameters selected. */ @NativeType("size_t") public static long ZDICT_optimizeTrainFromBuffer_cover(@NativeType("void *") ByteBuffer dictBuffer, @NativeType("const void *") ByteBuffer samplesBuffer, @NativeType("const size_t *") PointerBuffer samplesSizes, @NativeType("ZDICT_cover_params_t *") ZDICTCoverParams parameters) { if (CHECKS) { if (DEBUG) { check(samplesBuffer, getSamplesBufferSize(samplesSizes)); } } return nZDICT_optimizeTrainFromBuffer_cover(memAddress(dictBuffer), dictBuffer.remaining(), memAddress(samplesBuffer), memAddress(samplesSizes), samplesSizes.remaining(), parameters.address()); } // --- [ ZDICT_finalizeDictionary ] --- /** Unsafe version of: {@link #ZDICT_finalizeDictionary finalizeDictionary} */ public static native long nZDICT_finalizeDictionary(long dictBuffer, long dictBufferCapacity, long dictContent, long dictContentSize, long samplesBuffer, long samplesSizes, int nbSamples, long parameters); /** * Given a custom content as a basis for dictionary, and a set of samples, finalize dictionary by adding headers and statistics. * *

Samples must be stored concatenated in a flat buffer {@code samplesBuffer}, supplied with an array of sizes {@code samplesSizes}, providing the size of * each sample in order.

* *

Notes:

* *
    *
  • {@code dictContentSize} must be ≥ {@link #ZDICT_CONTENTSIZE_MIN CONTENTSIZE_MIN} bytes.
  • *
  • {@code maxDictSize} must be ≥ {@code dictContentSize}, and must be ≥ {@link #ZDICT_DICTSIZE_MIN DICTSIZE_MIN} bytes.
  • *
  • {@code ZDICT_finalizeDictionary()} will push notifications into {@code stderr} if instructed to, using {@code notificationLevel>0}.
  • *
  • {@code dictBuffer} and {@code dictContent} can overlap.
  • *
* * @param dictBuffer * @param dictContent * @param samplesBuffer * @param samplesSizes * @param parameters * * @return size of dictionary stored into {@code dictBuffer} (≤ {@code dictBufferCapacity}) or an error code, which can be tested with {@link #ZDICT_isError isError}. */ @NativeType("size_t") public static long ZDICT_finalizeDictionary(@NativeType("void *") ByteBuffer dictBuffer, @NativeType("const void *") ByteBuffer dictContent, @NativeType("const void *") ByteBuffer samplesBuffer, @NativeType("const size_t *") PointerBuffer samplesSizes, @NativeType("ZDICT_params_t") ZDICTParams parameters) { if (CHECKS) { if (DEBUG) { check(samplesBuffer, getSamplesBufferSize(samplesSizes)); } } return nZDICT_finalizeDictionary(memAddress(dictBuffer), dictBuffer.remaining(), memAddress(dictContent), dictContent.remaining(), memAddress(samplesBuffer), memAddress(samplesSizes), samplesSizes.remaining(), parameters.address()); } private static long getSamplesBufferSize(PointerBuffer samplesSizes) { long bytes = 0L; for (int i = 0; i < samplesSizes.remaining(); i++) { bytes += samplesSizes.get(i); } return bytes; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy