From c8679ad5926ede3683e254a81d5099bffbd4d750 Mon Sep 17 00:00:00 2001 From: Kai Huang Date: Mon, 4 Nov 2024 09:51:15 +0800 Subject: [PATCH] Qwen layernorm as input (#12309) * qwen layernorm as input * add group size --- .../LLM/Pipeline-Models/qwen.py | 2 ++ .../transformers/npu_pipeline_model/qwen.py | 18 +++++++++++------- 2 files changed, 13 insertions(+), 7 deletions(-) diff --git a/python/llm/example/NPU/HF-Transformers-AutoModels/LLM/Pipeline-Models/qwen.py b/python/llm/example/NPU/HF-Transformers-AutoModels/LLM/Pipeline-Models/qwen.py index 0055b248482..e25b6390099 100644 --- a/python/llm/example/NPU/HF-Transformers-AutoModels/LLM/Pipeline-Models/qwen.py +++ b/python/llm/example/NPU/HF-Transformers-AutoModels/LLM/Pipeline-Models/qwen.py @@ -47,6 +47,7 @@ parser.add_argument("--n-predict", type=int, default=32, help="Max tokens to predict") parser.add_argument("--max-context-len", type=int, default=1024) parser.add_argument("--max-prompt-len", type=int, default=960) + parser.add_argument("--quantization_group_size", type=int, default=0) parser.add_argument('--load_in_low_bit', type=str, default="sym_int4", help='Load in low bit to use') parser.add_argument("--disable-transpose-value-cache", action="store_true", default=False) @@ -62,6 +63,7 @@ load_in_low_bit=args.load_in_low_bit, max_context_len=args.max_context_len, max_prompt_len=args.max_prompt_len, + quantization_group_size=args.quantization_group_size, torch_dtype=torch.float16, attn_implementation="eager", transpose_value_cache=not args.disable_transpose_value_cache, diff --git a/python/llm/src/ipex_llm/transformers/npu_pipeline_model/qwen.py b/python/llm/src/ipex_llm/transformers/npu_pipeline_model/qwen.py index c151ac93be7..be0244e9020 100644 --- a/python/llm/src/ipex_llm/transformers/npu_pipeline_model/qwen.py +++ b/python/llm/src/ipex_llm/transformers/npu_pipeline_model/qwen.py @@ -149,8 +149,8 @@ def convert_qwen_layer(model, layer_idx, n_splits_linear, n_splits_down_proj, single_decoder = LowBitQwenMultiDecoderlayer( [1, 1, num_heads * head_dim], - input_layernorm_weights=[layer_norm_0], - post_attn_layernorm_weights=[layer_norm_1], + input_layernorm_weights=None, + post_attn_layernorm_weights=None, q_biases=None, k_biases=None, v_biases=None, @@ -174,17 +174,21 @@ def convert_qwen_layer(model, layer_idx, n_splits_linear, n_splits_down_proj, temp_dir) # 0, 1, 2 are input_embed/attention_mask/position_id - q_bias_bin_file = os.path.join(weight_dir, f"model_{layer_idx}_input_3.bin") - k_bias_bin_file = os.path.join(weight_dir, f"model_{layer_idx}_input_4.bin") - v_bias_bin_file = os.path.join(weight_dir, f"model_{layer_idx}_input_5.bin") + input_lm_bin_file = os.path.join(weight_dir, f"model_{layer_idx}_input_3.bin") + post_lm_bin_file = os.path.join(weight_dir, f"model_{layer_idx}_input_4.bin") + layer_norm_0.data.numpy().tofile(input_lm_bin_file) + layer_norm_1.data.numpy().tofile(post_lm_bin_file) + q_bias_bin_file = os.path.join(weight_dir, f"model_{layer_idx}_input_5.bin") + k_bias_bin_file = os.path.join(weight_dir, f"model_{layer_idx}_input_6.bin") + v_bias_bin_file = os.path.join(weight_dir, f"model_{layer_idx}_input_7.bin") q_bias.data.numpy().tofile(q_bias_bin_file) k_bias.data.numpy().tofile(k_bias_bin_file) v_bias.data.numpy().tofile(v_bias_bin_file) # 6, 7 are past k/v for idx, (weight, scale) in enumerate(weights): - bin_file = os.path.join(weight_dir, f"model_{layer_idx}_input_{8+idx*2}.bin") + bin_file = os.path.join(weight_dir, f"model_{layer_idx}_input_{10+idx*2}.bin") weight.numpy().tofile(bin_file) - bin_file = os.path.join(weight_dir, f"model_{layer_idx}_input_{8+idx*2+1}.bin") + bin_file = os.path.join(weight_dir, f"model_{layer_idx}_input_{10+idx*2+1}.bin") scale.numpy().tofile(bin_file) del single_decoder