How do Structured Outputs Work?
Overview
Structured Outputs is a feature for forcing the LLM’s output to follow a specified format 100% of the time. This increases the reliability of LLM in enterprise applications where downstream applications expect the LLM output to be correctly formatted. By forcing the model to follow a structured schema, hallucinated fields and entries in structured data can be reliably eliminated.
Compatible models:
- Command R+ 08 2024
- Command R+
- Command R 08 2024
- Command R
How to Use Structured Outputs
There are two ways to use Structured Outputs:
- Structured Outputs (JSON). This is primarily used in text generation use cases.
- Structured Outputs (Tools). This is primarily used in tool use and agents use cases via function calling.
API Compatibility
Structured Outputs with Tools are only supported in Chat API V2 via the strict_tools
parameter. This parameter is not supported in Chat API V1.
Structured Outputs (JSON)
Here, you can call the Chat API to generate Structured Outputs in JSON format. JSON is a lightweight format that is easy for humans to read and write and is also easy for machines to parse.
This is particularly useful in text generation use cases, for example, when you want to extract specific information from the responses, perform data analysis, or integrate the responses into your applications seamlessly.
There are two ways of specifying the JSON output:
- JSON mode
- JSON Schema mode
JSON mode
In JSON mode, when making an API request, you can specify the response_format
parameter to indicate that you want the response in a JSON object format.
By setting the response_format
type to "json_object"
in the Chat API, the output of the model is guaranteed to be a valid JSON object.
Important
When using { "type": "json_object" }
your message
should always explicitly instruct the model to generate a JSON (eg: “Generate a JSON …”) . Otherwise the model may end up getting stuck generating an infinite stream of characters and eventually run out of context length.
Note
This feature is currently not supported in RAG mode.
JSON Schema mode
In JSON Schema mode, you can optionally define a schema as part of the response_format
parameter. A JSON Schema is a way to describe the structure of the JSON object you want the LLM to generate.
This forces the LLM to stick to this schema, thus giving you greater control over the output.
For example, let’s say you want the LLM to generate a JSON object with specific keys for a book, such as “title,” “author,” and “publication_year.” Your API request might look like this:
In this schema, we defined three keys (“title,” “author,” “publication_year”) and their expected data types (“string” and “integer”). The LLM will generate a JSON object that adheres to this structure.
Nested Array Schema Json Example
Here’s an example of a nested array. Note that the top level json structure must always be a json object.
The output for this example would be:
Important
Note: Each schema provided (in both JSON and Tools modes) will incur a latency overhead required for processing the schema. This is only applicable for the first few requests.
Structured Outputs (Tools)
When you use the Chat API with tools
, setting the strict_tools
parameter to True
will enforce that every generated tool call follows the specified tool schema.
With strict_tools
enabled, the API will ensure that the tool names and tool parameters are generated according to the tool definitions. This eliminates tool name and parameter hallucinations, ensures that each parameter matches the specified data type, and that all required parameters are included in the model response.
Additionally, this results in faster development. You don’t need to spend a lot of time prompt engineering the model to avoid hallucinations.
In the example below, we create a tool that can retrieve weather data for a given location. The tool is called get_weather
which contains a parameter called location
. We then invoke the Chat API with strict_tools
set to True
to ensure that the generated tool calls always include the correct function and parameter names.
When the strict_tools
parameter is set to True
, you can define a maximum of 200 fields across all tools being passed to an API call.
Important
When strict_tools
is enabled, tool definitions that have optional parameters must specify at least one required
parameter as well. Tools with only optional parameters are not supported in this mode.
When to Use Structured Outputs (JSON) vs. Structured Outputs (Tools)
Structured Outputs (JSON) are ideal for text generation use cases where you want to format the model’s responses to users in a specific way.
For example, when building a travel planner application, you might want the LLM to generate itineraries in a specific JSON format, allowing the application to use the output in the other parts of the application.
Structured Outputs (Tools) are ideal for function calling, tool use or agents use cases where you need the model to interact with external data or services. For instance, you can grant the model access to functions that interact with databases or other APIs.
In summary, opt for:
- Structured Outputs (JSON) when you need the model’s response to follow a specific structure.
- Structured Outputs (Tools) when you need the model to interact with external data or services.
Specifying a schema
Generating nested objects
The model can be configured to output objects with up to 5 levels of nesting. When a schema
is specified, there are no limitations on the levels of nesting.
Schema constraints
When constructing a schema
keep the following constraints in mind:
- The
type
in the top level schema must beobject
- Every object in the schema must have at least one
required
field specified
Parameter types support
Supported schema features
The Structured Outputs feature (both JSON and Tools mode) relies on the JSON Schema notation for defining the parameters. JSON Schema allows developers to specify the expected format of JSON objects, ensuring that the data adheres to predefined rules and constraints.
Structured Outputs supports a subset of the JSON Schema specification, detailed in the tables below. This is broken down into three categories:
- Structured Outputs (JSON)
- Structured Outputs (Tools) - When
strict_tools
is set toTrue
- Tool Use - When
strict_tools
is set toFalse
Basic types
See usage examples for JSON and Tools.
Arrays
See usage examples for JSON and Tools.
Others
¹ Const is supported for these types: int
, float
, bool
, type(None)
, str
.
² Format is supported for these values: date-time
, uuid
, date
, time
.
³ In Structured Outputs (JSON), additionalProperties
does not enforce required
, dependencies
, propertyNames
, anyOf
, allOf
, oneOf
.
⁴ In Structured Outputs (Tools), additionalProperties
does not enforce required
, dependencies
, propertyNames
, any Of
, all Of
, one Of
.
See usage examples for JSON and Tools.
Unsupported schema features
We do not support the entirety of the JSON Schema specification. Below is a list of some unsupported features:
- Schema Composition (
allOf
,oneOf
andnot
) - Numeric Ranges (
maximum
andminimum
) - Array Length Ranges (
minItems
andmaxItems
) - String limitations:
- String Length (
maxLength
andminLength
) - The following are not supported in Regular Expressions
^
$
?=
?!
- The following formats are the only supported ones
date-time
uuid
date
time
- String Length (