diff --git a/lumen/ai/llm.py b/lumen/ai/llm.py index 3400ed994..3040094eb 100644 --- a/lumen/ai/llm.py +++ b/lumen/ai/llm.py @@ -4,10 +4,10 @@ from functools import partial +import instructor import panel as pn import param -from instructor import from_anthropic, from_openai from instructor.dsl.partial import Partial from instructor.patch import Mode, patch from pydantic import BaseModel @@ -220,7 +220,7 @@ def get_client(self, model_key: str, response_model: BaseModel | None = None, ** model_kwargs["organization"] = self.organization llm = openai.AsyncOpenAI(**model_kwargs) if response_model: - client = from_openai(llm) + client = instructor.from_openai(llm) client_callable = partial(client.chat.completions.create, model=model) else: client_callable = partial(llm.chat.completions.create, model=model) @@ -260,7 +260,7 @@ def get_client(self, model_key: str, response_model: BaseModel | None = None, ** model_kwargs["azure_endpoint"] = self.azure_endpoint llm = openai.AsyncAzureOpenAI(**model_kwargs) if response_model: - client = from_openai(llm) + client = instructor.from_openai(llm) client_callable = partial(client.chat.completions.create, model=model) else: client_callable = partial(llm.chat.completions.create, model=model) @@ -418,7 +418,7 @@ def get_client(self, model_key: str, response_model: BaseModel | None = None, ** llm = AsyncAnthropic(api_key=self.api_key) if response_model: - client = from_anthropic(llm) + client = instructor.from_anthropic(llm) return partial(client.messages.create, model=model) else: return partial(llm.messages.create, model=model)