fix(anthropic): implement temperature/topP mutual exclusivity#11458
Merged
lgrammel merged 2 commits intovercel:mainfrom Jan 5, 2026
Merged
Conversation
Resolves the Anthropic API breaking change where sampling parameters must use only temperature OR top_p, not both. When both parameters are provided, temperature takes priority and topP is ignored with a warning message.
lgrammel
approved these changes
Jan 5, 2026
lgrammel
approved these changes
Jan 5, 2026
4 tasks
gr2m
added a commit
that referenced
this pull request
Apr 2, 2026
…els (#14052) ## Background The `@ai-sdk/anthropic` provider enforces temperature/topP mutual exclusivity for all models (#11458), matching a constraint in the Anthropic API. However, providers like Minimax use the Anthropic-compatible API endpoint with non-Anthropic models (e.g. `MiniMax-M2.7`) that require both `temperature` and `top_p` to be set simultaneously. The SDK currently drops `topP` whenever both are provided, with no way to override this behavior. ## Summary - Renamed `isKnownModel` to `isKnownAnthropicModel` for clarity - Updated the fallback in `getModelCapabilities` to return `true` for unknown models whose ID starts with `claude-` (forward-compatible with future Anthropic models) - Added `isKnownAnthropicModel` as a guard for the temperature/topP mutual exclusivity check — non-Anthropic models using the Anthropic-compatible API can now send both parameters ## Manual Verification Created a test using a non-Anthropic model ID (`MiniMax-M2.7`) that verifies both `temperature` and `top_p` are sent in the request body without warnings.
This file contains hidden or 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
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
Background
Anthropic introduced a breaking change in their API requiring that sampling parameters use only
temperatureORtop_p, not both. This aligns with their Claude 4 migration guidelines.Previously, the AI SDK Anthropic provider would send both parameters to the API when both were specified, which would result in an API error with the new Anthropic API requirements.
See: https://platform.claude.com/docs/en/about-claude/models/migrating-to-claude-4
Summary
This PR implements mutual exclusivity between
temperatureandtopPparameters in the Anthropic provider:Changes:
temperatureandtopPare provided:temperaturetakes prioritytopPis set toundefinedand excluded from the API requestFiles Modified:
packages/anthropic/src/anthropic-messages-language-model.ts(lines 436-446)packages/anthropic/src/anthropic-messages-language-model.test.tsManual Verification
Test Suite Verification: All 235 tests pass, including:
Expected Behavior:
temperatureis provided → sends temperature to API ✅topPis provided → sends topP to API ✅Checklist
pnpm changesetin the project root)Related Issues
Resolves the Anthropic API breaking change for Claude 4 parameter requirements.