{
  "schema_version": "2.0",
  "metadata": {
    "diagram_id": "substructure_attention_transformer"
  },
  "global_properties": {
    "topic": "Substructure and Node Attention in Graph Transformers",
    "purpose": "architecture_overview",
    "target_audience": "researcher",
    "complexity_level": "publication_quality",
    "domain": "Machine Learning",
    "visual_format": "block_diagram",
    "diagram_type": "architecture_diagram",
    "layout_grid": "2x2",
    "style_theme": "professional_light",
    "background_color": "#FFFFFF",
    "font_family": "Helvetica, Arial, sans-serif",
    "title": {
      "text": "",
      "is_present": false
    }
  },
  "components": [
    {
      "id": "gc1",
      "type": "group_container",
      "label": "",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#F6FCFF",
        "border_color": "#A9A9A9",
        "border_width": 2,
        "border_style": "dashed"
      }
    },
    {
      "id": "gc2",
      "type": "group_container",
      "label": "",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#F6FCFF",
        "border_color": "#A9A9A9",
        "border_width": 2,
        "border_style": "dashed"
      }
    },
    {
      "id": "gc3",
      "type": "group_container",
      "label": "",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#F6FCFF",
        "border_color": "#A9A9A9",
        "border_width": 2,
        "border_style": "dashed"
      }
    },
    {
      "id": "gc4",
      "type": "group_container",
      "label": "",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#F6FCFF",
        "border_color": "#A9A9A9",
        "border_width": 2,
        "border_style": "dashed"
      }
    },
    {
      "id": "t1",
      "type": "text_node",
      "label": "Local Attention on Substructures",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#EAF8FF",
        "border_color": "#EAF8FF",
        "border_width": 0,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "t2",
      "type": "text_node",
      "label": "Global Attention on Nodes",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#EAF8FF",
        "border_color": "#EAF8FF",
        "border_width": 0,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "sub1",
      "type": "custom_element",
      "label": "Substructure 1",
      "sub_label": "",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#F8D7DA",
        "border_color": "#A9A9A9",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "sub2",
      "type": "custom_element",
      "label": "Substructure 2",
      "sub_label": "",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#D4EDDA",
        "border_color": "#A9A9A9",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "sub3",
      "type": "custom_element",
      "label": "Substructure 3",
      "sub_label": "",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#D1ECF1",
        "border_color": "#A9A9A9",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "sub4",
      "type": "custom_element",
      "label": "Substructure 4",
      "sub_label": "",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#FFF3CD",
        "border_color": "#A9A9A9",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "tokens1",
      "type": "group_container",
      "label": "Node Tokens",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#F6FCFF",
        "border_color": "#F6FCFF",
        "border_width": 0,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "nt1",
      "type": "shape_node",
      "label": "C",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#A9A9A9",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#FFFFFF"
      }
    },
    {
      "id": "nt2",
      "type": "shape_node",
      "label": "B",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#A9A9A9",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#FFFFFF"
      }
    },
    {
      "id": "nt3",
      "type": "shape_node",
      "label": "A",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#A9A9A9",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#FFFFFF"
      }
    },
    {
      "id": "nt4",
      "type": "shape_node",
      "label": "C",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#A9A9A9",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#FFFFFF"
      }
    },
    {
      "id": "nt5",
      "type": "shape_node",
      "label": "A",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#A9A9A9",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#FFFFFF"
      }
    },
    {
      "id": "nt6",
      "type": "shape_node",
      "label": "B",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#A9A9A9",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#FFFFFF"
      }
    },
    {
      "id": "nt7",
      "type": "shape_node",
      "label": "B",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#A9A9A9",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#FFFFFF"
      }
    },
    {
      "id": "nt8",
      "type": "shape_node",
      "label": "B",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#A9A9A9",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#FFFFFF"
      }
    },
    {
      "id": "nt9",
      "type": "shape_node",
      "label": "A",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#A9A9A9",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#FFFFFF"
      }
    },
    {
      "id": "nt10",
      "type": "shape_node",
      "label": "A",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#A9A9A9",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#FFFFFF"
      }
    },
    {
      "id": "graph1",
      "type": "custom_element",
      "label": "Graph with Substructures",
      "geometry": {
        "shape": "freeform"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#A9A9A9",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "ff1",
      "type": "shape_node",
      "label": "Feed-Forward Layer",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#7ED957",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "sa1",
      "type": "shape_node",
      "label": "Self Attention",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#5BC0EB",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "ff2",
      "type": "shape_node",
      "label": "Feed-Forward Layer",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#7ED957",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "sa2",
      "type": "shape_node",
      "label": "Self Attention",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#5BC0EB",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "t3",
      "type": "text_node",
      "label": "n ×",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#FFFFFF",
        "border_width": 0,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "pe1",
      "type": "shape_node",
      "label": "Position Encoding For Nodes",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#D4EDDA",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "se1",
      "type": "shape_node",
      "label": "Permutation-based Substructure Encoding",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#D1ECF1",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "legend1",
      "type": "group_container",
      "label": "Legend",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#FFFFFF",
        "border_width": 0,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "legend_sub",
      "type": "text_node",
      "label": "Substructure Tokens",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#FFFFFF",
        "border_width": 0,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "legend_node",
      "type": "text_node",
      "label": "Node Tokens",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#FFFFFF",
        "border_width": 0,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    }
  ],
  "connections": [
    {
      "id": "conn1",
      "from_id": "gc1",
      "to_id": "gc2",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "orthogonal",
        "style": "solid",
        "color": "#A9A9A9",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "large"
      }
    },
    {
      "id": "conn2",
      "from_id": "gc2",
      "to_id": "gc3",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "orthogonal",
        "style": "solid",
        "color": "#A9A9A9",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "large"
      }
    },
    {
      "id": "conn3",
      "from_id": "gc3",
      "to_id": "gc4",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "orthogonal",
        "style": "solid",
        "color": "#A9A9A9",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "large"
      }
    }
  ],
  "layout_constraints": [
    {
      "type": "containment",
      "container_id": "gc1",
      "element_ids": [
        "t1",
        "sub1",
        "sub2",
        "sub3",
        "sub4",
        "tokens1",
        "t2"
      ],
      "padding": "medium"
    },
    {
      "type": "containment",
      "container_id": "gc2",
      "element_ids": [
        "ff1",
        "sa1",
        "ff2",
        "sa2",
        "t3"
      ],
      "padding": "medium"
    },
    {
      "type": "containment",
      "container_id": "gc3",
      "element_ids": [
        "pe1",
        "se1",
        "sub1",
        "sub2",
        "sub3",
        "sub4",
        "tokens1",
        "legend1",
        "legend_sub",
        "legend_node"
      ],
      "padding": "medium"
    },
    {
      "type": "containment",
      "container_id": "gc4",
      "element_ids": [
        "graph1"
      ],
      "padding": "medium"
    },
    {
      "type": "alignment",
      "alignment_type": "horizontal_center",
      "element_ids": [
        "gc1",
        "gc2",
        "gc3",
        "gc4"
      ]
    },
    {
      "type": "distribution",
      "distribution_type": "vertical_equal_spacing",
      "element_ids": [
        "gc1",
        "gc2",
        "gc3",
        "gc4"
      ]
    },
    {
      "type": "distribution",
      "distribution_type": "horizontal_equal_spacing",
      "element_ids": [
        "sub1",
        "sub2",
        "sub3",
        "sub4"
      ]
    },
    {
      "type": "distribution",
      "distribution_type": "horizontal_equal_spacing",
      "element_ids": [
        "nt1",
        "nt2",
        "nt3",
        "nt4",
        "nt5",
        "nt6",
        "nt7",
        "nt8",
        "nt9",
        "nt10"
      ]
    }
  ]
}