{
  "schema_version": "2.0",
  "metadata": {
    "diagram_id": "tsan_model_architecture_v1"
  },
  "global_properties": {
    "topic": "TSAN Model Architecture",
    "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": "TSAN Model Architecture",
      "is_present": true
    }
  },
  "components": [
    {
      "id": "c1",
      "type": "shape_node",
      "label": "Temporal Input",
      "sub_label": "X_temporal ∈ ℝ^{l×w×f}\nSequence of w connection records",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#D9EAFB",
        "border_color": "#7DA7D9",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#222222"
      }
    },
    {
      "id": "c2",
      "type": "group_container",
      "label": "Temporal Encoder",
      "sub_label": "Positional Embedding\nMulti-Head Attention\nLayerNorm + Feed-Forward Network\nh_temp ∈ ℝ^{d_temp}",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#D9EAFB",
        "border_color": "#7DA7D9",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#222222"
      }
    },
    {
      "id": "c3",
      "type": "shape_node",
      "label": "h_temp*proj = Dense(h_temp)",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#D9EAFB",
        "border_color": "#7DA7D9",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#222222"
      }
    },
    {
      "id": "c4",
      "type": "shape_node",
      "label": "Spatial Input",
      "sub_label": "X_spatial ∈ ℝ^{l×f}\nIndividual connection features",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#C7F5D9",
        "border_color": "#6FCF97",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#222222"
      }
    },
    {
      "id": "c5",
      "type": "group_container",
      "label": "Spatial Encoder",
      "sub_label": "Conv1D + MaxPool + BatchNorm\nConv1D + MaxPool + BatchNorm\nFlatten + Dense\nh_spat ∈ ℝ^{d_spat}",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#C7F5D9",
        "border_color": "#6FCF97",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#222222"
      }
    },
    {
      "id": "c6",
      "type": "shape_node",
      "label": "h_spat*proj = Dense(h_spat)",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#C7F5D9",
        "border_color": "#6FCF97",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#222222"
      }
    },
    {
      "id": "c7",
      "type": "group_container",
      "label": "Cross-Attention Mechanism",
      "sub_label": "Concatenate Features\nMulti-Head Attention + Dense\nh_combined ∈ ℝ^{d_combined}",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#FFF3C7",
        "border_color": "#E2C97A",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#222222"
      }
    },
    {
      "id": "c8",
      "type": "group_container",
      "label": "Multi-Task Heads",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#FAD6D6",
        "border_color": "#E2A7A7",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#222222"
      }
    },
    {
      "id": "c9",
      "type": "shape_node",
      "label": "DoS Detection",
      "sub_label": "Main Task",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#F9E6B3",
        "border_color": "#E2C97A",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#222222"
      }
    },
    {
      "id": "c10",
      "type": "shape_node",
      "label": "Traffic Pattern",
      "sub_label": "Auxiliary Task 1",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#F9E6B3",
        "border_color": "#E2C97A",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#222222"
      }
    },
    {
      "id": "c11",
      "type": "shape_node",
      "label": "Protocol Dist.",
      "sub_label": "Auxiliary Task 2",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#D9EAFB",
        "border_color": "#7DA7D9",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#222222"
      }
    },
    {
      "id": "c12",
      "type": "shape_node",
      "label": "Temporal Cons.",
      "sub_label": "Auxiliary Task 3",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#D9EAFB",
        "border_color": "#7DA7D9",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#222222"
      }
    }
  ],
  "connections": [
    {
      "id": "conn1",
      "from_id": "c1",
      "to_id": "c2",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#222222"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#7DA7D9",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn2",
      "from_id": "c2",
      "to_id": "c3",
      "label": {
        "text": "h_temp ∈ ℝ^{d_temp}",
        "position": "middle_above",
        "text_color": "#7DA7D9"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#7DA7D9",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn3",
      "from_id": "c3",
      "to_id": "c7",
      "label": {
        "text": "h_temp*proj",
        "position": "end",
        "text_color": "#7DA7D9"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#7DA7D9",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn4",
      "from_id": "c4",
      "to_id": "c5",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#222222"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#6FCF97",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn5",
      "from_id": "c5",
      "to_id": "c6",
      "label": {
        "text": "h_spat ∈ ℝ^{d_spat}",
        "position": "middle_above",
        "text_color": "#6FCF97"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#6FCF97",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn6",
      "from_id": "c6",
      "to_id": "c7",
      "label": {
        "text": "h_spat*proj",
        "position": "end",
        "text_color": "#6FCF97"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#6FCF97",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn7",
      "from_id": "c7",
      "to_id": "c8",
      "label": {
        "text": "h_combined ∈ ℝ^{d_combined}",
        "position": "end",
        "text_color": "#E2C97A"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#E2C97A",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn8",
      "from_id": "c8",
      "to_id": "c9",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#E2A7A7"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#E2A7A7",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn9",
      "from_id": "c8",
      "to_id": "c10",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#E2A7A7"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#E2A7A7",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn10",
      "from_id": "c8",
      "to_id": "c11",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#E2A7A7"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#E2A7A7",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn11",
      "from_id": "c8",
      "to_id": "c12",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#E2A7A7"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#E2A7A7",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    }
  ],
  "layout_constraints": [
    {
      "type": "alignment",
      "alignment_type": "horizontal_center",
      "element_ids": [
        "c1",
        "c2",
        "c3",
        "c7",
        "c8"
      ]
    },
    {
      "type": "alignment",
      "alignment_type": "horizontal_center",
      "element_ids": [
        "c4",
        "c5",
        "c6"
      ]
    },
    {
      "type": "distribution",
      "distribution_type": "horizontal_equal_spacing",
      "element_ids": [
        "c9",
        "c10",
        "c11",
        "c12"
      ]
    },
    {
      "type": "relative_arrangement",
      "element_ids": [
        "c1",
        "c2",
        "c3"
      ],
      "container_id": null
    },
    {
      "type": "relative_arrangement",
      "element_ids": [
        "c4",
        "c5",
        "c6"
      ],
      "container_id": null
    },
    {
      "type": "containment",
      "container_id": "c8",
      "element_ids": [
        "c9",
        "c10",
        "c11",
        "c12"
      ],
      "padding": "medium"
    }
  ]
}