-
Notifications
You must be signed in to change notification settings - Fork 777
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
OpenAI representation fails to produce output when response content is None #2176
Comments
Thank you for sharing this. I see that you opened a similar issue (#2177). Are you alright with closing that one? To me, they seem like duplicates. With respect to your issue, the idea of content violation was mentioned in earlier issues and addressed with the following: BERTopic/bertopic/representation/_openai.py Lines 232 to 237 in 9518035
Which makes it rather surprising that you get this issue. It may be that the API of OpenAI was updated and now always returns "content" but I'm not sure. Either way, simply doing an additional check here makes sense to me. |
No, I'm sorry this was unclear, for this specific issue I don't get any errors regarding content violation. It simply seems that the result of response.choices[0].message returns None, which then produces an error, since you can't use strip on a NoneType object. I don't know when/why this happens, but it doesnt seem to be the result of an error produced by the API, since the response object exists. Also the reason why I created a separate "issue" (discussion/question) for the content violation, since I grasped from the code that that supposed to have been fixed, but I'm still running into this unfortunately. But that is a discussion for the #2177 as far as I'm concerned. They don't seem to be related. (as far as I can tell) |
I think that this:
and this:
contradict with one another. The reason why I think that is because you shouldn't be able to reach BERTopic/bertopic/representation/_openai.py Lines 232 to 237 in 9518035
Thus, Looking through the issues, it seems that this was mentioned before and a PR that hasn't been updated in a couple of months. API changes might relate here but also the reason why you get a None, which typically is a content violation issue. Based on what I see, I'm convinced they relate to one another since the None you get is typically some sort of content violation issue. |
Yeas, I mean that the content returns None, the response exists, but the content its returning is empty, the element content does exist in the response object. Funny thing is, I'm still also getting content violation errors, but let's keep that out of this discussion for now ;) |
It does seem to be inactive and unfortunately, I currently do not have the time to look it over. I would also be alright with a small PR just making sure it gives no error. Any additional work can be done later. |
Ok, I can look into that! |
Hello Maarten and Jean, I started seeing this error. My model was working fine a few weeks ago but now I see the "AttributeError: 'NoneType' object has no attribute 'strip'" error. The error goes away if I am not using OpenAI. Any idea how can we resolve this? I tried adding the below check, but it still gives the same error
Thanks for your help! |
Hi Abdul,
I do know a way to solve this, I’m on vacation at the moment, will be back by the end of next week. After which I can share the solution with you and also start working on a PR to fix it. In short the solution is to alter the if statement within the Bertopic openai class and add a check of the respons content is not None. But I’d you can wait I can share the code with you when I’m back.
Regards,
Jeanine
…On 13 Jan 2025 at 11:39 -0600, abdul-1996 ***@***.***>, wrote:
Hello Maarten and Jean, I started seeing this error. My model was working fine a few weeks ago but now I see the "AttributeError: 'NoneType' object has no attribute 'strip'" error. The error goes away if I am not using OpenAI.
Any idea how can we resolve this? I tried adding the below check, but it still gives the same error
if hasattr(response.choices[0].message, "content") and response.choices[0].message.content: label = response.choices[0].message.content.strip().replace("topic: ", "") else: label = "No label returned" return label
Thanks for your help!
—
Reply to this email directly, view it on GitHub, or unsubscribe.
You are receiving this because you authored the thread.Message ID: ***@***.***>
|
@jeaninejuliettes That would be great! Any help is greatly appreciated 😄 Also note that there was a PR that started this work (since OpenAI has several content filters) but I believe it will be closed, so a new one can be opened. |
Have you searched existing issues? 🔎
Desribe the bug
I ran into issues when using the OpenAI representation as it sometimes produces a content of None, which then produced an error when trying to run:
label = response.choices[0].message.content.strip().replace("topic: ", "")
Which makes sense, since the content is not a string.
I'm unable to generate a minimal example since this is due to the output of OpenAI GPT.
I see two ways to work around this, but both have their own downsides/impact on the results, maybe anyone else sees better option:
For now I fixed it by creating an inherited customOpenAI representation class within my script where I used the second option as a solution.
Reproduction
BERTopic Version
0.16.4
The text was updated successfully, but these errors were encountered: