EN_QA_PROMPT = """, and you need to continuously ask questions and reason until you can identify the name/term/concept. You can ask questions to narrow down the possibilities. Your questions must be in the form of a single, four-option multiple-choice question at a time.
You can only ask one multiple-choice question at a time. Each question is crucial and should be based on your reasoning, professional knowledge, and the previous rounds of questions and answers. Please try to identify the term/concept in as few rounds as possible.

I have now preset a name/term/concept. Please begin with your first question.
"""

EN_EVAL_PROMPT_V2 = """, and I need to identify it by asking questions and using reasoning. I can ask questions to narrow down the scope, and my method of questioning will be a single, four-option multiple-choice question at a time. 
The specific details regarding my question are all within the <qa_response> part. You will respond to my questions based on some "golden information" (reference material).

The name/term/concept you have preset is: {puzzle_name}
Reference material:<reference_material> {puzzle_reference} </reference_material>

In your reply, you must include a <pure_parse> ... </pure_parse> block and a <pure_answer>...</pure_answer> block.

For the <pure_parse> ... </pure_parse> block:
You will only judge the correctness of the options.For example, when option A,D are correct, and option B,C are incorrect:
<pure_parse>A is correct, B is incorrect, C is incorrect, D is correct</pure_parse>
when all options are incorrect, reply with <pure_parse>A is incorrect, B is incorrect, C is incorrect, D is incorrect</pure_parse>
If the <qa_response> part provides only an incorrect final guess without including a multiple-choice question, reply with <pure_parse>Your guess is incorrect, please ask a new question</pure_parse> and <pure_answer>None</pure_answer>.
The <pure_parse> block is forbidden from containing the name of the preset name/term/concept or any other content from the <reference_material> part.

For the <pure_answer>...</pure_answer> block:
If the message you receive in the <qa_response> part(or one of the options in the <qa_response> part) explicitly states the name of your preset name/term/concept (or its alias), then include <pure_answer>Your preset name</pure_answer> in your reply(Here, "Your preset name" should be replaced with the actual name that appears). 
If it does not, then include <pure_answer>None</pure_answer>.

All of your replies must include both of these blocks.
"""

EVAL_SUCCESS_PROMPT = """
# ROLE 
You are a meticulous content verifier.  
# TASK 
Your sole task is to analyze a provided "Source Text" and determine if it to a great extent contains the information described in the "Specified Content". "Reference" part shows some detailed information that may be helpful for you to verify.

You must not infer information or make assumptions.  
# RULES 
1.  If the "Source Text"(or one part of the "Source Text") to a great extent contains the core of the "Specified Content", you MUST respond with only `<judge>True</judge>`.
2.  Reference part may show you some alias or alternative name of the "Specified Content", you should consider them as the "Specified Content" too when you verify.
3.  If the "Source Text" does not clearly contain the "Specified Content", you MUST respond with only `<judge>False</judge>`. 
4.  Do not provide any explanations or additional text. Your entire response must be either `<judge>True</judge>` or `<judge>False</judge>`.  
# INPUT 
**Source Text:{source_text}  
**Specified Content:** {specified_content}
**Reference:** {reference}
"""
EN_ECONOMICS_PUZZLE_BENCHMARK_QA_PROMPT = """
You are an economics expert. I will have a preset economics term/concept in mind""" + EN_QA_PROMPT

EN_ECONOMICS_PUZZLE_BENCHMARK_EVAL_PROMPT = """
You are an economics expert. You will have a preset economics term/concept in mind""" + EN_EVAL_PROMPT_V2

EN_PHILOSOPHY_PUZZLE_BENCHMARK_QA_PROMPT = """
You are a philosophy expert. I will have a preset philosophy term/concept in mind""" + EN_QA_PROMPT

EN_PHILOSOPHY_PUZZLE_BENCHMARK_EVAL_PROMPT = """
You are a philosophy expert. You will have a preset philosophy term/concept in mind""" + EN_EVAL_PROMPT_V2

EN_CHEMISTRY_PUZZLE_BENCHMARK_QA_PROMPT = """
You are a chemistry expert. I will have a preset chemistry term/concept in mind""" + EN_QA_PROMPT

EN_CHEMISTRY_PUZZLE_BENCHMARK_EVAL_PROMPT = """
You are a chemistry expert. You will have a preset chemistry term/concept in mind""" + EN_EVAL_PROMPT_V2

EN_COMPUTER_SCIENCE_PUZZLE_BENCHMARK_QA_PROMPT = """
You are a computer science expert. I will have a preset computer science term/concept in mind""" + EN_QA_PROMPT

EN_COMPUTER_SCIENCE_PUZZLE_BENCHMARK_EVAL_PROMPT = """
You are a computer science expert. You will have a preset computer science term/concept in mind""" + EN_EVAL_PROMPT_V2

EN_NAME_PUZZLE_BENCHMARK_QA_PROMPT = """
You are a puzzle expert. I will have a preset name/term/concept in mind""" + EN_QA_PROMPT

EN_NAME_PUZZLE_BENCHMARK_EVAL_PROMPT = """
You are a puzzle expert. You will have a preset name/term/concept in mind""" + EN_EVAL_PROMPT_V2

EN_MEDICAL_PUZZLE_BENCHMARK_QA_PROMPT = """
You are a doctor. I will have a preset human disease name in mind""" + EN_QA_PROMPT

EN_MEDICAL_PUZZLE_BENCHMARK_EVAL_PROMPT = """
You are a doctor. You will have a preset human disease name in mind""" + EN_EVAL_PROMPT_V2

EN_MATHEMATICS_PUZZLE_BENCHMARK_QA_PROMPT = """
You are a mathematics expert. I will have a preset mathematics term/concept in mind""" + EN_QA_PROMPT

EN_MATHEMATICS_PUZZLE_BENCHMARK_EVAL_PROMPT = """
You are a mathematics expert. You will have a preset mathematics term/concept in mind""" + EN_EVAL_PROMPT_V2

EN_BIOLOGY_PUZZLE_BENCHMARK_QA_PROMPT = """
You are a biology expert. I will have a preset biology term/concept in mind""" + EN_QA_PROMPT

EN_BIOLOGY_PUZZLE_BENCHMARK_EVAL_PROMPT = """
You are a biology expert. You will have a preset biology term/concept in mind""" + EN_EVAL_PROMPT_V2

EN_PHYSICAL_PUZZLE_BENCHMARK_QA_PROMPT = """
You are a physics expert. I will have a preset physics term/concept in mind""" + EN_QA_PROMPT

EN_PHYSICAL_PUZZLE_BENCHMARK_EVAL_PROMPT = """
You are a physics expert. You will have a preset physics term/concept in mind""" + EN_EVAL_PROMPT_V2

EN_SEMICONDUCTOR_PUZZLE_BENCHMARK_QA_PROMPT = """
You are a semiconductor expert. I will have a preset semiconductor term/concept in mind""" + EN_QA_PROMPT

EN_SEMICONDUCTOR_PUZZLE_BENCHMARK_EVAL_PROMPT = """
You are a semiconductor expert. You will have a preset semiconductor term/concept in mind""" + EN_EVAL_PROMPT_V2

EN_QA_PROMPT_4_COMMAND = """, and you need to continuously ask questions and reason until you can identify the command. You can ask questions to narrow down the possibilities. Your questions must be in the form of a single, four-option multiple-choice question at a time.
You can only ask one multiple-choice question at a time. Each question is crucial and should be based on your reasoning, professional knowledge, and the previous rounds of questions and answers. Please try to identify the command in as few rounds as possible.

I have now preset a command. Please begin with your first question.
"""

EN_EVAL_PROMPT_4_COMMAND_V2 = """, and I need to identify it by asking questions and using reasoning. I can ask questions to narrow down the scope, and my method of questioning will be a single, four-option multiple-choice question at a time. 
The specific details regarding my question are all within the <qa_response> part. You will respond to my questions based on some "golden information" (reference material).

The name/term/concept you have preset is: {puzzle_name}
Reference material:<reference_material> {puzzle_reference} </reference_material>

In your reply, you must include a <pure_parse> ... </pure_parse> block and a <pure_answer>...</pure_answer> block.

For the <pure_parse> ... </pure_parse> block:
You will only judge the correctness of the options.For example, when option A,D are correct, and option B,C are incorrect:
<pure_parse>A is correct, B is incorrect, C is incorrect, D is correct</pure_parse>
when all options are incorrect, reply with <pure_parse>A is incorrect, B is incorrect, C is incorrect, D is incorrect</pure_parse>
If the <qa_response> part provides only an incorrect final guess without including a multiple-choice question, reply with <pure_parse>Your guess is incorrect, please ask a new question</pure_parse> and <pure_answer>None</pure_answer>.
The <pure_parse> block is forbidden from containing the name of the preset name/term/concept or any other content from the <reference_material> part.

For the <pure_answer>...</pure_answer> block:
If the message you receive in the <qa_response> part(or one of the options in the <qa_response> part) explicitly states the name of your preset command name, then include <pure_answer>Your preset name</pure_answer> in your reply. 
If it does not, then include <pure_answer>None</pure_answer>.

All of your replies must include both of these blocks.
"""

EN_EDAICC_PUZZLE_BENCHMARK_QA_PROMPT = """
You are an EDA expert specializing in IC Compiler™ Tool commands. I will have a preset IC Compiler™ Tool command name in mind""" + EN_QA_PROMPT_4_COMMAND

EN_EDAICC_PUZZLE_BENCHMARK_EVAL_PROMPT = """
You are an EDA expert specializing in IC Compiler™ Tool commands. You will have a preset IC Compiler™ Tool command name in mind""" + EN_EVAL_PROMPT_4_COMMAND_V2

EN_EDAICC2_PUZZLE_BENCHMARK_QA_PROMPT = """
You are an EDA expert specializing in Synopsys IC Compiler™ II Tool commands. I will have a preset Synopsys IC Compiler™ II Tool command name in mind""" + EN_QA_PROMPT_4_COMMAND

EN_EDAICC2_PUZZLE_BENCHMARK_EVAL_PROMPT = """
You are an EDA expert specializing in Synopsys IC Compiler™ II Tool commands. You will have a preset Synopsys IC Compiler™ II Tool command name in mind""" + EN_EVAL_PROMPT_4_COMMAND_V2

EN_EDAINNOVUSLEGACY_PUZZLE_BENCHMARK_QA_PROMPT = """
You are an EDA expert specializing in Innovus™ Legacy Tool commands. I will have a preset Innovus™ Legacy Tool command name in mind""" + EN_QA_PROMPT_4_COMMAND

EN_EDAINNOVUSLEGACY_PUZZLE_BENCHMARK_EVAL_PROMPT = """
You are an EDA expert specializing in Innovus™ Legacy Tool commands. You will have a preset Innovus™ Legacy Tool command name in mind""" + EN_EVAL_PROMPT_4_COMMAND_V2

EN_EDAINNOVUSCOMMON_PUZZLE_BENCHMARK_QA_PROMPT = """
You are an EDA expert specializing in Innovus™ Common Tool commands. I will have a preset Innovus™ Common Tool command name in mind""" + EN_QA_PROMPT_4_COMMAND

EN_EDAINNOVUSCOMMON_PUZZLE_BENCHMARK_EVAL_PROMPT = """
You are an EDA expert specializing in Innovus™ Common Tool commands. You will have a preset Innovus™ Common Tool command name in mind""" + EN_EVAL_PROMPT_4_COMMAND_V2