How to use Structured Responses
To properly use the “response_format” you can define your schema with various “properties”, representing categories of outputs, each with individually configured data types. These objects can be nested to create more advanced structures of outputs. Here is an example of an API call using response_format to explain the step-by-step process of solving a math equation. You can see that the properties were configured to require both “steps” and “final_answer” within the response. Within nesting, the steps category consists of both an “explanation” and an “output”, each as strings.Gotchas
Here are some key requirements to keep in mind when using Structured Outputs via response_format:- Initial requests using response_format may take longer to generate a response. Subsequent requests will not experience the same latency as the initial request.
- 
For larger queries, the model can fail to complete if either max_tokensor model timeout are reached, or if any rate limits are violated
- Incorrect schema format will result in errors on completion, usually due to timeout
- Although response_format ensures the model will output a particular way, it does not guarantee that the model provided the correct information within. The content is driven by the prompt and the model performance.
- Structured Outputs via response_format are not compatible with parallel function calls
- 
Important: All fields or parameters must include a requiredtag. To make a field optional, you need to add anulloption within thetypeof the field, like this"type": ["string", "null"]
- 
It is possible to make fields optional by giving a nulloptions within the required field to allow an empty response.
- 
Important: additionalPropertiesmust be set to false for response_format to work properly
- 
Important: strictmust be set to true for response_format to work properly