mirror of
https://github.com/ggml-org/llama.cpp.git
synced 2025-10-28 08:31:25 +00:00
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.
49 lines
1.3 KiB
Bash
Executable File
49 lines
1.3 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
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
|
|
if [ -z "$CONVERTED_MODEL" ]; then
|
|
echo "Error: Model path must be provided either as:" >&2
|
|
echo " 1. Command line argument" >&2
|
|
echo " 2. CONVERTED_MODEL environment variable" >&2
|
|
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
|
|
if [[ "$QUANTIZED_MODEL" == *.gguf ]]; then
|
|
# Remove .gguf suffix, add quantized type, then add .gguf back
|
|
BASE_NAME="${QUANTIZED_MODEL%.gguf}"
|
|
QUANTIZED_MODEL="${BASE_NAME}-${QUANTIZED_TYPE}.gguf"
|
|
else
|
|
echo "Error: QUANTIZED_MODEL must end with .gguf extension" >&2
|
|
exit 1
|
|
fi
|
|
|
|
cmake --build ../../build --target llama-quantize -j8
|
|
|
|
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"
|