Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Support structured output for chat completions #38999

Open
wants to merge 8 commits into
base: feature/azure-ai-inference-beta7
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 6 additions & 0 deletions sdk/ai/azure-ai-inference/CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,12 @@
### Features Added

* Added a client for Image Embeddings, named `ImageEmbeddingsClient`. See package README.md and new samples.
* Added support for specifying the JSON schema of the Chat Completion response. See new class `ChatCompletionsResponseFormatJsonSchema`. See sample ...

### Breaking Changes

* class `ChatCompletionsResponseFormatJson` renamed to `ChatCompletionsResponseFormatJsonObject`, to accommodate
the new class `ChatCompletionsResponseFormatJsonSchema`.

### Bugs Fixed

Expand Down
22 changes: 15 additions & 7 deletions sdk/ai/azure-ai-inference/azure/ai/inference/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,24 +5,32 @@
# Code generated by Microsoft (R) Python Code Generator.
# Changes may cause incorrect behavior and will be lost if the code is regenerated.
# --------------------------------------------------------------------------
# pylint: disable=wrong-import-position

from ._patch import ChatCompletionsClient
from ._patch import EmbeddingsClient
from ._patch import ImageEmbeddingsClient
from typing import TYPE_CHECKING

if TYPE_CHECKING:
from ._patch import * # pylint: disable=unused-wildcard-import

from ._client import ChatCompletionsClient # type: ignore
from ._client import EmbeddingsClient # type: ignore
from ._client import ImageEmbeddingsClient # type: ignore
from ._version import VERSION

__version__ = VERSION


from ._patch import load_client
try:
from ._patch import __all__ as _patch_all
from ._patch import *
except ImportError:
_patch_all = []
from ._patch import patch_sdk as _patch_sdk

__all__ = [
"load_client",
"ChatCompletionsClient",
"EmbeddingsClient",
"ImageEmbeddingsClient",
]

__all__.extend([p for p in _patch_all if p not in __all__]) # pyright: ignore

_patch_sdk()
7 changes: 3 additions & 4 deletions sdk/ai/azure-ai-inference/azure/ai/inference/_client.py
Original file line number Diff line number Diff line change
Expand Up @@ -28,11 +28,10 @@
from ._serialization import Deserializer, Serializer

if TYPE_CHECKING:
# pylint: disable=unused-import,ungrouped-imports
from azure.core.credentials import TokenCredential


class ChatCompletionsClient(ChatCompletionsClientOperationsMixin): # pylint: disable=client-accepts-api-version-keyword
class ChatCompletionsClient(ChatCompletionsClientOperationsMixin):
"""ChatCompletionsClient.
:param endpoint: Service host. Required.
Expand Down Expand Up @@ -110,7 +109,7 @@ def __exit__(self, *exc_details: Any) -> None:
self._client.__exit__(*exc_details)


class EmbeddingsClient(EmbeddingsClientOperationsMixin): # pylint: disable=client-accepts-api-version-keyword
class EmbeddingsClient(EmbeddingsClientOperationsMixin):
"""EmbeddingsClient.
:param endpoint: Service host. Required.
Expand Down Expand Up @@ -188,7 +187,7 @@ def __exit__(self, *exc_details: Any) -> None:
self._client.__exit__(*exc_details)


class ImageEmbeddingsClient(ImageEmbeddingsClientOperationsMixin): # pylint: disable=client-accepts-api-version-keyword
class ImageEmbeddingsClient(ImageEmbeddingsClientOperationsMixin):
"""ImageEmbeddingsClient.
:param endpoint: Service host. Required.
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -14,11 +14,10 @@
from ._version import VERSION

if TYPE_CHECKING:
# pylint: disable=unused-import,ungrouped-imports
from azure.core.credentials import TokenCredential


class ChatCompletionsClientConfiguration: # pylint: disable=too-many-instance-attributes,name-too-long
class ChatCompletionsClientConfiguration: # pylint: disable=too-many-instance-attributes
"""Configuration for ChatCompletionsClient.
Note that all parameters used to create this instance are saved as instance
Expand Down Expand Up @@ -75,7 +74,7 @@ def _configure(self, **kwargs: Any) -> None:
self.authentication_policy = self._infer_policy(**kwargs)


class EmbeddingsClientConfiguration: # pylint: disable=too-many-instance-attributes,name-too-long
class EmbeddingsClientConfiguration: # pylint: disable=too-many-instance-attributes
"""Configuration for EmbeddingsClient.
Note that all parameters used to create this instance are saved as instance
Expand Down Expand Up @@ -132,7 +131,7 @@ def _configure(self, **kwargs: Any) -> None:
self.authentication_policy = self._infer_policy(**kwargs)


class ImageEmbeddingsClientConfiguration: # pylint: disable=too-many-instance-attributes,name-too-long
class ImageEmbeddingsClientConfiguration: # pylint: disable=too-many-instance-attributes
"""Configuration for ImageEmbeddingsClient.
Note that all parameters used to create this instance are saved as instance
Expand Down
Loading
Loading