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

.Net: adds support for strict mode with OpenAI #9924

Open
wants to merge 54 commits into
base: main
Choose a base branch
from

Conversation

baywet
Copy link
Member

@baywet baywet commented Dec 10, 2024

fixes #9786
closes #9741

eiriktsarpalis and others added 23 commits December 10, 2024 07:39
Signed-off-by: Vincent Biret <[email protected]>
Signed-off-by: Vincent Biret <[email protected]>
@baywet baywet requested a review from a team as a code owner December 10, 2024 12:40
@markwallace-microsoft markwallace-microsoft added .NET Issue or Pull requests regarding .NET code kernel Issues or pull requests impacting the core kernel kernel.core labels Dec 10, 2024
@github-actions github-actions bot changed the title adds support for strict mode with OpenAI .Net: adds support for strict mode with OpenAI Dec 10, 2024
dotnet/samples/Concepts/Plugins/ApiManifestBasedPlugins.cs Outdated Show resolved Hide resolved
@@ -178,7 +178,7 @@ public static async IAsyncEnumerable<ChatMessageContent> GetMessagesAsync(Assist

FunctionCallsProcessor functionProcessor = new(logger);
// This matches current behavior. Will be configurable upon integrating with `FunctionChoice` (#6795/#5200)
FunctionChoiceBehaviorOptions functionOptions = new() { AllowConcurrentInvocation = true, AllowParallelCalls = true };
FunctionChoiceBehaviorOptions functionOptions = new() { AllowConcurrentInvocation = true, AllowParallelCalls = true, AllowStrictSchemaAdherence = true };
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Shouldn't we have the strict mode configurable? To keep it off by default and allow it to be enabled if necessary. This way, we can avoid unnecessary behavioral changes.

@@ -33,7 +33,7 @@ public string? ArgumentName
/// <summary>
/// The parameter type - string, integer, number, boolean, array and object.
/// </summary>
internal string Type { get; }
public string Type { get; }
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The type and array item type parameters together with constructor were intentionally kept internal because their types will change during the migration to Microsoft.OpenApi V2. Consider adding a freezable setter to the Schema property, like the one for the ArgumentName property, so that a modified schema can be assigned.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The reason why I had to change those to public is because I need access to it in the samples.
https://github.com/baywet/semantic-kernel/blob/3b296e91b4e35a63edf537d58e56a7ef4dcd2c6d/dotnet/samples/Concepts/Plugins/CopilotAgentBasedPlugins.cs#L161

Do you have an example of a freezable setter implementation?

@baywet baywet deployed to integration January 3, 2025 12:56 — with GitHub Actions Active
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
kernel.core kernel Issues or pull requests impacting the core kernel .NET Issue or Pull requests regarding .NET code
Projects
None yet
Development

Successfully merging this pull request may close these issues.

.Net: Extend function calling model to support strict mode
6 participants