interface ChatWatsonxInput {
    authenticator?: string;
    cache?: boolean | BaseCache<Generation[]>;
    callbackManager?: CallbackManager;
    callbacks?: Callbacks;
    disableStreaming?: boolean;
    frequencyPenalty?: number;
    headers?: OutgoingHttpHeaders;
    idOrName?: string;
    logprobs?: boolean;
    maxConcurrency?: number;
    maxRetries?: number;
    maxTokens?: number;
    messages?: TextChatMessages[];
    metadata?: Record<string, unknown>;
    model: string;
    n?: number;
    onFailedAttempt?: FailedAttemptHandler;
    presencePenalty?: number;
    projectId?: string;
    responseFormat?: TextChatResponseFormat;
    serviceUrl: string;
    spaceId?: string;
    streaming?: boolean;
    tags?: string[];
    temperature?: number;
    timeLimit?: number;
    toolChoiceOption?: string;
    tools?: TextChatParameterTools[];
    topLogprobs?: number;
    topP?: number;
    verbose?: boolean;
    version: string;
    watsonxCallbacks?: RequestCallbacks<any>;
}

Hierarchy (view full)

Implemented by

Properties

authenticator?: string
cache?: boolean | BaseCache<Generation[]>
callbackManager?: CallbackManager

Use callbacks instead

callbacks?: Callbacks
disableStreaming?: boolean

Whether to disable streaming.

If streaming is bypassed, then stream() will defer to invoke().

  • If true, will always bypass streaming case.
  • If false (default), will always use streaming case if available.
frequencyPenalty?: number

Positive values penalize new tokens based on their existing frequency in the text so far, decreasing the model's likelihood to repeat the same line verbatim.

headers?: OutgoingHttpHeaders
idOrName?: string
logprobs?: boolean

Whether to return log probabilities of the output tokens or not. If true, returns the log probabilities of each output token returned in the content of message.

maxConcurrency?: number

The maximum number of concurrent calls that can be made. Defaults to Infinity, which means no limit.

maxRetries?: number

The maximum number of retries that can be made for a single call, with an exponential backoff between each attempt. Defaults to 6.

maxTokens?: number

The maximum number of tokens that can be generated in the chat completion. The total length of input tokens and generated tokens is limited by the model's context length.

messages?: TextChatMessages[]

The messages for this chat session.

metadata?: Record<string, unknown>
model: string
n?: number

How many chat completion choices to generate for each input message. Note that you will be charged based on the number of generated tokens across all of the choices. Keep n as 1 to minimize costs.

onFailedAttempt?: FailedAttemptHandler

Custom handler to handle failed attempts. Takes the originally thrown error object as input, and should itself throw an error if the input error is not retryable.

presencePenalty?: number

Positive values penalize new tokens based on whether they appear in the text so far, increasing the model's likelihood to talk about new topics.

projectId?: string

The project that contains the resource. Either space_id or project_id has to be given.

responseFormat?: TextChatResponseFormat

The chat response format parameters.

serviceUrl: string
spaceId?: string

The space that contains the resource. Either space_id or project_id has to be given.

streaming?: boolean
tags?: string[]
temperature?: number

What sampling temperature to use,. Higher values like 0.8 will make the output more random, while lower values like 0.2 will make it more focused and deterministic.

We generally recommend altering this or top_p but not both.

timeLimit?: number

Time limit in milliseconds - if not completed within this time, generation will stop. The text generated so far will be returned along with the `TIME_LIMIT`` stop reason. Depending on the users plan, and on the model being used, there may be an enforced maximum time limit.

toolChoiceOption?: string

Using none means the model will not call any tool and instead generates a message.

The following options (auto and required) are not yet supported.

Using auto means the model can pick between generating a message or calling one or more tools. Using required means the model must call one or more tools.

Only one of tool_choice_option or tool_choice must be present.

tools?: TextChatParameterTools[]

Tool functions that can be called with the response.

topLogprobs?: number

An integer specifying the number of most likely tokens to return at each token position, each with an associated log probability. The option logprobs must be set to true if this parameter is used.

topP?: number

An alternative to sampling with temperature, called nucleus sampling, where the model considers the results of the tokens with top_p probability mass. So 0.1 means only the tokens comprising the top 10% probability mass are considered.

We generally recommend altering this or temperature but not both.

verbose?: boolean
version: string
watsonxCallbacks?: RequestCallbacks<any>