Trimming Input Messages
Use litellm.trim_messages() to ensure messages does not exceed a model's token limit or specified max_tokens
Usage
from litellm import completion
from litellm.utils import trim_messages
response = completion(
model=model,
messages=trim_messages(messages, model) # trim_messages ensures tokens(messages) < max_tokens(model)
)
Usage - set max_tokens
from litellm import completion
from litellm.utils import trim_messages
response = completion(
model=model,
messages=trim_messages(messages, model, max_tokens=10), # trim_messages ensures tokens(messages) < max_tokens
)
Parameters
The function uses the following parameters:
messages
:[Required] This should be a list of input messagesmodel
:[Optional] This is the LiteLLM model being used. This parameter is optional, as you can alternatively specify themax_tokens
parameter.system_message
:[Optional] This is a string containing an optional system message that will be preserved at the beginning of the conversation. This parameter is optional and set toNone
by default.max_tokens
:[Optional] This is an int, manually set upper limit on messagestrim_ratio
:[Optional] This represents the target ratio of tokens to use following trimming. It's default value is 0.75, which implies that messages will be trimmed to utilise about 75%