{
  "schema_version": "2.0",
  "metadata": {
    "diagram_id": "mappo_state_encoder_traffic"
  },
  "global_properties": {
    "topic": "State Encoder and MAPPO Architecture for Multi-Agent Traffic Environment",
    "purpose": "architecture_overview",
    "target_audience": "researcher",
    "complexity_level": "detailed_schematic",
    "domain": "Reinforcement Learning",
    "visual_format": "block_diagram",
    "diagram_type": "architecture_diagram",
    "layout_grid": "3-tier_vertical",
    "style_theme": "professional_light",
    "background_color": "#FFFFFF",
    "font_family": "Helvetica, Arial, sans-serif",
    "title": {
      "text": "State Encoder and MAPPO Architecture",
      "is_present": false
    }
  },
  "components": [
    {
      "id": "env1",
      "type": "custom_element",
      "label": "Environment",
      "sub_label": "",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#EDEDED",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "raw_obs_group",
      "type": "group_container",
      "label": "Raw Observation",
      "sub_label": "",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "dashed"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "raw_obs1",
      "type": "shape_node",
      "label": "1",
      "sub_label": "",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "raw_obs2",
      "type": "shape_node",
      "label": "2",
      "sub_label": "",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "raw_obsN",
      "type": "shape_node",
      "label": "N",
      "sub_label": "",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "state_encoder",
      "type": "group_container",
      "label": "State Encoder",
      "sub_label": "M x",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#EAF3FF",
        "border_color": "#7F7F7F",
        "border_width": 2,
        "border_style": "dashed"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "reshape",
      "type": "operator_node",
      "label": "Reshape",
      "sub_label": "",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#D9EAD3",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "feedforward",
      "type": "operator_node",
      "label": "Feed-forward",
      "sub_label": "(K x K)",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#6EC6FF",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "flatten1",
      "type": "operator_node",
      "label": "Flatten",
      "sub_label": "",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#E3EAF7",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "addnorm",
      "type": "operator_node",
      "label": "Add & Norm",
      "sub_label": "",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#F4CCCC",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "multihead_attention",
      "type": "operator_node",
      "label": "Multi-head Attention",
      "sub_label": "h",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#FFF2CC",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "encoded_obs",
      "type": "shape_node",
      "label": "Encoded observation",
      "sub_label": "(N x X)",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "flatten2",
      "type": "operator_node",
      "label": "Flatten",
      "sub_label": "",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#E3EAF7",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "mappo",
      "type": "group_container",
      "label": "MAPPO",
      "sub_label": "",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#EAD1DC",
        "border_color": "#7F7F7F",
        "border_width": 2,
        "border_style": "dashed"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "actor",
      "type": "shape_node",
      "label": "Actor",
      "sub_label": "(FC)",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#6EC6FF",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "critic",
      "type": "shape_node",
      "label": "Critic",
      "sub_label": "(FC)",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#6EC6FF",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "action_probs",
      "type": "group_container",
      "label": "Action Probabilities",
      "sub_label": "",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#F4CCCC",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "prob_1",
      "type": "shape_node",
      "label": "0.09",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#F4CCCC",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "prob_2",
      "type": "shape_node",
      "label": "0.1",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#F4CCCC",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "prob_3",
      "type": "shape_node",
      "label": "0.5",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#F4CCCC",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "prob_4",
      "type": "shape_node",
      "label": "0.01",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#F4CCCC",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "prob_5",
      "type": "shape_node",
      "label": "0.3",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#F4CCCC",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "state_value",
      "type": "shape_node",
      "label": "0.7",
      "geometry": {
        "shape": "circle"
      },
      "styling": {
        "fill_color": "#F4CCCC",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    }
  ],
  "connections": [
    {
      "id": "conn_env_rawobs",
      "from_id": "env1",
      "to_id": "raw_obs_group",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "curved_clockwise",
        "style": "solid",
        "color": "#000000",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn_rawobs_stateenc",
      "from_id": "raw_obs_group",
      "to_id": "state_encoder",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#000000",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn_stateenc_multihead",
      "from_id": "state_encoder",
      "to_id": "multihead_attention",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#000000",
        "width": 1.5
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "none",
        "size": "medium"
      }
    },
    {
      "id": "conn_multihead_addnorm",
      "from_id": "multihead_attention",
      "to_id": "addnorm",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#000000",
        "width": 1.5
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "none",
        "size": "medium"
      }
    },
    {
      "id": "conn_addnorm_flatten1",
      "from_id": "addnorm",
      "to_id": "flatten1",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#000000",
        "width": 1.5
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "none",
        "size": "medium"
      }
    },
    {
      "id": "conn_flatten1_feedforward",
      "from_id": "flatten1",
      "to_id": "feedforward",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#000000",
        "width": 1.5
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "none",
        "size": "medium"
      }
    },
    {
      "id": "conn_feedforward_reshape",
      "from_id": "feedforward",
      "to_id": "reshape",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#000000",
        "width": 1.5
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "none",
        "size": "medium"
      }
    },
    {
      "id": "conn_reshape_encodedobs",
      "from_id": "reshape",
      "to_id": "encoded_obs",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#000000",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn_encodedobs_flatten2",
      "from_id": "encoded_obs",
      "to_id": "flatten2",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#000000",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn_flatten2_mappo",
      "from_id": "flatten2",
      "to_id": "mappo",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#000000",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "none",
        "size": "medium"
      }
    },
    {
      "id": "conn_mappo_actor",
      "from_id": "mappo",
      "to_id": "actor",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#000000",
        "width": 1.5
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "none",
        "size": "medium"
      }
    },
    {
      "id": "conn_mappo_critic",
      "from_id": "mappo",
      "to_id": "critic",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#000000",
        "width": 1.5
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "none",
        "size": "medium"
      }
    },
    {
      "id": "conn_actor_actionprobs",
      "from_id": "actor",
      "to_id": "action_probs",
      "label": {
        "text": "Action Probabilities",
        "position": "end",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#000000",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn_critic_statevalue",
      "from_id": "critic",
      "to_id": "state_value",
      "label": {
        "text": "State Value",
        "position": "end",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#000000",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    }
  ],
  "layout_constraints": [
    {
      "type": "containment",
      "container_id": "raw_obs_group",
      "element_ids": [
        "raw_obs1",
        "raw_obs2",
        "raw_obsN"
      ],
      "padding": "small"
    },
    {
      "type": "containment",
      "container_id": "state_encoder",
      "element_ids": [
        "reshape",
        "feedforward",
        "flatten1",
        "addnorm",
        "multihead_attention"
      ],
      "padding": "medium"
    },
    {
      "type": "containment",
      "container_id": "mappo",
      "element_ids": [
        "actor",
        "critic"
      ],
      "padding": "medium"
    },
    {
      "type": "containment",
      "container_id": "action_probs",
      "element_ids": [
        "prob_1",
        "prob_2",
        "prob_3",
        "prob_4",
        "prob_5"
      ],
      "padding": "small"
    },
    {
      "type": "alignment",
      "alignment_type": "horizontal_center",
      "element_ids": [
        "env1",
        "raw_obs_group",
        "state_encoder",
        "encoded_obs",
        "flatten2",
        "mappo"
      ]
    },
    {
      "type": "distribution",
      "distribution_type": "horizontal_equal_spacing",
      "element_ids": [
        "prob_1",
        "prob_2",
        "prob_3",
        "prob_4",
        "prob_5"
      ]
    }
  ]
}