Skip to content
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

Figure out what we can do to help explain differences between update vs. values #2698

Open
1 task done
eyurtsev opened this issue Dec 10, 2024 · 0 comments
Open
1 task done
Labels
maintainer Issue created by library maintainer

Comments

@eyurtsev
Copy link
Contributor

eyurtsev commented Dec 10, 2024

Privileged issue

  • I am a LangChain maintainer, or was asked directly by a LangChain maintainer to create an issue here.

Issue Content

There can be some subtle differences when using update vs. values.

Specifically, b/c update is prior to the reducer, message coercion never takes place.

This means that update and values give different types for the messages!

One option is to use the built in message type everywhere

from typing_extensions import TypedDict, Literal
from langchain_openai import ChatOpenAI
from langgraph.graph import MessagesState, StateGraph, START, END
import uuid

def node(state):
    return {
        "messages": [{
            "role": "ai",
            "content": "hello"
        }]
    }

builder = StateGraph(MessagesState)
builder.add_node("node", node)
builder.add_edge(START, "node")
graph = builder.compile()

for update in graph.stream(
    {'messages': []},
    stream_mode='updates',
):
    print(update)

print('----')

for update in graph.stream(
    {'messages': []},
    stream_mode='values',
):
    print(update)

Output from update:

{'node': {'messages': [{'role': 'ai', 'content': 'hello'}]}}

Output from values:
{'messages': []}
{'messages': [AIMessage(content='hello', additional_kwargs={}, response_metadata={}, id='2f277693-67e6-4b5a-9ba0-80877b4ba6ce')]}

Note that it's AIMessage in values, but dict format in update.

While the behavior is as designed, I am not sure if it's as expected by users.

@vbarda vbarda added the maintainer Issue created by library maintainer label Jan 15, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
maintainer Issue created by library maintainer
Projects
None yet
Development

No branches or pull requests

2 participants