Nota:
El acceso a esta página requiere autorización. Puede intentar iniciar sesión o cambiar directorios.
El acceso a esta página requiere autorización. Puede intentar cambiar los directorios.
Use databricks Unity Catalog para integrar funciones de SQL y Python como herramientas en flujos de trabajo de OpenAI. Esta integración combina la gobernanza del catálogo de Unity con OpenAI para crear aplicaciones eficaces de inteligencia artificial de generación.
Requisitos
- Instale Python 3.10 o superior.
Integración de herramientas de Catálogo de Unity con OpenAI
Ejecute el código siguiente en un cuaderno o script de Python para crear una herramienta de catálogo de Unity y usarla al llamar a un modelo de OpenAI.
Instale el paquete de integración del catálogo de Unity de Databricks para OpenAI.
%pip install unitycatalog-openai[databricks] %pip install mlflow -U dbutils.library.restartPython()Cree una instancia del cliente de funciones del catálogo de Unity.
from unitycatalog.ai.core.base import get_uc_function_client client = get_uc_function_client()Cree una función de catálogo de Unity escrita en Python.
CATALOG = "your_catalog" SCHEMA = "your_schema" func_name = f"{CATALOG}.{SCHEMA}.code_function" def code_function(code: str) -> str: """ Runs Python code. Args: code (str): The python code to run. Returns: str: The result of running the Python code. """ import sys from io import StringIO stdout = StringIO() sys.stdout = stdout exec(code) return stdout.getvalue() client.create_python_function( func=code_function, catalog=CATALOG, schema=SCHEMA, replace=True )Cree una instancia de la función catálogo de Unity como un kit de herramientas y compruebe que la herramienta se comporta correctamente mediante la ejecución de la función.
from unitycatalog.ai.openai.toolkit import UCFunctionToolkit import mlflow # Enable tracing mlflow.openai.autolog() # Create a UCFunctionToolkit that includes the UC function toolkit = UCFunctionToolkit(function_names=[func_name]) # Fetch the tools stored in the toolkit tools = toolkit.tools client.execute_function = tools[0]Envíe la solicitud al modelo openAI junto con las herramientas.
import openai messages = [ { "role": "system", "content": "You are a helpful customer support assistant. Use the supplied tools to assist the user.", }, {"role": "user", "content": "What is the result of 2**10?"}, ] response = openai.chat.completions.create( model="gpt-4o-mini", messages=messages, tools=tools, ) # check the model response print(response)Después de que OpenAI devuelva una respuesta, invoque la función de Unity Catalog para generar la respuesta a OpenAI.
import json # OpenAI sends only a single request per tool call tool_call = response.choices[0].message.tool_calls[0] # Extract arguments that the Unity Catalog function needs to run arguments = json.loads(tool_call.function.arguments) # Run the function based on the arguments result = client.execute_function(func_name, arguments) print(result.value)Una vez que se haya devuelto la respuesta, puede construir la carga de respuesta para las llamadas posteriores a OpenAI.
# Create a message containing the result of the function call function_call_result_message = { "role": "tool", "content": json.dumps({"content": result.value}), "tool_call_id": tool_call.id, } assistant_message = response.choices[0].message.to_dict() completion_payload = { "model": "gpt-4o-mini", "messages": [*messages, assistant_message, function_call_result_message], } # Generate final response openai.chat.completions.create( model=completion_payload["model"], messages=completion_payload["messages"] )
Utilidades
Para simplificar el proceso de creación de la respuesta de la herramienta, el ucai-openai paquete tiene una utilidad, generate_tool_call_messages, que convierte los mensajes de respuesta de ChatCompletion de OpenAI para que se puedan usar para la generación de respuestas.
from unitycatalog.ai.openai.utils import generate_tool_call_messages
messages = generate_tool_call_messages(response=response, client=client)
print(messages)
Nota:
Si la respuesta contiene varias entradas de opción, puede pasar el argumento choice_index al llamar a generate_tool_call_messages para elegir qué entrada de elección usar. Actualmente no hay compatibilidad con el procesamiento de varias entradas de elección.