{
  "schema_version": "2.0",
  "metadata": {
    "diagram_id": "transformer_adapter_block"
  },
  "global_properties": {
    "topic": "Transformer Block with Adapter Module",
    "purpose": "architecture_overview",
    "target_audience": "researcher",
    "complexity_level": "publication_quality",
    "domain": "Machine Learning",
    "visual_format": "block_diagram",
    "diagram_type": "architecture_diagram",
    "layout_grid": "2x1",
    "style_theme": "professional_light",
    "background_color": "#FFFFFF",
    "font_family": "Helvetica, Arial, sans-serif",
    "title": {
      "text": "Transformer Block and Adapter Architecture",
      "is_present": false
    }
  },
  "components": [
    {
      "id": "block_container",
      "type": "group_container",
      "label": "Block m",
      "sub_label": "",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#F8FBFF",
        "border_color": "#1A2A3A",
        "border_width": 2,
        "border_style": "dashed"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#1A2A3A"
      }
    },
    {
      "id": "snowflake_icon",
      "type": "icon_node",
      "label": "Frozen",
      "sub_label": "",
      "geometry": {
        "shape": "custom"
      },
      "styling": {
        "fill_color": "#B3E6FF",
        "border_color": "#B3E6FF",
        "border_width": 0,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#1A2A3A"
      }
    },
    {
      "id": "transformer_layer",
      "type": "text_node",
      "label": "Transformer layer",
      "sub_label": "",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#1A2A3A",
        "border_width": 0,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#1A2A3A"
      }
    },
    {
      "id": "addnorm1",
      "type": "shape_node",
      "label": "Add & Norm",
      "sub_label": "",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#FFF2CC",
        "border_color": "#B7A04B",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#1A2A3A"
      }
    },
    {
      "id": "feedforward",
      "type": "shape_node",
      "label": "Feed-forward",
      "sub_label": "",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#D9E2F3",
        "border_color": "#6C8EBF",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#1A2A3A"
      }
    },
    {
      "id": "addnorm2",
      "type": "shape_node",
      "label": "Add & Norm",
      "sub_label": "",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#FFF2CC",
        "border_color": "#B7A04B",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#1A2A3A"
      }
    },
    {
      "id": "multihead_attention",
      "type": "shape_node",
      "label": "Multi-head Attention",
      "sub_label": "",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#FFE5CC",
        "border_color": "#E69138",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#1A2A3A"
      }
    },
    {
      "id": "adapter_container",
      "type": "group_container",
      "label": "Adapter s^m",
      "sub_label": "",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#EAF7E1",
        "border_color": "#7CB342",
        "border_width": 3,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#2E7D32"
      }
    },
    {
      "id": "fire_icon",
      "type": "icon_node",
      "label": "Trainable",
      "sub_label": "",
      "geometry": {
        "shape": "custom"
      },
      "styling": {
        "fill_color": "#FF9800",
        "border_color": "#FF9800",
        "border_width": 0,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#E65100"
      }
    },
    {
      "id": "adapter_addnorm",
      "type": "shape_node",
      "label": "Add & Norm",
      "sub_label": "",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#FFF2CC",
        "border_color": "#B7A04B",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#1A2A3A"
      }
    },
    {
      "id": "adapter_input_vec",
      "type": "custom_element",
      "label": "",
      "sub_label": "Input vector",
      "geometry": {
        "shape": "row_of_circles"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#1A2A3A",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#1A2A3A"
      }
    },
    {
      "id": "adapter_up_project",
      "type": "shape_node",
      "label": "Feedforward up-project",
      "sub_label": "",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#E0E0E0",
        "border_color": "#757575",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#1A2A3A"
      }
    },
    {
      "id": "adapter_nonlinearity",
      "type": "shape_node",
      "label": "Nonlinearity",
      "sub_label": "",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#E0E0E0",
        "border_color": "#757575",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#1A2A3A"
      }
    },
    {
      "id": "adapter_bottleneck_vec",
      "type": "custom_element",
      "label": "",
      "sub_label": "Bottleneck vector",
      "geometry": {
        "shape": "row_of_circles"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#1A2A3A",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#1A2A3A"
      }
    },
    {
      "id": "adapter_down_project",
      "type": "shape_node",
      "label": "Feedforward down-project",
      "sub_label": "",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#E0E0E0",
        "border_color": "#757575",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#1A2A3A"
      }
    },
    {
      "id": "adapter_output_vec",
      "type": "custom_element",
      "label": "",
      "sub_label": "Output vector",
      "geometry": {
        "shape": "row_of_circles"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#1A2A3A",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#1A2A3A"
      }
    },
    {
      "id": "plus_operator",
      "type": "operator_node",
      "label": "+",
      "sub_label": "",
      "geometry": {
        "shape": "circle"
      },
      "styling": {
        "fill_color": "#EAF7E1",
        "border_color": "#7CB342",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#2E7D32"
      }
    },
    {
      "id": "q_function",
      "type": "text_node",
      "label": "Q(·)",
      "sub_label": "",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#FFF2CC",
        "border_color": "#E69138",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#E69138"
      }
    }
  ],
  "connections": [
    {
      "id": "conn1",
      "from_id": "multihead_attention",
      "to_id": "addnorm2",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#1A2A3A",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn2",
      "from_id": "addnorm2",
      "to_id": "feedforward",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#1A2A3A",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn3",
      "from_id": "feedforward",
      "to_id": "addnorm1",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#1A2A3A",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn4",
      "from_id": "addnorm1",
      "to_id": "transformer_layer",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#1A2A3A",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "none",
        "size": "medium"
      }
    },
    {
      "id": "conn5",
      "from_id": "block_container",
      "to_id": "q_function",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "orthogonal",
        "style": "solid",
        "color": "#4CAF50",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "none",
        "size": "medium"
      }
    },
    {
      "id": "conn6",
      "from_id": "q_function",
      "to_id": "adapter_input_vec",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "orthogonal",
        "style": "solid",
        "color": "#4CAF50",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "none",
        "size": "medium"
      }
    },
    {
      "id": "conn7",
      "from_id": "adapter_input_vec",
      "to_id": "adapter_up_project",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#388E3C",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn8",
      "from_id": "adapter_up_project",
      "to_id": "adapter_nonlinearity",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#388E3C",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn9",
      "from_id": "adapter_nonlinearity",
      "to_id": "adapter_bottleneck_vec",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#388E3C",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "none",
        "size": "medium"
      }
    },
    {
      "id": "conn10",
      "from_id": "adapter_bottleneck_vec",
      "to_id": "adapter_down_project",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#388E3C",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn11",
      "from_id": "adapter_down_project",
      "to_id": "adapter_output_vec",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#388E3C",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "none",
        "size": "medium"
      }
    },
    {
      "id": "conn12",
      "from_id": "adapter_output_vec",
      "to_id": "plus_operator",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#388E3C",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn13",
      "from_id": "plus_operator",
      "to_id": "adapter_addnorm",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#388E3C",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    }
  ],
  "layout_constraints": [
    {
      "type": "containment",
      "container_id": "block_container",
      "element_ids": [
        "snowflake_icon",
        "transformer_layer",
        "addnorm1",
        "feedforward",
        "addnorm2",
        "multihead_attention"
      ],
      "padding": "medium"
    },
    {
      "type": "containment",
      "container_id": "adapter_container",
      "element_ids": [
        "fire_icon",
        "adapter_addnorm",
        "adapter_input_vec",
        "adapter_up_project",
        "adapter_nonlinearity",
        "adapter_bottleneck_vec",
        "adapter_down_project",
        "adapter_output_vec",
        "plus_operator"
      ],
      "padding": "medium"
    },
    {
      "type": "relative_arrangement",
      "element_ids": [
        "block_container",
        "adapter_container"
      ]
    },
    {
      "type": "alignment",
      "alignment_type": "horizontal_center",
      "element_ids": [
        "adapter_addnorm",
        "adapter_input_vec",
        "adapter_up_project",
        "adapter_nonlinearity",
        "adapter_bottleneck_vec",
        "adapter_down_project",
        "adapter_output_vec",
        "plus_operator"
      ]
    },
    {
      "type": "alignment",
      "alignment_type": "horizontal_center",
      "element_ids": [
        "addnorm1",
        "feedforward",
        "addnorm2",
        "multihead_attention"
      ]
    }
  ]
}