From e8e8f9e97de90393f610fef555df9dc2897be0ff Mon Sep 17 00:00:00 2001 From: John Wang Date: Sun, 21 May 2023 17:06:04 +0800 Subject: [PATCH] Fix: move pre prompt to user massasge in chat mode (#126) --- api/core/completion.py | 18 ++++++++++-------- 1 file changed, 10 insertions(+), 8 deletions(-) diff --git a/api/core/completion.py b/api/core/completion.py index 5bacce8f75..d05d8417da 100644 --- a/api/core/completion.py +++ b/api/core/completion.py @@ -157,11 +157,6 @@ And answer according to the language of the user's question. else: messages: List[BaseMessage] = [] - if pre_prompt: - # append pre prompt as system message - system_message = PromptBuilder.to_system_message(pre_prompt, inputs) - messages.append(system_message) - human_inputs = { "query": query } @@ -170,7 +165,7 @@ And answer according to the language of the user's question. if chain_output: human_inputs['context'] = chain_output - human_message_prompt = """Use the following CONTEXT as your learned knowledge. + human_message_instruction = """Use the following CONTEXT as your learned knowledge. [CONTEXT] {context} [END CONTEXT] @@ -180,9 +175,16 @@ When answer to user: - If you don't know when you are not sure, ask for clarification. Avoid mentioning that you obtained the information from the context. And answer according to the language of the user's question. +""" + if pre_prompt: + human_inputs.update(inputs) + human_message_instruction += pre_prompt + "\n" -Q:{query} -A:""" + human_message_prompt = human_message_instruction + "Q:{query}\nA:" + else: + if pre_prompt: + human_inputs.update(inputs) + human_message_prompt = pre_prompt + "\n" + human_message_prompt # construct main prompt human_message = PromptBuilder.to_human_message(