Search icon CANCEL
Subscription
0
Cart icon
Your Cart (0 item)
Close icon
You have no products in your basket yet
Save more on your purchases! discount-offer-chevron-icon
Savings automatically calculated. No voucher code required.
Arrow left icon
Explore Products
Best Sellers
New Releases
Books
Videos
Audiobooks
Learning Hub
Free Learning
Arrow right icon

Large Language Models (LLMs) and Knowledge Graphs

Save for later
  • 7 min read
  • 15 Nov 2023

article-image

Dive deeper into the world of AI innovation and stay ahead of the AI curve! Subscribe to our AI_Distilled newsletter for the latest insights. Don't miss out – sign up today!

Introduction

Harnessing the power of AI, this article explores how Large Language Models (LLMs) like OpenAI's GPT can analyze data from Knowledge Graphs to revolutionize data interpretation, particularly in healthcare. We'll illustrate a use case where an LLM assesses patient symptoms from a Knowledge Graph to suggest diagnoses, showcasing LLM’s potential to support medical diagnostics with precision.

Brief Introduction Into Large Language Models (LLMs)

Large Language Models (LLMs), such as OpenAI's GPT series, represent a significant advancement in the field of artificial intelligence. These models are trained on vast datasets of text, enabling them to understand and generate human-like language.

LLMs are adept at understanding complex questions and providing appropriate responses, akin to human analysis. This capability stems from their extensive training on diverse datasets, allowing them to interpret context and generate relevant text-based answers.

large-language-models-llms-and-knowledge-graphs-img-0

While LLMs possess advanced data processing capabilities, their effectiveness is often limited by the static nature of their training data. Knowledge Graphs step in to fill this gap, offering a dynamic and continuously updated source of information. This integration not only equips LLMs with the latest data, enhancing the accuracy and relevance of their output but also empowers them to solve more complex problems with a greater level of sophistication. As we harness this powerful combination, we pave the way for innovative solutions across various sectors that demand real-time intelligence, such as the ever-fluctuating stock market.

Exploring Knowledge Graphs and How LLMs Can Benefit From Them

Knowledge Graphs represent a pivotal advancement in organizing and utilizing data, especially in enhancing the capabilities of Large Language Models (LLMs).

Knowledge Graphs organize data in a graph format, where entities (like people, places, and things) are nodes, and the relationships between them are edges. This structure allows for a more nuanced representation of data and its interconnected nature.

 large-language-models-llms-and-knowledge-graphs-img-1

Take the above Knowledge Graph as an example.

  • Doctor Node: This node represents the doctor. It is connected to the patient node with an edge labeled "Patient," indicating the doctor-patient relationship.
  • Patient Node (Patient123): This is the central node representing a specific patient, known as "Patient123." It serves as a junction point connecting to various symptoms that the patient is experiencing.
  • Symptom Nodes: There are three separate nodes representing individual symptoms that the patient has: "Fever," "Cough," and "Shortness of breath." Each of these symptoms is connected to the patient node by edges labeled "Symptom," indicating that these are the symptoms experienced by "Patient123.          

To simplify, the Knowledge Graph shows that "Patient123" is a patient of the "Doctor" and is experiencing three symptoms: fever, cough, and shortness of breath. This type of graph is useful in medical contexts where it's essential to model the relationships between patients, their healthcare providers, and their medical conditions or symptoms. It allows for easy querying of related data—for example, finding all symptoms associated with a particular patient or identifying all patients experiencing a certain symptom.

Practical Integration of LLMs and Knowledge Graphs

Step 1: Installing and Importing the Necessary Libraries

In this step, we're going to bring in two essential libraries: rdflib for constructing our Knowledge Graph and openai for tapping into the capabilities of GPT, the Large Language Model.

Unlock access to the largest independent learning library in Tech for FREE!
Get unlimited access to 7500+ expert-authored eBooks and video courses covering every tech area you can think of.
Renews at €18.99/month. Cancel anytime
!pip install rdflib
!pip install openai==0.28
import rdflib
import openai

Step 2: Import your Personal OPENAI API KEY

openai.api_key = "Insert Your Personal OpenAI API Key Here"

Step 3: Creating a Knowledge Graph

# Create a new and empty Knowledge graph
g = rdflib.Graph()

# Define a Namespace for health-related data
namespace = rdflib.Namespace("http://example.org/health/")

Step 4: Adding data to Our Graph

In this part of the code, we will introduce a single entry to the Knowledge Graph pertaining to patient124. This entry will consist of three distinct nodes, each representing a different symptom exhibited by the patient.

def add_patient_data(patient_id, symptoms):
    patient_uri = rdflib.URIRef(patient_id)
   
    for symptom in symptoms:
        symptom_predicate = namespace.hasSymptom
        g.add((patient_uri, symptom_predicate, rdflib.Literal(symptom)))

# Example of adding patient data
add_patient_data("Patient123", ["fever", "cough", "shortness of breath"])

Step 5: Identifying the get_stock_price function

We will utilize a simple query in order to extract the required data from the knowledge graph.

def get_patient_symptoms(patient_id):
    # Correctly reference the patient's URI in the SPARQL query
    patient_uri = rdflib.URIRef(patient_id)

    sparql_query = f"""
        PREFIX ex: <http://example.org/health/>
        SELECT ?symptom
        WHERE {{
            <{patient_uri}> ex:hasSymptom ?symptom.
        }}
    """
    query_result = g.query(sparql_query)
    symptoms = [str(row.symptom) for row in query_result]
    return symptoms

Step 6: Identifying the generate_llm_response function

The generate_daignosis_response function takes as input the user’s name along with the list of symptoms extracted from the graph. Moving on, the LLM uses such data in order to give the patient the most appropriate diagnosis.

def generate_diagnosis_response(patient_id, symptoms):
    symptoms_list = ", ".join(symptoms)
    prompt = f"A patient with the following symptoms - {symptoms_list} - has been observed. Based on these symptoms, what could be a potential diagnosis?"
   
    # Placeholder for LLM response (use the actual OpenAI API)
    llm_response = openai.Completion.create(
        model="text-davinci-003",
        prompt=prompt,
        max_tokens=100
    )
    return llm_response.choices[0].text.strip()

# Example usage
patient_id = "Patient123"
symptoms = get_patient_symptoms(patient_id)
if symptoms:
    diagnosis = generate_diagnosis_response(patient_id, symptoms)
    print(diagnosis)
else:
    print(f"No symptoms found for {patient_id}.")

Output: 

The potential diagnosis could be pneumonia. Pneumonia is a type of respiratory infection that causes symptoms including fever, cough, and shortness of breath. Other potential diagnoses should be considered as well and should be discussed with a medical professional.

As demonstrated, the LLM connected the three symptoms—fever, cough, and shortness of breath—to suggest that patient123 may potentially be diagnosed with pneumonia.

Conclusion

In summary, the collaboration of Large Language Models and Knowledge Graphs presents a substantial advancement in the realm of data analysis. This article has provided a straightforward illustration of their potential when working in tandem, with LLMs to efficiently extract and interpret data from Knowledge Graphs.

As we further develop and refine these technologies, we hold the promise of significantly improving analytical capabilities and informing more sophisticated decision-making in an increasingly data-driven world.

Author Bio

Mostafa Ibrahim is a dedicated software engineer based in London, where he works in the dynamic field of Fintech. His professional journey is driven by a passion for cutting-edge technologies, particularly in the realms of machine learning and bioinformatics. When he's not immersed in coding or data analysis, Mostafa loves to travel.

Medium