(model: ModelConfig)
| 23 | } |
| 24 | |
| 25 | export function getModelMaxTokens(model: ModelConfig): number { |
| 26 | const contextLimit = getModelContextLimit(model); |
| 27 | const maxTokens = model.defaultCompletionOptions?.maxTokens; |
| 28 | |
| 29 | return maxTokens === undefined |
| 30 | ? Math.ceil( |
| 31 | Math.min(contextLimit * DEFAULT_MAX_TOKENS_RATIO, MAX_MAX_TOKENS), |
| 32 | ) |
| 33 | : maxTokens; |
| 34 | } |
| 35 | |
| 36 | /** |
| 37 | * Count tokens in message content (string or multimodal array) |
no test coverage detected