forked from Azure/azure-sdk-for-python
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Beta4 release of azure-ai-projects SDK (Azure#38873)
- Loading branch information
Showing
79 changed files
with
1,590 additions
and
597 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,101 @@ | ||
# FunctionTool Specifications | ||
|
||
FunctionTool is the utility allowing developers to provide functions within their code and invoke during streaming or running. | ||
|
||
## Example of Function | ||
|
||
Here is an example of a function: | ||
```python | ||
def fetch_weather(location: str) -> str: | ||
""" | ||
Fetches the weather information for the specified location. | ||
:param location (str): The location to fetch weather for. | ||
:return: Weather information as a JSON string. | ||
:rtype: str | ||
""" | ||
# In a real-world scenario, you'd integrate with a weather API. | ||
mock_weather_data = {"New York": "Sunny, 25°C", "London": "Cloudy, 18°C", "Tokyo": "Rainy, 22°C"} | ||
weather = mock_weather_data.get(location, "Weather data not available for this location.") | ||
weather_json = json.dumps({"weather": weather}) | ||
return weather_json | ||
``` | ||
|
||
Here is an example to attach this function definition to create_agent | ||
|
||
```python | ||
functions = FunctionTool({fetch_weather}) | ||
|
||
agent = project_client.agents.create_agent( | ||
model=os.environ["MODEL_DEPLOYMENT_NAME"], | ||
name="my-assistant", | ||
instructions="You are a helpful assistant", | ||
tools=functions.definitions, | ||
) | ||
``` | ||
|
||
To verify that the SDK parsed the docstring properly, you can print the definition: | ||
|
||
```python | ||
[print(json.dumps(tool.as_dict(), indent=4)) for tool in functions.definitions] | ||
``` | ||
|
||
Alternatively user can check the tools property in newly created agent: | ||
|
||
```python | ||
[print(json.dumps(tool.as_dict(), indent=4)) for tool in agent.tools if tool.type == "function"] | ||
``` | ||
|
||
The terminal will display the definition as below: | ||
|
||
```json | ||
[ | ||
{ | ||
"type": "function", | ||
"function": { | ||
"name": "fetch_weather", | ||
"description": "Fetches the weather information for the specified location.", | ||
"parameters": { | ||
"type": "object", | ||
"properties": { | ||
"location": { | ||
"type": "string", | ||
"description": "The location to fetch weather for." | ||
} | ||
}, | ||
"required": [ | ||
"location" | ||
] | ||
} | ||
} | ||
} | ||
] | ||
``` | ||
|
||
## Requirements for FunctionTool | ||
|
||
To ensure `FunctionTool` operates correctly and generates accurate function definitions that agents can reliably call, adhere to the following standards: | ||
|
||
1. **Type Annotations** | ||
- All function parameters and return types should be explicitly type-annotated using Python's type hinting. | ||
|
||
2. **Structured Docstrings** | ||
- Utilize a consistent docstring format similar to the example above (see also related agent samples in this repository). | ||
- Include clear descriptions for each function and parameter. | ||
|
||
3. **Supported Types** | ||
|
||
`FunctionTool` maps common Python types to their JSON Schema equivalents, ensuring accurate representation without complex type details: | ||
|
||
- **Strings and Numbers** | ||
- `str` → `string` | ||
- `int` → `integer` | ||
- `float` → `number` | ||
- `bool` → `boolean` | ||
|
||
- **Collections** | ||
- `list` → `array` | ||
- `dict` → `object` | ||
|
||
- **Nullable Types** | ||
- `Optional[type]` includes `null` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.