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;
}
}