{
  "schema_version": "2.0",
  "metadata": {
    "diagram_id": "cross_modal_dual_guidance_01"
  },
  "global_properties": {
    "topic": "Cross-modal Alignment and Dual Guidance for Attribute Prediction",
    "purpose": "architecture_overview",
    "target_audience": "researcher",
    "complexity_level": "publication_quality",
    "domain": "Computer Vision",
    "visual_format": "block_diagram",
    "diagram_type": "architecture_diagram",
    "layout_grid": "2x1_vertical",
    "style_theme": "professional_light",
    "background_color": "#FFFFFF",
    "font_family": "Helvetica, Arial, sans-serif",
    "title": {
      "text": "Cross-modal Alignment and Dual Guidance Framework",
      "is_present": false
    }
  },
  "components": [
    {
      "id": "cma_stage_label",
      "type": "text_node",
      "label": "Cross-modal Alignment Stage",
      "geometry": {
        "shape": "none"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#FFFFFF",
        "border_width": 0,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "dg_stage_label",
      "type": "text_node",
      "label": "Dual Guidance Stage",
      "geometry": {
        "shape": "none"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#FFFFFF",
        "border_width": 0,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "attr_prompt",
      "type": "shape_node",
      "label": "Attribute Prompt",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#4CAF50",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "token_embedding",
      "type": "shape_node",
      "label": "Token Embedding",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#E3ECF7",
        "border_color": "#4A90E2",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "image_stack",
      "type": "custom_element",
      "label": "Image Batch",
      "geometry": {
        "shape": "stacked_images"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#FF9800",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "image_encoder_cma",
      "type": "shape_node",
      "label": "Image Encoder",
      "sub_label": "Frozen",
      "geometry": {
        "shape": "right_triangle"
      },
      "styling": {
        "fill_color": "#E3ECF7",
        "border_color": "#4A90E2",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "text_encoder_cma",
      "type": "shape_node",
      "label": "Text Encoder",
      "sub_label": "Frozen",
      "geometry": {
        "shape": "right_triangle"
      },
      "styling": {
        "fill_color": "#E3ECF7",
        "border_color": "#4A90E2",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "fixed_text_tokens",
      "type": "group_container",
      "label": "Fixed Text Tokens",
      "geometry": {
        "shape": "horizontal_stack"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#4A90E2",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#4A90E2"
      }
    },
    {
      "id": "learnable_attr_tokens",
      "type": "group_container",
      "label": "Learnable Attribute Tokens",
      "geometry": {
        "shape": "horizontal_stack"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#4CAF50",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#4CAF50"
      }
    },
    {
      "id": "feature_matrix",
      "type": "custom_element",
      "label": "Feature Matrix",
      "geometry": {
        "shape": "matrix"
      },
      "styling": {
        "fill_color": "#E3ECF7",
        "border_color": "#B0B0B0",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "attribute_encoder_cma",
      "type": "shape_node",
      "label": "Attribute Encoder",
      "sub_label": "Trainable",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#D9EAD3",
        "border_color": "#4CAF50",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "predicted_attr_tokens_cma",
      "type": "group_container",
      "label": "Predicted Attribute Tokens",
      "geometry": {
        "shape": "horizontal_stack"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#8BC34A",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#8BC34A"
      }
    },
    {
      "id": "loss_feat",
      "type": "text_node",
      "label": "L_feat",
      "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": "loss_attrA",
      "type": "text_node",
      "label": "L_attrA",
      "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": "attr_pseudo_label",
      "type": "group_container",
      "label": "Attribute Pseudo Label",
      "geometry": {
        "shape": "horizontal_stack"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#FF9800",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#FF9800"
      }
    },
    {
      "id": "image_encoder_dg",
      "type": "shape_node",
      "label": "Image Encoder",
      "sub_label": "Trainable",
      "geometry": {
        "shape": "right_triangle"
      },
      "styling": {
        "fill_color": "#D9EAD3",
        "border_color": "#4CAF50",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "text_encoder_dg",
      "type": "shape_node",
      "label": "Text Encoder",
      "sub_label": "Frozen",
      "geometry": {
        "shape": "right_triangle"
      },
      "styling": {
        "fill_color": "#E3ECF7",
        "border_color": "#4A90E2",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "attribute_encoder_dg",
      "type": "shape_node",
      "label": "Attribute Encoder",
      "sub_label": "Trainable",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#D9EAD3",
        "border_color": "#4CAF50",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "predicted_attr_tokens_dg",
      "type": "group_container",
      "label": "Predicted Attribute Tokens",
      "geometry": {
        "shape": "horizontal_stack"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#8BC34A",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#8BC34A"
      }
    },
    {
      "id": "loss_CE",
      "type": "text_node",
      "label": "L_CE",
      "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": "loss_attrG",
      "type": "text_node",
      "label": "L_attrG",
      "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": "loss_id_tri",
      "type": "text_node",
      "label": "L_id + L_tri",
      "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_frozen",
      "type": "icon_node",
      "label": "Frozen Module",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#E3ECF7",
        "border_color": "#4A90E2",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "legend_trainable",
      "type": "icon_node",
      "label": "Trainable Module",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#D9EAD3",
        "border_color": "#4CAF50",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "legend_fixed_text",
      "type": "icon_node",
      "label": "Fixed Text Token",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#4A90E2",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#4A90E2"
      }
    },
    {
      "id": "legend_learnable_attr",
      "type": "icon_node",
      "label": "Learnable Attribute Token",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#4CAF50",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#4CAF50"
      }
    },
    {
      "id": "legend_predicted_attr",
      "type": "icon_node",
      "label": "Predicted Attribute Token",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#8BC34A",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#8BC34A"
      }
    },
    {
      "id": "legend_pseudo_label",
      "type": "icon_node",
      "label": "Attribute Pseudo Label",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#FF9800",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#FF9800"
      }
    }
  ],
  "connections": [
    {
      "id": "conn1",
      "from_id": "attr_prompt",
      "to_id": "token_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": "conn2",
      "from_id": "token_embedding",
      "to_id": "fixed_text_tokens",
      "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": "conn3",
      "from_id": "token_embedding",
      "to_id": "learnable_attr_tokens",
      "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": "conn4",
      "from_id": "image_stack",
      "to_id": "image_encoder_cma",
      "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": "conn5",
      "from_id": "fixed_text_tokens",
      "to_id": "text_encoder_cma",
      "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": "conn6",
      "from_id": "learnable_attr_tokens",
      "to_id": "text_encoder_cma",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#4CAF50",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn7",
      "from_id": "image_encoder_cma",
      "to_id": "feature_matrix",
      "label": {
        "text": "I_1, ..., I_B",
        "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": "conn8",
      "from_id": "text_encoder_cma",
      "to_id": "feature_matrix",
      "label": {
        "text": "T_1, ..., T_B",
        "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": "conn9",
      "from_id": "feature_matrix",
      "to_id": "loss_feat",
      "label": {
        "text": "L_feat",
        "position": "end",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "dashed",
        "color": "#000000",
        "width": 1.5
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "none",
        "size": "small"
      }
    },
    {
      "id": "conn10",
      "from_id": "feature_matrix",
      "to_id": "attribute_encoder_cma",
      "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": "conn11",
      "from_id": "attribute_encoder_cma",
      "to_id": "predicted_attr_tokens_cma",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#8BC34A",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn12",
      "from_id": "predicted_attr_tokens_cma",
      "to_id": "loss_attrA",
      "label": {
        "text": "L_attrA",
        "position": "end",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "dashed",
        "color": "#000000",
        "width": 1.5
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "none",
        "size": "small"
      }
    },
    {
      "id": "conn13",
      "from_id": "attr_pseudo_label",
      "to_id": "text_encoder_dg",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#FF9800",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn14",
      "from_id": "image_stack",
      "to_id": "image_encoder_dg",
      "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": "conn15",
      "from_id": "fixed_text_tokens",
      "to_id": "text_encoder_dg",
      "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": "conn16",
      "from_id": "image_encoder_dg",
      "to_id": "feature_matrix",
      "label": {
        "text": "I_1, ..., I_B",
        "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": "conn17",
      "from_id": "text_encoder_dg",
      "to_id": "feature_matrix",
      "label": {
        "text": "T_1, ..., T_B",
        "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": "conn18",
      "from_id": "feature_matrix",
      "to_id": "loss_CE",
      "label": {
        "text": "L_CE",
        "position": "end",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "dashed",
        "color": "#000000",
        "width": 1.5
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "none",
        "size": "small"
      }
    },
    {
      "id": "conn19",
      "from_id": "feature_matrix",
      "to_id": "attribute_encoder_dg",
      "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": "conn20",
      "from_id": "attribute_encoder_dg",
      "to_id": "predicted_attr_tokens_dg",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#8BC34A",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn21",
      "from_id": "predicted_attr_tokens_dg",
      "to_id": "loss_attrG",
      "label": {
        "text": "L_attrG",
        "position": "end",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "dashed",
        "color": "#000000",
        "width": 1.5
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "none",
        "size": "small"
      }
    },
    {
      "id": "conn22",
      "from_id": "feature_matrix",
      "to_id": "loss_id_tri",
      "label": {
        "text": "L_id + L_tri",
        "position": "end",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "dashed",
        "color": "#000000",
        "width": 1.5
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "none",
        "size": "small"
      }
    }
  ],
  "layout_constraints": [
    {
      "type": "relative_arrangement",
      "element_ids": [
        "cma_stage_label",
        "attr_prompt",
        "token_embedding",
        "fixed_text_tokens",
        "learnable_attr_tokens",
        "image_stack",
        "image_encoder_cma",
        "text_encoder_cma",
        "feature_matrix",
        "attribute_encoder_cma",
        "predicted_attr_tokens_cma",
        "loss_feat",
        "loss_attrA"
      ]
    },
    {
      "type": "relative_arrangement",
      "element_ids": [
        "dg_stage_label",
        "attr_prompt",
        "token_embedding",
        "fixed_text_tokens",
        "attr_pseudo_label",
        "image_stack",
        "image_encoder_dg",
        "text_encoder_dg",
        "feature_matrix",
        "attribute_encoder_dg",
        "predicted_attr_tokens_dg",
        "loss_CE",
        "loss_attrG",
        "loss_id_tri"
      ]
    },
    {
      "type": "alignment",
      "alignment_type": "horizontal_center",
      "element_ids": [
        "image_stack",
        "image_encoder_cma",
        "image_encoder_dg"
      ]
    },
    {
      "type": "alignment",
      "alignment_type": "horizontal_center",
      "element_ids": [
        "feature_matrix",
        "attribute_encoder_cma",
        "attribute_encoder_dg"
      ]
    },
    {
      "type": "containment",
      "container_id": "legend_frozen",
      "padding": "small"
    },
    {
      "type": "distribution",
      "distribution_type": "vertical_equal_spacing",
      "element_ids": [
        "legend_frozen",
        "legend_trainable",
        "legend_fixed_text",
        "legend_learnable_attr",
        "legend_predicted_attr",
        "legend_pseudo_label"
      ]
    }
  ]
}