propose_prompt = '''[
    {"role":"user", "content":"""You are given a set of numbers. Your task is to choose exactly two of these numbers, and then use one of the basic arithmetic operations (addition +, subtraction -, multiplication *, or division /) to combine them into a new number. Then, replace the two numbers you chose with the result of your calculation, leaving you with one fewer number in the list.

Instructions:
- You must select two different numbers from the list.
- Apply one of the four basic operations (+, -, *, or /).
- Show the result as a new number, and update the list to show the numbers that remain after this step.
- List all possible valid choices for this step as separate lines.

Example Input:
2 8 8 14

Example Output:
2 + 8 = 10
8 / 2 = 4
14 + 2 = 16
2 * 8 = 16
8 - 2 = 6
14 - 8 = 6
14 / 2 = 7
14 - 2 = 12

Task:
Given the input below, list all possible valid next steps according to the instructions above.
Do not use numbered lists! Stick exactly to the formatting as shown above!

Input:
{input}"""}
]
'''

apply_prompt = '''[
    {"role":"user", "content":"""Please carry out the step on the given input.
The result has to be the numbers given in the input that were not used in the lefthand-side of the equation given by step, extended by the newly calculated number.
The order of the numbers does not matter.
As a quick check, the amount of numbers in the input is always exactly one more than in the remaining numbers. E.g. if four input numbers are given, three must remain. If this rule is violated, the approach can never be correct.
Here is how it works:

Input: 2 8 8 14
Step: 2 + 8 = 10
Approach:
1) Remove the use numbers from the input. 2 and 8 were used, input is 2 8 8 14. Removing 2 and 8 once leaves 8 14.
2) Extend the remaining numbers with the result of the equation (10). 8 14 were remaining, which together with 10 gives 8 10 14.
Result: 8 10 14

Input: 2 4 8
Step: 8 / 2 = 4
Approach:
1) Remove the use numbers from the input. 8 and 2 were used, input is 2 4 8. Removing 8 and 2 once leaves 4.
2) Extend the remaining numbers with the result of the equation (4). 4 was remaining, which together with 4 gives 4 4.
Result: 4 4

Input: 12 17
Step: 12 + 17 = 29
Approach:
1) Remove the use numbers from the input. 12 and 17 were used, input is 12 17. Removing 12 and 17 once leaves an empty list.
2) Extend the remaining numbers with the result of the equation (29). An empty list was remaining, which together with 29 gives 29.
Result: 29

Now, here is your input for which you should act accordingly:
Input: {input}
Step: {step}
Approach:"""}
]'''

apply_follow_up_prompt = {"role":"user", "content":\
"""
Now, please answer with just the result and nothing else."""
}


verify_math_prompt = '''[
    {"role":"user", "content":"""Is the calculation correct: " {input} "?"""}
]
'''

verify_leftovers_prompt = '''[
    {"role":"user", "content":"""Check whether the numbers given by Result are the correct numbers. 
They have to be the numbers given in the input that were not used in the equation given in Step, extended by the newly calculated number.
The order of the numbers does not matter.
As a quick check, the amount of numbers in the input is always exactly one more than in the remaining numbers. E.g. if four input numbers are given, three must remain. If this rule is violated, the approach can never be correct.
Here is how it works:

Input: 4 4 6 8
Step: 4 + 8 = 12 
Result: 4 6 12
Reasoning:
Quick check: We have four input numbers, therefore we must have exactly three numbers left. This seems to be the case, so we can continue.
Taking 4 and 8 out of the input 4 4 6 8 leaves 4 6. The calculation gave 12, resulting in 4 6 12. The numbers in Result are 4 6 12, which are the same, so the numbers are correct.

Input: 1 4 8
Step: 1 + 8 = 9
Result: 9
Reasoning:
Quick check: We have three input numbers, therefore we must have exactly two numbers left. However, only 9 was given, which can never be true, so the numbers are incorrect.

Input: 7 12
Step: 12 - 7 = 5
Result: 5
Reasoning:
Quick check: We have two input numbers, so we must have exactly one number left. 5 is given, so the quick check is okay. Let's check the correctness now.
Taking 12 and 7 out of the input 7 12 leaves no numbers. The calculation gave 5, resulting in a set of 5. The numbers in Result are 5, so the numbers are correct.

Now, please apply the same reasoning and rules to this new input and give your best judgment on the correctness:
Input: {input}
Step: {step}
Result: {result}"""},
]
'''

verify_numbers_selection_prompt = '''[
    {"role":"user", "content":"""Check whether the given numerical literal occurences in the LHS of an equation are included in a given input and that only two occurences of literals are there.
Examples:

Input: 2 6 12
Equation: 2 + 6 = 8
Reasoning:
1) Extract literal occurences of LHS.
"2 + 6", gives 2 and 6.
2) Check: Only two literal occurences? 2 and 6 were used, so check passes.
3) Check: Literals in input? 
Removing 2 from input 2 6 12 gives 6 12, continuing.
Removing 6 from 6 12 leaves 12, continuing.
Both removals were possible, so check passes.
Result: Since both checks passed, the literals are correct!

Input: 1 4 8 8
Equation: 1 + 5 = 6
Reasoning:
1) Extract literal occurences of LHS.
"1 + 5" gives 1 and 5.
2) Check: Only two literal occurences? 1 and 5 were used, so check passes.
3) Check: Literals in input?
Removing 1 from 1 4 8 8 leaves 4 8 8, continuing.
Removing 5 from 4 8 8 is not possible, abort!
Result: Since second check failed, the literals are incorrect!

Input: 1 2 3 12
Equation: 1 + (2 - 1) = 2
Reasoning:
1) Extract literal occurences of LHS.
"1 + (2 - 1)" gives 1, 2 and 1.
2) Check: Only two literal occurences? 1, 2 and 1 were used, which are three occurences, abort!
Result: Since first check failed, the literals are incorrect!

Now, apply the same reasoning and logic for the following input and equation. Do not simplify or evaluate any expressions. Count each literal occurence separately!
Input: {input}
Equation: {steps}"""}
]'''

verification_follow_up_prompt = {"role":"user", "content":"Summing up, please give a final answer to only the last problem. Answer with 'yes' you came to the conclusion that it was correct or 'no' if it was incorrect. Answer only with yes or no."}


has_finished_prompt = '''[
    {"role":"user","content":\
"""Does the given input contain a single number, e.g. '21', '1', '120', '2.222', and a single number only? E.g. '12 2', '1 1' or 'a 12' are all wrong, since there are multiple numbers or even letters.
Input: '{input}'
Answer only with yes or no!"""}
]'''

is_solution_prompt = '''[{"role":"user","content": """Please decide whether the string '{input}' shows the number 24 and only the number 24. Answer only with yes or no."""}]'''


value_prompt = '''[
    {"role": "user", "content": """Evaluate if given numbers can reach 24 (sure/likely/impossible).
Here is how you should approach it:

Input: 10 14
Output:
10 + 14 = 24
sure

Input: 11 12
Output:
11 + 12 = 23
12 - 11 = 1
11 * 12 = 132
11 / 12 = 0.91
impossible

Input: 4 4 10
Output:
4 + 4 + 10 = 8 + 10 = 18
4 * 10 - 4 = 40 - 4 = 36
(10 - 4) * 4 = 6 * 4 = 24
sure

Input: 4 9 11
Output:
9 + 11 + 4 = 20 + 4 = 24
sure

Input: 5 7 8
Output:
5 + 7 + 8 = 12 + 8 = 20
(8 - 5) * 7 = 3 * 7 = 21
I cannot obtain 24 now, but numbers are within a reasonable range
likely

Input: 5 6 6
Output:
5 + 6 + 6 = 17
(6 - 5) * 6 = 1 * 6 = 6
I cannot obtain 24 now, but numbers are within a reasonable range
likely

Input: 10 10 11
Output:
10 + 10 + 11 = 31
(11 - 10) * 10 = 10
10 10 10 are all too big
impossible

Input: 1 3 3
Output:
1 * 3 * 3 = 9
(1 + 3) * 3 = 12
1 3 3 are all too small
impossible

Input: {input}
Output:"""}
]'''


value_follow_up_prompt = {"role":"user", "content":"So what is the output to the last problem now? Answer only with (sure/likely/impossible) and nothing else."}


finalize_answer_prompt = '''[
{"role":"user", "content": """Use numbers and basic arithmetic operations (+ - * /) to obtain 24. Each step, you are only allowed to choose two of the remaining numbers to obtain a new number.

Input: 4 4 6 8
Steps:
4 + 8 = 12 (left: 4 6 12)
6 - 4 = 2 (left: 2 12)
2 * 12 = 24 (left: 24)
Answer: (6 - 4) * (4 + 8) = 24
Input: 2 9 10 12
Steps:
12 * 2 = 24 (left: 9 10 24)
10 - 9 = 1 (left: 1 24)
24 * 1 = 24 (left: 24)
Answer: (12 * 2) * (10 - 9) = 24
Input: 4 9 10 13
Steps:
13 - 10 = 3 (left: 3 4 9)
9 - 3 = 6 (left: 4 6)
4 * 6 = 24 (left: 24)
Answer: 4 * (9 - (13 - 10)) = 24
Input: 1 4 8 8
Steps:
8 / 4 = 2 (left: 1 2 8)
1 + 2 = 3 (left: 3 8)
3 * 8 = 24 (left: 24)
Answer: (1 + 8 / 4) * 8 = 24
Input: 5 5 5 9
Steps:
5 + 5 = 10 (left: 5 9 10)
10 + 5 = 15 (left: 9 15)
15 + 9 = 24 (left: 24)
Answer: ((5 + 5) + 5) + 9 = 24

Now, given a new set of steps, please follow the same logic and reasoning. Build the complete equation by correctly nesting all operations with parentheses, and present it in the same format:
Remember, that the equation has to use all the numbers given in input!

Input: {input}
Steps:
{steps}"""}
]'''

finalize_answer_follow_up_prompt = {"role":"user", "content":"So what is the final answer now? Answer only with the equation in plain text (no latex! Use + - / * for the operators) and nothing else."}


shortcut_prompt = '''[
    {"role":"user", "content":"""I need you to carry out a specific task. Here is an example:

Input:
parent = [2 8 9]
child = [7 8]
Approach:
1. Length check: parent has 3 elements, child has 2. Lengths can differ by at most one, continuing
2. Element removal: Try & remove elements from child from parent. First element in child is 7, which is not in parent.
Next element in child is 8, which is in parent. Removing it gives parent = [2 9] and child = [7]. Final results after removing all possible elements is child = [7] and parent = [2 9].
3. Size check. Only two cases are allowed: |parent| == 2 and |child| == 1 (case 1) or |parent| == 1 and |child| == 0 (case 2).
Our parent has two elements and child has one, so we are in case 1. Continuing.
4. **Case 1** Equation search: Can the remaining numbers in parent ([2 9]) be combined with one of the basic arithmetic operators (+-*/) to obtain the remaining number in child ([7])?
Let's see. 
2 - 9 = -7
2 * 9 = 18
9 - 2 = 7 (found it)
Answer: Yes, the equation is 1 + 9 = 10

Input:
parent = [3 6 9 12]
child = [3 9 12]
Approach:
1. Length check: parent has 4 elements, child has 3. Lengths can differ by at most one, continuing
2. Element removal: Try & remove elements from child from parent. First element in child is 3, which is in parent. Removing it gives parent = [6 9 12] and child = [9 12].
Next element in child is 9, which is in parent. Removing it gives parent = [6 12] and child = [12]. 
Next element in child is 12, which is in parent. Removing it gives parent = [6] and child = []. 
Final results after removing all possible elements is parent = [6] and child = [].
3. Size check. Only two cases are allowed: |parent| == 2 and |child| == 1 (case 1) or |parent| == 1 and |child| == 0 (case 2).
Our parent has one element and child has zero, so we are in case 2. Continuing.
4. **Case 2** Equation search: Can the remaining number from parent ([12]) and any of the numbers from the original child ([3 9 12]) be combined with one of the basic arithmetic operators (+-*/) to obtain any of the numbers in child ([3 9 12])?
Let's see. 
3 - 6 = -3
12 + 3 = 15
3 * 9 = 27
12 - 9 = 3 (found it)
Answer: Yes, the equation is 12 - 9 = 3

Try to repeat these steps on this new input. If any of the checks fail, abort and answer "No".
Input:
parent = [{parent}]
child = [{child}]"""}
]'''

shortcut_follow_up_prompt = {"role":"user", "content":"So what is the final move now? Answer only with the equation, including the result, and nothing else."}




io_turns_prompt = '''[
{"role":"user", "content": """Use numbers and basic arithmetic operations (+ - * /) to obtain 24.

Examples:
Input: 4 4 6 8
Output: (4 + 8) * (6 - 4) = 24

Input: 2 9 10 12
Output: 2 * 12 * (10 - 9) = 24

Input 4 9 10 13
Answer: 4 * (9 - (13 - 10)) = 24

Input: 1 4 8 8
Output: (8 / 4 + 1) * 8 = 24

Input 5 5 5 9
Answer: ((5 + 5) + 5) + 9 = 24

Now solve:
Input: {input}"""}
]'''


cot_turns_prompt = '''[
    {"role":"user", "content": """Use numbers and basic arithmetic operations (+ - * /) to obtain 24. Each step, you are only allowed to choose two of the remaining numbers to obtain a new number.

Examples:

Input 4 4 6 8
Steps:
4 + 8 = 12 (left: 4 6 12)
6 - 4 = 2 (left: 2 12)
2 * 12 = 24 (left: 24)
Answer: (6 - 4) * (4 + 8) = 24

Input 2 9 10 12
Steps:
12 * 2 = 24 (left: 9 10 24)
10 - 9 = 1 (left: 1 24)
24 * 1 = 24 (left: 24)
Answer: (12 * 2) * (10 - 9) = 24

Input 4 9 10 13
Steps:
13 - 10 = 3 (left: 3 4 9)
9 - 3 = 6 (left: 4 6)
4 * 6 = 24 (left: 24)
Answer: 4 * (9 - (13 - 10)) = 24

Input 1 4 8 8
Steps:
8 / 4 = 2 (left: 1 2 8)
1 + 2 = 3 (left: 3 8)
3 * 8 = 24 (left: 24)
Answer: (1 + 8 / 4) * 8 = 24

Input 5 5 5 9
Steps:
5 + 5 = 10 (left: 5 9 10)
10 + 5 = 15 (left: 9 15)
15 + 9 = 24 (left: 24)
Answer: ((5 + 5) + 5) + 9 = 24

Now solve:
Input {input}"""},
]'''


finalize_io_follow_up_prompt = {"role":"user", "content":"So what is the final answer now? Answer only with the equation in plain text (no latex! Use + - / * for the operators) and nothing else."}

finalize_io_mixed_follow_up_prompt = {"role":"user", "content":'So what is the final answer now? Answer only with the equation in plain text (no latex! Use + - / * for the operators) or "impossible" and nothing else.'}

io_turns_mixed_prompt = '''[
{"role":"user", "content": """Use numbers and basic arithmetic operations (+ - * /) to obtain 24. Answer "impossible" if no solution exists.

Examples:
Input: 4 4 6 8
Output: (4 + 8) * (6 - 4) = 24

Input: 2 9 10 12
Output: 2 * 12 * (10 - 9) = 24

Input 1 1 2 3
Answer: impossible

Input: 1 4 8 8
Output: (8 / 4 + 1) * 8 = 24

Input 2 4 9 11
Answer: impossible

Now solve:
Input: {input}"""}
]'''

cot_turns_mixed_prompt = '''[
    {"role":"user", "content": """Use numbers and basic arithmetic operations (+ - * /) to obtain 24. Each step, you are only allowed to choose two of the remaining numbers to obtain a new number.

Examples:

Input 4 4 6 8
Steps:
4 + 8 = 12 (left: 4 6 12)
6 - 4 = 2 (left: 2 12)
2 * 12 = 24 (left: 24)
Answer: (6 - 4) * (4 + 8) = 24

Input 2 9 10 12
Steps:
12 * 2 = 24 (left: 9 10 24)
10 - 9 = 1 (left: 1 24)
24 * 1 = 24 (left: 24)
Answer: (12 * 2) * (10 - 9) = 24

Input 1 1 2 3
1 + 2 = 3 (left: 2 2 3)
2 * 3 = 6 (left: 2 6)
2 * 6 = 12 (left: 12)
Answer: impossible

Input 1 4 8 8
Steps:
8 / 4 = 2 (left: 1 2 8)
1 + 2 = 3 (left: 3 8)
3 * 8 = 24 (left: 24)
Answer: (1 + 8 / 4) * 8 = 24

Input 2 4 9 11
2 * 11 = 22 (left: 4 9 22)
22 - 9 = 13 (left: 4 13)
4 * 13 = 52 (left: 52)
not possible, now trying:
2 * 9 = 18 (left: 4 11 18)
11 - 4 = 7 (left: 7 18)
18 - 7 = 11 (left: 11)
not possible, now trying:
4 * 9 = 36 (left: 2 11 36)
36 - 11 = 25 (left: 2 25)
25 - 2 = 23 (left: 23)
...and so on for all permutations and operations.
Answer: impossible

Now solve:
Input {input}"""},
]'''