-
Notifications
You must be signed in to change notification settings - Fork 5.6k
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
Inconsistent dictionary structure in autogen.ChatCompletion.logged_history #412
Comments
These are great observations. I've mainly only been using Even in verbose logging, it's weird to have a dictionary instead of a list, unless we're expecting it to be sparse at some point? Basically it means we need to be a little careful when iterating through the items... there's no guarantee they will be sequential in this structure. |
@victordibia, all your observations are true. It will be good to define/generate a JSON Schema for logging messages and use it consistently for messages. Having the whole message as a key is indeed an unusual choice. So, I agree with your proposal to make this consistent irrespective of the flag. |
Yes, the dictionary returned with compact = True or False is quite different, and I did spend some time to make them consistent to and the func |
Thanks @kevin666aa . It looks like the new changes driven by updates to the openai lib will be relevant here #203, #7 . I will revisit this when #203 is complete. |
I managed to find a work around that seems to work for me, e.g.: conversations = dict()
autogen.ChatCompletion.start_logging(conversations)
# ... do AutoGen stuff...
# extract content from an entry (in the conversations list):
get_content_list = lambda conversations: list(conversations)[0]
content_list = get_content_list(conversations)
content_list_json = json.loads(content_list)
# get content of all conversations:
conversations_content = "\n".join(conversation.get('content') for conversation in content_list_json) Quite crazy having to do this kind of stuff... I hope it will be fixed soon! |
seems super stale and a workaround is posted. closing won't fix |
#179 added much needed support for tracking token count and cost (thanks @kevin666aa ).
However, there is some unexpected/inconsistent structure in the dictionary returned.
Currently
autogen.ChatCompletion.start_logging(compact=True)
is used to start a logging session and ends withautogen.ChatCompletion.stop_logging()
. Next the logs can be accessed viaautogen.ChatCompletion.logged_history
.Unexpected Structure in
autogen.ChatCompletion.logged_history
when compact=TrueWhen compact is set to True,
logged_history
is a dictionary. However, the key is the entire chat historyThis makes it very challenging to reuse this data structure in apps. It might be valuable to have output with some structured keys.
Further more, the structure of
logged_history
is significantly different when compact=FalsePotential action items
Happy to get more thoughts here @gagb @afourney @pcdeadeasy
Related .
Documentation here may need an update.
The text was updated successfully, but these errors were encountered: