{
  "schema_version": "2.0",
  "metadata": {
    "diagram_id": "hybrid_cnn_transformer_architecture_01"
  },
  "global_properties": {
    "topic": "Hybrid CNN-Transformer Architecture for Mathematical Expression Recognition",
    "purpose": "architecture_overview",
    "target_audience": "researcher",
    "complexity_level": "publication_quality",
    "domain": "Computer Vision",
    "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": "",
      "is_present": false
    }
  },
  "components": [
    {
      "id": "c1",
      "type": "group_container",
      "label": "Input Pipeline",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#B4C7E7",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "c2",
      "type": "shape_node",
      "label": "Training Data",
      "sub_label": "",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#B4C7E7",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "c3",
      "type": "custom_element",
      "label": "2d + 3/β (image)",
      "sub_label": "",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#000000",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#FFFFFF"
      }
    },
    {
      "id": "c4",
      "type": "shape_node",
      "label": "Data Process",
      "sub_label": "",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#FFD966",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "c5",
      "type": "custom_element",
      "label": "2d + 3/β (image)",
      "sub_label": "",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#000000",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#FFFFFF"
      }
    },
    {
      "id": "c6",
      "type": "shape_node",
      "label": "DenseNet Encoder",
      "sub_label": "",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#C6E0B4",
        "border_color": "#A9D18E",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "c7",
      "type": "group_container",
      "label": "CNN View",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#F8FBFF",
        "border_color": "#8EA9DB",
        "border_width": 2,
        "border_style": "dashed"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "c8",
      "type": "shape_node",
      "label": "Mask",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#BFBFBF",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "c9",
      "type": "operator_node",
      "label": "⊗",
      "geometry": {
        "shape": "circle"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "c10",
      "type": "shape_node",
      "label": "Conv2D",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#FFF2CC",
        "border_color": "#FFD966",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "c11",
      "type": "shape_node",
      "label": "BatchNorm2D",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#D9E1F2",
        "border_color": "#8EA9DB",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "c12",
      "type": "shape_node",
      "label": "ChannelAttn",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#D9F2F2",
        "border_color": "#00B0F0",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "c13",
      "type": "shape_node",
      "label": "Conv2D",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#FFF2CC",
        "border_color": "#FFD966",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "c14",
      "type": "shape_node",
      "label": "Sigmoid",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#F4CCCC",
        "border_color": "#E06666",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "c15",
      "type": "shape_node",
      "label": "GRU",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#BFBFBF",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "c16",
      "type": "shape_node",
      "label": "Counting Pred",
      "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": "c17",
      "type": "group_container",
      "label": "Transformer View",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#F8FBFF",
        "border_color": "#8EA9DB",
        "border_width": 2,
        "border_style": "dashed"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "c18",
      "type": "group_container",
      "label": "N",
      "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": "c19",
      "type": "shape_node",
      "label": "Multihead Attention",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#E2F0D9",
        "border_color": "#70AD47",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "c20",
      "type": "shape_node",
      "label": "Implicit Attention",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#00B050",
        "border_color": "#006837",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#FFFFFF"
      }
    },
    {
      "id": "c21",
      "type": "shape_node",
      "label": "FFN",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#FCE4D6",
        "border_color": "#ED7D31",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "c22",
      "type": "shape_node",
      "label": "Multihead Attention",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#E2F0D9",
        "border_color": "#70AD47",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "c23",
      "type": "shape_node",
      "label": "Linear",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#F4B183",
        "border_color": "#C65911",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "c24",
      "type": "shape_node",
      "label": "Linear",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#F4B183",
        "border_color": "#C65911",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "c25",
      "type": "shape_node",
      "label": "Layernum",
      "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": "c26",
      "type": "shape_node",
      "label": "Position",
      "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": "c27",
      "type": "group_container",
      "label": "",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#8EA9DB",
        "border_width": 1,
        "border_style": "dashed"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "c28",
      "type": "shape_node",
      "label": "Counting loss",
      "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": "c29",
      "type": "shape_node",
      "label": "Rec loss",
      "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": "c30",
      "type": "shape_node",
      "label": "Posi loss",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "dashed"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    }
  ],
  "connections": [
    {
      "id": "conn1",
      "from_id": "c2",
      "to_id": "c3",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#000000",
        "width": 1
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "small"
      }
    },
    {
      "id": "conn2",
      "from_id": "c3",
      "to_id": "c4",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#000000",
        "width": 1
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "small"
      }
    },
    {
      "id": "conn3",
      "from_id": "c4",
      "to_id": "c5",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#000000",
        "width": 1
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "small"
      }
    },
    {
      "id": "conn4",
      "from_id": "c5",
      "to_id": "c6",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#000000",
        "width": 1
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "small"
      }
    },
    {
      "id": "conn5",
      "from_id": "c6",
      "to_id": "c9",
      "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": "solid_triangle",
        "size": "small"
      }
    },
    {
      "id": "conn6",
      "from_id": "c8",
      "to_id": "c9",
      "label": {
        "text": "",
        "position": "start",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "orthogonal",
        "style": "solid",
        "color": "#000000",
        "width": 1
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "none",
        "size": "small"
      }
    },
    {
      "id": "conn7",
      "from_id": "c9",
      "to_id": "c10",
      "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": "solid_triangle",
        "size": "small"
      }
    },
    {
      "id": "conn8",
      "from_id": "c10",
      "to_id": "c11",
      "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": "solid_triangle",
        "size": "small"
      }
    },
    {
      "id": "conn9",
      "from_id": "c11",
      "to_id": "c12",
      "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": "solid_triangle",
        "size": "small"
      }
    },
    {
      "id": "conn10",
      "from_id": "c12",
      "to_id": "c13",
      "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": "solid_triangle",
        "size": "small"
      }
    },
    {
      "id": "conn11",
      "from_id": "c13",
      "to_id": "c14",
      "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": "solid_triangle",
        "size": "small"
      }
    },
    {
      "id": "conn12",
      "from_id": "c14",
      "to_id": "c15",
      "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": "solid_triangle",
        "size": "small"
      }
    },
    {
      "id": "conn13",
      "from_id": "c15",
      "to_id": "c16",
      "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": "solid_triangle",
        "size": "small"
      }
    },
    {
      "id": "conn14",
      "from_id": "c6",
      "to_id": "c17",
      "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": "solid_triangle",
        "size": "small"
      }
    },
    {
      "id": "conn15",
      "from_id": "c17",
      "to_id": "c18",
      "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": "small"
      }
    },
    {
      "id": "conn16",
      "from_id": "c18",
      "to_id": "c19",
      "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": "solid_triangle",
        "size": "small"
      }
    },
    {
      "id": "conn17",
      "from_id": "c19",
      "to_id": "c20",
      "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": "solid_triangle",
        "size": "small"
      }
    },
    {
      "id": "conn18",
      "from_id": "c20",
      "to_id": "c21",
      "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": "solid_triangle",
        "size": "small"
      }
    },
    {
      "id": "conn19",
      "from_id": "c21",
      "to_id": "c22",
      "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": "solid_triangle",
        "size": "small"
      }
    },
    {
      "id": "conn20",
      "from_id": "c22",
      "to_id": "c23",
      "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": "solid_triangle",
        "size": "small"
      }
    },
    {
      "id": "conn21",
      "from_id": "c22",
      "to_id": "c24",
      "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": "solid_triangle",
        "size": "small"
      }
    },
    {
      "id": "conn22",
      "from_id": "c23",
      "to_id": "c25",
      "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": "solid_triangle",
        "size": "small"
      }
    },
    {
      "id": "conn23",
      "from_id": "c24",
      "to_id": "c26",
      "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": "solid_triangle",
        "size": "small"
      }
    },
    {
      "id": "conn24",
      "from_id": "c16",
      "to_id": "c28",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "dashed",
        "color": "#000000",
        "width": 1
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "small"
      }
    },
    {
      "id": "conn25",
      "from_id": "c25",
      "to_id": "c29",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "dashed",
        "color": "#000000",
        "width": 1
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "small"
      }
    },
    {
      "id": "conn26",
      "from_id": "c26",
      "to_id": "c30",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "dashed",
        "color": "#000000",
        "width": 1
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "small"
      }
    }
  ],
  "layout_constraints": [
    {
      "type": "containment",
      "container_id": "c1",
      "element_ids": [
        "c2",
        "c3",
        "c4",
        "c5",
        "c6"
      ],
      "padding": "medium"
    },
    {
      "type": "containment",
      "container_id": "c7",
      "element_ids": [
        "c8",
        "c9",
        "c10",
        "c11",
        "c12",
        "c13",
        "c14",
        "c15",
        "c16"
      ],
      "padding": "medium"
    },
    {
      "type": "containment",
      "container_id": "c17",
      "element_ids": [
        "c18",
        "c19",
        "c20",
        "c21",
        "c22",
        "c23",
        "c24",
        "c25",
        "c26"
      ],
      "padding": "medium"
    },
    {
      "type": "containment",
      "container_id": "c18",
      "element_ids": [
        "c19",
        "c20",
        "c21"
      ],
      "padding": "small"
    },
    {
      "type": "containment",
      "container_id": "c27",
      "element_ids": [
        "c28",
        "c29",
        "c30"
      ],
      "padding": "small"
    },
    {
      "type": "alignment",
      "alignment_type": "vertical_center",
      "element_ids": [
        "c1",
        "c7",
        "c17",
        "c27"
      ]
    },
    {
      "type": "distribution",
      "distribution_type": "horizontal_equal_spacing",
      "element_ids": [
        "c1",
        "c7",
        "c17"
      ]
    },
    {
      "type": "alignment",
      "alignment_type": "horizontal_center",
      "element_ids": [
        "c28",
        "c29",
        "c30"
      ]
    }
  ]
}