mirror of
https://github.com/facebook/zstd.git
synced 2025-08-05 19:15:58 +03:00
@@ -167,11 +167,13 @@
|
|||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<ClCompile Include="..\..\..\lib\common\xxhash.c" />
|
<ClCompile Include="..\..\..\lib\common\xxhash.c" />
|
||||||
<ClCompile Include="..\..\..\programs\datagen.c" />
|
<ClCompile Include="..\..\..\programs\datagen.c" />
|
||||||
|
<ClCompile Include="..\..\..\programs\bench.c" />
|
||||||
<ClCompile Include="..\..\..\tests\fullbench.c" />
|
<ClCompile Include="..\..\..\tests\fullbench.c" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<ClInclude Include="..\..\..\lib\zstd.h" />
|
<ClInclude Include="..\..\..\lib\zstd.h" />
|
||||||
<ClInclude Include="..\..\..\programs\datagen.h" />
|
<ClInclude Include="..\..\..\programs\datagen.h" />
|
||||||
|
<ClInclude Include="..\..\..\programs\bench.h" />
|
||||||
<ClInclude Include="..\..\..\programs\util.h" />
|
<ClInclude Include="..\..\..\programs\util.h" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
|
@@ -176,6 +176,7 @@
|
|||||||
<ClCompile Include="..\..\..\lib\decompress\huf_decompress.c" />
|
<ClCompile Include="..\..\..\lib\decompress\huf_decompress.c" />
|
||||||
<ClCompile Include="..\..\..\lib\decompress\zstd_decompress.c" />
|
<ClCompile Include="..\..\..\lib\decompress\zstd_decompress.c" />
|
||||||
<ClCompile Include="..\..\..\programs\datagen.c" />
|
<ClCompile Include="..\..\..\programs\datagen.c" />
|
||||||
|
<ClCompile Include="..\..\..\programs\bench.c" />
|
||||||
<ClCompile Include="..\..\..\tests\fullbench.c" />
|
<ClCompile Include="..\..\..\tests\fullbench.c" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
@@ -197,6 +198,7 @@
|
|||||||
<ClInclude Include="..\..\..\lib\legacy\zstd_legacy.h" />
|
<ClInclude Include="..\..\..\lib\legacy\zstd_legacy.h" />
|
||||||
<ClInclude Include="..\..\..\programs\datagen.h" />
|
<ClInclude Include="..\..\..\programs\datagen.h" />
|
||||||
<ClInclude Include="..\..\..\programs\util.h" />
|
<ClInclude Include="..\..\..\programs\util.h" />
|
||||||
|
<ClInclude Include="..\..\..\programs\bench.h" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" />
|
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" />
|
||||||
<ImportGroup Label="ExtensionTargets">
|
<ImportGroup Label="ExtensionTargets">
|
||||||
|
1080
programs/bench.c
1080
programs/bench.c
File diff suppressed because it is too large
Load Diff
202
programs/bench.h
202
programs/bench.h
@@ -19,25 +19,121 @@ extern "C" {
|
|||||||
#define ZSTD_STATIC_LINKING_ONLY /* ZSTD_compressionParameters */
|
#define ZSTD_STATIC_LINKING_ONLY /* ZSTD_compressionParameters */
|
||||||
#include "zstd.h" /* ZSTD_compressionParameters */
|
#include "zstd.h" /* ZSTD_compressionParameters */
|
||||||
|
|
||||||
|
/* Creates a struct of type typeName with an int type .error field
|
||||||
|
* and a .result field of some baseType. Functions with return
|
||||||
|
* typeName pass a successful result with .error = 0 and .result
|
||||||
|
* with the intended result, while returning an error will result
|
||||||
|
* in .error != 0.
|
||||||
|
*/
|
||||||
|
#define ERROR_STRUCT(baseType, typeName) typedef struct { \
|
||||||
|
baseType result; \
|
||||||
|
int error; \
|
||||||
|
} typeName
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
size_t cSize;
|
size_t cSize;
|
||||||
double cSpeed; /* bytes / sec */
|
double cSpeed; /* bytes / sec */
|
||||||
double dSpeed;
|
double dSpeed;
|
||||||
} BMK_result_t;
|
} BMK_result_t;
|
||||||
|
|
||||||
/* 0 = no Error */
|
ERROR_STRUCT(BMK_result_t, BMK_return_t);
|
||||||
typedef struct {
|
|
||||||
int errorCode;
|
|
||||||
BMK_result_t result;
|
|
||||||
} BMK_return_t;
|
|
||||||
|
|
||||||
/* called in cli */
|
/* called in cli */
|
||||||
int BMK_benchFiles(const char** fileNamesTable, unsigned nbFiles, const char* dictFileName,
|
/* Loads files in fileNamesTable into memory, as well as a dictionary
|
||||||
int cLevel, int cLevelLast, const ZSTD_compressionParameters* compressionParams,
|
* from dictFileName, and then uses benchMem */
|
||||||
|
/* fileNamesTable - name of files to benchmark
|
||||||
|
* nbFiles - number of files (size of fileNamesTable), must be > 0
|
||||||
|
* dictFileName - name of dictionary file to load
|
||||||
|
* cLevel - compression level to benchmark, errors if invalid
|
||||||
|
* compressionParams - basic compression Parameters
|
||||||
|
* displayLevel - what gets printed
|
||||||
|
* 0 : no display;
|
||||||
|
* 1 : errors;
|
||||||
|
* 2 : + result + interaction + warnings;
|
||||||
|
* 3 : + progression;
|
||||||
|
* 4 : + information
|
||||||
|
* return
|
||||||
|
* .error will give a nonzero error value if an error has occured
|
||||||
|
* .result - if .error = 0, .result will return the time taken to compression speed
|
||||||
|
* (.cSpeed), decompression speed (.dSpeed), and compressed size (.cSize) of the original
|
||||||
|
* file
|
||||||
|
*/
|
||||||
|
BMK_return_t BMK_benchFiles(const char* const * const fileNamesTable, unsigned const nbFiles,
|
||||||
|
const char* const dictFileName,
|
||||||
|
int const cLevel, const ZSTD_compressionParameters* const compressionParams,
|
||||||
int displayLevel);
|
int displayLevel);
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
BMK_timeMode = 0,
|
||||||
|
BMK_iterMode = 1
|
||||||
|
} BMK_loopMode_t;
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
BMK_both = 0,
|
||||||
|
BMK_decodeOnly = 1,
|
||||||
|
BMK_compressOnly = 2
|
||||||
|
} BMK_mode_t;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
BMK_mode_t mode; /* 0: all, 1: compress only 2: decode only */
|
||||||
|
BMK_loopMode_t loopMode; /* if loopmode, then nbSeconds = nbLoops */
|
||||||
|
unsigned nbSeconds; /* default timing is in nbSeconds */
|
||||||
|
size_t blockSize; /* Maximum allowable size of a block*/
|
||||||
|
unsigned nbWorkers; /* multithreading */
|
||||||
|
unsigned realTime; /* real time priority */
|
||||||
|
int additionalParam; /* used by python speed benchmark */
|
||||||
|
unsigned ldmFlag; /* enables long distance matching */
|
||||||
|
unsigned ldmMinMatch; /* below: parameters for long distance matching, see zstd.1.md for meaning */
|
||||||
|
unsigned ldmHashLog;
|
||||||
|
unsigned ldmBucketSizeLog;
|
||||||
|
unsigned ldmHashEveryLog;
|
||||||
|
} BMK_advancedParams_t;
|
||||||
|
|
||||||
|
/* returns default parameters used by nonAdvanced functions */
|
||||||
|
BMK_advancedParams_t BMK_initAdvancedParams(void);
|
||||||
|
|
||||||
|
/* See benchFiles for normal parameter uses and return, see advancedParams_t for adv */
|
||||||
|
BMK_return_t BMK_benchFilesAdvanced(const char* const * const fileNamesTable, unsigned const nbFiles,
|
||||||
|
const char* const dictFileName,
|
||||||
|
int const cLevel, const ZSTD_compressionParameters* const compressionParams,
|
||||||
|
int displayLevel, const BMK_advancedParams_t* const adv);
|
||||||
|
|
||||||
|
/* called in cli */
|
||||||
|
/* Generates a sample with datagen with the compressibility argument*/
|
||||||
|
/* cLevel - compression level to benchmark, errors if invalid
|
||||||
|
* compressibility - determines compressibility of sample
|
||||||
|
* compressionParams - basic compression Parameters
|
||||||
|
* displayLevel - see benchFiles
|
||||||
|
* adv - see advanced_Params_t
|
||||||
|
* return
|
||||||
|
* .error will give a nonzero error value if an error has occured
|
||||||
|
* .result - if .error = 0, .result will return the time taken to compression speed
|
||||||
|
* (.cSpeed), decompression speed (.dSpeed), and compressed size (.cSize) of the original
|
||||||
|
* file
|
||||||
|
*/
|
||||||
|
BMK_return_t BMK_syntheticTest(int cLevel, double compressibility,
|
||||||
|
const ZSTD_compressionParameters* compressionParams,
|
||||||
|
int displayLevel, const BMK_advancedParams_t * const adv);
|
||||||
|
|
||||||
/* basic benchmarking function, called in paramgrill
|
/* basic benchmarking function, called in paramgrill
|
||||||
* ctx, dctx must be valid */
|
* applies ZSTD_compress_generic() and ZSTD_decompress_generic() on data in srcBuffer
|
||||||
|
* with specific compression parameters specified by other arguments using benchFunction
|
||||||
|
* (cLevel, comprParams + adv in advanced Mode) */
|
||||||
|
/* srcBuffer - data source, expected to be valid compressed data if in Decode Only Mode
|
||||||
|
* srcSize - size of data in srcBuffer
|
||||||
|
* cLevel - compression level
|
||||||
|
* comprParams - basic compression parameters
|
||||||
|
* dictBuffer - a dictionary if used, null otherwise
|
||||||
|
* dictBufferSize - size of dictBuffer, 0 otherwise
|
||||||
|
* ctx - Compression Context (must be provided)
|
||||||
|
* dctx - Decompression Context (must be provided)
|
||||||
|
* diplayLevel - see BMK_benchFiles
|
||||||
|
* displayName - name used by display
|
||||||
|
* return
|
||||||
|
* .error will give a nonzero value if an error has occured
|
||||||
|
* .result - if .error = 0, will give the same results as benchFiles
|
||||||
|
* but for the data stored in srcBuffer
|
||||||
|
*/
|
||||||
BMK_return_t BMK_benchMem(const void* srcBuffer, size_t srcSize,
|
BMK_return_t BMK_benchMem(const void* srcBuffer, size_t srcSize,
|
||||||
const size_t* fileSizes, unsigned nbFiles,
|
const size_t* fileSizes, unsigned nbFiles,
|
||||||
const int cLevel, const ZSTD_compressionParameters* comprParams,
|
const int cLevel, const ZSTD_compressionParameters* comprParams,
|
||||||
@@ -45,20 +141,82 @@ BMK_return_t BMK_benchMem(const void* srcBuffer, size_t srcSize,
|
|||||||
ZSTD_CCtx* ctx, ZSTD_DCtx* dctx,
|
ZSTD_CCtx* ctx, ZSTD_DCtx* dctx,
|
||||||
int displayLevel, const char* displayName);
|
int displayLevel, const char* displayName);
|
||||||
|
|
||||||
/* Set Parameters */
|
/* See benchMem for normal parameter uses and return, see advancedParams_t for adv */
|
||||||
void BMK_setNbSeconds(unsigned nbLoops);
|
BMK_return_t BMK_benchMemAdvanced(const void* srcBuffer, size_t srcSize,
|
||||||
void BMK_setBlockSize(size_t blockSize);
|
const size_t* fileSizes, unsigned nbFiles,
|
||||||
void BMK_setNbWorkers(unsigned nbWorkers);
|
const int cLevel, const ZSTD_compressionParameters* comprParams,
|
||||||
void BMK_setRealTime(unsigned priority);
|
const void* dictBuffer, size_t dictBufferSize,
|
||||||
void BMK_setNotificationLevel(unsigned level);
|
ZSTD_CCtx* ctx, ZSTD_DCtx* dctx,
|
||||||
void BMK_setSeparateFiles(unsigned separate);
|
int displayLevel, const char* displayName,
|
||||||
void BMK_setAdditionalParam(int additionalParam);
|
const BMK_advancedParams_t* adv);
|
||||||
void BMK_setDecodeOnlyMode(unsigned decodeFlag);
|
|
||||||
void BMK_setLdmFlag(unsigned ldmFlag);
|
typedef struct {
|
||||||
void BMK_setLdmMinMatch(unsigned ldmMinMatch);
|
size_t sumOfReturn; /* sum of return values */
|
||||||
void BMK_setLdmHashLog(unsigned ldmHashLog);
|
U64 nanoSecPerRun; /* time per iteration */
|
||||||
void BMK_setLdmBucketSizeLog(unsigned ldmBucketSizeLog);
|
} BMK_customResult_t;
|
||||||
void BMK_setLdmHashEveryLog(unsigned ldmHashEveryLog);
|
|
||||||
|
ERROR_STRUCT(BMK_customResult_t, BMK_customReturn_t);
|
||||||
|
|
||||||
|
typedef size_t (*BMK_benchFn_t)(const void*, size_t, void*, size_t, void*);
|
||||||
|
typedef size_t (*BMK_initFn_t)(void*);
|
||||||
|
|
||||||
|
/* This function times the execution of 2 argument functions, benchFn and initFn */
|
||||||
|
|
||||||
|
/* benchFn - (*benchFn)(srcBuffers[i], srcSizes[i], dstBuffers[i], dstCapacities[i], benchPayload)
|
||||||
|
* is run nbLoops times
|
||||||
|
* initFn - (*initFn)(initPayload) is run once per benchmark at the beginning. This argument can
|
||||||
|
* be NULL, in which case nothing is run.
|
||||||
|
* blockCount - number of blocks (size of srcBuffers, srcSizes, dstBuffers, dstCapacities)
|
||||||
|
* srcBuffers - an array of buffers to be operated on by benchFn
|
||||||
|
* srcSizes - an array of the sizes of above buffers
|
||||||
|
* dstBuffers - an array of buffers to be written into by benchFn
|
||||||
|
* dstCapacities - an array of the capacities of above buffers.
|
||||||
|
* nbLoops - defines number of times benchFn is run.
|
||||||
|
* return
|
||||||
|
* .error will give a nonzero value if ZSTD_isError() is nonzero for any of the return
|
||||||
|
* of the calls to initFn and benchFn, or if benchFunction errors internally
|
||||||
|
* .result - if .error = 0, then .result will contain the sum of all return values of
|
||||||
|
* benchFn on the first iteration through all of the blocks (.sumOfReturn) and also
|
||||||
|
* the time per run of benchFn (.nanoSecPerRun). For the former, this
|
||||||
|
* is generally intended to be used on functions which return the # of bytes written
|
||||||
|
* into dstBuffer, hence this value will be the total amount of bytes written to
|
||||||
|
* dstBuffer.
|
||||||
|
*/
|
||||||
|
BMK_customReturn_t BMK_benchFunction(
|
||||||
|
BMK_benchFn_t benchFn, void* benchPayload,
|
||||||
|
BMK_initFn_t initFn, void* initPayload,
|
||||||
|
size_t blockCount,
|
||||||
|
const void* const * const srcBuffers, const size_t* srcSizes,
|
||||||
|
void* const * const dstBuffers, const size_t* dstCapacities,
|
||||||
|
unsigned nbLoops);
|
||||||
|
|
||||||
|
|
||||||
|
/* state information needed to advance computation for benchFunctionTimed */
|
||||||
|
typedef struct BMK_timeState_t BMK_timedFnState_t;
|
||||||
|
/* initializes timeState object with desired number of seconds */
|
||||||
|
BMK_timedFnState_t* BMK_createTimeState(unsigned nbSeconds);
|
||||||
|
/* resets existing timeState object */
|
||||||
|
void BMK_resetTimeState(BMK_timedFnState_t*, unsigned nbSeconds);
|
||||||
|
/* deletes timeState object */
|
||||||
|
void BMK_freeTimeState(BMK_timedFnState_t* state);
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
BMK_customReturn_t result;
|
||||||
|
int completed;
|
||||||
|
} BMK_customTimedReturn_t;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Benchmarks custom functions like BMK_benchFunction(), but runs for nbSeconds seconds rather than a fixed number of loops
|
||||||
|
* arguments mostly the same other than BMK_benchFunction()
|
||||||
|
* Usage - benchFunctionTimed will return in approximately one second. Keep calling BMK_benchFunctionTimed() until the return's completed field = 1.
|
||||||
|
* to continue updating intermediate result. Intermediate return values are returned by the function.
|
||||||
|
*/
|
||||||
|
BMK_customTimedReturn_t BMK_benchFunctionTimed(BMK_timedFnState_t* cont,
|
||||||
|
BMK_benchFn_t benchFn, void* benchPayload,
|
||||||
|
BMK_initFn_t initFn, void* initPayload,
|
||||||
|
size_t blockCount,
|
||||||
|
const void* const * const srcBlockBuffers, const size_t* srcBlockSizes,
|
||||||
|
void* const * const dstBlockBuffers, const size_t* dstBlockCapacities);
|
||||||
|
|
||||||
#endif /* BENCH_H_121279284357 */
|
#endif /* BENCH_H_121279284357 */
|
||||||
|
|
||||||
|
@@ -32,7 +32,7 @@
|
|||||||
#include <errno.h> /* errno */
|
#include <errno.h> /* errno */
|
||||||
#include "fileio.h" /* stdinmark, stdoutmark, ZSTD_EXTENSION */
|
#include "fileio.h" /* stdinmark, stdoutmark, ZSTD_EXTENSION */
|
||||||
#ifndef ZSTD_NOBENCH
|
#ifndef ZSTD_NOBENCH
|
||||||
# include "bench.h" /* BMK_benchFiles, BMK_SetNbSeconds */
|
# include "bench.h" /* BMK_benchFiles */
|
||||||
#endif
|
#endif
|
||||||
#ifndef ZSTD_NODICT
|
#ifndef ZSTD_NODICT
|
||||||
# include "dibio.h" /* ZDICT_cover_params_t, DiB_trainFromFiles() */
|
# include "dibio.h" /* ZDICT_cover_params_t, DiB_trainFromFiles() */
|
||||||
@@ -398,6 +398,8 @@ int main(int argCount, const char* argv[])
|
|||||||
setRealTimePrio = 0,
|
setRealTimePrio = 0,
|
||||||
singleThread = 0,
|
singleThread = 0,
|
||||||
ultra=0;
|
ultra=0;
|
||||||
|
double compressibility = 0.5;
|
||||||
|
BMK_advancedParams_t adv = BMK_initAdvancedParams();
|
||||||
unsigned bench_nbSeconds = 3; /* would be better if this value was synchronized from bench */
|
unsigned bench_nbSeconds = 3; /* would be better if this value was synchronized from bench */
|
||||||
size_t blockSize = 0;
|
size_t blockSize = 0;
|
||||||
zstd_operation_mode operation = zom_compress;
|
zstd_operation_mode operation = zom_compress;
|
||||||
@@ -609,7 +611,7 @@ int main(int argCount, const char* argv[])
|
|||||||
/* Decoding */
|
/* Decoding */
|
||||||
case 'd':
|
case 'd':
|
||||||
#ifndef ZSTD_NOBENCH
|
#ifndef ZSTD_NOBENCH
|
||||||
BMK_setDecodeOnlyMode(1);
|
adv.mode = BMK_decodeOnly;
|
||||||
if (operation==zom_bench) { argument++; break; } /* benchmark decode (hidden option) */
|
if (operation==zom_bench) { argument++; break; } /* benchmark decode (hidden option) */
|
||||||
#endif
|
#endif
|
||||||
operation=zom_decompress; argument++; break;
|
operation=zom_decompress; argument++; break;
|
||||||
@@ -702,11 +704,19 @@ int main(int argCount, const char* argv[])
|
|||||||
case 'p': argument++;
|
case 'p': argument++;
|
||||||
#ifndef ZSTD_NOBENCH
|
#ifndef ZSTD_NOBENCH
|
||||||
if ((*argument>='0') && (*argument<='9')) {
|
if ((*argument>='0') && (*argument<='9')) {
|
||||||
BMK_setAdditionalParam(readU32FromChar(&argument));
|
adv.additionalParam = (int)readU32FromChar(&argument);
|
||||||
} else
|
} else
|
||||||
#endif
|
#endif
|
||||||
main_pause=1;
|
main_pause=1;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
/* Select compressibility of synthetic sample */
|
||||||
|
case 'P':
|
||||||
|
{ argument++;
|
||||||
|
compressibility = (double)readU32FromChar(&argument) / 100;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
/* unknown command */
|
/* unknown command */
|
||||||
default : CLEAN_RETURN(badusage(programName));
|
default : CLEAN_RETURN(badusage(programName));
|
||||||
}
|
}
|
||||||
@@ -807,21 +817,46 @@ int main(int argCount, const char* argv[])
|
|||||||
/* Check if benchmark is selected */
|
/* Check if benchmark is selected */
|
||||||
if (operation==zom_bench) {
|
if (operation==zom_bench) {
|
||||||
#ifndef ZSTD_NOBENCH
|
#ifndef ZSTD_NOBENCH
|
||||||
BMK_setSeparateFiles(separateFiles);
|
adv.blockSize = blockSize;
|
||||||
BMK_setBlockSize(blockSize);
|
adv.nbWorkers = nbWorkers;
|
||||||
BMK_setNbWorkers(nbWorkers);
|
adv.realTime = setRealTimePrio;
|
||||||
BMK_setRealTime(setRealTimePrio);
|
adv.nbSeconds = bench_nbSeconds;
|
||||||
BMK_setNbSeconds(bench_nbSeconds);
|
adv.ldmFlag = ldmFlag;
|
||||||
BMK_setLdmFlag(ldmFlag);
|
adv.ldmMinMatch = g_ldmMinMatch;
|
||||||
BMK_setLdmMinMatch(g_ldmMinMatch);
|
adv.ldmHashLog = g_ldmHashLog;
|
||||||
BMK_setLdmHashLog(g_ldmHashLog);
|
|
||||||
if (g_ldmBucketSizeLog != LDM_PARAM_DEFAULT) {
|
if (g_ldmBucketSizeLog != LDM_PARAM_DEFAULT) {
|
||||||
BMK_setLdmBucketSizeLog(g_ldmBucketSizeLog);
|
adv.ldmBucketSizeLog = g_ldmBucketSizeLog;
|
||||||
}
|
}
|
||||||
if (g_ldmHashEveryLog != LDM_PARAM_DEFAULT) {
|
if (g_ldmHashEveryLog != LDM_PARAM_DEFAULT) {
|
||||||
BMK_setLdmHashEveryLog(g_ldmHashEveryLog);
|
adv.ldmHashEveryLog = g_ldmHashEveryLog;
|
||||||
}
|
}
|
||||||
BMK_benchFiles(filenameTable, filenameIdx, dictFileName, cLevel, cLevelLast, &compressionParams, g_displayLevel);
|
|
||||||
|
if (cLevel > ZSTD_maxCLevel()) cLevel = ZSTD_maxCLevel();
|
||||||
|
if (cLevelLast > ZSTD_maxCLevel()) cLevelLast = ZSTD_maxCLevel();
|
||||||
|
if (cLevelLast < cLevel) cLevelLast = cLevel;
|
||||||
|
if (cLevelLast > cLevel)
|
||||||
|
DISPLAYLEVEL(2, "Benchmarking levels from %d to %d\n", cLevel, cLevelLast);
|
||||||
|
if(filenameIdx) {
|
||||||
|
if(separateFiles) {
|
||||||
|
unsigned i;
|
||||||
|
for(i = 0; i < filenameIdx; i++) {
|
||||||
|
int c;
|
||||||
|
DISPLAYLEVEL(2, "Benchmarking %s \n", filenameTable[i]);
|
||||||
|
for(c = cLevel; c <= cLevelLast; c++) {
|
||||||
|
BMK_benchFilesAdvanced(&filenameTable[i], 1, dictFileName, c, &compressionParams, g_displayLevel, &adv);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
for(; cLevel <= cLevelLast; cLevel++) {
|
||||||
|
BMK_benchFilesAdvanced(filenameTable, filenameIdx, dictFileName, cLevel, &compressionParams, g_displayLevel, &adv);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
for(; cLevel <= cLevelLast; cLevel++) {
|
||||||
|
BMK_syntheticTest(cLevel, compressibility, &compressionParams, g_displayLevel, &adv);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#else
|
#else
|
||||||
(void)bench_nbSeconds; (void)blockSize; (void)setRealTimePrio; (void)separateFiles;
|
(void)bench_nbSeconds; (void)blockSize; (void)setRealTimePrio; (void)separateFiles;
|
||||||
#endif
|
#endif
|
||||||
|
@@ -128,7 +128,7 @@ fullbench fullbench32 : CPPFLAGS += $(MULTITHREAD_CPP)
|
|||||||
fullbench fullbench32 : LDFLAGS += $(MULTITHREAD_LD)
|
fullbench fullbench32 : LDFLAGS += $(MULTITHREAD_LD)
|
||||||
fullbench fullbench32 : DEBUGFLAGS = # turn off assert() for speed measurements
|
fullbench fullbench32 : DEBUGFLAGS = # turn off assert() for speed measurements
|
||||||
fullbench fullbench32 : $(ZSTD_FILES)
|
fullbench fullbench32 : $(ZSTD_FILES)
|
||||||
fullbench fullbench32 : $(PRGDIR)/datagen.c fullbench.c
|
fullbench fullbench32 : $(PRGDIR)/datagen.c $(PRGDIR)/bench.c fullbench.c
|
||||||
$(CC) $(FLAGS) $^ -o $@$(EXT)
|
$(CC) $(FLAGS) $^ -o $@$(EXT)
|
||||||
|
|
||||||
fullbench-lib : zstd-staticLib
|
fullbench-lib : zstd-staticLib
|
||||||
|
@@ -30,6 +30,7 @@
|
|||||||
#include "zstd.h" /* ZSTD_versionString */
|
#include "zstd.h" /* ZSTD_versionString */
|
||||||
#include "util.h" /* time functions */
|
#include "util.h" /* time functions */
|
||||||
#include "datagen.h"
|
#include "datagen.h"
|
||||||
|
#include "bench.h" /* CustomBench*/
|
||||||
|
|
||||||
|
|
||||||
/*_************************************
|
/*_************************************
|
||||||
@@ -93,14 +94,15 @@ static size_t BMK_findMaxMem(U64 requiredMem)
|
|||||||
/*_*******************************************************
|
/*_*******************************************************
|
||||||
* Benchmark wrappers
|
* Benchmark wrappers
|
||||||
*********************************************************/
|
*********************************************************/
|
||||||
size_t local_ZSTD_compress(void* dst, size_t dstSize, void* buff2, const void* src, size_t srcSize)
|
|
||||||
|
size_t local_ZSTD_compress(const void* src, size_t srcSize, void* dst, size_t dstSize, void* buff2)
|
||||||
{
|
{
|
||||||
(void)buff2;
|
(void)buff2;
|
||||||
return ZSTD_compress(dst, dstSize, src, srcSize, 1);
|
return ZSTD_compress(dst, dstSize, src, srcSize, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
static size_t g_cSize = 0;
|
static size_t g_cSize = 0;
|
||||||
size_t local_ZSTD_decompress(void* dst, size_t dstSize, void* buff2, const void* src, size_t srcSize)
|
size_t local_ZSTD_decompress(const void* src, size_t srcSize, void* dst, size_t dstSize, void* buff2)
|
||||||
{
|
{
|
||||||
(void)src; (void)srcSize;
|
(void)src; (void)srcSize;
|
||||||
return ZSTD_decompress(dst, dstSize, buff2, g_cSize);
|
return ZSTD_decompress(dst, dstSize, buff2, g_cSize);
|
||||||
@@ -110,14 +112,14 @@ static ZSTD_DCtx* g_zdc = NULL;
|
|||||||
|
|
||||||
#ifndef ZSTD_DLL_IMPORT
|
#ifndef ZSTD_DLL_IMPORT
|
||||||
extern size_t ZSTD_decodeLiteralsBlock(ZSTD_DCtx* ctx, const void* src, size_t srcSize);
|
extern size_t ZSTD_decodeLiteralsBlock(ZSTD_DCtx* ctx, const void* src, size_t srcSize);
|
||||||
size_t local_ZSTD_decodeLiteralsBlock(void* dst, size_t dstSize, void* buff2, const void* src, size_t srcSize)
|
size_t local_ZSTD_decodeLiteralsBlock(const void* src, size_t srcSize, void* dst, size_t dstSize, void* buff2)
|
||||||
{
|
{
|
||||||
(void)src; (void)srcSize; (void)dst; (void)dstSize;
|
(void)src; (void)srcSize; (void)dst; (void)dstSize;
|
||||||
return ZSTD_decodeLiteralsBlock((ZSTD_DCtx*)g_zdc, buff2, g_cSize);
|
return ZSTD_decodeLiteralsBlock((ZSTD_DCtx*)g_zdc, buff2, g_cSize);
|
||||||
}
|
}
|
||||||
|
|
||||||
extern size_t ZSTD_decodeSeqHeaders(ZSTD_DCtx* dctx, int* nbSeq, const void* src, size_t srcSize);
|
extern size_t ZSTD_decodeSeqHeaders(ZSTD_DCtx* dctx, int* nbSeq, const void* src, size_t srcSize);
|
||||||
size_t local_ZSTD_decodeSeqHeaders(void* dst, size_t dstSize, void* buff2, const void* src, size_t srcSize)
|
size_t local_ZSTD_decodeSeqHeaders(const void* src, size_t srcSize, void* dst, size_t dstSize, void* buff2)
|
||||||
{
|
{
|
||||||
int nbSeq;
|
int nbSeq;
|
||||||
(void)src; (void)srcSize; (void)dst; (void)dstSize;
|
(void)src; (void)srcSize; (void)dst; (void)dstSize;
|
||||||
@@ -126,7 +128,7 @@ size_t local_ZSTD_decodeSeqHeaders(void* dst, size_t dstSize, void* buff2, const
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
static ZSTD_CStream* g_cstream= NULL;
|
static ZSTD_CStream* g_cstream= NULL;
|
||||||
size_t local_ZSTD_compressStream(void* dst, size_t dstCapacity, void* buff2, const void* src, size_t srcSize)
|
size_t local_ZSTD_compressStream(const void* src, size_t srcSize, void* dst, size_t dstCapacity, void* buff2)
|
||||||
{
|
{
|
||||||
ZSTD_outBuffer buffOut;
|
ZSTD_outBuffer buffOut;
|
||||||
ZSTD_inBuffer buffIn;
|
ZSTD_inBuffer buffIn;
|
||||||
@@ -143,7 +145,7 @@ size_t local_ZSTD_compressStream(void* dst, size_t dstCapacity, void* buff2, con
|
|||||||
return buffOut.pos;
|
return buffOut.pos;
|
||||||
}
|
}
|
||||||
|
|
||||||
static size_t local_ZSTD_compress_generic_end(void* dst, size_t dstCapacity, void* buff2, const void* src, size_t srcSize)
|
static size_t local_ZSTD_compress_generic_end(const void* src, size_t srcSize, void* dst, size_t dstCapacity, void* buff2)
|
||||||
{
|
{
|
||||||
ZSTD_outBuffer buffOut;
|
ZSTD_outBuffer buffOut;
|
||||||
ZSTD_inBuffer buffIn;
|
ZSTD_inBuffer buffIn;
|
||||||
@@ -159,7 +161,7 @@ static size_t local_ZSTD_compress_generic_end(void* dst, size_t dstCapacity, voi
|
|||||||
return buffOut.pos;
|
return buffOut.pos;
|
||||||
}
|
}
|
||||||
|
|
||||||
static size_t local_ZSTD_compress_generic_continue(void* dst, size_t dstCapacity, void* buff2, const void* src, size_t srcSize)
|
static size_t local_ZSTD_compress_generic_continue(const void* src, size_t srcSize, void* dst, size_t dstCapacity, void* buff2)
|
||||||
{
|
{
|
||||||
ZSTD_outBuffer buffOut;
|
ZSTD_outBuffer buffOut;
|
||||||
ZSTD_inBuffer buffIn;
|
ZSTD_inBuffer buffIn;
|
||||||
@@ -176,7 +178,7 @@ static size_t local_ZSTD_compress_generic_continue(void* dst, size_t dstCapacity
|
|||||||
return buffOut.pos;
|
return buffOut.pos;
|
||||||
}
|
}
|
||||||
|
|
||||||
static size_t local_ZSTD_compress_generic_T2_end(void* dst, size_t dstCapacity, void* buff2, const void* src, size_t srcSize)
|
static size_t local_ZSTD_compress_generic_T2_end(const void* src, size_t srcSize, void* dst, size_t dstCapacity, void* buff2)
|
||||||
{
|
{
|
||||||
ZSTD_outBuffer buffOut;
|
ZSTD_outBuffer buffOut;
|
||||||
ZSTD_inBuffer buffIn;
|
ZSTD_inBuffer buffIn;
|
||||||
@@ -193,7 +195,7 @@ static size_t local_ZSTD_compress_generic_T2_end(void* dst, size_t dstCapacity,
|
|||||||
return buffOut.pos;
|
return buffOut.pos;
|
||||||
}
|
}
|
||||||
|
|
||||||
static size_t local_ZSTD_compress_generic_T2_continue(void* dst, size_t dstCapacity, void* buff2, const void* src, size_t srcSize)
|
static size_t local_ZSTD_compress_generic_T2_continue(const void* src, size_t srcSize, void* dst, size_t dstCapacity, void* buff2)
|
||||||
{
|
{
|
||||||
ZSTD_outBuffer buffOut;
|
ZSTD_outBuffer buffOut;
|
||||||
ZSTD_inBuffer buffIn;
|
ZSTD_inBuffer buffIn;
|
||||||
@@ -212,7 +214,7 @@ static size_t local_ZSTD_compress_generic_T2_continue(void* dst, size_t dstCapac
|
|||||||
}
|
}
|
||||||
|
|
||||||
static ZSTD_DStream* g_dstream= NULL;
|
static ZSTD_DStream* g_dstream= NULL;
|
||||||
static size_t local_ZSTD_decompressStream(void* dst, size_t dstCapacity, void* buff2, const void* src, size_t srcSize)
|
static size_t local_ZSTD_decompressStream(const void* src, size_t srcSize, void* dst, size_t dstCapacity, void* buff2)
|
||||||
{
|
{
|
||||||
ZSTD_outBuffer buffOut;
|
ZSTD_outBuffer buffOut;
|
||||||
ZSTD_inBuffer buffIn;
|
ZSTD_inBuffer buffIn;
|
||||||
@@ -231,7 +233,7 @@ static size_t local_ZSTD_decompressStream(void* dst, size_t dstCapacity, void* b
|
|||||||
static ZSTD_CCtx* g_zcc = NULL;
|
static ZSTD_CCtx* g_zcc = NULL;
|
||||||
|
|
||||||
#ifndef ZSTD_DLL_IMPORT
|
#ifndef ZSTD_DLL_IMPORT
|
||||||
size_t local_ZSTD_compressContinue(void* dst, size_t dstCapacity, void* buff2, const void* src, size_t srcSize)
|
size_t local_ZSTD_compressContinue(const void* src, size_t srcSize, void* dst, size_t dstCapacity, void* buff2)
|
||||||
{
|
{
|
||||||
(void)buff2;
|
(void)buff2;
|
||||||
ZSTD_compressBegin(g_zcc, 1 /* compressionLevel */);
|
ZSTD_compressBegin(g_zcc, 1 /* compressionLevel */);
|
||||||
@@ -239,7 +241,7 @@ size_t local_ZSTD_compressContinue(void* dst, size_t dstCapacity, void* buff2, c
|
|||||||
}
|
}
|
||||||
|
|
||||||
#define FIRST_BLOCK_SIZE 8
|
#define FIRST_BLOCK_SIZE 8
|
||||||
size_t local_ZSTD_compressContinue_extDict(void* dst, size_t dstCapacity, void* buff2, const void* src, size_t srcSize)
|
size_t local_ZSTD_compressContinue_extDict(const void* src, size_t srcSize, void* dst, size_t dstCapacity, void* buff2)
|
||||||
{
|
{
|
||||||
BYTE firstBlockBuf[FIRST_BLOCK_SIZE];
|
BYTE firstBlockBuf[FIRST_BLOCK_SIZE];
|
||||||
|
|
||||||
@@ -255,7 +257,7 @@ size_t local_ZSTD_compressContinue_extDict(void* dst, size_t dstCapacity, void*
|
|||||||
return ZSTD_compressEnd(g_zcc, dst, dstCapacity, (const BYTE*)src + FIRST_BLOCK_SIZE, srcSize - FIRST_BLOCK_SIZE);
|
return ZSTD_compressEnd(g_zcc, dst, dstCapacity, (const BYTE*)src + FIRST_BLOCK_SIZE, srcSize - FIRST_BLOCK_SIZE);
|
||||||
}
|
}
|
||||||
|
|
||||||
size_t local_ZSTD_decompressContinue(void* dst, size_t dstCapacity, void* buff2, const void* src, size_t srcSize)
|
size_t local_ZSTD_decompressContinue(const void* src, size_t srcSize, void* dst, size_t dstCapacity, void* buff2)
|
||||||
{
|
{
|
||||||
size_t regeneratedSize = 0;
|
size_t regeneratedSize = 0;
|
||||||
const BYTE* ip = (const BYTE*)buff2;
|
const BYTE* ip = (const BYTE*)buff2;
|
||||||
@@ -288,8 +290,9 @@ static size_t benchMem(const void* src, size_t srcSize, U32 benchNb)
|
|||||||
size_t const dstBuffSize = ZSTD_compressBound(srcSize);
|
size_t const dstBuffSize = ZSTD_compressBound(srcSize);
|
||||||
void* buff2;
|
void* buff2;
|
||||||
const char* benchName;
|
const char* benchName;
|
||||||
size_t (*benchFunction)(void* dst, size_t dstSize, void* verifBuff, const void* src, size_t srcSize);
|
BMK_benchFn_t benchFunction;
|
||||||
double bestTime = 100000000.;
|
BMK_customReturn_t r;
|
||||||
|
int errorcode = 0;
|
||||||
|
|
||||||
/* Selection */
|
/* Selection */
|
||||||
switch(benchNb)
|
switch(benchNb)
|
||||||
@@ -419,45 +422,24 @@ static size_t benchMem(const void* src, size_t srcSize, U32 benchNb)
|
|||||||
default : ;
|
default : ;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/* warming up memory */
|
/* warming up memory */
|
||||||
{ size_t i; for (i=0; i<dstBuffSize; i++) dstBuff[i]=(BYTE)i; }
|
{ size_t i; for (i=0; i<dstBuffSize; i++) dstBuff[i]=(BYTE)i; }
|
||||||
|
|
||||||
/* benchmark loop */
|
|
||||||
{ U32 loopNb;
|
|
||||||
U32 nbRounds = (U32)((50 MB) / (srcSize+1)) + 1; /* initial conservative speed estimate */
|
|
||||||
# define TIME_SEC_MICROSEC (1*1000000ULL) /* 1 second */
|
|
||||||
# define TIME_SEC_NANOSEC (1*1000000000ULL) /* 1 second */
|
|
||||||
DISPLAY("%2i- %-30.30s : \r", benchNb, benchName);
|
|
||||||
for (loopNb = 1; loopNb <= g_nbIterations; loopNb++) {
|
|
||||||
UTIL_time_t clockStart;
|
|
||||||
size_t benchResult=0;
|
|
||||||
U32 roundNb;
|
|
||||||
|
|
||||||
UTIL_sleepMilli(5); /* give processor time to other processes */
|
/* benchmark loop */
|
||||||
UTIL_waitForNextTick();
|
{
|
||||||
clockStart = UTIL_getTime();
|
r = BMK_benchFunction(benchFunction, buff2,
|
||||||
for (roundNb=0; roundNb < nbRounds; roundNb++) {
|
NULL, NULL, 1, &src, &srcSize,
|
||||||
benchResult = benchFunction(dstBuff, dstBuffSize, buff2, src, srcSize);
|
(void * const * const)&dstBuff, &dstBuffSize, g_nbIterations);
|
||||||
if (ZSTD_isError(benchResult)) {
|
if(r.error) {
|
||||||
DISPLAY("ERROR ! %s() => %s !! \n", benchName, ZSTD_getErrorName(benchResult));
|
DISPLAY("ERROR %d ! ! \n", r.error);
|
||||||
exit(1);
|
errorcode = r.error;
|
||||||
} }
|
goto _cleanOut;
|
||||||
{ U64 const clockSpanNano = UTIL_clockSpanNano(clockStart);
|
}
|
||||||
double const averageTime = (double)clockSpanNano / TIME_SEC_NANOSEC / nbRounds;
|
|
||||||
if (clockSpanNano > 0) {
|
DISPLAY("%2u#Speed: %f MB/s - Size: %f MB - %s\n", benchNb, (double)srcSize / r.result.nanoSecPerRun * 1000, (double)r.result.sumOfReturn / 1000000, benchName);
|
||||||
if (averageTime < bestTime) bestTime = averageTime;
|
|
||||||
assert(bestTime > (1./2000000000));
|
|
||||||
nbRounds = (U32)(1. / bestTime); /* aim for 1 sec */
|
|
||||||
DISPLAY("%2i- %-30.30s : %7.1f MB/s (%9u)\r",
|
|
||||||
loopNb, benchName,
|
|
||||||
(double)srcSize / (1 MB) / bestTime,
|
|
||||||
(U32)benchResult);
|
|
||||||
} else {
|
|
||||||
assert(nbRounds < 40000000); /* avoid overflow */
|
|
||||||
nbRounds *= 100;
|
|
||||||
}
|
}
|
||||||
} } }
|
|
||||||
DISPLAY("%2u\n", benchNb);
|
|
||||||
|
|
||||||
_cleanOut:
|
_cleanOut:
|
||||||
free(dstBuff);
|
free(dstBuff);
|
||||||
@@ -466,7 +448,7 @@ _cleanOut:
|
|||||||
ZSTD_freeDCtx(g_zdc); g_zdc=NULL;
|
ZSTD_freeDCtx(g_zdc); g_zdc=NULL;
|
||||||
ZSTD_freeCStream(g_cstream); g_cstream=NULL;
|
ZSTD_freeCStream(g_cstream); g_cstream=NULL;
|
||||||
ZSTD_freeDStream(g_dstream); g_dstream=NULL;
|
ZSTD_freeDStream(g_dstream); g_dstream=NULL;
|
||||||
return 0;
|
return errorcode;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@@ -162,18 +162,15 @@ const char* g_stratName[ZSTD_btultra+1] = {
|
|||||||
"ZSTD_btlazy2 ", "ZSTD_btopt ", "ZSTD_btultra "};
|
"ZSTD_btlazy2 ", "ZSTD_btopt ", "ZSTD_btultra "};
|
||||||
|
|
||||||
/* TODO: support additional parameters (more files, fileSizes) */
|
/* TODO: support additional parameters (more files, fileSizes) */
|
||||||
|
|
||||||
//TODO: benchMem dctx can't = NULL in new system
|
|
||||||
static size_t
|
static size_t
|
||||||
BMK_benchParam(BMK_result_t* resultPtr,
|
BMK_benchParam(BMK_result_t* resultPtr,
|
||||||
const void* srcBuffer, size_t srcSize,
|
const void* srcBuffer, size_t srcSize,
|
||||||
ZSTD_CCtx* ctx, ZSTD_DCtx* dctx,
|
ZSTD_CCtx* ctx, ZSTD_DCtx* dctx,
|
||||||
const ZSTD_compressionParameters cParams) {
|
const ZSTD_compressionParameters cParams) {
|
||||||
|
|
||||||
|
|
||||||
BMK_return_t res = BMK_benchMem(srcBuffer,srcSize, &srcSize, 1, 0, &cParams, NULL, 0, ctx, dctx, 0, "File");
|
BMK_return_t res = BMK_benchMem(srcBuffer,srcSize, &srcSize, 1, 0, &cParams, NULL, 0, ctx, dctx, 0, "File");
|
||||||
*resultPtr = res.result;
|
*resultPtr = res.result;
|
||||||
return res.errorCode;
|
return res.error;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void BMK_printWinner(FILE* f, U32 cLevel, BMK_result_t result, ZSTD_compressionParameters params, size_t srcSize)
|
static void BMK_printWinner(FILE* f, U32 cLevel, BMK_result_t result, ZSTD_compressionParameters params, size_t srcSize)
|
||||||
|
Reference in New Issue
Block a user