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>
		
			
				
	
	
		
			57 lines
		
	
	
	
		
			1.4 KiB
		
	
	
	
		
			CMake
		
	
	
	
	
	
			
		
		
	
	
			57 lines
		
	
	
	
		
			1.4 KiB
		
	
	
	
		
			CMake
		
	
	
	
	
	
| # dependencies
 | |
| 
 | |
| find_package(Threads REQUIRED)
 | |
| 
 | |
| # third-party
 | |
| 
 | |
| # ...
 | |
| 
 | |
| # examples
 | |
| 
 | |
| include_directories(${CMAKE_CURRENT_SOURCE_DIR})
 | |
| 
 | |
| if (EMSCRIPTEN)
 | |
| else()
 | |
|     add_subdirectory(cvector-generator)
 | |
|     add_subdirectory(baby-llama)
 | |
|     add_subdirectory(batched-bench)
 | |
|     add_subdirectory(batched)
 | |
|     add_subdirectory(benchmark)
 | |
|     add_subdirectory(convert-llama2c-to-ggml)
 | |
|     add_subdirectory(embedding)
 | |
|     add_subdirectory(eval-callback)
 | |
|     add_subdirectory(export-lora)
 | |
|     add_subdirectory(finetune)
 | |
|     add_subdirectory(gbnf-validator)
 | |
|     add_subdirectory(gguf-hash)
 | |
|     add_subdirectory(gguf-split)
 | |
|     add_subdirectory(gguf)
 | |
|     add_subdirectory(gritlm)
 | |
|     add_subdirectory(imatrix)
 | |
|     add_subdirectory(infill)
 | |
|     add_subdirectory(llama-bench)
 | |
|     add_subdirectory(llava)
 | |
|     add_subdirectory(lookahead)
 | |
|     add_subdirectory(lookup)
 | |
|     add_subdirectory(main)
 | |
|     add_subdirectory(parallel)
 | |
|     add_subdirectory(passkey)
 | |
|     add_subdirectory(perplexity)
 | |
|     add_subdirectory(quantize-stats)
 | |
|     add_subdirectory(quantize)
 | |
|     add_subdirectory(retrieval)
 | |
|     if (GGML_RPC)
 | |
|         add_subdirectory(rpc)
 | |
|     endif()
 | |
|     if (LLAMA_BUILD_SERVER)
 | |
|     add_subdirectory(server)
 | |
|     endif()
 | |
|     if (GGML_SYCL)
 | |
|         add_subdirectory(sycl)
 | |
|     endif()
 | |
|     add_subdirectory(save-load-state)
 | |
|     add_subdirectory(simple)
 | |
|     add_subdirectory(speculative)
 | |
|     add_subdirectory(tokenize)
 | |
|     add_subdirectory(train-text-from-scratch)
 | |
| endif()
 |