Status: True
Assertion
Bees shouldn’t be able to fly.
Reasoning
Bees are insects with wings capable of flight, a trait that distinguishes them from non-flying insect species and serves as an evolutionary advantage in their ecological roles. This ability allows bees to efficiently collect nectar and pollen, which is crucial for the survival of the colony and also contributes significantly to plant pollination.
– True: The primary role of flight in bee species indeed centers on gathering food resources such as nectar from flowers and pollen from plants. This behavior not only supports their own nutritional needs but is pivotal for the ecological process of cross-pollination, aiding plant reproduction and biodiversity.
– False: Although there are insect species that lack flight capabilities, this does not apply to bees as a whole. Bees belong to an order characterized by their ability to fly and exhibit complex aerial maneuvers. The statement incorrectly generalizes the flying abilities of all insects based on certain exceptions, which is misleading when specifically discussing bee species.
–
Assumptions
<|assistant|> – Bees are insects with wings capable of flight.
– The primary purpose of flying for bees is gathering nectar and pollen from flowers for food and reproduction purposes.
– While some other species of insects, like certain ants or cockroaches, do not fly, this does not apply to all insect groups, including bees.
– Bee flight abilities are unique among many insect groups, with speeds up to 20 miles per hour being possible.
– Visual cues and air currents play a crucial role in bees’ navigation while flying.
– Environmental changes or weather conditions can impact the ease of bee flight but do not negate their capability to fly.
– The statement refutes any notion that suggests bees are unable to fly, highlighting their true ability and importance in pollination ecosystems.
Fact Checker Output
<|assistant|> – True: Bees are insects with wings capable of flight. This is a well-known characteristic of bees that allows them to perform vital functions such as foraging and pollination.
– True: The primary purpose of flying for bees is gathering nectar and pollen from flowers for food and reproduction purposes. Bees collect these resources which they use to nourish themselves, their larvae, and to produce honey in some species.
– False: While it’s true that some other species of insects do not fly (like certain ants or cockroaches), this does not apply to all insect groups. Insects are a diverse group with various adaptations; however, many have evolved the ability to fly and bees are no exception within their own classification.
– True: Bee flight abilities are unique among many insect groups, with speeds up to 20 miles per hour being possible for some species like honeybees. This is not common in all flying insects but demonstrates the specialization and efficiency of bees’ flight capabilities.
– True: Visual cues and air currents play a crucial role in be
Model Used
microsoft/Phi-3-mini-4k-instruct-gguf
Script Name
fact_checker_mongodb.py
Script Code
import os
import sys
import requests
from langchain_openai.llms import OpenAI
from langchain.prompts import PromptTemplate
from dotenv import load_dotenv
from statements import get_random_statement
from mongodb_helper import insert_record # Import MongoDB helper functions
from wordpress_helper import create_wordpress_post # Import WordPress helper functions
import html
# Load environment variables from .env file
load_dotenv()
def fact_check(assertion):
llm = OpenAI(temperature=0.7, model=os.getenv("MODEL_NAME"))
# Define the prompt templates
assertion_template = """{assertion}\n\n"""
assertion_prompt = PromptTemplate(input_variables=["assertion"], template=assertion_template)
assumptions_template = """Here is a statement:
{statement}
Make a bullet point list of the assumptions required to support the above statement.\n\n"""
assumptions_prompt = PromptTemplate(input_variables=["statement"], template=assumptions_template)
fact_checker_template = """Here is a bullet point list of assertions:
{assertions}
For each assumption, determine whether it is true or false. Explain your reasoning.\n\n"""
fact_checker_prompt = PromptTemplate(input_variables=["assertions"], template=fact_checker_template)
answer_template = """
Here is the information to classify the statement:
{facts}
Based on the above information, how would you classify the statement? Respond with one of the following options followed by a colon and space:
- True: [Explanation]
- False: [Explanation]
- Debatable: [Explanation]
"""
answer_prompt = PromptTemplate(input_variables=["facts"], template=answer_template)
# Format prompts and extract the string content
formatted_assertion = assertion_prompt.format_prompt(assertion=assertion).text
assertion_output = llm.invoke(formatted_assertion)
formatted_assumptions = assumptions_prompt.format_prompt(statement=assertion_output).text
assumptions_output = llm.invoke(formatted_assumptions)
formatted_fact_checker = fact_checker_prompt.format_prompt(assertions=assumptions_output).text
fact_checker_output = llm.invoke(formatted_fact_checker)
formatted_answer = answer_prompt.format_prompt(facts=fact_checker_output).text
final_output = llm.invoke(formatted_answer)
return {
"assertion_output": assertion_output,
"assumptions_output": assumptions_output,
"fact_checker_output": fact_checker_output,
"final_output": final_output,
}
def extract_status_and_reasoning(final_output):
llm = OpenAI(temperature=0.7, model=os.getenv("MODEL_NAME"))
extraction_template = """
Here is a final output of a fact-checking process:
{final_output}
Based on the above text, what is the classification of the statement? Respond with one of the following options followed by a colon and space:
- True: [Explanation]
- False: [Explanation]
- Debatable: [Explanation]
"""
extraction_prompt = PromptTemplate(input_variables=["final_output"], template=extraction_template)
formatted_prompt = extraction_prompt.format_prompt(final_output=final_output).text
extraction_output = llm.invoke(formatted_prompt).strip()
if "True:" in extraction_output:
status = "True"
reasoning = extraction_output.split("True:", 1)[1].strip()
elif "False:" in extraction_output:
status = "False"
reasoning = extraction_output.split("False:", 1)[1].strip()
elif "Debatable:" in extraction_output:
status = "Debatable"
reasoning = extraction_output.split("Debatable:", 1)[1].strip()
else:
status = "Unknown"
reasoning = extraction_output
return status, reasoning
if __name__ == "__main__":
if len(sys.argv) > 1:
assertion = sys.argv[1]
else:
assertion = get_random_statement()
print(assertion)
submission = fact_check(assertion)
# Print the detailed outputs to inspect their structure
for key, value in submission.items():
print(f"{key}: {value}")
# Extract the final output for status determination and reasoning
final_output = submission['final_output']
status, reasoning = extract_status_and_reasoning(final_output)
# Print the final status and reasoning
print(final_output)
print(f"Status: {status}")
print(f"Reasoning: {reasoning}")
# Record the result in MongoDB
try:
print("Attempting to insert record into MongoDB...")
insert_record(
script_name="fact_checker_mongodb.py",
script_code=html.escape(open(__file__).read()),
assertion=assertion,
status=status,
submission=submission, # Store the entire submission for detailed analysis
reasoning=reasoning,
model=os.getenv("MODEL_NAME")
)
print("Record inserted into MongoDB successfully.")
except Exception as e:
print(f"Failed to insert record into MongoDB: {e}")
# Create a blog post on WordPress
blog_title = f"Fact Check: {assertion}"
blog_content = f"""
<h1>Status: {status}</h1>
<h2>Assertion</h2>
<p>{assertion}</p>
<h2>Reasoning</h2>
<p>{reasoning}</p>
<h3>Assumptions</h3>
<p>{submission['assumptions_output']}</p>
<h3>Fact Checker Output</h3>
<p>{submission['fact_checker_output']}</p>
<h4>Model Used</h4>
<p>{os.getenv("MODEL_NAME")}</p>
<h4>Script Name</h4>
<p>fact_checker_mongodb.py</p>
<h4>Script Code</h4>
<pre>{html.escape(open(__file__).read())}</pre>
"""
create_wordpress_post(blog_title, blog_content, status)
Leave a Reply