Von Vektoren zu Graphen

Retrieval Augmented Generation (RAG) mit LangChain

Meri Nova

Machine Learning Engineer

Einschränkungen von Vector RAG

Der typische Vektorstore-RAG-Workflow.

Eine Sprechblase mit „Themen und Beziehungen“.

Retrieval Augmented Generation (RAG) mit LangChain

Einschränkungen von Vector RAG

Der typische Vektorstore-RAG-Workflow.

Eine Sprechblase mit „Skalierbarkeit“.

Retrieval Augmented Generation (RAG) mit LangChain

Einschränkungen von Vector RAG

Der typische Vektorstore-RAG-Workflow.

Eine Sprechblase mit „heterogene Daten integrieren“.

Retrieval Augmented Generation (RAG) mit LangChain

Graphdatenbanken

Ein Graph mit Verbindungen zwischen Personen, Orten und Interessen.

Retrieval Augmented Generation (RAG) mit LangChain

Graphdatenbanken – Knoten

Ein Graph mit Verbindungen zwischen Personen, Orten und Interessen.

Retrieval Augmented Generation (RAG) mit LangChain

Graphdatenbanken – Kanten

Ein Graph mit Verbindungen zwischen Personen, Orten und Interessen.

Retrieval Augmented Generation (RAG) mit LangChain

Neo4j-Graphdatenbanken

 

Das Neo4j-Logo.

Das LangChain-Logo.

Retrieval Augmented Generation (RAG) mit LangChain

Von Grafiken zu Graphen …

Ein Graph mit Verbindungen zwischen Personen, Orten und Interessen.

Retrieval Augmented Generation (RAG) mit LangChain

Von Grafiken zu Graphen …

barcelona_graph.jpg

Retrieval Augmented Generation (RAG) mit LangChain

Von Grafiken zu Graphen …

barcelona_graph.jpg

Retrieval Augmented Generation (RAG) mit LangChain

Wikipedia-Seiten laden und in Chunks teilen

from langchain_community.document_loaders import WikipediaLoader
from langchain_text_splitters import TokenTextSplitter

raw_documents = WikipediaLoader(query="large language model").load()

text_splitter = TokenTextSplitter(chunk_size=100, chunk_overlap=20) documents = text_splitter.split_documents(raw_documents[:3]) print(documents[0])
page_content='A large language model (LLM) is a computational model capable of...' 
metadata={'title': 'Large language model',
          'summary': "A large language model (LLM) is...",
          'source': 'https://en.wikipedia.org/wiki/Large_language_model'}
Retrieval Augmented Generation (RAG) mit LangChain

Von Text zu Graphen!

from langchain_openai import ChatOpenAI

from langchain_experimental.graph_transformers import LLMGraphTransformer
llm = ChatOpenAI(api_key="...", temperature=0, model_name="gpt-4o-mini")
llm_transformer = LLMGraphTransformer(llm=llm)
graph_documents = llm_transformer.convert_to_graph_documents(documents) print(graph_documents)
Retrieval Augmented Generation (RAG) mit LangChain

Von Text zu Graphen!

[GraphDocument(
    nodes=[
        Node(id='Llm', type='Computational model'),
        Node(id='Language Generation', type='Concept'),
        Node(id='Natural Language Processing Tasks', type='Concept'),
        Node(id='Llama Family', type='Computational model'),
        Node(id='Ibm', type='Organization'),
        ..., Node(id='Bert', type='Computational model')],
    relationships=[
        Relationship(source=Node(id='Llm', type='Computational model'),
                     target=Node(id='Language Generation', type='Concept'),
                     type='CAPABLE_OF'),
        ...])]
Retrieval Augmented Generation (RAG) mit LangChain

Lass uns üben!

Retrieval Augmented Generation (RAG) mit LangChain

Preparing Video For Download...