mirror of
				https://github.com/ggml-org/llama.cpp.git
				synced 2025-10-31 08:51:55 +00:00 
			
		
		
		
	model-conversion : add qat-q4 quantization targets (#15588)
This commit adds two targets to the Makefile for quantizing of Quantization Aware Trained (QAT) models to Q4_0 format. The motivation for this is that this sets the token embedding and the output tensors data types to Q8_0 instead of the default Q6_K. This is someting that we wish to enforce for QAT Q4_0 models that are to be uploaded to ggml-org on Huggingface to guarantee the best quality.
This commit is contained in:
		| @@ -4,6 +4,8 @@ set -e | ||||
|  | ||||
| CONVERTED_MODEL="${1:-"$CONVERTED_MODEL"}" | ||||
| QUANTIZED_TYPE="${2:-"$QUANTIZED_TYPE"}" | ||||
| TOKEN_EMBD_TYPE="${3:-"${TOKEN_EMBD_TYPE}"}" | ||||
| OUTPUT_TYPE="${4:-"${OUTPUT_TYPE}"}" | ||||
| QUANTIZED_MODEL=$CONVERTED_MODEL | ||||
|  | ||||
| # Final check if we have a model path | ||||
| @@ -14,6 +16,11 @@ if [ -z "$CONVERTED_MODEL" ]; then | ||||
|     exit 1 | ||||
| fi | ||||
|  | ||||
| if [ -z "$QUANTIZED_TYPE" ]; then | ||||
|     echo "Error: QUANTIZED_TYPE is required" >&2 | ||||
|     exit 1 | ||||
| fi | ||||
|  | ||||
| echo $CONVERTED_MODEL | ||||
|  | ||||
| # Process the quantized model filename | ||||
| @@ -26,9 +33,16 @@ else | ||||
|     exit 1 | ||||
| fi | ||||
|  | ||||
|  | ||||
| cmake --build ../../build --target llama-quantize -j8 | ||||
|  | ||||
| ../../build/bin/llama-quantize $CONVERTED_MODEL $QUANTIZED_MODEL $QUANTIZED_TYPE | ||||
| echo $TOKEN_EMBD_TYPE | ||||
| echo $OUTPUT_TYPE | ||||
|  | ||||
| CMD_ARGS=("../../build/bin/llama-quantize") | ||||
| [[ -n "$TOKEN_EMBD_TYPE" ]] && CMD_ARGS+=("--token-embedding-type" "$TOKEN_EMBD_TYPE") | ||||
| [[ -n "$OUTPUT_TYPE" ]]     && CMD_ARGS+=("--output-tensor-type" "$OUTPUT_TYPE") | ||||
| CMD_ARGS+=("$CONVERTED_MODEL" "$QUANTIZED_MODEL" "$QUANTIZED_TYPE") | ||||
|  | ||||
| "${CMD_ARGS[@]}" | ||||
|  | ||||
| echo "Quantized model saved to: $QUANTIZED_MODEL" | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Daniel Bevenius
					Daniel Bevenius