mirror of
https://github.com/run-llama/ts-agents.git
synced 2026-07-01 21:14:01 -04:00
74 lines
1.9 KiB
TypeScript
74 lines
1.9 KiB
TypeScript
import {
|
|
OpenAI,
|
|
FunctionTool,
|
|
OpenAIAgent,
|
|
Settings,
|
|
SimpleDirectoryReader,
|
|
HuggingFaceEmbedding,
|
|
VectorStoreIndex,
|
|
QueryEngineTool
|
|
} from "llamaindex"
|
|
import 'dotenv/config'
|
|
|
|
async function main() {
|
|
|
|
// set LLM and the embedding model
|
|
Settings.llm = new OpenAI({
|
|
apiKey: process.env.OPENAI_API_KEY,
|
|
model: "gpt-4o",
|
|
})
|
|
Settings.embedModel = new HuggingFaceEmbedding({
|
|
modelType: "BAAI/bge-small-en-v1.5",
|
|
quantized: false
|
|
})
|
|
/*
|
|
Set up logging so we can see the work in progress.
|
|
Available events:
|
|
llm-start
|
|
llm-end
|
|
agent-start
|
|
agent-end
|
|
llm-tool-call
|
|
llm-tool-result
|
|
*/
|
|
Settings.callbackManager.on("llm-tool-call", (event) => {
|
|
console.log(event.detail.payload)
|
|
})
|
|
Settings.callbackManager.on("llm-tool-result", (event) => {
|
|
console.log(event.detail.payload)
|
|
})
|
|
|
|
// load our data and create a query engine
|
|
const reader = new SimpleDirectoryReader()
|
|
const documents = await reader.loadData("../data")
|
|
const index = await VectorStoreIndex.fromDocuments(documents)
|
|
const retriever = await index.asRetriever()
|
|
retriever.similarityTopK = 10
|
|
const queryEngine = await index.asQueryEngine({
|
|
retriever
|
|
})
|
|
|
|
|
|
// define the query engine as a tool
|
|
const tools = [
|
|
new QueryEngineTool({
|
|
queryEngine: queryEngine,
|
|
metadata: {
|
|
name: "san_francisco_budget_tool",
|
|
description: `This tool can answer detailed questions about the individual components of the budget of San Francisco in 2023-2024.`,
|
|
},
|
|
}),
|
|
]
|
|
|
|
// create the agent
|
|
const agent = new OpenAIAgent({tools})
|
|
|
|
let response = await agent.chat({
|
|
message: "What's the budget of San Francisco in 2023-2024?",
|
|
})
|
|
|
|
console.log(response)
|
|
}
|
|
|
|
main().catch(console.error);
|