{
  "schema_version": "2.0",
  "metadata": {
    "diagram_id": "video_object_mask_model_01"
  },
  "global_properties": {
    "topic": "Video Object Mask Generation Model",
    "purpose": "architecture_overview",
    "target_audience": "researcher",
    "complexity_level": "high_level_overview",
    "domain": "Computer Vision",
    "visual_format": "block_diagram",
    "diagram_type": "architecture_diagram",
    "layout_grid": "3-tier_vertical",
    "style_theme": "professional_light",
    "background_color": "#E9EDF2",
    "font_family": "Times New Roman, serif",
    "title": {
      "text": "Model for Valid Object Mask Generation on Video Frames",
      "is_present": false
    }
  },
  "components": [
    {
      "id": "container1",
      "type": "group_container",
      "label": "model",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#E9EDF2",
        "border_color": "#A0A8B0",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#222222"
      }
    },
    {
      "id": "c_prompt",
      "type": "text_node",
      "label": "prompt",
      "geometry": {
        "shape": "none"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#FFFFFF",
        "border_width": 0,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#222A2A"
      }
    },
    {
      "id": "c_video_frame",
      "type": "text_node",
      "label": "video frame",
      "geometry": {
        "shape": "none"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#FFFFFF",
        "border_width": 0,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#222A2A"
      }
    },
    {
      "id": "c_image_encoder",
      "type": "shape_node",
      "label": "image\nencoder",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#D6F5D6",
        "border_color": "#A0A8B0",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#222222"
      }
    },
    {
      "id": "c_prompt_encoder",
      "type": "shape_node",
      "label": "prompt\nencoder",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#E6E6FA",
        "border_color": "#A0A8B0",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#222222"
      }
    },
    {
      "id": "c_memory_attention",
      "type": "shape_node",
      "label": "memory\nattention",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#CFE7FA",
        "border_color": "#A0A8B0",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#222222"
      }
    },
    {
      "id": "c_memory_bank",
      "type": "shape_node",
      "label": "memory\nbank",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#FFD6D6",
        "border_color": "#A0A8B0",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#222222"
      }
    },
    {
      "id": "c_mask_decoder",
      "type": "shape_node",
      "label": "mask\ndecoder",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#FFF2D6",
        "border_color": "#A0A8B0",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#222222"
      }
    },
    {
      "id": "c_output",
      "type": "text_node",
      "label": "valid object mask on each frame",
      "geometry": {
        "shape": "none"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#FFFFFF",
        "border_width": 0,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#222A2A"
      }
    }
  ],
  "connections": [
    {
      "id": "conn1",
      "from_id": "c_prompt",
      "to_id": "c_prompt_encoder",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#222222"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#222222",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn2",
      "from_id": "c_video_frame",
      "to_id": "c_image_encoder",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#222222"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#222222",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn3",
      "from_id": "c_image_encoder",
      "to_id": "c_memory_attention",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#222222"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#A0A8B0",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn4",
      "from_id": "c_prompt_encoder",
      "to_id": "c_mask_decoder",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#222222"
      },
      "line_properties": {
        "type": "orthogonal",
        "style": "solid",
        "color": "#A0A8B0",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn5",
      "from_id": "c_memory_attention",
      "to_id": "c_mask_decoder",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#222222"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#A0A8B0",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn6",
      "from_id": "c_memory_bank",
      "to_id": "c_memory_attention",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#222222"
      },
      "line_properties": {
        "type": "curved_clockwise",
        "style": "solid",
        "color": "#A0A8B0",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn7",
      "from_id": "c_mask_decoder",
      "to_id": "c_memory_bank",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#222222"
      },
      "line_properties": {
        "type": "curved_clockwise",
        "style": "solid",
        "color": "#A0A8B0",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn8",
      "from_id": "c_mask_decoder",
      "to_id": "c_output",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#222222"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#222222",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    }
  ],
  "layout_constraints": [
    {
      "type": "containment",
      "container_id": "container1",
      "element_ids": [
        "c_image_encoder",
        "c_prompt_encoder",
        "c_memory_attention",
        "c_memory_bank",
        "c_mask_decoder"
      ],
      "padding": "medium"
    },
    {
      "type": "alignment",
      "alignment_type": "horizontal_center",
      "element_ids": [
        "c_video_frame",
        "c_image_encoder",
        "c_memory_attention",
        "c_mask_decoder",
        "c_output"
      ]
    },
    {
      "type": "alignment",
      "alignment_type": "top_edge",
      "element_ids": [
        "c_prompt",
        "c_video_frame"
      ]
    },
    {
      "type": "distribution",
      "distribution_type": "horizontal_equal_spacing",
      "element_ids": [
        "c_prompt_encoder",
        "c_memory_attention",
        "c_memory_bank"
      ]
    }
  ]
}