GenAI agents in 2024 with LlamaIndex

2024-09-06 Gen AI Hackathon
What are we talking about?
- What is LlamaIndex
- Why you should use it
- What can it do
	- Retrieval augmented generation
- World class parsing
- Agents and multi-agent systems
 
What is LlamaIndex?
Python: docs.llamaindex.ai
TypeScript: ts.llamaindex.ai
LlamaParse
Free for 1000 pages/day!
LlamaCloud

1. Sign up:
LlamaHub
- Data loaders
- Embedding models
- Vector stores
- LLMs
- Agent tools
- Pre-built strategies
- More!
Why LlamaIndex?
- Build faster
- Skip the boilerplate
- Avoid early pitfalls
What can LlamaIndex
do for me?
Loading
RAG, step 1:
documents = SimpleDirectoryReader("data").load_data()Parsing
RAG, step 2:
(LlamaParse: it's really good. Really!)
# must have a LLAMA_CLOUD_API_KEY
# bring in deps
from llama_parse import LlamaParse
from llama_index.core import SimpleDirectoryReader
# set up parser
parser = LlamaParse(
    result_type="markdown"  # "text" also available
)
# use SimpleDirectoryReader to parse our file
file_extractor = {".pdf": parser}
documents = SimpleDirectoryReader(
	input_files=['data/canada.pdf'],
    file_extractor=file_extractor
).load_data()
print(documents)Embedding
RAG, step 3:
Settings.embed_model = HuggingFaceEmbedding(model_name="BAAI/bge-small-en-v1.5")Storing
RAG, step 4:
index = VectorStoreIndex.from_documents(documents)Retrieving
RAG, step 5:
retriever = index.as_retriever()
nodes = retriever.retrieve("Who is Paul Graham?")Querying
RAG, step 6:
query_engine = index.as_query_engine()
response = query_engine.query("Who is Paul Graham?")Multi-modal
npx create-llama

LlamaBot
A slack bot
Agents
Putting together an agent
def multiply(a: float, b: float) -> float:
    """Multiply two numbers and returns the product"""
    return a * b
multiply_tool = FunctionTool.from_defaults(fn=multiply)
llm = OpenAI(model="gpt-4o", temperature=0.4)
agent = ReActAgent.from_tools(
  [multiply_tool], 
  llm=llm, 
  verbose=True
)RAG + Agents
budget_tool = QueryEngineTool.from_defaults(
    query_engine,
    name="canadian_budget_2023",
    description="A RAG engine with some basic facts",
)
llm = OpenAI(model="gpt-4o", temperature=0.4)
agent = ReActAgent.from_tools(
  [budget_tool], 
  llm=llm, 
  verbose=True
)Workflows
Multi-agent workflow
Multi-agent concierge
Full-stack python workflow
Thanks!
Follow me on Twitter/X:
@seldo
Please don't add me on LinkedIn.

GenAI agents in 2024 with LlamaIndex (Gen AI Hackathon)
By Laurie Voss
GenAI agents in 2024 with LlamaIndex (Gen AI Hackathon)
- 993
 
   
   
  