With the advancement of AI, scientific research has seen a massive transformation. Millions of papers are published annually on different technologies and sectors. But, navigating this ocean of information to retrieve accurate and relevant content is a herculean task. Enter PaperQA, a Retrieval-Augmented Generative (RAG) Agent designed to tackle this exact problem. It is researched and developed by Jakub Lala ´, Odhran O’Donoghue, Aleksandar Shtedritski, Sam Cox, Samuel G Rodriques, and Andrew D White.
This innovative tool is specifically engineered to assist researchers by retrieving information from full-text scientific papers, synthesizing that data, and generating accurate answers with reliable citations. This article explores PaperQA’s benefits, workings, implementation, and limitations.
As scientific papers continue to multiply exponentially, it’s becoming harder for researchers to sift through the ever-expanding body of literature. In 2022 alone, over five million academic papers were published, adding to the more than 200 million articles currently available. This massive body of research often results in significant findings going unnoticed or taking years to be recognized. Traditional methods, including keyword searches and vector similarity embeddings, only scratch the surface of what’s possible for retrieving pertinent information. These methods are often highly manual, slow, and leave room for oversight.
PaperQA provides a robust solution to this problem by leveraging the potential of Large Language Models (LLMs), combined with Retrieval-Augmented Generation (RAG) techniques. Unlike typical LLMs, which can hallucinate or rely on outdated information, PaperQA uses a dynamic approach to information retrieval, combining the strengths of search engines, evidence gathering, and intelligent answering, all while minimizing errors and improving efficiency. By breaking the standard RAG into modular components, PaperQA adapts to specific research questions and ensures the answers provided are rooted in factual, up-to-date sources.
Also read: A Comprehensive Guide to Building Multimodal RAG Systems
The Agentic RAG Model refers to a type of Retrieval-Augmented Generation (RAG) model designed to integrate an agentic approach. In this context, “agentic” implies the model’s capability to act autonomously and decide how to retrieve, process, and generate information. It refers to a system where the model not only retrieves and augments information but also actively manages various tasks or subtasks to optimize for a specific goal.
Also read: Unveiling Retrieval Augmented Generation (RAG)| Where AI Meets Human Knowledge
PaperQA is engineered specifically to be an agentic RAG model designed for working with scientific papers. This means it is particularly optimized for tasks like:
In summary, the Agentic RAG Model is a sophisticated system that retrieves relevant information and generates responses, and autonomously manages tasks to ensure efficiency and relevance. PaperQA2 applies this model to the domain of scientific papers, making it highly effective for academic and research purposes.
Also read: Enhancing RAG with Retrieval Augmented Fine-tuning
The PaperQA system is composed of:
The process begins with an input query that the user enters. This could be a question or a search topic that requires an answer based on scientific papers.
This overall structure ensures that PaperQA can effectively search, retrieve, summarize, and synthesize information from large collections of scientific papers to provide a thorough and relevant answer to a user’s query. The key advantage is its ability to break down complex scientific content, apply intelligent retrieval methods, and provide evidence-based answers.
These tools work in harmony, allowing PaperQA to collect multiple pieces of evidence from various sources, ensuring a thorough, evidence-based answer is generated. The entire process is managed by a central LLM agent, which dynamically adjusts its strategy based on the query’s complexity.
The LitQA dataset was developed to measure PaperQA’s performance. This dataset consists of 50 multiple-choice questions derived from recent scientific literature (post-September 2021). The questions span various domains in biomedical research, requiring PaperQA to retrieve information and synthesize it across multiple documents. LitQA provides a rigorous benchmark that goes beyond typical multiple-choice science QA datasets, requiring PaperQA to engage in full-text retrieval and synthesis, tasks closer to those performed by human researchers.
In evaluating PaperQA’s performance on LitQA, the system was found to be highly competitive with expert human researchers. When researchers and PaperQA were given the same set of questions, PaperQA performed on par with humans, showing a similar accuracy rate (69.5% versus 66.8% for humans). Moreover, PaperQA was faster and more cost-effective, answering all questions in 2.4 hours compared to 2.5 hours for human experts. One notable strength of PaperQA is its lower rate of answering incorrectly, as it is calibrated to acknowledge uncertainty when evidence is lacking, further reducing the risk of incorrect conclusions.
The PaperQA system is built on the LangChain agent framework and utilizes multiple LLMs, including GPT-3.5 and GPT-4, each assigned to different tasks (e.g., summarizing and answering). The system pulls papers from various databases, uses a map-reduce approach to gather and summarize evidence, and generates final answers in a scholarly tone with complete citations. Importantly, PaperQA’s modular design allows it to rephrase questions, adjust search terms, and retry steps, ensuring accuracy and relevance.
Step 1: Install the required library
Run the following command to install paper-qa:
pip install paper-qa
Step 2: Set up your research folder
Create a folder and place your research paper(s) in it. For example, I’ve added the paper titled “Attention is All You Need.”
Step 3: Navigate to your folder
Use the following command to navigate to the folder:
cd folder-name
Step 4: Ask your question
Run the following command to ask about a topic:
pqa ask "What is transformers?"
Result:
CROSSREF_API_KEY
is missing). This means CrossRef couldn’t be used as a data source for this search.SEMANTIC_SCHOLAR_API_KEY
is not set). This resulted in a timeout, and no metadata was retrieved.import os
from dotenv import load_dotenv
from paperqa import Settings, agent_query, QueryRequest
load_dotenv()
answer = await agent_query(
QueryRequest(
query="What is transformers? ",
settings=Settings(temperature=0.5, paper_directory="/home/badrinarayan/paper-qa"),
)
)
Here’s an explanation of the code, broken down into a structured and clear format:
pip install paper-qaimport os
from dotenv import load_dotenv
from paperqa import Settings, agent_query, QueryRequest
.env
file into the environment.paperqa
library that allows querying scientific papers. It provides classes and functions like Settings
, agent_query
, and QueryRequest
for configuring and running queries.load_dotenv()
.env
file, typically used to store sensitive information like API keys, file paths, or other configurations.load_dotenv()
, it ensures that the environment variables are available to be accessed in the script.PaperQA
Systemanswer = await agent_query(
QueryRequest(
query="What is transformers? ",
settings=Settings(temperature=0.5, paper_directory="/home/badrinarayan/paper-qa"),
)
)
This part of the code queries the PaperQA system using an agent and structured request. It performs the following steps:
agent_query()
: This is an asynchronous function used to send a query to the PaperQA system.await
keyword since it is an async
function, meaning it runs concurrently with other code while awaiting the result.QueryRequest
: This defines the structure of the query request. It takes the query and settings as parameters. In this case:"What is transformers?"
is the research question being asked of the system. It expects an answer drawn from the papers in the specified directory.Settings
to configure the query, which includes:0.5
make the response more deterministic (factual), while higher values generate more varied answers."/home/badrinarayan/paper-qa"
.OUTPUT
Question: What is transformers?The Transformer is a neural network architecture designed for sequence
transduction tasks, such as machine translation, that relies entirely on
attention mechanisms, eliminating the need for recurrence and convolutions.
It features an encoder-decoder structure, where both the encoder and decoder
consist of a stack of six identical layers. Each encoder layer includes a
multi-head self-attention mechanism and a position-wise fully connected
feed-forward network, employing residual connections and layer
normalization. The decoder incorporates an additional sub-layer for multi-
head attention over the encoder's output and uses masking to ensure auto-
regressive generation (Vaswani2023 pages 2-3).The Transformer improves parallelization and reduces training time compared
to recurrent models, achieving state-of-the-art results in translation
tasks. It set a BLEU score of 28.4 on the WMT 2014 English-to-German task
and 41.8 on the English-to-French task after training for 3.5 days on eight
GPUs (Vaswani2023 pages 1-2). The model's efficiency is further enhanced by
reducing the number of operations needed to relate signals from different
positions to a constant, leveraging Multi-Head Attention to maintain
effective resolution (Vaswani2023 pages 2-2).In addition to translation, the Transformer has demonstrated strong
performance in tasks like English constituency parsing, achieving high F1
scores in both supervised and semi-supervised settings (Vaswani2023 pages 9-
10).References
1. (Vaswani2023 pages 2-3): Vaswani, Ashish, et al. "Attention Is All You
Need." arXiv, 2 Aug. 2023, arxiv.org/abs/1706.03762v7. Accessed 2024.2. (Vaswani2023 pages 1-2): Vaswani, Ashish, et al. "Attention Is All You
Need." arXiv, 2 Aug. 2023, arxiv.org/abs/1706.03762v7. Accessed 2024.3. (Vaswani2023 pages 9-10): Vaswani, Ashish, et al. "Attention Is All You
Need." arXiv, 2 Aug. 2023, arxiv.org/abs/1706.03762v7. Accessed 2024.4. (Vaswani2023 pages 2-2): Vaswani, Ashish, et al. "Attention Is All You
Need." arXiv, 2 Aug. 2023, arxiv.org/abs/1706.03762v7. Accessed 2024.
The system appears to rely on external databases, such as academic databases or repositories, to answer the question. Based on the references, it’s highly likely that this particular system is querying sources like:
Despite its strengths, PaperQA is not without limitations. First, its reliance on existing research papers means it assumes that the information in the sources is accurate. If faulty papers are retrieved, PaperQA’s answers could be flawed. Moreover, the system can struggle with ambiguous or vague queries that don’t align with the available literature. Finally, while the system effectively synthesizes information from full-text papers, it cannot yet handle real-time calculations or tasks that require up-to-date numerical data.
In conclusion, PaperQA represents a leap forward in the automation of scientific research. By integrating retrieval-augmented generation with intelligent agents, PaperQA transforms the research process, cutting down the time needed to find and synthesize information from complex literature. Its ability to dynamically adjust, retrieve full-text papers, and iterate on answers brings the world of scientific question-answering one step closer to human-level expertise, but with a fraction of the cost and time. As science advances at breakneck speed, tools like PaperQA will play a pivotal role in ensuring researchers can keep up and push the boundaries of innovation.
Also, check out the new course on AI Agent: Introduction to AI Agents
Ans. PaperQA is a Retrieval-Augmented Generative (RAG) tool designed to help researchers navigate and extract relevant information from full-text scientific papers, synthesizing answers with reliable citations.
Ans. Unlike traditional search tools that rely on keyword searches, PaperQA uses Large Language Models (LLMs) combined with retrieval mechanisms to pull data from multiple documents, generating more accurate and context-rich responses.
Ans. The Agentic RAG Model allows PaperQA to autonomously retrieve, process, and generate information by breaking down queries, managing tasks, and optimizing responses using an agentic approach.
Ans. PaperQA competes well with human researchers, achieving similar accuracy rates (around 69.5%) while answering questions faster and with fewer errors.
Ans. PaperQA’s limitations include potential reliance on faulty sources, difficulty with ambiguous queries, and an inability to perform real-time calculations or handle up-to-date numerical data.