- 
                Notifications
    You must be signed in to change notification settings 
- Fork 1.2k
feat: Add max_output_tokens as argument to Response API #3699
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
base: main
Are you sure you want to change the base?
Conversation
| Hi @abhibongale! Thank you for your pull request and welcome to our community. Action RequiredIn order to merge any pull request (code, docs, etc.), we require contributors to sign our Contributor License Agreement, and we don't seem to have one on file for you. ProcessIn order for us to review and merge your suggested changes, please sign at https://code.facebook.com/cla. If you are contributing on behalf of someone else (eg your employer), the individual CLA may not be sufficient and your employer may need to sign the corporate CLA. Once the CLA is signed, our tooling will perform checks and validations. Afterwards, the pull request will be tagged with  If you have received this in error or have any questions, please contact us at [email protected]. Thanks! | 
Responses and Completions have a max_output_tokens field. It is currently missing from the create and response object in Responses API. This PR fixes it. fixes: llamastack#3562 Signed-off-by: Abhishek Bongale <[email protected]>
5fa97b5    to
    bb58da2      
    Compare
  
    | Thank you for signing our Contributor License Agreement. We can now accept your code for this (and any) Meta Open Source project. Thanks! | 
| messages=messages, | ||
| response_tools=tools, | ||
| temperature=temperature, | ||
| max_tokens=max_output_tokens, | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
why did you change the name to max_tokens here? keep the same thing?
| description: "Agents | ||
| APIs for creating and interacting with agentic systems." | ||
| APIs for creating and interacting with agentic systems." | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
looks like your pre-commit setup is not correct. it needs python3.12 and pre-commit==4.3.0
| _ = response.output[0].call_id | ||
|  | ||
|  | ||
| def test_response_with_max_output_tokens(compat_client, text_model_id): | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
before testing, maybe keep PRs in draft state? you have not implemented the functionality.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think fully supporting this parameter might be more complicated than what this PR is doing.  It is important to keep in mind that a single Responses call can involve multiple rounds of calling chat completions, invoking tools, and then calling chat completions again with the result.  The code needs to keep track of how many tokens have been used so far, keep reducing the max_output_tokens on each call, and then probably have some special handling for the case where it runs out of tokens but it is not done with the inference + tool calling loop.
Responses and Completions have a max_output_tokens field. It is currently missing from the create and response object in Responses API.
This PR fixes it.
fixes: #3562