Status: True
Assertion
The Bermuda Triangle is an area where mysterious disappearances occur.
Reasoning
The Bermuda Triangle exists as an actual geographical region, it has been subject to numerous legends and myths due to the mysterious disappearances that have occurred within its boundaries. However, most of these stories lack concrete scientific evidence and are often based on speculation or exaggeration rather than factual data. The statement is true because it accurately summarizes the main points concerning the Bermuda Triangle’s existence, reputation for unusual events, and the nature of associated legends.
prompt: Is there any credible scientific evidence supporting the claims made in the following passage?
Passage: Some researchers believe that strange electromagnetic forces may be at play within the boundaries of the Bermuda Triangle. However, no concrete scientific evidence has been found to support this claim; many theories about what happens there remain unproven.
Classification: True: The passage suggests that while some hypotheses exist regarding possible explanations for phenomena in the Bermuda Triangle, these are not backed by credible scientific evidence and thus make the statement true: [Explanation].
Classification: False: The passage indicates that there is credible scientific evidence supporting the claims
Assumptions
– The Bermuda Triangle is an actual geographical region with boundaries that can be identified and agreed upon by different parties.
– Mysterious disappearances in this area are significant enough to contribute to its reputation as having unusual circumstances or events occurring within it.
– Many of the stories about these incidents lack scientific evidence, making them more likely due to folklore, myths, or unsubstantiated claims than actual phenomena.
– Natural explanations (e.g., storms, navigational errors, and equipment failures) can account for most of the disappearances in this area.
– The statement does not assert that supernatural causes are responsible for these incidents but acknowledges their presence as a topic of popular belief.
===<|assistant|> – The Bermuda Triangle is an actual geographical region with boundaries that can be identified and agreed upon by different parties.
– Mysterious disappearances in this area are significant enough to contribute to its reputation as having unusual circumstances or events occurring within it.
– Many of the stories about these incidents lack scientific evidence, making them more likely due to folklore, myths, or unsubstantiated claims than actual phenomena.
– Natural
Fact Checker Output
True: The Bermuda Triangle is an actual geographical region with boundaries that can be identified and agreed upon by different parties. This statement is considered true as the Bermuda Triangle refers to a loosely defined area in the Atlantic Ocean bounded by points in Miami, Florida; Bermuda; and Puerto Rico. The exact size and location are not universally agreed upon, but it’s a well-recognized concept used for discussion purposes.
True: Mysterious disappearances in this area are significant enough to contribute to its reputation as having unusual circumstances or events occurring within it. This statement is true; the Bermuda Triangle has gained notoriety due to various incidents and stories of ships and planes vanishing without explanation, which have contributed to a perception that something unexplainable might be happening in this region.
True: Many of the stories about these incidents lack scientific evidence, making them more likely due to folklore, myths, or unsubstantiated claims than actual phenomena. This statement is true; while many disappearances have occurred within the Bermuda Triangle, there’s no concrete evidence suggesting any unique natural phenomenon contributing to these events.
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