-
Notifications
You must be signed in to change notification settings - Fork 159
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
[Bug] gemini-1.5-pro-latest returns error when combining tools and output schema #703
Comments
We will take a look at this. Thanks for reporting! Changed the title for readability as the exact error message(s) is/are repeated in the bug reports itself. |
Thank you @MichaelDoyle 🙏 |
Looking into this, just reproduced it. Seems to happen with gemini 1.5 flash too, so unlikely the model |
An issue where they're getting the same message, linking just for reference google-gemini/generative-ai-swift#195 |
I believe this is a limitation of the Gemini API at the moment, I will try to follow up and get it passed on to them |
Can confirm @cabljac, I just came across this same bug using 1.5 Flash. |
This is a good example of why I'm so curious about the philosophy behind when to use tools vs. custom services: https://github.com/firebase/genkit/discussions/731. This seems like a use-case where services might be necessary, at least for the time being, if we want to do things like compose model responses, resolve promises, etc., while also validating output? |
Okay, thank you. |
In my opinion genkit is such a "service", it does parsing, validation, generation, has an interface for tools, etc... I believe the end user shouldn't have to build their own abstraction on top of these building blocks, just like I don't have to build any abstraction layers when I'm using firestore, firebase storage, callable functions or any other firebase service. |
That more or less aligns with my understanding of Genkit's goals @lazakrisz, and I agree. I initially developed a "service" abstraction for my own use-case because I was just stubbing things in until I got up to speed using tools. It was only when I went to refactor and replace the service abstraction with Genkit's tools that I hit up against this limitation. Specifically, I'm identifying the names/types of fields in a form given a form name. I then use the field type to determine the corresponding candidate field attributes, which get used to dynamically generate an output schema. The current inefficiency is that I'm essentially using this service abstraction to fan-out model calls for every field/attribute pair. I'm working on creating one mega-prompt that asks the model to select from the candidate attributes in one go, which would get it down to just two API calls.
Okay, looking at @MichaelDoyle's response in this other discussion, I don't think this is actually true. In this case, even though I just need a tool to retrieve a static value from a local object or JSON file, I suppose there would still need to be two API calls. |
Are you two in the genkit discord? I feel like this and any other feedback you have would be highly valued there |
Just joined @cabljac, thanks for the suggestion! |
My suggestion for this is to check for the condition of tools + json mode in the Gemini plugins (Google/Vertex) and simply don't set JSON mode when that's the case. Gemini output was pretty good before we even had JSON mode implemented, it should work in the majority of cases. We can separately suggest it as a fix at the Gemini API layer. |
Note this probably only occurs the Google AI plugin, as that's the only one which supports strict json mode currently |
Describe the bug
data:image/s3,"s3://crabby-images/b20a3/b20a3f7ba8809f3fc98e59ce32eda89d7254d628" alt="image"
data:image/s3,"s3://crabby-images/67b7b/67b7bbf270718c7b029f566f248cb153656b6c7a" alt="image"
When using Gemini 1.5 Pro with tool calling, (function calling ) and specifying output schema within
generate
, the generate call returns an error:[GoogleGenerativeAI Error]: Error fetching from https://generativelanguage.googleapis.com/v1beta/models/gemini-1.5-pro-latest:generateContent: [400 Bad Request] Function calling with a response mime type: 'application/json' is unsupported
.What's interesting is upon removal of the
output.schema
property the generate function does output valid JSON. (see screenshot below)and here is the topmost part of the response:
for clarity here is the entire response / logs cycle:
I've also tried the vertex ai plugin but got a similar esoteric error message.
Tried the following manual function invocation however generate once again throws an error:
the original source code which throws an error:
here is the quizTool, which is the same in both cases:
If I remove the
output.schema
, all works and I get an object as a response, but the object takes an arbitrary shape instead of the desired shape that I'd like, which makes parsing things quite tedious.here is an example:
and the Genkit local dashboard output:
input:
output:
here is the input for the one that Errors out:
data:image/s3,"s3://crabby-images/871dc/871dcb271696007249ebadf72b381101a0f71628" alt="image"
To Reproduce
Expected behavior
data:image/s3,"s3://crabby-images/eee36/eee36c8e30a6c6e87c52aa8d12a4191fa76637ec" alt="image"
I would expect to be able to call functions / tools via the model and the output should be JSON / zod parsable. I thought this was entirely possible according to the document / sample code given on the Genkit site + the model description site.
where it is stated that the model supports:
Screenshots
please see the screenshot above, thank you.
Runtime (please complete the following information):
** Node version
Additional context
Should I cross post this into: https://github.com/google-gemini/generative-ai-js as that seems to be the root cause of the issue? 🤔 Is this something that is not currently supported? 🤔 It seems weird that I'm unable to specify a concrete schema for the generate function, but the model itself is capable of returning JSON / object responses, am I missing something? Thank you 🙏
The text was updated successfully, but these errors were encountered: