Fact Check: Coffee stunts your growth.

Status: False

Assertion

Coffee stunts your growth.

Reasoning

The original statement “This statement is false” creates a paradox, also known as the liar’s paradox. If we assume that all assertions listed are true, then this self-referential statement cannot be consistently classified as either true or false without leading to an inconsistency. In other words, it doesn’t fit neatly into any of our predetermined categories because its truthfulness depends on the very assertion it makes about itself.
===
– False: The original statement “This statement is false” creates a paradox, also known as the liar’s paradox. If we assume that all assertions listed are true, then this self-referential statement cannot be consistently classified as either true or false without leading to an inconsistency. In other words, it doesn’t fit neatly into any of our predetermined categories because its truthfulness depends on the very assertion it makes about itself.

Assumptions

<|assistant|> To support the given statements about caffeine’s effects on human growth and sleep patterns, the following assumptions can be made:

Assumptions for statement “This statement is false”:

* The claim that coffee directly stunts human growth lacks scientific evidence or consensus among experts in relevant fields.
* Human growth occurs until an individual reaches their genetically determined height during puberty, and it does not continue throughout a person’s life due to external factors like caffeine consumption.

Assumptions for statement “Caffeine is indeed a stimulant and can affect sleep patterns”:

* Caffeine has the ability to block adenosine receptors in the brain, which plays a role in promoting sleep and relaxation.
* The effects of caffeine on an individual’s sleep pattern may vary depending on factors such as dosage, sensitivity, and personal habits (like regular consumption or tolerance).
* Sleep disruption caused by caffeine can have potential negative consequences for overall health, but other external factors like stress, lifestyle choices, and underlying medical conditions may also play a role.

Fact Checker Output

For the statement “This statement is false,” assume that all assertions listed are true:
<|assistant|> Based on the provided assumptions for the statements, let’s evaluate their truthfulness:

1. The claim that coffee directly stunts human growth lacks scientific evidence or consensus among experts in relevant fields (Assumption): True – As of now, there is no strong scientific evidence supporting a direct causal relationship between caffeine consumption and stunted growth. Research on the subject has produced mixed results, so it’s safe to assume that this statement lacks robust support from the scientific community.
2. Human growth occurs until an individual reaches their genetically determined height during puberty (Assumption): True – This is a widely accepted biological fact; human growth in terms of overall stature typically ends when adolescence and puberty are reached, after which our bodies stop growing taller due to the slowing down of bone development.
3. The effects of caffeine on an individual’s sleep pattern may vary depending on factors such as dosage, sensitivity, and personal habits (Assumption): True – Numerous studies have shown that caffeine can affect

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=__file__,
            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)

Comments

Leave a Reply

Your email address will not be published. Required fields are marked *