Exemplos de uso de ferramentas
Aqui estão alguns exemplos de código demonstrando vários padrões e técnicas de uso de ferramentas. Por uma questão de brevidade, as ferramentas são ferramentas simples e as descrições das ferramentas são mais curtas do que seria ideal para garantir o melhor desempenho. Veja especificando ferramentas para mais informações.
Ferramenta única
Este exemplo mostra uma situação básica de ferramenta única, usando uma ferramenta get_weather
.
Claude retornará uma resposta semelhante a:
{
"id": "msg_01Aq9w938a90dw8q",
"model": "claude-3-opus-20240229",
"stop_reason": "tool_use",
"role": "assistant",
"content": [
{
"type": "text",
"text": "<thinking>Preciso chamar a função get_weather, e o usuário quer SF, que provavelmente é São Francisco, CA.</thinking>"
},
{
"type": "tool_use",
"id": "toolu_01A09q90qw90lq917835lq9",
"name": "get_weather",
"input": {"location": "São Francisco, CA", "unit": "celsius"}
}
]
}
Você então precisaria executar a função get_weather
com a entrada fornecida e retornar o resultado em uma nova mensagem de user
:
Isso imprimirá a resposta final de Claude, incorporando os dados do clima:
{
"id": "msg_01Aq9w938a90dw8q",
"model": "claude-3-opus-20240229",
"stop_reason": "stop_sequence",
"role": "assistant",
"content": [
{
"type": "text",
"text": "O clima atual em São Francisco é de 15 graus Celsius (59 graus Fahrenheit). É um dia frio na cidade à beira da baía!"
}
]
}
Informações ausentes
Se o prompt do usuário não incluir informações suficientes para preencher todos os parâmetros necessários para uma ferramenta, o Claude 3 Opus tem muito mais probabilidade de reconhecer que um parâmetro está faltando e pedir por ele. O Claude 3 Sonnet pode perguntar, especialmente quando solicitado a pensar antes de gerar uma solicitação de ferramenta. Mas também pode fazer o possível para inferir um valor razoável.
Por exemplo, usando a ferramenta get_weather
acima, se você perguntar ao Claude “Como está o tempo?” sem especificar um local, o Claude, particularmente o Claude 3 Sonnet, pode tentar adivinhar as entradas das ferramentas:
{
"type": "tool_use",
"id": "toolu_01A09q90qw90lq917835lq9",
"name": "get_weather",
"input": {"location": "Nova York, NY", "unit": "fahrenheit"}
}
Esse comportamento não é garantido, especialmente para prompts mais ambíguos e para modelos menos inteligentes que o Claude 3 Opus. Se o Claude 3 Opus não tiver contexto suficiente para preencher os parâmetros necessários, é muito mais provável que responda com uma pergunta de esclarecimento em vez de fazer uma chamada de ferramenta.
Múltiplas ferramentas
Você pode fornecer ao Claude várias ferramentas para escolher em uma única solicitação. Aqui está um exemplo com uma ferramenta get_weather
e uma ferramenta get_time
, junto com uma consulta do usuário que pede por ambas.
Nesse caso, o Claude provavelmente tentará usar duas ferramentas separadas, uma de cada vez - get_weather
e depois get_time
- para responder completamente à pergunta do usuário. No entanto, ocasionalmente também pode gerar dois blocos tool_use
de uma vez, particularmente se eles não forem dependentes um do outro. Você precisaria executar cada ferramenta e retornar seus resultados em blocos tool_result
separados dentro de uma única mensagem de user
.
Ferramentas sequenciais
Algumas tarefas podem exigir a chamada de várias ferramentas em sequência, usando a saída de uma ferramenta como entrada para outra. Nesse caso, o Claude chamará uma ferramenta por vez. Se solicitado a chamar todas as ferramentas de uma vez, o Claude provavelmente adivinhará os parâmetros para ferramentas mais adiante se eles dependerem dos resultados de ferramentas anteriores.
Aqui está um exemplo de uso de uma ferramenta get_location
para obter a localização do usuário e, em seguida, passar essa localização para a ferramenta get_weather
:
Nesse caso, o Claude primeiro chamaria a ferramenta get_location
para obter a localização do usuário. Depois que você retornar a localização em um tool_result
, o Claude então chamaria get_weather
com essa localização para obter a resposta final.
A conversa completa pode ser assim:
Função | Conteúdo |
---|---|
Usuário | Como está o tempo onde eu estou? |
Assistente | <thinking>Para responder isso, primeiro preciso determinar a localização do usuário usando a ferramenta get_location. Então posso passar essa localização para a ferramenta get_weather para descobrir o clima atual lá.</thinking>[Uso da ferramenta para get_location] |
Usuário | [Resultado da ferramenta para get_location com id correspondente e resultado de São Francisco, CA] |
Assistente | [Uso da ferramenta para get_weather com a seguinte entrada]{ “location”: “São Francisco, CA”, “unit”: “fahrenheit” } |
Usuário | [Resultado da ferramenta para get_weather com id correspondente e resultado de “59°F (15°C), principalmente nublado”] |
Assistente | Com base na sua localização atual em São Francisco, CA, o clima agora é de 59°F (15°C) e principalmente nublado. É um dia bastante frio e nublado na cidade. Você pode querer levar uma jaqueta leve se for sair. |
Este exemplo demonstra como o Claude pode encadear várias chamadas de ferramentas para responder a uma pergunta que requer a coleta de dados de diferentes fontes. As etapas principais são:
- O Claude primeiro percebe que precisa da localização do usuário para responder à pergunta sobre o clima, então chama a ferramenta
get_location
. - O usuário (ou seja, o código do cliente) executa a função
get_location
real e retorna o resultado “São Francisco, CA” em um blocotool_result
. - Com a localização agora conhecida, o Claude prossegue para chamar a ferramenta
get_weather
, passando “São Francisco, CA” como o parâmetrolocation
(bem como um parâmetrounit
adivinhado, já queunit
não é um parâmetro obrigatório). - O usuário novamente executa a função
get_weather
real com os argumentos fornecidos e retorna os dados do clima em outro blocotool_result
. - Finalmente, o Claude incorpora os dados do clima em uma resposta em linguagem natural à pergunta original.
Uso de ferramentas com cadeia de pensamento
Por padrão, o Claude 3 Opus é solicitado a pensar antes de responder a uma consulta de uso de ferramenta para melhor determinar se uma ferramenta é necessária, qual ferramenta usar e os parâmetros apropriados. O Claude 3 Sonnet e o Claude 3 Haiku são solicitados a tentar usar ferramentas o máximo possível e têm mais probabilidade de chamar uma ferramenta desnecessária ou inferir parâmetros ausentes. Para solicitar que o Sonnet ou o Haiku avaliem melhor a consulta do usuário antes de fazer chamadas de ferramentas, o seguinte prompt pode ser usado:
Prompt de cadeia de pensamento
Responda à solicitação do usuário usando ferramentas relevantes (se estiverem disponíveis). Antes de chamar uma ferramenta, faça uma análise dentro das tags \<thinking>\</thinking>. Primeiro, pense sobre qual das ferramentas fornecidas é a ferramenta relevante para responder à solicitação do usuário. Segundo, percorra cada um dos parâmetros necessários da ferramenta relevante e determine se o usuário forneceu diretamente ou deu informações suficientes para inferir um valor. Ao decidir se o parâmetro pode ser inferido, considere cuidadosamente todo o contexto para ver se ele suporta um valor específico. Se todos os parâmetros necessários estiverem presentes ou puderem ser razoavelmente inferidos, feche a tag de pensamento e prossiga com a chamada da ferramenta. MAS, se um dos valores para um parâmetro necessário estiver faltando, NÃO invoque a função (nem mesmo com preenchimentos para os parâmetros ausentes) e, em vez disso, peça ao usuário para fornecer os parâmetros ausentes. NÃO peça mais informações sobre parâmetros opcionais se não forem fornecidos.
Modo JSON
Você pode usar ferramentas para fazer com que o Claude produza uma saída JSON que segue um esquema, mesmo que não tenha intenção de executar essa saída por meio de uma ferramenta ou função.
Ao usar ferramentas dessa maneira:
- Você geralmente deseja fornecer uma única ferramenta
- Você deve definir
tool_choice
(consulte Forçando o uso de ferramentas) para instruir o modelo a usar explicitamente essa ferramenta - Lembre-se de que o modelo passará a
input
para a ferramenta, então o nome da ferramenta e a descrição devem ser da perspectiva do modelo.
O seguinte usa uma ferramenta record_summary
para descrever uma imagem seguindo um formato específico.