{
  "schema_version": "2.0",
  "metadata": {
    "diagram_id": "stage1_warmup"
  },
  "global_properties": {
    "topic": "Stage I: Warm-up in Multimodal Transformer Training",
    "purpose": "workflow",
    "target_audience": "researcher",
    "complexity_level": "detailed_schematic",
    "domain": "Computer Vision",
    "visual_format": "flowchart",
    "diagram_type": "flowchart",
    "layout_grid": "3-tier_vertical",
    "style_theme": "professional_light",
    "background_color": "#FFFFFF",
    "font_family": "Helvetica, Arial, sans-serif",
    "title": {
      "text": "Stage I: Warm-up",
      "is_present": true
    }
  },
  "components": [
    {
      "id": "legend_container",
      "type": "group_container",
      "label": "Legend",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#000000",
        "border_width": 2,
        "border_style": "dashed"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "legend_activated",
      "type": "text_node",
      "label": "Activated forward",
      "geometry": {
        "shape": "none"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#FFFFFF",
        "border_width": 0,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "legend_nonactivated",
      "type": "text_node",
      "label": "Non-activated forward",
      "geometry": {
        "shape": "none"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#FFFFFF",
        "border_width": 0,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "legend_evolution",
      "type": "text_node",
      "label": "Evolution",
      "geometry": {
        "shape": "none"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#FFFFFF",
        "border_width": 0,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#D7263D"
      }
    },
    {
      "id": "legend_train",
      "type": "text_node",
      "label": "Train",
      "geometry": {
        "shape": "none"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#FFFFFF",
        "border_width": 0,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#FF9900"
      }
    },
    {
      "id": "legend_freeze",
      "type": "text_node",
      "label": "Freeze",
      "geometry": {
        "shape": "none"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#FFFFFF",
        "border_width": 0,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#0074D9"
      }
    },
    {
      "id": "main_container",
      "type": "group_container",
      "label": "Transformer Block",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#F3F3F3",
        "border_color": "#CCCCCC",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "addnorm1",
      "type": "shape_node",
      "label": "ADD & Norm",
      "sub_label": "🔥",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#FFF2CC",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "ffn",
      "type": "shape_node",
      "label": "FFN",
      "sub_label": "🔥",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#C9DAF8",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "addnorm2",
      "type": "shape_node",
      "label": "ADD & Norm",
      "sub_label": "🔥",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#FFF2CC",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "self_attention",
      "type": "shape_node",
      "label": "Self-Attention",
      "sub_label": "🔥",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#FFF2CC",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "word_embedding",
      "type": "shape_node",
      "label": "Word Embedding",
      "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": "mlp",
      "type": "shape_node",
      "label": "MLP",
      "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": "vision_encoder",
      "type": "shape_node",
      "label": "Vision Encoder",
      "sub_label": "❄️",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#E6E6E6",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#0074D9"
      }
    },
    {
      "id": "text_input",
      "type": "text_node",
      "label": "Text",
      "geometry": {
        "shape": "none"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#FFFFFF",
        "border_width": 0,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "image_input",
      "type": "text_node",
      "label": "Image",
      "geometry": {
        "shape": "none"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#FFFFFF",
        "border_width": 0,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    }
  ],
  "connections": [
    {
      "id": "conn_text_wordembedding",
      "from_id": "text_input",
      "to_id": "word_embedding",
      "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_image_visionencoder",
      "from_id": "image_input",
      "to_id": "vision_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_visionencoder_mlp",
      "from_id": "vision_encoder",
      "to_id": "mlp",
      "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_wordembedding_selfattention",
      "from_id": "word_embedding",
      "to_id": "self_attention",
      "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_mlp_selfattention",
      "from_id": "mlp",
      "to_id": "self_attention",
      "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_selfattention_addnorm2",
      "from_id": "self_attention",
      "to_id": "addnorm2",
      "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_addnorm2_ffn",
      "from_id": "addnorm2",
      "to_id": "ffn",
      "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_ffn_addnorm1",
      "from_id": "ffn",
      "to_id": "addnorm1",
      "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_addnorm1_output",
      "from_id": "addnorm1",
      "to_id": "main_container",
      "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_selfattention_addnorm2_skip",
      "from_id": "self_attention",
      "to_id": "addnorm2",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "dashed",
        "color": "#000000",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn_addnorm2_ffn_evolution",
      "from_id": "addnorm2",
      "to_id": "ffn",
      "label": {
        "text": "Evolution",
        "position": "middle_above",
        "text_color": "#D7263D"
      },
      "line_properties": {
        "type": "straight",
        "style": "dashed",
        "color": "#D7263D",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    }
  ],
  "layout_constraints": [
    {
      "type": "containment",
      "container_id": "legend_container",
      "element_ids": [
        "legend_activated",
        "legend_nonactivated",
        "legend_evolution",
        "legend_train",
        "legend_freeze"
      ],
      "padding": "small"
    },
    {
      "type": "containment",
      "container_id": "main_container",
      "element_ids": [
        "addnorm1",
        "ffn",
        "addnorm2",
        "self_attention"
      ],
      "padding": "medium"
    },
    {
      "type": "alignment",
      "alignment_type": "vertical_center",
      "element_ids": [
        "word_embedding",
        "self_attention",
        "addnorm2",
        "ffn",
        "addnorm1"
      ]
    },
    {
      "type": "distribution",
      "distribution_type": "horizontal_equal_spacing",
      "element_ids": [
        "word_embedding",
        "mlp"
      ]
    },
    {
      "type": "alignment",
      "alignment_type": "bottom_edge",
      "element_ids": [
        "text_input",
        "image_input"
      ]
    }
  ]
}