agentscope.web.workstation.workflow_dag module
AgentScope workstation DAG running engine.
This module defines various workflow nodes that can be used to construct a computational DAG. Each node represents a step in the DAG and can perform certain actions when called.
- class ASDiGraph(*args, **kwargs)[source]
Bases:
DiGraph
A class that represents a directed graph, extending the functionality of networkx’s DiGraph to suit specific workflow requirements in AgentScope.
This graph supports operations such as adding nodes with associated computations and executing these computations in a topological order.
- nodes_not_in_graph
A set of nodes that are not included in
- Type:
set
- the computation graph.
- add_as_node(node_id: str, node_info: dict, config: dict) Any [source]
Add a node to the graph based on provided node information and configuration.
- Parameters:
node_id (str) – The identifier for the node being added.
node_info (dict) – A dictionary containing information about the node.
config (dict) – Configuration information for the node dependencies.
- Returns:
The computation object associated with the added node.
- exec_node(node_id: str, x_in: Any | None = None) Any [source]
Execute the computation associated with a given node in the graph.
- Parameters:
node_id (str) – The identifier of the node whose computation is to be executed.
x_in – The input to the node’s computation. Defaults to None.
- Returns:
The output of the node’s computation.
- build_dag(config: dict) ASDiGraph [source]
Construct a Directed Acyclic Graph (DAG) from the provided configuration.
Initializes the graph nodes based on the configuration, adds model nodes first, then non-model nodes, and finally adds edges between the nodes.
- Parameters:
config (dict) – The configuration to build the graph from, containing node info such as name, type, arguments, and connections.
- Returns:
The constructed directed acyclic graph.
- Return type:
- Raises:
ValueError – If the resulting graph is not acyclic.
- sanitize_node_data(raw_info: dict) dict [source]
Clean and validate node data, evaluating callable expressions where necessary.
Processes the raw node information, removes empty arguments, and evaluates any callable expressions provided as string literals.
- Parameters:
raw_info (dict) – The raw node information dictionary that may contain callable expressions as strings.
- Returns:
- The sanitized node information with callable expressions
evaluated.
- Return type:
dict