Fact Check: Octopuses have three hearts.

Status: True

Assertion

Octopuses have three hearts.

Results

<|assistant|> Based on the provided information, I would classify the statement as “True.” The multiple hearts in *Octopus vulgaris* serve distinct functions that align with their physiological needs and active lifestyle. Each heart plays a role in circulation or respiration, which is essential for an organism living in a water environment where oxygen availability can vary.

Assumptions

<|assistant|> – The common octopus, *Octopus vulgaris*, possesses multiple hearts as an adaptation for its physiological needs and lifestyle.
– Each heart within *Octopus vulgaris* has a specific function related to circulation or respiration.
– Two branchial hearts are responsible for pumping blood through the gills, which is necessary for oxygenating the blood in an aquatic environment.
– The third heart circulates blood throughout the octopus’s body, ensuring efficient distribution and waste removal from tissues.
– Octopuses lead active lifestyles that demand high levels of metabolic activity requiring effective circulation systems.
– Respiratory efficiency in *Octopus vulgaris* is lower compared to terrestrial animals such as humans due to the direct gas exchange with water.
– The adaptation of multiple hearts helps compensate for the less efficient respiratory system by enhancing oxygenation and waste removal processes.
– The circulatory and respiratory systems in aquatic organisms like *Octopus vulgaris* operate differently from terrestrial animals, necessitating unique adaptations such as multiple hearts to meet physiological demands.

Fact Checker Output

Tutor: – True: The common octopus, *Octopus vulgaris*, does possess multiple hearts. This adaptation allows for more efficient circulation and respiration in an aquatic environment where they live. Each heart has a specific function related to their needs.
– True: Within *Octopus vulgaris*, each heart indeed has a particular role concerning blood flow or oxygen uptake, which is necessary due to the nature of their physiological processes and lifestyle.
– True: The two branchial hearts are responsible for pumping blood through the gills in *Octopus vulgaris*. This process is crucial as it enables them to extract dissolved oxygen from water, which is essential for respiration given the direct gas exchange with their environment.
– True: There is a third heart that circulates blood throughout the octopus’s body. This function supports efficient distribution of nutrients and removal of waste products in tissues, contributing to overall metabolic health.
– True: Octopuses lead active lives which demand high levels of metabolic activity; therefore, an effective circulatory system is necessary for maintaining their lifestyle. Their multiple hearts are a significant adaptation that

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
}

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)

    # 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:
    - True
    - False
    - Debatable
    """
    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(final_output):
    final_output = final_output.lower().strip()
    if "true" in final_output:
        return "True"
    elif "false" in final_output:
        return "False"
    elif "debatable" in final_output:
        return "Debatable"
    else:
        return "Unknown"

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
    final_output = submission['final_output']
    
    # Determine the status based on the final output text
    status = extract_status(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>{final_output}</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 *