AI That Is aware of When to Double-Examine

Giant language fashions possess transformative capabilities throughout numerous duties however typically produce responses with factual inaccuracies as a consequence of their reliance on parametric data. Retrieval-Augmented Technology was launched to deal with this by incorporating related exterior data. Nevertheless, typical RAG strategies retrieve a hard and fast variety of passages with out adaptability, resulting in irrelevant or inconsistent outputs. To beat these limitations, Self-Reflective Retrieval-Augmented Technology (Self-RAG) was developed. Self-RAG enhances LLM high quality and factuality by way of adaptive retrieval and self-reflection utilizing reflection tokens, permitting fashions to tailor their habits to various duties. This text explores Self-RAG, its working, benefits, and implementation utilizing LangChain.

Studying Targets

  • Perceive the restrictions of normal Retrieval-Augmented Technology (RAG) and the way they impression LLM efficiency.
  • Learn the way Self-RAG enhances factual accuracy utilizing on-demand retrieval and self-reflection mechanisms.
  • Discover the position of reflection tokens (ISREL, ISSUP, ISUSE) in bettering output high quality and relevance.
  • Uncover some great benefits of customizable retrieval and adaptive habits in Self-RAG.
  • Acquire insights into implementing Self-RAG with LangChain and LangGraph for real-world functions.

This text was printed as part of the Knowledge Science Blogathon.

Downside with Normal RAG

Whereas RAG mitigates factual inaccuracies in LLMs utilizing exterior data, however has limitations. Normal RAG approaches endure from a number of key issues:

  • Indiscriminate Retrieval: RAG retrieves a hard and fast variety of paperwork, no matter relevance or want. This wastes assets and may introduce irrelevant info which causes lower-quality outputs.
  • Lack of Adaptability: Normal RAG strategies don’t modify to completely different process necessities. They lack the management to find out when and the way a lot to retrieve, not like Self-RAG which may adapt retrieval frequency.
  • Inconsistency with Retrieved Passages: The generated output typically fails to align with the retrieved info as a result of the fashions lack express coaching to make use of it.
  • No Self-Analysis or Critique: RAG doesn’t consider the standard or relevance of retrieved passages, nor does it critique its output. It blindly incorporates passages, not like Self-RAG which does a self-assessment.
  • Restricted Attribution: Normal RAG doesn’t supply detailed citations or point out if the generated textual content is supported by the sources. Self-RAG, in distinction, supplies detailed citations and assessments.

Briefly, commonplace RAG’s inflexible method to retrieval, lack of self-evaluation, and inconsistency restrict its effectiveness. highlighting the necessity for a extra adaptive and self-aware methodology like Self-RAG.

Introducing Self-RAG

Self-reflective retrieval-augmented Technology (Self-RAG) improves the standard and factuality of LLMs by incorporating retrieval and self-reflection mechanisms. In contrast to conventional RAG strategies, Self-RAG trains an arbitrary LM to adaptively retrieve passages on demand. It generates textual content knowledgeable by these passages and critiques its output utilizing particular reflection tokens.

Listed below are the important thing parts and traits of Self-RAG:

  • On-Demand Retrieval: It retrieves passages on-demand utilizing a “retrieve token,” solely when wanted, which makes it extra environment friendly than commonplace RAG.
  • Use Reflection Tokens: It makes use of particular reflection tokens (each retrieval and critique tokens) to evaluate its technology course of. Retrieval tokens sign the necessity for retrieval. Critique tokens consider the relevance of retrieved passages (ISREL), the help supplied by passages to the output (ISSUP), and the general utility of the response (ISUSE).
  • Self-Critique and Analysis: Self-RAG critiques its personal output, assessing the relevance and help of retrieved passages, and the general high quality of the generated response.
  • Practice Finish-to-Finish: The mannequin generates each the output and reflection tokens by utilizing a critic mannequin offline to create reflection tokens, which it then incorporates into the coaching information. This eliminates the necessity for a critic throughout inference.
  • Allow Customizable Decoding: Self-RAG permits for versatile adjustment of retrieval frequency and adaptation to completely different duties, enabling exhausting or tender constraints through reflection tokens. This permits for test-time customizations (e.g. balancing quotation precision and completeness) with out retraining.

How Self-RAG Works

Allow us to now dive deeper into how self RAG works:

Enter Processing and Retrieval Choice

Self-RAG begins by evaluating the enter immediate (x) and any previous generations (y<t) to find out if exterior data is critical. In contrast to commonplace RAG, which all the time retrieves paperwork, Self-RAG makes use of a retrieve token to determine whether or not to retrieve, to not retrieve, or to proceed utilizing beforehand retrieved proof.

This on-demand retrieval makes Self-RAG extra environment friendly by solely retrieving when wanted and continuing on to output technology if retrieval is pointless.

Retrieval of Related Passages

If the mannequin decides retrieval is required (Retrieve = Sure), it fetches related passages from a large-scale assortment of paperwork utilizing a retriever mannequin (R).

  • The retrieval is predicated on the enter immediate and the previous generations.
  • The retriever mannequin (R) is usually an off-the-shelf mannequin like Contriever-MS MARCO.
  • The system retrieves a number of passages (Okay passages) in parallel, which is not like commonplace RAG that makes use of a hard and fast variety of passages.

Parallel Processing and Section Technology

The generator mannequin processes every retrieved passage in parallel, producing a number of continuation candidates.

  • For every passage, the mannequin generates the subsequent response section, together with its critique tokens.
  • This step leads to Okay completely different continuation candidates, every related to a retrieved passage and critique tokens.

Self-Critique and Analysis with Reflection Tokens

For every retrieved passage, Self-RAG generates critique tokens to judge its personal predictions. These critique tokens embrace:

  • Relevance token (ISREL): Evaluates whether or not the retrieved passage supplies helpful info to resolve the enter (x). The output is both Related or Irrelevant.
  • Assist token (ISSUP): This token evaluates whether or not the generated section (yt) is supported by the retrieved passage (d), with the output indicating full help, partial help, or no help.
  • Utility token (ISUSE): Judges if the response is a helpful reply to the enter (x), unbiased of the retrieved passages. The output is on a scale of 1 to five, with 5 being probably the most helpful.

The mannequin generates reflection tokens as a part of its subsequent token prediction course of and makes use of the critique tokens to evaluate and rank the generated segments.

Self-Critique and Evaluation with Reflection Tokens

Choice of the Finest Section and Output

Self-RAG makes use of a segment-level beam search to establish the most effective output sequence. The rating of every section is adjusted utilizing a critic rating that’s primarily based on the weighted chances of the critique tokens.

These weights will be adjusted for various duties. For instance, the next weight will be given to ISSUP for duties requiring excessive factual accuracy. The mannequin also can filter out segments with undesirable critique tokens.

Coaching Course of

The Self-RAG mannequin is educated in an end-to-end method, with two levels:

  • Critic Mannequin Coaching: First, researchers prepare a critic mannequin (C) to generate reflection tokens primarily based on enter, retrieved passages, and generated textual content. They prepare this critic mannequin on information collected by prompting GPT-4 and use it offline throughout generator coaching.
  • Generator Mannequin Coaching: The generator mannequin (M) is educated utilizing an ordinary subsequent token prediction goal, utilizing information augmented with reflection tokens from the critic (C) and retrieved passages. The generator learns to foretell each process outputs and the reflection tokens.

Key Benefits of Self-RAG

There are a number of key benefits of Self-RAG, together with:

  • On-demand retrieval reduces factual errors by retrieving exterior data solely when wanted.
  • By evaluating its personal output and selecting the right section, it achieves greater factual accuracy in comparison with commonplace LLMs and RAG fashions.
  • Self-RAG maintains the flexibility of LMs by not all the time counting on retrieved info.
  • Adaptive retrieval with a threshold permits the mannequin to dynamically modify retrieval frequency for various functions.
  • Self-RAG cites every section and assesses whether or not the output is supported by the passage, making truth verification simpler.
  • Coaching with a critic mannequin offline eliminates the necessity for a critic mannequin throughout inference, lowering overhead.
  • The usage of reflection tokens allows controllable technology throughout inference, permitting the mannequin to adapt its habits.
  • The mannequin’s use of a segment-level beam search permits for the number of the most effective output at every step, combining technology with self-evaluation.

Implementation of Self-RAG Utilizing LangChain and LangGraph

Beneath we are going to comply with the steps of self-RAG utilizing LangChain and LangGraph:

Step 1: Dependencies Setup

The system requires a number of key libraries:

  • `duckdeckgo-search`: For internet search capabilities
  • `langgraph`: For constructing workflow graphs
  • `faiss-gpu`: For vector similarity search
  • `langchain` and `langchain-openai`: For LLM operations
  • Further utilities: `pydantic` and `typing-extensions`
!pip set up langgraph pypdf langchain langchain-openai pydantic typing-extensions
!pip set up langchain-community
!pip set up faiss-cpu 

Output

Amassing langgraph
  Downloading langgraph-0.2.62-py3-none-any.whl.metadata (15 kB)
Requirement already happy: langchain-core (from langgraph) (0.3.29)
Amassing langgraph-checkpoint<3.0.0,>=2.0.4 (from langgraph)
  Downloading langgraph_checkpoint-2.0.10-py3-none-any.whl.metadata (4.6 kB)
Amassing langgraph-sdk<0.2.0,>=0.1.42 (from langgraph)
.
.
.
.
.
Downloading langgraph-0.2.62-py3-none-any.whl (138 kB)
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 138.2/138.2 kB 4.0 MB/s eta 0:00:00
Downloading langgraph_checkpoint-2.0.10-py3-none-any.whl (37 kB)
Downloading langgraph_sdk-0.1.51-py3-none-any.whl (44 kB)
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 44.7/44.7 kB 2.6 MB/s eta 0:00:00
Putting in collected packages: langgraph-sdk, langgraph-checkpoint, langgraph tiktoken, langchain-openai faiss-cpu-1.9.0.post1
Efficiently put in langgraph-0.2.62 langgraph-checkpoint-2.0.10 langgraph-sdk-0.1.51 langchain-openai-0.3.0 tiktoken-0.8.0

Step 2: Surroundings Configuration

Imports obligatory libraries for typing, information dealing with:

import os
from google.colab import userdata
from typing import Record, Non-obligatory
from typing_extensions import TypedDict
from pprint import pprint

from langchain_core.pydantic_v1 import BaseModel, Area

from langchain_openai import OpenAIEmbeddings
from langchain.document_loaders import CSVLoader
from langchain.text_splitter import RecursiveCharacterTextSplitter
from langchain.vectorstores import FAISS

from langgraph.graph import END, StateGraph, START

Units up OpenAI API key from consumer information:

# Set OpenAI API key
os.environ["OPENAI_API_KEY"] = userdata.get('OPENAI_API_KEY')

Step 3: Knowledge Fashions Definition

Creates three evaluator courses utilizing Pydantic:

  • `SourceEvaluator`: Assesses if paperwork are related to the query
  • `AccuracyEvaluator`: Checks if generated solutions are factually grounded
  • `CompletionEvaluator`: Verifies if solutions absolutely deal with questions

Additionally defines `WorkflowState` to keep up workflow state together with:

  • Query textual content
  • Generated response
  • Retrieved paperwork
# Set OpenAI API key
os.environ["OPENAI_API_KEY"] = userdata.get('OPENAI_API_KEY')

# Step 3: Outline Knowledge Fashions
from langchain_core.pydantic_v1 import BaseModel, Area

class SourceEvaluator(BaseModel):
    """Evaluates doc relevance to the query"""
    rating: str = Area(description="Paperwork are related to the query, 'sure' or 'no'")

class AccuracyEvaluator(BaseModel):
    """Evaluates whether or not technology is grounded in details"""
    rating: str = Area(description="Reply is grounded within the details, 'sure' or 'no'")

class CompletionEvaluator(BaseModel):
    """Evaluates whether or not reply addresses the query"""
    rating: str = Area(description="Reply addresses the query, 'sure' or 'no'")

class WorkflowState(TypedDict):
    """Defines the state construction for the workflow graph"""
    query: str
    technology: Non-obligatory[str]
    paperwork: Record[str]

Step 4: Doc Processing Setup

Implements doc dealing with pipeline:

  • Initializes OpenAI embeddings
  • Obtain the dataset.
  • Hundreds paperwork from CSV file
  • Splits paperwork into manageable chunks
  • Creates FAISS vector retailer for environment friendly retrieval
  • Units up doc retriever
# Initialize embeddings
embeddings = OpenAIEmbeddings()

# Load and course of paperwork
loader = CSVLoader("/content material/information.csv")
paperwork = loader.load()

# Cut up paperwork
text_splitter = RecursiveCharacterTextSplitter(chunk_size=500, chunk_overlap=0)
paperwork = text_splitter.split_documents(paperwork)

# Create vectorstore
vectorstore = FAISS.from_documents(paperwork, embeddings)
retriever = vectorstore.as_retriever()

Step 5: Evaluator Configuration

Units up three analysis chains:

  • Doc Relevance Evaluator:
    • Assesses key phrase and semantic relevance
    • Produces binary sure/no scores
  • Accuracy Evaluator:
    • Checks if technology is supported by details
    • Makes use of retrieved paperwork as floor fact
  • Completion Evaluator:
    • Verifies reply completeness
    • Ensures query is absolutely addressed
# Doc relevance evaluator
source_system_prompt = """You're an evaluator assessing relevance of retrieved paperwork to consumer questions.
    If the doc accommodates key phrases or semantic which means associated to the query, grade it as related.
    Give a binary rating 'sure' or 'no' to point doc relevance."""

source_evaluator = (
    ChatPromptTemplate.from_messages([
        ("system", source_system_prompt),
        ("human", "Retrieved document: nn {document} nn User question: {question}")
    ]) | llm.with_structured_output(SourceEvaluator)
)

# Accuracy evaluator
accuracy_system_prompt = """You're an evaluator assessing whether or not an LLM technology is grounded in retrieved details.
    Give a binary rating 'sure' or 'no'. 'Sure' means the reply is supported by the details."""
    
accuracy_evaluator = (
    ChatPromptTemplate.from_messages([
        ("system", accuracy_system_prompt),
        ("human", "Set of facts: nn {documents} nn LLM generation: {generation}")
    ]) | llm.with_structured_output(AccuracyEvaluator)
)

# Completion evaluator
completion_system_prompt = """You're an evaluator assessing whether or not a solution addresses/resolves a query.
    Give a binary rating 'sure' or 'no'. 'Sure' means the reply resolves the query."""
    
completion_evaluator = (
    ChatPromptTemplate.from_messages([
        ("system", completion_system_prompt),
        ("human", "User question: nn {question} nn LLM generation: {generation}")
    ]) | llm.with_structured_output(CompletionEvaluator)
)

Step 6: RAG Chain Setup

Creates the core RAG pipeline:

  • Defines template for context and query
  • Chains template with LLM
  • Implements string output parsing
# Step 6: Set Up RAG Chain
from langchain_core.output_parsers import StrOutputParser

template = """You're a useful assistant that solutions questions primarily based on the next context:
    Context: {context}
    Query: {query}
    Reply:"""
    
rag_chain = (
    ChatPromptTemplate.from_template(template) | 
    llm | 
    StrOutputParser()
)

Step 7: Workflow Features

Implements key workflow capabilities:

  • `retrieve`: Will get related paperwork for question
  • `generate`: Produces reply utilizing RAG
  • `evaluate_documents`: Filters related paperwork
  • `check_documents`: Choice level for technology
  • `evaluate_generation`: High quality evaluation of technology
# Step 7: Outline Workflow Features
def retrieve(state: WorkflowState) -> WorkflowState:
    """Retrieve related paperwork for the query"""
    print("---RETRIEVE---")
    paperwork = retriever.get_relevant_documents(state["question"])
    return {"paperwork": paperwork, "query": state["question"]}

def generate(state: WorkflowState) -> WorkflowState:
    """Generate reply utilizing RAG"""
    print("---GENERATE---")
    technology = rag_chain.invoke({
        "context": state["documents"],
        "query": state["question"]
    })
    return {**state, "technology": technology}

def evaluate_documents(state: WorkflowState) -> WorkflowState:
    """Consider doc relevance"""
    print("---CHECK DOCUMENT RELEVANCE TO QUESTION---")
    filtered_docs = []
    
    for doc in state["documents"]:
        rating = source_evaluator.invoke({
            "query": state["question"],
            "doc": doc.page_content
        })
        
        if rating.rating == "sure":
            print("---EVALUATION: DOCUMENT RELEVANT---")
            filtered_docs.append(doc)
        else:
            print("---EVALUATION: DOCUMENT NOT RELEVANT---")
            
    return {"paperwork": filtered_docs, "query": state["question"]}

def check_documents(state: WorkflowState) -> str:
    """Determine whether or not to proceed with technology"""
    print("---ASSESS EVALUATED DOCUMENTS---")
    if not state["documents"]:
        print("---DECISION: NO RELEVANT DOCUMENTS FOUND---")
        return "no_relevant_documents"
    print("---DECISION: PROCEED WITH GENERATION---")
    return "generate"

def evaluate_generation(state: WorkflowState) -> str:
    """Consider technology high quality"""
    print("---CHECK ACCURACY---")
    
    accuracy_score = accuracy_evaluator.invoke({
        "paperwork": state["documents"],
        "technology": state["generation"]
    })
    
    if accuracy_score.rating == "sure":
        print("---DECISION: GENERATION IS ACCURATE---")
        
        completion_score = completion_evaluator.invoke({
            "query": state["question"],
            "technology": state["generation"]
        })
        
        if completion_score.rating == "sure":
            print("---DECISION: GENERATION ADDRESSES QUESTION---")
            return "acceptable"
        print("---DECISION: GENERATION INCOMPLETE---")
        return "not_acceptable"
        
    print("---DECISION: GENERATION NEEDS IMPROVEMENT---")
    return "retry_generation"

Step 8: Workflow Building

Builds workflow graph:

  • Creates StateGraph with outlined state construction
  • Provides processing nodes
  • Defines edges and conditional paths
  • Compiles workflow into executable app
# Construct workflow
workflow = StateGraph(WorkflowState)

# Add nodes
workflow.add_node("retrieve", retrieve)
workflow.add_node("evaluate_documents", evaluate_documents)
workflow.add_node("generate", generate)

# Add edges
workflow.add_edge(START, "retrieve")
workflow.add_edge("retrieve", "evaluate_documents")

workflow.add_conditional_edges(
    "evaluate_documents",
    check_documents,
    {
        "generate": "generate",
        "no_relevant_documents": END,
    }
)

workflow.add_conditional_edges(
    "generate",
    evaluate_generation,
    {
        "retry_generation": "generate",
        "acceptable": END,
    }
)

# Compile
app = workflow.compile()

Step 9: Testing Implementation

Assessments system with two situations:

  • Related question (mortgage-related)
  • Unrelated question (quantum computing)
# Step 9: Check the System
# Check with mortgage-related question
test_question1 = "clarify the completely different parts of mortgage curiosity"
print("nTesting query 1:", test_question1)
print("=" * 80)

for output in app.stream({"query": test_question1}):
    for key, worth in output.objects():
        pprint(f"Node '{key}':")
    pprint("n---n")

if "technology" in worth:
    pprint(worth["generation"])
else:
    pprint("No related paperwork discovered or no technology produced.")

# Check with unrelated question
test_question2 = "describe the basics of quantum computing"
print("nTesting query 2:", test_question2)
print("=" * 80)

for output in app.stream({"query": test_question2}):
    for key, worth in output.objects():
        pprint(f"Node '{key}':")
    pprint("n---n")

if "technology" in worth:
    pprint(worth["generation"])
else:
    pprint("No related paperwork discovered or no technology produced.")

Output:

Testing query 1: clarify the completely different parts of mortgage curiosity
================================================================================
---RETRIEVE---
"Node 'retrieve':"
'n---n'
---CHECK DOCUMENT RELEVANCE TO QUESTION---
---EVALUATION: DOCUMENT RELEVANT---
---EVALUATION: DOCUMENT RELEVANT---
---EVALUATION: DOCUMENT RELEVANT---
---EVALUATION: DOCUMENT RELEVANT---
---ASSESS EVALUATED DOCUMENTS---
---DECISION: PROCEED WITH GENERATION---
"Node 'evaluate_documents':"
'n---n'
---GENERATE---
---CHECK ACCURACY---
---DECISION: GENERATION IS ACCURATE---
---DECISION: GENERATION ADDRESSES QUESTION---
"Node 'generate':"
'n---n'
('The completely different parts of mortgage curiosity embrace rates of interest, '
 'origination charges, low cost factors, and lender-charges. Rates of interest are '
 'the proportion charged by the lender for borrowing the mortgage quantity. '
 'Origination charges are charges charged by the lender for processing the mortgage, and '
 'typically they may also be used to purchase down the rate of interest. Low cost '
 'factors are a type of pre-paid curiosity the place one level equals one p.c of '
 'the mortgage quantity, and paying factors might help scale back the rate of interest on the '
 'mortgage. Lender-charges, reminiscent of origination charges and low cost factors, are '
 'listed on the HUD-1 Settlement Assertion.')

Testing query 2: describe the basics of quantum computing
================================================================================
---RETRIEVE---
"Node 'retrieve':"
'n---n'
---CHECK DOCUMENT RELEVANCE TO QUESTION---
---EVALUATION: DOCUMENT NOT RELEVANT---
---EVALUATION: DOCUMENT NOT RELEVANT---
---EVALUATION: DOCUMENT NOT RELEVANT---
---EVALUATION: DOCUMENT NOT RELEVANT---
---ASSESS EVALUATED DOCUMENTS---
---DECISION: NO RELEVANT DOCUMENTS FOUND---
"Node 'evaluate_documents':"
'n---n'
'No related paperwork discovered or no technology produced.'

Limitations of Self-RAG

Whereas the Self-RAG has numerous advantages over commonplace RAG and however there additionally some limitations:

  • Outputs is probably not absolutely supported: Self-RAG can produce outputs that aren’t utterly supported by the cited proof, even with its self-reflection mechanisms.
  • Potential for factual inaccuracies: Like different LLMs, Self-RAG continues to be inclined to creating factual errors regardless of its enhancements in factuality and quotation accuracy.
  • Smaller fashions could produce shorter outputs: Smaller Self-RAG fashions can typically outperform bigger ones on factual precision as a consequence of their tendency to supply shorter, extra grounded outputs.
  • Customization trade-offs: Adjusting the mannequin’s habits utilizing reflection tokens can result in trade-offs; for instance, prioritizing quotation help could scale back the fluency of the generated textual content.

Conclusion

SELF-RAG improves LLMs by way of on-demand retrieval and self-reflection. It selectively retrieves exterior data when wanted, not like commonplace RAG. The mannequin makes use of reflection tokens (ISREL, ISSUP, ISUSE) to critique its personal generations, assessing the relevance, help, and utility of retrieved passages and generated textual content. This improves accuracy and reduces factual errors. SELF-RAG will be personalized at inference by adjusting reflection token weights. It affords higher quotation and verifiability, and has demonstrated superior efficiency over different fashions. The coaching is completed offline for effectivity.

Key Takeaways

  • Self-RAG addresses RAG limitations by enabling on-demand retrieval, adaptive habits, and self-evaluation for extra correct and related outputs.
  • Reflection tokens improve output high quality by critiquing retrieval relevance, technology help, and utility, guaranteeing higher factual accuracy.
  • Customizable inference permits Self-RAG to tailor retrieval frequency and output habits to fulfill particular process necessities.
  • Environment friendly offline coaching eliminates the necessity for a critic mannequin throughout inference, lowering overhead whereas sustaining efficiency.
  • Improved quotation and verifiability make Self-RAG outputs extra dependable and factually grounded in comparison with commonplace LLMs and RAG methods.

Ceaselessly Requested Questions

Q1. What’s Self-RAG?

A. Self-RAG (Self-Reflective Retrieval-Augmented Technology) is a framework that improves LLM efficiency by combining on-demand retrieval with self-reflection to boost factual accuracy and relevance.

Q2. How does Self-RAG differ from commonplace RAG?

A. In contrast to commonplace RAG, Self-RAG retrieves passages solely when wanted, makes use of reflection tokens to critique its outputs, and adapts its habits primarily based on process necessities.

Q3. What are reflection tokens?

A. Reflection tokens (ISREL, ISSUP, ISUSE) consider retrieval relevance, help for generated textual content, and general utility, enabling self-assessment and higher outputs.

This fall. What are the principle benefits of Self-RAG?

A. Self-RAG improves accuracy, reduces factual errors, affords higher citations, and permits task-specific customization throughout inference.

Q5. Can Self-RAG utterly get rid of factual inaccuracies?

A. No, whereas Self-RAG reduces inaccuracies considerably, it’s nonetheless liable to occasional factual errors like all LLM.

The media proven on this article is just not owned by Analytics Vidhya and is used on the Writer’s discretion.