Aracılığıyla paylaş


İnsan müdahalesi ile onaylama süreçlerinde işlevsel araçları kullanma

Bu öğretici adımında, Azure OpenAI Sohbet Tamamlama hizmeti üzerinde oluşturulmuş bir ajan ile insan onayı gerektiren fonksiyon araçlarının nasıl kullanılacağı gösterilir.

Aracılar, örneğin bir işlev çağrısını onaylamak için herhangi bir kullanıcı girdisi gerektirdiğinde, bu insan katılımı döngüsü örüntüsü olarak adlandırılır. Kullanıcı girişi gerektiren bir aracı çalıştırmak, son bir yanıtla tamamlanmak yerine, kullanıcıdan hangi girişin gerekli olduğunu belirten bir yanıtla tamamlanır. Aracı çağıran kişi, kullanıcıdan gerekli girdiği almaktan ve bunu yeni bir agent çalıştırmasının parçası olarak aracıya geri iletmekten sorumludur.

Önkoşullar

Önkoşullar ve NuGet paketlerini yükleme için bu öğreticideki Basit bir aracı oluşturma ve çalıştırma adımına bakın.

İşlev araçlarıyla aracı oluşturma

İşlevleri kullanırken, her işlev için yürütülmeden önce insan onayı gerekip gerekmediğini belirtmek mümkündür. Bu, bir AIFunction örneği ApprovalRequiredAIFunction örneğinin içinde sarmalayarak yapılır.

Burada, belirli bir konumun hava durumunu alma sahtesini gösteren basit bir işlev aracı örneği verilmiştir.

using System;
using System.ComponentModel;
using System.Linq;
using Azure.AI.OpenAI;
using Azure.Identity;
using Microsoft.Agents.AI;
using Microsoft.Extensions.AI;
using OpenAI;

[Description("Get the weather for a given location.")]
static string GetWeather([Description("The location to get the weather for.")] string location)
    => $"The weather in {location} is cloudy with a high of 15°C.";

Önce bir oluşturmak ve ardından içinde sarmalamak için şunları yapabilirsiniz:

AIFunction weatherFunction = AIFunctionFactory.Create(GetWeather);
AIFunction approvalRequiredWeatherFunction = new ApprovalRequiredAIFunction(weatherFunction);

Aracıyı oluştururken, artık CreateAIAgent yöntemine bir araç listesi geçirerek, onay gerektiren bir işlev aracını aracıya sağlayabilirsiniz.

AIAgent agent = new AzureOpenAIClient(
    new Uri("https://<myresource>.openai.azure.com"),
    new AzureCliCredential())
     .GetChatClient("gpt-4o-mini")
     .CreateAIAgent(instructions: "You are a helpful assistant", tools: [approvalRequiredWeatherFunction]);

Artık onay gerektiren bir işleviniz olduğundan aracı, işlevi doğrudan yürütmek ve sonucu döndürmek yerine bir onay isteğiyle yanıt verebilir. Herhangi bir FunctionApprovalRequestContent örneğin yanıt içeriğini denetleyebilirsiniz. Bu, aracının bir işlev için kullanıcı onayı gerektirdiğini gösterir.

AgentThread thread = agent.GetNewThread();
AgentRunResponse response = await agent.RunAsync("What is the weather like in Amsterdam?", thread);

var functionApprovalRequests = response.Messages
    .SelectMany(x => x.Contents)
    .OfType<FunctionApprovalRequestContent>()
    .ToList();

Herhangi bir işlev onay isteği varsa, işlev çağrısının ad ve bağımsız değişkenler de dahil olmak üzere ayrıntıları örnekteki özelliğinde FunctionCallFunctionApprovalRequestContent bulunabilir. Bu, kullanıcıya gösterilebilir, böylece işlev çağrısını onaylamaya veya reddetmeye karar verebilir. Bu örnekte bir istek olduğunu varsayalım.

FunctionApprovalRequestContent requestContent = functionApprovalRequests.First();
Console.WriteLine($"We require approval to execute '{requestContent.FunctionCall.Name}'");

Kullanıcı girdisini sağladıktan sonra, FunctionApprovalResponseContent yöntemini CreateResponse üzerinde kullanarak bir FunctionApprovalRequestContent örneği oluşturabilirsiniz. true işlev çağrısını onaylamak için, veya false reddetmek için geçirin.

Daha sonra yanıt içeriği, aracıdan sonucu geri almak için aynı iş parçacığı nesnesiyle birlikte aracıya yeni bir yapı UserChatMessage içinde geçirilebilir.

var approvalMessage = new ChatMessage(ChatRole.User, [requestContent.CreateResponse(true)]);
Console.WriteLine(await agent.RunAsync(approvalMessage, thread));

İşlev araçlarını insan onaylarıyla birlikte kullandığınızda, her ajanın çalıştırılmasından sonra, tüm işlev çağrıları onaylanana veya reddedilene kadar, yanıttaki FunctionApprovalRequestContent örnekleri denetlemeyi unutmayın.

Bu adımda, bir aracın yardımıyla insan onayı gereksinimi duyan fonksiyon araçlarının nasıl kullanılacağı gösterilir.

Aracılar, örneğin bir işlev çağrısını onaylamak için herhangi bir kullanıcı girdisi gerektirdiğinde, bu insan katılımı döngüsü örüntüsü olarak adlandırılır. Kullanıcı girişi gerektiren bir aracı çalıştırmak, son bir yanıtla tamamlanmak yerine, kullanıcıdan hangi girişin gerekli olduğunu belirten bir yanıtla tamamlanır. Aracı çağıran kişi, kullanıcıdan gerekli girdiği almaktan ve bunu yeni bir agent çalıştırmasının parçası olarak aracıya geri iletmekten sorumludur.

Önkoşullar

Önkoşullar ve Python paketlerini yükleme için bu öğreticideki Basit bir aracı oluşturma ve çalıştırma adımına bakın.

Onay gerektiren işlev araçlarıyla aracı oluşturma

İşlevleri kullanırken, her işlev için yürütülmeden önce insan onayı gerekip gerekmediğini belirtmek mümkündür. Bu işlem, @ai_function dekoratörü kullanılırken approval_mode parametresini "always_require" olarak ayarlayarak gerçekleştirilir.

Burada, belirli bir konumun hava durumunu alma sahtesini gösteren basit bir işlev aracı örneği verilmiştir.

from typing import Annotated
from agent_framework import ai_function

@ai_function
def get_weather(location: Annotated[str, "The city and state, e.g. San Francisco, CA"]) -> str:
    """Get the current weather for a given location."""
    return f"The weather in {location} is cloudy with a high of 15°C."

Onay gerektiren bir işlev oluşturmak için parametresini approval_mode kullanabilirsiniz:

@ai_function(approval_mode="always_require")
def get_weather_detail(location: Annotated[str, "The city and state, e.g. San Francisco, CA"]) -> str:
    """Get detailed weather information for a given location."""
    return f"The weather in {location} is cloudy with a high of 15°C, humidity 88%."

Aracıyı oluştururken, artık oluşturucuya bir araç listesi geçirerek ChatAgent onay gerektiren işlev aracını araca sağlayabilirsiniz.

from agent_framework import ChatAgent
from agent_framework.openai import OpenAIResponsesClient

async with ChatAgent(
    chat_client=OpenAIResponsesClient(),
    name="WeatherAgent",
    instructions="You are a helpful weather assistant.",
    tools=[get_weather, get_weather_detail],
) as agent:
    # Agent is ready to use

Artık onay gerektiren bir işleviniz olduğundan aracı, işlevi doğrudan yürütmek ve sonucu döndürmek yerine bir onay isteğiyle yanıt verebilir. Herhangi bir kullanıcı giriş isteği için yanıtı denetleyebilirsiniz. Bu, aracının bir işlev için kullanıcı onayı gerektirdiğini gösterir.

result = await agent.run("What is the detailed weather like in Amsterdam?")

if result.user_input_requests:
    for user_input_needed in result.user_input_requests:
        print(f"Function: {user_input_needed.function_call.name}")
        print(f"Arguments: {user_input_needed.function_call.arguments}")

Herhangi bir işlev onayı isteği varsa, işlev çağrısının ad ve bağımsız değişkenler de dahil olmak üzere ayrıntıları kullanıcı giriş isteğindeki function_call özelliğinde bulunabilir. Bu, kullanıcıya gösterilebilir, böylece işlev çağrısını onaylamaya veya reddetmeye karar verebilir.

Kullanıcı girdisini sağladıktan sonra, kullanıcı giriş isteğindeki create_response yöntemini kullanarak bir yanıt oluşturabilirsiniz. True işlev çağrısını onaylamak için, veya False reddetmek için geçirin.

Ardından, yanıt, sonucu aracıdan geri almak için yeni bir ChatMessage içinde aracıya iletilebilir.

from agent_framework import ChatMessage, Role

# Get user approval (in a real application, this would be interactive)
user_approval = True  # or False to reject

# Create the approval response
approval_message = ChatMessage(
    role=Role.USER, 
    contents=[user_input_needed.create_response(user_approval)]
)

# Continue the conversation with the approval
final_result = await agent.run([
    "What is the detailed weather like in Amsterdam?",
    ChatMessage(role=Role.ASSISTANT, contents=[user_input_needed]),
    approval_message
])
print(final_result.text)

Bir döngü içinde onayları işleme

Onay gerektiren birden çok işlev çağrısıyla çalışırken, tüm işlevler onaylanana veya reddedilene kadar döngüdeki onayları işlemeniz gerekebilir:

async def handle_approvals(query: str, agent) -> str:
    """Handle function call approvals in a loop."""
    current_input = query

    while True:
        result = await agent.run(current_input)

        if not result.user_input_requests:
            # No more approvals needed, return the final result
            return result.text

        # Build new input with all context
        new_inputs = [query]

        for user_input_needed in result.user_input_requests:
            print(f"Approval needed for: {user_input_needed.function_call.name}")
            print(f"Arguments: {user_input_needed.function_call.arguments}")

            # Add the assistant message with the approval request
            new_inputs.append(ChatMessage(role=Role.ASSISTANT, contents=[user_input_needed]))

            # Get user approval (in practice, this would be interactive)
            user_approval = True  # Replace with actual user input

            # Add the user's approval response
            new_inputs.append(
                ChatMessage(role=Role.USER, contents=[user_input_needed.create_response(user_approval)])
            )

        # Continue with all the context
        current_input = new_inputs

# Usage
result_text = await handle_approvals("Get detailed weather for Seattle and Portland", agent)
print(result_text)

İnsan müdahalesi gerekli olduğunda işlev araçlarını kullanırken, her araç çalıştırıldığında, tüm işlev çağrıları onaylanana veya reddedilene kadar yanıt üzerinde kullanıcı giriş isteklerini kontrol etmeyi unutmayın.

Sonraki Adımlar