mirror of
https://github.com/ggerganov/llama.cpp.git
synced 2024-12-27 03:44:35 +00:00
f7cab35ef9
CLI to hash GGUF files to detect difference on a per model and per tensor level The hash type we support is: - `--xxh64`: use xhash 64bit hash mode (default) - `--sha1`: use sha1 - `--uuid`: use uuid - `--sha256`: use sha256 While most POSIX systems already have hash checking programs like sha256sum, it is designed to check entire files. This is not ideal for our purpose if we want to check for consistency of the tensor data even if the metadata content of the gguf KV store has been updated. This program is designed to hash a gguf tensor payload on a 'per tensor layer' in addition to a 'entire tensor model' hash. The intent is that the entire tensor layer can be checked first but if there is any detected inconsistencies, then the per tensor hash can be used to narrow down the specific tensor layer that has inconsistencies. Co-authored-by: Georgi Gerganov <ggerganov@gmail.com>
16 lines
618 B
CMake
16 lines
618 B
CMake
set(TARGET llama-gguf-hash)
|
|
add_executable(${TARGET} gguf-hash.cpp)
|
|
install(TARGETS ${TARGET} RUNTIME)
|
|
|
|
# clibs dependencies
|
|
include_directories(deps/)
|
|
add_library(xxhash OBJECT deps/xxhash/xxhash.c deps/xxhash/xxhash.h)
|
|
target_link_libraries(${TARGET} PRIVATE xxhash)
|
|
add_library(sha1 OBJECT deps/sha1/sha1.c deps/sha1/sha1.h)
|
|
target_link_libraries(${TARGET} PRIVATE sha1)
|
|
add_library(sha256 OBJECT deps/sha256/sha256.c deps/sha256/sha256.h)
|
|
target_link_libraries(${TARGET} PRIVATE sha256)
|
|
|
|
target_link_libraries(${TARGET} PRIVATE ggml ${CMAKE_THREAD_LIBS_INIT})
|
|
target_compile_features(${TARGET} PRIVATE cxx_std_11)
|