{
  "schema_version": "2.0",
  "metadata": {
    "diagram_id": "hash_commitment_protocol_01"
  },
  "global_properties": {
    "topic": "Hash Commitment Protocol for Shared Seed Generation",
    "purpose": "workflow",
    "target_audience": "researcher",
    "complexity_level": "detailed_schematic",
    "domain": "Cryptography",
    "visual_format": "flowchart",
    "diagram_type": "flowchart",
    "layout_grid": "3-tier_horizontal",
    "style_theme": "professional_light",
    "background_color": "#FFFFFF",
    "font_family": "Helvetica, Arial, sans-serif",
    "title": {
      "text": "Hash Commitment Protocol for Shared Seed Generation",
      "is_present": false
    }
  },
  "components": [
    {
      "id": "c1",
      "type": "group_container",
      "label": "Sender i",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#D9EAFB",
        "border_color": "#3A5A7A",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#2C4A7A"
      }
    },
    {
      "id": "icon1",
      "type": "icon_node",
      "label": "Sender i Icon",
      "geometry": {
        "shape": "custom"
      },
      "styling": {
        "fill_color": "#FCE5CD",
        "border_color": "#000000",
        "border_width": 0,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "c2",
      "type": "shape_node",
      "label": "1) Commitment:\nci\nhi = h(ci)",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#B7D3F2",
        "border_color": "#3A5A7A",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#2C4A7A"
      }
    },
    {
      "id": "c3",
      "type": "shape_node",
      "label": "2) Revelation:\nDisclose ci",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#B7D3F2",
        "border_color": "#3A5A7A",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#2C4A7A"
      }
    },
    {
      "id": "c4",
      "type": "shape_node",
      "label": "3) Compute h(s||i)",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#B7D3F2",
        "border_color": "#3A5A7A",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#2C4A7A"
      }
    },
    {
      "id": "c5",
      "type": "shape_node",
      "label": "4) Hash-to-curve:\n[ρi]2 := f(h(s||i))",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#B7D3F2",
        "border_color": "#3A5A7A",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#2C4A7A"
      }
    },
    {
      "id": "c6",
      "type": "group_container",
      "label": "Protocol Core",
      "geometry": {
        "shape": "cloud"
      },
      "styling": {
        "fill_color": "#FFF2CC",
        "border_color": "#E6B800",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#B8860B"
      }
    },
    {
      "id": "c7",
      "type": "text_node",
      "label": "Agree upon:\nHash function h(·)",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#FFF2CC",
        "border_color": "#E6B800",
        "border_width": 0,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#B8860B"
      }
    },
    {
      "id": "c8",
      "type": "shape_node",
      "label": "Broadcast Public hi",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#FFF2CC",
        "border_color": "#E6B800",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#B8860B"
      }
    },
    {
      "id": "c9",
      "type": "shape_node",
      "label": "Broadcast Public ci",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#FFF2CC",
        "border_color": "#E6B800",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#B8860B"
      }
    },
    {
      "id": "c10",
      "type": "shape_node",
      "label": "Broadcast shared seed",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#FFF2CC",
        "border_color": "#E6B800",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#B8860B"
      }
    },
    {
      "id": "c11",
      "type": "group_container",
      "label": "All Senders",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#E2F0CB",
        "border_color": "#4B7B2B",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#3C6B1A"
      }
    },
    {
      "id": "icon2",
      "type": "icon_node",
      "label": "All Senders Icon",
      "geometry": {
        "shape": "custom"
      },
      "styling": {
        "fill_color": "#FCE5CD",
        "border_color": "#000000",
        "border_width": 0,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "c12",
      "type": "shape_node",
      "label": "1) Get {h1, ..., hn}",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#C9E6B2",
        "border_color": "#4B7B2B",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#3C6B1A"
      }
    },
    {
      "id": "c13",
      "type": "shape_node",
      "label": "2) Verify if hi = h(ci)?",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#C9E6B2",
        "border_color": "#4B7B2B",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#3C6B1A"
      }
    },
    {
      "id": "c14",
      "type": "shape_node",
      "label": "3) Compute shared seed\ns = h(c1||...||cn)",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#C9E6B2",
        "border_color": "#4B7B2B",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#3C6B1A"
      }
    }
  ],
  "connections": [
    {
      "id": "conn1",
      "from_id": "c2",
      "to_id": "c8",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#6FA8DC",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn2",
      "from_id": "c3",
      "to_id": "c9",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#6FA8DC",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn3",
      "from_id": "c4",
      "to_id": "c10",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#93C47D",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn4",
      "from_id": "c8",
      "to_id": "c12",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#6FA8DC",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn5",
      "from_id": "c9",
      "to_id": "c13",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#6FA8DC",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn6",
      "from_id": "c10",
      "to_id": "c14",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#93C47D",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    }
  ],
  "layout_constraints": [
    {
      "type": "containment",
      "container_id": "c1",
      "element_ids": [
        "icon1",
        "c2",
        "c3",
        "c4",
        "c5"
      ],
      "padding": "medium"
    },
    {
      "type": "containment",
      "container_id": "c6",
      "element_ids": [
        "c7",
        "c8",
        "c9",
        "c10"
      ],
      "padding": "medium"
    },
    {
      "type": "containment",
      "container_id": "c11",
      "element_ids": [
        "icon2",
        "c12",
        "c13",
        "c14"
      ],
      "padding": "medium"
    },
    {
      "type": "alignment",
      "alignment_type": "vertical_center",
      "element_ids": [
        "c1",
        "c6",
        "c11"
      ]
    },
    {
      "type": "distribution",
      "distribution_type": "horizontal_equal_spacing",
      "element_ids": [
        "c1",
        "c6",
        "c11"
      ]
    },
    {
      "type": "alignment",
      "alignment_type": "top_edge",
      "element_ids": [
        "c1",
        "c6",
        "c11"
      ]
    }
  ]
}