ai_agents / modules /reasoning /chain_of_thought.py
jpfearnworks's picture
Decouple components from interface, adds tabs
9d0c72d
raw
history blame
1.65 kB
from langchain import PromptTemplate, LLMChain
import streamlit as st
from .reasoning_strategy import ReasoningStrategy, ReasoningConfig
from typing import Callable
import pprint
class ChainOfThoughtStrategy(ReasoningStrategy):
def __init__(self, config: ReasoningConfig, display: Callable):
super().__init__(config=config, display=display)
print("Creating Reasoning Router with config: ")
pprint.pprint(vars(config))
def run(self, question):
print('Using Chain of Thought')
self.display("Using 'Chain of Thought'")
template_cot = """You are asked a question and rather than simply guessing the right answer break down the solution into a series of staps
The question is {question}
Write out your step by step reasoning and after considering all of the facts and applying this reasoning write out your final answer
"""
prompt = PromptTemplate(template=template_cot, input_variables=["question"])
llm_chain = LLMChain(prompt=prompt, llm=self.llm)
response_cot = llm_chain.run(question)
print(response_cot)
self.display(response_cot)
return response_cot
def get_cot_confg(temperature: float = 0.7) -> ReasoningConfig:
usage = """
This problem is simple and the solution may be obtained by focusing on generating a coherent series
of reasoning steps that lead to the final answer. The approach provides interpretability, decomposes
multi-step problems into intermediate steps, and allows for additional computation allocation
"""
return ReasoningConfig(usage=usage, temperature=temperature)