Chain-of-thought and self-consistency prompting

ChatGPT Prompt Engineering for Developers

Fouad Trad

Machine Learning Engineer

Chain-of-thought prompting

  • Requires LLMs to provide reasoning steps (thoughts) before giving answer
  • Used for complex reasoning tasks
  • Help reduce model errors

Image showing how a chain-of-thought prompt asks the model to solve a problem step by step, and the output contains the reasoning for each step followed.

ChatGPT Prompt Engineering for Developers

Chain-of-thought prompting

Standard prompting to solve a reasoning task
prompt = """Q: You start with 15 books in your collection. At the bookstore, you 
purchase 8 new books. Then, you lend 3 to your friend and 2 to your cousin. Later, 
you visit another bookstore and buy 5 more books. How many books do you have now? 
A: The answer is"""

print(get_response(prompt))
25 books
ChatGPT Prompt Engineering for Developers

Chain-of-thought prompting

Chain-of-thought prompting to solve a reasoning task
prompt = """Q: You start with 15 books in your collection. At the bookstore, you 
purchase 8 new books. Then, you lend 3 to your friend and 2 to your cousin. Later, 
you visit another bookstore and buy 5 more books. How many books do you have now? 
A: Let's think step by step""" 
print(get_response(prompt))
Step 1: Start with the number of books in your collection: 15 books
Step 2: Purchase 8 new books at the bookstore: 15 + 8 = 23 books
Step 3: Lend 3 books to your friend: 23 - 3 = 20 books
Step 4: Lend 2 books to your cousin: 20 - 2 = 18 books
Step 5: Visit another bookstore and buy 5 more books: 18 + 5 = 23 books
Therefore, you have 23 books now.
ChatGPT Prompt Engineering for Developers

Chain-of-thought prompting with few-shots

example = """
Q: The odd numbers in this group add up to an even number:  9, 10, 13, 4, 2.
A: Adding all the odd numbers (9, 13) gives 22. The answer is True.
"""

question = """ Q: The odd numbers in this group add up to an even number: 15, 13, 82, 7. A: """
prompt = example + question print(get_response(prompt))
Adding all the odd numbers (15, 13, 7) gives 35. The answer is False.
ChatGPT Prompt Engineering for Developers

Chain-of-thought versus multi-step prompting

Multi-step prompts

  • Incorporate steps inside the prompt

Diagram showing that a multi-step prompt is a prompt that gives the model a series of sequential steps to perform.

ChatGPT Prompt Engineering for Developers

Chain-of-thought versus multi-step prompting

Multi-step prompts

  • Incorporate steps inside the prompt

Diagram showing that a multi-step prompt is a prompt that gives the model a series of sequential steps to perform.

Chain-of-thought prompts

  • Ask model to generate intermediate steps

Image showing that in chain-of-thought prompts, the steps are produced by the model while generating the output.

ChatGPT Prompt Engineering for Developers

Chain-of-thought limitation

  • One unsuccessful thought --> unsuccessful outcome
  • Self-consistency prompts were introduced

Diagram for a chain-of-thought prompt highlighting that one thought with flawed reasoning will lead to an unsuccessful outcome.

ChatGPT Prompt Engineering for Developers

Self-consistency prompting

  • Generates multiple chain-of-thoughts by prompting the model several times
  • Majority vote to obtain final output

Image showing that a self-consistency prompt is just about multiple chain-of-thoughts, each of which having an output, and the final outcome is obtained by majority vote.

ChatGPT Prompt Engineering for Developers

Self-consistency prompting

Can be done by defining multiple prompts or a prompt generating multiple responses.

self_consistency_instruction = "Imagine three completely independent experts who 
reason differently are answering this question. The final answer is obtained by 
majority vote. The question is: "

problem_to_solve = "If there are 10 cars in the parking lot and 3 more cars arrive. Half the original number of cars leave. Then, half of the current number of cars arrive. How many cars are there in the parking?"
prompt = self_consistency_instruction + problem_to_solve print(get_response(prompt))
ChatGPT Prompt Engineering for Developers

Self-consistency prompt

Expert 1: Let's go step by step [...] Therefore, the total number of cars in the 
parking lot is 8 + 4 = 12.

Expert 2: First, let's calculate [...] Therefore, the total number of cars in the 
parking lot is now 5 + 2 = 7 cars.

Expert 3: Initially, there are 10 cars [...] Thus, the final answer is 8 + 4 = 12 
cars in the parking lot.

Based on the majority vote, the final answer is that there are 12 cars in the 
parking lot.
ChatGPT Prompt Engineering for Developers

Let's practice!

ChatGPT Prompt Engineering for Developers

Preparing Video For Download...