Text completions
POST/v1/completions
Generate text based on the given text prompt. See available models at this pricing table.
To successfully run an inference request, it is mandatory to enter a personal access token (e.g. flp_XXX) value in the Bearer Token field. Refer to the authentication section on our introduction page to learn how to acquire this variable and visit here to generate your token.
Request
Header Parameters
ID of team to run requests as (optional parameter).
- application/json
Body
- Prompt
- Tokens
- Array [
- ]
- Array [
- ]
The prompt (i.e., input text) to generate completion for. Either prompt
or tokens
field is required.
The tokenized prompt (i.e., input tokens). Either prompt
or tokens
field is required.
Code of the model to use. See available model list.
Whether to stream generation result. When set true, each token will be sent as server-sent events once generated. Not supported when using beam search.
Request timeout. Gives the HTTP 429 Too Many Requests
response status code. Default behavior is no timeout.
The maximum number of tokens to generate. For decoder-only models like GPT, the length of your input tokens plus max_tokens
should not exceed the model's maximum length (e.g., 2048 for OpenAI GPT-3). For encoder-decoder models like T5 or BlenderBot, max_tokens
should not exceed the model's maximum output length. This is similar to Hugging Face's max_new_tokens
argument.
The maximum number of tokens including both the generated result and the input tokens. Only allowed for decoder-only models. Only one argument between max_tokens
and max_total_tokens
is allowed. Default value is the model's maximum length. This is similar to Hugging Face's max_length
argument.
The minimum number of tokens to generate. default value is 0. this is similar to hugging face's min_new_tokens
argument.
The minimum number of tokens including both the generated result and the input tokens. Only allowed for decoder-only models. Only one argument between min_tokens
and min_total_tokens
is allowed. This is similar to Hugging Face's min_length
argument.
The number of independently generated results for the prompt. Not supported when using beam search. Defaults to 1. This is similar to Hugging Face's num_return_sequences
argument.
Number of beams for beam search. Numbers between 1 and 31 (both inclusive) are allowed. Default behavior is no beam search. This is similar to Hugging Face's num_beams
argument.
Coefficient for exponential length penalty that is used with beam search. Only allowed for beam search. Defaults to 1.0. This is similar to Hugging Face's length_penalty
argument.
Whether to stop the beam search when at least num_beams
beams are finished with the EOS token. Only allowed for beam search. Defaults to false. This is similar to Hugging Face's early_stopping
argument.
If this exceeds 1, every ngram of that size can only occur once among the generated result (plus the input tokens for decoder-only models). 1 means that this mechanism is disabled (i.e., you cannot prevent 1-gram from being generated repeatedly). Defaults to 1. This is similar to Hugging Face's no_repeat_ngram_size
argument.
If this exceeds 1, every ngram of that size occurring in the input token sequence cannot appear in the generated result. 1 means that this mechanism is disabled (i.e., you cannot prevent 1-gram from being generated repeatedly). Only allowed for encoder-decoder models. Defaults to 1. This is similar to Hugging Face's encoder_no_repeat_ngram_size
argument.
Penalizes tokens that have already appeared in the generated result (plus the input tokens for decoder-only models). should be greater than or equal to 1.0. 1.0 means no penalty. see keskar et al., 2019 for more details. this is similar to Hugging Face's repetition_penalty
argument.
Penalizes tokens that have already appeaared in the input tokens. Should be greater than or equal to 1.0. 1.0 means no penalty. Only allowed for encoder-decoder models. See Keskar et al., 2019 for more details. This is similar to Hugging Face's encoder_repetition_penalty
argument.
Number between -2.0 and 2.0. Positive values penalizes tokens that have been sampled, taking into account their frequency in the preceding text. This penalization diminishes the model's tendency to reproduce identical lines verbatim.
Number between -2.0 and 2.0. Positive values penalizes tokens that have been sampled at least once in the existing text.
Sampling temperature. Smaller temperature makes the generation result closer to greedy, argmax (i.e., top_k = 1
) sampling. defaults to 1.0. this is similar to hugging face's temperature
argument.
The number of highest probability tokens to keep for sampling. Numbers between 0 and the vocab size of the model (both inclusive) are allowed. The default value is 0, which means that the API does not apply top-k filtering. This is similar to Hugging Face's top_k
argument.
Tokens comprising the top top_p
probability mass are kept for sampling. Numbers between 0.0 (exclusive) and 1.0 (inclusive) are allowed. Defaults to 1.0. This is similar to Hugging Face's top_p
argument.
When one of the stop phrases appears in the generation result, the API will stop generation.
The stop phrases are excluded from the result.
This option is incompatible with beam search (specified by num_beams
); use stop_tokens
for that case instead.
Defaults to empty list.
stop_tokens object[]nullable
Stop generating further tokens when generated token corresponds to any of the tokens in the sequence. If beam search is enabled, all of the active beams should contain the stop token to terminate generation.
A List of token IDs.
Seed to control random procedure. If nothing is given, the API generate the seed randomly, use it for sampling, and return the seed along with the generated result. When using the n
argument, you can pass a list of seed values to control all of the independent generations.
A list of token indices where to replace the embeddings of input tokens provided via either tokens
or prompt
.
A list of flattened embedding vectors used for replacing the tokens at the specified indices provided via token_index_to_replace
.
One of DETERMINISTIC
, NAIVE_SAMPLING
, and STOCHASTIC
. Which beam search type to use. DETERMINISTIC
means the standard, deterministic beam search, which is similar to Hugging Face's beam_search
. Argmuents for controlling random sampling such as top_k
and top_p
are not allowed for this option. NAIVE_SAMPLING
is similar to Hugging Face's beam_sample
. STOCHASTIC
means stochastic beam search (more details in Kool et al. (2019)). This option is ignored if num_beams
is not provided. Defaults to DETERMINISTIC
.
Text phrases that should not be generated.
For a bad word phrase that contains N tokens, if the first N-1 tokens appears at the last of the generated result, the logit for the last token of the phrase is set to -inf.
Before checking whether a bard word is included in the result, the word is converted into tokens.
We recommend using bad_word_tokens
because it is clearer.
For example, after tokenization, phrases "clear" and " clear" can result in different token sequences due to the prepended space character.
Defaults to empty list.
bad_word_tokens object[]nullable
Same as the above bad_words
field, but receives token sequences instead of text phrases. This is similar to Hugging Face's bad_word_ids
argument.
A List of token IDs.
Whether to include the output logits to the generation output.
Whether to include the output logprobs to the generation output.
A list of endpoint sentence tokens.
response_format TextResponseFormatnullable
The enforced format of the model's output.
Note that the content of the output message may be truncated if it exceeds the max_tokens
.
You can check this by verifying that the finish_reason
of the output message is "length"
.
Important
You must explicitly instruct the model to produce the desired output format using a system prompt or user message (e.g., You are an API generating a valid JSON as output.
).
Otherwise, the model may result in an unending stream of whitespace or other characters.
Possible values: [text
, json_object
, regex
]
Type of the response format.
The schema of the output. For { "type": "json_object" }
, schema
should be a serialized string of JSON schema. For { "type": "regex" }
, schema
should be a regex pattern.
Caveat
For the JSON object type, recursive definitions are not supported. Optional properties are also not supported; all properties of { "type": "object" }
are generated regardless of whether they are listed in the required
field.
For the regex type, lookaheads/lookbehinds (e.g., \a
, \z
, ^
, $
, (?=)
, (?!)
, (?<=...)
, (?<!...)
) are not supported. Group specials (e.g., \w
, \W
, \d
, \D
, \s
, \S
) do not support non-ASCII characters. Unicode escape patterns (e.g., \N
, \p
, \P
) are not supported. Additionally, conditional matching ((?(
) and back-references can cause inefficiency.
Responses
- 200
Successfully generated completions. When streaming mode is used (i.e., stream
option is set to true
), the response is in MIME type text/event-stream
. Otherwise, the content type is application/json
.
- application/json
- text/event-stream
- Schema
- Example (No Streaming)
Schema
- Array [
- ]
choices object[]
The index of the choice in the list of generated choices.
Random seed used for the generation.
Generated text output.
Generated output tokens.
usage object
Number of tokens in the prompt.
Number of tokens in the generated completion.
Total number of tokens used in the request (prompt_tokens
+ completion_tokens
).
No streaming example
{
"choices": [
{
"index": 0,
"seed": 42,
"text": "\n\nThis is indeed a test",
"tokens": [
3,
3,
412,
15,
5440,
129,
3391
]
}
],
"usage": {
"prompt_tokens": 5,
"completion_tokens": 7,
"total_tokens": 12
}
}
- Schema
- Example (Streaming)
Schema
- token_sampled
- complete
- Array [
- ]
Possible values: [token_sampled
, complete
]
Type of server-sent event
The index of the choice in the list of generated choices.
Generated text output.
Generated output token.
choices object[]
The index of the choice in the list of generated choices.
Random seed used for the generation.
Generated text output.
Generated output tokens.
usage object
Number of tokens in the prompt.
Number of tokens in the generated completion.
Total number of tokens used in the request (prompt_tokens
+ completion_tokens
).
Streaming example (server-sent events)
data: {"event": "token_sampled", "index": 0, "text": "\n", "token": 3}
data: {"event": "token_sampled", "index": 0, "text": "\n", "token": 3}
data: {"event": "token_sampled", "index": 0, "text": "This", "token": 412}
data: {"event": "token_sampled", "index": 0, "text": " is", "token": 15}
data: {"event": "token_sampled", "index": 0, "text": " indeed", "token": 5440}
data: {"event": "token_sampled", "index": 0, "text": " a", "token": 129}
data: {"event": "token_sampled", "index": 0, "text": " test", "token": 3391}
data: {
"event": "complete",
"choices": [
{
"index": 0,
"seed": 42,
"text": "\n\nThis is indeed a test",
"tokens": [3, 3, 412, 15, 5440, 129, 3391]
}
],
"usage": {
"prompt_tokens": 5,
"completion_tokens": 7,
"total_tokens": 12
}
}