Status: True
Assertion
The Earth’s surface is covered by roughly 71% water.
Results
The statement is true, as it accurately reflects the composition and distribution of oceanic and continental crust. It acknowledges that both types of crust make up a significant portion of Earth’s surface volume and are integral parts of our planet’s geology. Furthermore, scientific data supports varying percentages for their coverage on Earth’s surface.
Explanation: The statement correctly compares the composition of oceanic (basaltic) and continental crust (granitic), recognizes that both types cover Earth’s surface, includes all surfaces in “total volume,” acknowledges distinct crustal types, and aligns with scientific percentages regarding their coverage.
Assumptions
* The percentage coverage by oceanic crust refers to its direct surface area, not volume or mass contribution relative to continental crust.
* Oceanic and continental crusts are distinctly different types of Earth’s crust.
* “Total volume” includes both land (continental) and underwater (oceanic) areas covered by the crust.
* The statement considers the entire surface area that is part of the ocean, not just the seafloor.
* It assumes a general understanding of Earth’s geological structure with its continental and oceanic crust.
* The figures provided (50% coverage, 61%, 71%) are based on commonly accepted scientific estimations or data sources.
===
Here is a list of assumptions required to support the statement:
* Oceanic and continental crusts have distinct characteristics in terms of composition, thickness, density, and formation processes.
* The Earth’s surface consists of both land (continental) and water (oceanic) surfaces.
* “Total volume” refers to the combined volume of all oceanic and continental areas covered by the crust.
* The statement takes into
Fact Checker Output
1. True – Oceanic crust primarily consists of basaltic rock formed at mid-ocean ridges through volcanic processes, whereas continental crust mainly comprises granitic rocks and has a different origin related to the Earth’s geological history.
2. True – The Earth’s surface includes landmasses (continents) as well as bodies of water (oceans), which are covered by both oceanic and continental crust.
3. True – When discussing “total volume,” it encompasses the entirety of both oceanic and continental surfaces under consideration, rather than focusing solely on one type of surface area.
4. True – The statement assumes a basic understanding of Earth’s geological structure, which acknowledges the existence of distinct types of crust: oceanic (often denser) and continental (typically less dense).
5. True – Percentages such as 50% coverage or specific values like 61%, 71% are generally based on scientific data, models, and estimations derived from various sources, including geological surveys, seafloor mapping, and other research methodologies. These figures aim to
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
import html
# Load environment variables from .env file
load_dotenv()
# Define category IDs
CATEGORY_IDS = {
"True": 2,
"False": 3,
"Debatable": 4,
"Unknown": 6
}
def create_wordpress_post(title, content, category):
data = {
"title": title,
"content": content,
"status": "publish",
"categories": [CATEGORY_IDS[category]]
}
response = requests.post(
os.getenv("WORDPRESS_POSTS_URL"),
json=data,
auth=(os.getenv("WORDPRESS_USERNAME"), os.getenv("WORDPRESS_PASSWORD"))
)
if response.status_code == 201:
print("Blog post created successfully.")
else:
print(f"Failed to create blog post: {response.status_code} - {response.text}")
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):
final_output = final_output.strip()
if "True:" in final_output:
status_start = final_output.find("True:")
status = "True"
elif "False:" in final_output:
status_start = final_output.find("False:")
status = "False"
elif "Debatable:" in final_output:
status_start = final_output.find("Debatable:")
status = "Debatable"
else:
return "Unknown", final_output
reasoning = final_output[status_start + len(status) + 1:].strip()
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)
# 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
model=os.getenv("MODEL_NAME")
)
print("Record inserted into MongoDB successfully.")
except Exception as e:
print(f"Failed to insert record into MongoDB: {e}")
print(final_output)
# 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>Results</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