{
  "schema_version": "2.0",
  "metadata": {
    "diagram_id": "coarse_fine_text_co_guide_diffusion_01"
  },
  "global_properties": {
    "topic": "Coarse-fine Text Co-guide in Diffusion Models",
    "purpose": "architecture_overview",
    "target_audience": "researcher",
    "complexity_level": "publication_quality",
    "domain": "Computer Vision",
    "visual_format": "block_diagram",
    "diagram_type": "architecture_diagram",
    "layout_grid": "2x1",
    "style_theme": "professional_light",
    "background_color": "#FDFCF7",
    "font_family": "Helvetica, Arial, sans-serif",
    "title": {
      "text": "Coarse-fine Text Co-guide",
      "is_present": true
    }
  },
  "components": [
    {
      "id": "g1",
      "type": "group_container",
      "label": "Forward Diffusion",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#E9EDF7",
        "border_color": "#000000",
        "border_width": 1.5,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "g2",
      "type": "group_container",
      "label": "Reverse Diffusion",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#F3F8F3",
        "border_color": "#000000",
        "border_width": 1.5,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "g3",
      "type": "group_container",
      "label": "",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#FFFDF6",
        "border_color": "#000000",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "x0",
      "type": "shape_node",
      "label": "x₀",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#3B6EA8",
        "border_color": "#3B6EA8",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#FFFFFF"
      }
    },
    {
      "id": "x1",
      "type": "shape_node",
      "label": "x₁",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#5B8FC6",
        "border_color": "#5B8FC6",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#FFFFFF"
      }
    },
    {
      "id": "xtm1",
      "type": "shape_node",
      "label": "x_{t-1}",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#8CB6E2",
        "border_color": "#8CB6E2",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#FFFFFF"
      }
    },
    {
      "id": "xt",
      "type": "shape_node",
      "label": "x_t",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#B3D2F2",
        "border_color": "#B3D2F2",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#FFFFFF"
      }
    },
    {
      "id": "x0_rev",
      "type": "shape_node",
      "label": "x₀",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#3B6EA8",
        "border_color": "#3B6EA8",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#FFFFFF"
      }
    },
    {
      "id": "rev_block1",
      "type": "shape_node",
      "label": "",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#FFE08A",
        "border_color": "#FFD966",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "rev_block2",
      "type": "shape_node",
      "label": "",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#FFE08A",
        "border_color": "#FFD966",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "rev_block3",
      "type": "shape_node",
      "label": "",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#FFE08A",
        "border_color": "#FFD966",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "rev_block4",
      "type": "shape_node",
      "label": "",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#FFE08A",
        "border_color": "#FFD966",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "rev_block5",
      "type": "shape_node",
      "label": "",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#FFE08A",
        "border_color": "#FFD966",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "fine_text",
      "type": "text_node",
      "label": "Fine Text",
      "sub_label": "His arm is extended and his hand is gripping the ball tightly.",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#E9F7E9",
        "border_color": "#B6D7A8",
        "border_width": 1,
        "border_style": "dashed"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#3C763D"
      }
    },
    {
      "id": "coarse_text",
      "type": "text_node",
      "label": "Coarse Text",
      "sub_label": "throw, cast, hurl, jettison",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#FFF7E6",
        "border_color": "#FFD966",
        "border_width": 1,
        "border_style": "dashed"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#B8860B"
      }
    },
    {
      "id": "text_encoder_fine",
      "type": "shape_node",
      "label": "Text Encoder",
      "geometry": {
        "shape": "trapezoid"
      },
      "styling": {
        "fill_color": "#2176C1",
        "border_color": "#1B4F72",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#FFFFFF"
      }
    },
    {
      "id": "text_encoder_coarse",
      "type": "shape_node",
      "label": "Text Encoder",
      "geometry": {
        "shape": "trapezoid"
      },
      "styling": {
        "fill_color": "#2176C1",
        "border_color": "#1B4F72",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#FFFFFF"
      }
    },
    {
      "id": "time_encoder",
      "type": "shape_node",
      "label": "Time Encoder",
      "geometry": {
        "shape": "trapezoid"
      },
      "styling": {
        "fill_color": "#A3C6E6",
        "border_color": "#1B4F72",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#FFFFFF"
      }
    },
    {
      "id": "Ef",
      "type": "shape_node",
      "label": "E_f",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#B6E6A3",
        "border_color": "#B6E6A3",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#3C763D"
      }
    },
    {
      "id": "El",
      "type": "shape_node",
      "label": "E_l",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#FFE08A",
        "border_color": "#FFD966",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#B8860B"
      }
    },
    {
      "id": "Et",
      "type": "shape_node",
      "label": "E_t",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#A3C6E6",
        "border_color": "#A3C6E6",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#2176C1"
      }
    },
    {
      "id": "t",
      "type": "text_node",
      "label": "t",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#A3C6E6",
        "border_width": 1,
        "border_style": "dashed"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#2176C1"
      }
    },
    {
      "id": "concat",
      "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": "contrastive_loss",
      "type": "shape_node",
      "label": "Contrastive Loss",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#5B8FC6",
        "border_color": "#1B4F72",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#FFFFFF"
      }
    }
  ],
  "connections": [
    {
      "id": "conn1",
      "from_id": "x0",
      "to_id": "x1",
      "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": "x1",
      "to_id": "xtm1",
      "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": "xtm1",
      "to_id": "xt",
      "label": {
        "text": "q(x_t|x_{t-1})",
        "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": "conn4",
      "from_id": "xt",
      "to_id": "rev_block1",
      "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": "rev_block1",
      "to_id": "rev_block2",
      "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": "rev_block2",
      "to_id": "rev_block3",
      "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": "conn7",
      "from_id": "rev_block3",
      "to_id": "rev_block4",
      "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": "conn8",
      "from_id": "rev_block4",
      "to_id": "rev_block5",
      "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": "conn9",
      "from_id": "rev_block5",
      "to_id": "x0_rev",
      "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": "conn10",
      "from_id": "fine_text",
      "to_id": "text_encoder_fine",
      "label": {
        "text": "",
        "position": "end",
        "text_color": "#3C763D"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#3C763D",
        "width": 1.5
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "small"
      }
    },
    {
      "id": "conn11",
      "from_id": "text_encoder_fine",
      "to_id": "Ef",
      "label": {
        "text": "",
        "position": "end",
        "text_color": "#3C763D"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#3C763D",
        "width": 1.5
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "small"
      }
    },
    {
      "id": "conn12",
      "from_id": "Ef",
      "to_id": "concat",
      "label": {
        "text": "",
        "position": "end",
        "text_color": "#3C763D"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#3C763D",
        "width": 1.5
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "small"
      }
    },
    {
      "id": "conn13",
      "from_id": "t",
      "to_id": "time_encoder",
      "label": {
        "text": "",
        "position": "end",
        "text_color": "#2176C1"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#2176C1",
        "width": 1.5
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "small"
      }
    },
    {
      "id": "conn14",
      "from_id": "time_encoder",
      "to_id": "Et",
      "label": {
        "text": "",
        "position": "end",
        "text_color": "#2176C1"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#2176C1",
        "width": 1.5
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "small"
      }
    },
    {
      "id": "conn15",
      "from_id": "Et",
      "to_id": "concat",
      "label": {
        "text": "",
        "position": "end",
        "text_color": "#2176C1"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#2176C1",
        "width": 1.5
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "small"
      }
    },
    {
      "id": "conn16",
      "from_id": "concat",
      "to_id": "contrastive_loss",
      "label": {
        "text": "",
        "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": "coarse_text",
      "to_id": "text_encoder_coarse",
      "label": {
        "text": "",
        "position": "end",
        "text_color": "#B8860B"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#B8860B",
        "width": 1.5
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "small"
      }
    },
    {
      "id": "conn18",
      "from_id": "text_encoder_coarse",
      "to_id": "El",
      "label": {
        "text": "",
        "position": "end",
        "text_color": "#B8860B"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#B8860B",
        "width": 1.5
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "small"
      }
    },
    {
      "id": "conn19",
      "from_id": "El",
      "to_id": "contrastive_loss",
      "label": {
        "text": "",
        "position": "end",
        "text_color": "#B8860B"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#B8860B",
        "width": 1.5
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "small"
      }
    }
  ],
  "layout_constraints": [
    {
      "type": "containment",
      "container_id": "g1",
      "element_ids": [
        "x0",
        "x1",
        "xtm1",
        "xt"
      ]
    },
    {
      "type": "containment",
      "container_id": "g2",
      "element_ids": [
        "rev_block1",
        "rev_block2",
        "rev_block3",
        "rev_block4",
        "rev_block5",
        "x0_rev"
      ]
    },
    {
      "type": "containment",
      "container_id": "g3",
      "element_ids": [
        "fine_text",
        "coarse_text",
        "text_encoder_fine",
        "text_encoder_coarse",
        "Ef",
        "El",
        "Et",
        "t",
        "time_encoder",
        "concat",
        "contrastive_loss"
      ]
    },
    {
      "type": "alignment",
      "alignment_type": "horizontal_center",
      "element_ids": [
        "x0",
        "x1",
        "xtm1",
        "xt"
      ]
    },
    {
      "type": "alignment",
      "alignment_type": "horizontal_center",
      "element_ids": [
        "rev_block1",
        "rev_block2",
        "rev_block3",
        "rev_block4",
        "rev_block5",
        "x0_rev"
      ]
    },
    {
      "type": "distribution",
      "distribution_type": "horizontal_equal_spacing",
      "element_ids": [
        "fine_text",
        "text_encoder_fine",
        "Ef",
        "concat",
        "Et",
        "time_encoder",
        "t"
      ]
    },
    {
      "type": "distribution",
      "distribution_type": "horizontal_equal_spacing",
      "element_ids": [
        "coarse_text",
        "text_encoder_coarse",
        "El",
        "contrastive_loss"
      ]
    }
  ]
}