{
  "schema_version": "2.0",
  "metadata": {
    "diagram_id": "grpo_challenger_solver_cycle_v1"
  },
  "global_properties": {
    "topic": "GRPO Challenger-Solver Training Cycle",
    "purpose": "workflow",
    "target_audience": "researcher",
    "complexity_level": "detailed_schematic",
    "domain": "Machine Learning",
    "visual_format": "flowchart",
    "diagram_type": "flowchart",
    "layout_grid": "2x1",
    "style_theme": "professional_light",
    "background_color": "#FFFFFF",
    "font_family": "Helvetica, Arial, sans-serif",
    "title": {
      "text": "Challenger-Solver Training Cycle with GRPO",
      "is_present": false
    }
  },
  "components": [
    {
      "id": "container1",
      "type": "group_container",
      "label": "Update by GRPO with Uncertainty Reward",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#F3F9F4",
        "border_color": "#B0B0B0",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#222222"
      }
    },
    {
      "id": "container2",
      "type": "group_container",
      "label": "Update by GRPO with Filtered Question",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#F8F5FA",
        "border_color": "#B0B0B0",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#222222"
      }
    },
    {
      "id": "challenger1",
      "type": "shape_node",
      "label": "Challenger",
      "sub_label": "",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#FFF6E5",
        "border_color": "#F5A623",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#222222"
      }
    },
    {
      "id": "icon_flame1",
      "type": "icon_node",
      "label": "flame",
      "geometry": {
        "shape": "custom"
      },
      "styling": {
        "fill_color": "#F5A623",
        "border_color": "#F5A623",
        "border_width": 0,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#F5A623"
      }
    },
    {
      "id": "icon_star1",
      "type": "icon_node",
      "label": "star",
      "geometry": {
        "shape": "custom"
      },
      "styling": {
        "fill_color": "#4FC3F7",
        "border_color": "#4FC3F7",
        "border_width": 0,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#4FC3F7"
      }
    },
    {
      "id": "input1",
      "type": "shape_node",
      "label": "x₁ ... xᵢ",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#F2F2F2",
        "border_color": "#B0B0B0",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#222222"
      }
    },
    {
      "id": "solver1",
      "type": "shape_node",
      "label": "Solver",
      "sub_label": "",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#E6F2FF",
        "border_color": "#4FC3F7",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#222222"
      }
    },
    {
      "id": "icon_star2",
      "type": "icon_node",
      "label": "star",
      "geometry": {
        "shape": "custom"
      },
      "styling": {
        "fill_color": "#4FC3F7",
        "border_color": "#4FC3F7",
        "border_width": 0,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#4FC3F7"
      }
    },
    {
      "id": "output1",
      "type": "shape_node",
      "label": "{y₁,₁, y₁,₂, ... y₁,ₘ}\n...\n{yᵢ,₁, yᵢ,₂, ... yᵢ,ₘ}",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#F2F2F2",
        "border_color": "#B0B0B0",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#222222"
      }
    },
    {
      "id": "majority1",
      "type": "operator_node",
      "label": "majority voting",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#B0B0B0",
        "border_width": 0,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#222222"
      }
    },
    {
      "id": "final_output1",
      "type": "shape_node",
      "label": "ŷ₁ ... ŷᵢ",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#B0B0B0",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#222222"
      }
    },
    {
      "id": "challenger2",
      "type": "shape_node",
      "label": "Challenger",
      "sub_label": "",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#FFF6E5",
        "border_color": "#F5A623",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#222222"
      }
    },
    {
      "id": "icon_star3",
      "type": "icon_node",
      "label": "star",
      "geometry": {
        "shape": "custom"
      },
      "styling": {
        "fill_color": "#4FC3F7",
        "border_color": "#4FC3F7",
        "border_width": 0,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#4FC3F7"
      }
    },
    {
      "id": "input2",
      "type": "shape_node",
      "label": "x₁ ... xᵢ",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#F2F2F2",
        "border_color": "#B0B0B0",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#222222"
      }
    },
    {
      "id": "solver2",
      "type": "shape_node",
      "label": "Solver",
      "sub_label": "",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#E6F2FF",
        "border_color": "#4FC3F7",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#222222"
      }
    },
    {
      "id": "icon_flame2",
      "type": "icon_node",
      "label": "flame",
      "geometry": {
        "shape": "custom"
      },
      "styling": {
        "fill_color": "#F5A623",
        "border_color": "#F5A623",
        "border_width": 0,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#F5A623"
      }
    },
    {
      "id": "output2",
      "type": "shape_node",
      "label": "{y₁,₁, y₁,₂, ... y₁,ₘ}\n...\n{yᵢ,₁, yᵢ,₂, ... yᵢ,ₘ}",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#F2F2F2",
        "border_color": "#B0B0B0",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#222222"
      }
    },
    {
      "id": "majority2",
      "type": "operator_node",
      "label": "majority voting",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#B0B0B0",
        "border_width": 0,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#222222"
      }
    },
    {
      "id": "final_output2",
      "type": "shape_node",
      "label": "ŷ₁ ... ŷᵢ",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#B0B0B0",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#222222"
      }
    },
    {
      "id": "arrow_challenger_training",
      "type": "custom_element",
      "label": "Challenger training",
      "geometry": {
        "shape": "curved_arrow"
      },
      "styling": {
        "fill_color": "#000000",
        "border_color": "#000000",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "arrow_solver_training",
      "type": "custom_element",
      "label": "Solver training",
      "geometry": {
        "shape": "curved_arrow"
      },
      "styling": {
        "fill_color": "#000000",
        "border_color": "#000000",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    }
  ],
  "connections": [
    {
      "id": "conn1",
      "from_id": "challenger1",
      "to_id": "input1",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#222222"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#F5A623",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn2",
      "from_id": "input1",
      "to_id": "solver1",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#222222"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#4FC3F7",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn3",
      "from_id": "solver1",
      "to_id": "output1",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#222222"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#4FC3F7",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn4",
      "from_id": "output1",
      "to_id": "majority1",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#222222"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#B0B0B0",
        "width": 1.5
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "small"
      }
    },
    {
      "id": "conn5",
      "from_id": "majority1",
      "to_id": "final_output1",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#222222"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#B0B0B0",
        "width": 1.5
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "small"
      }
    },
    {
      "id": "conn6",
      "from_id": "challenger2",
      "to_id": "input2",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#222222"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#F5A623",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn7",
      "from_id": "input2",
      "to_id": "solver2",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#222222"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#4FC3F7",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn8",
      "from_id": "solver2",
      "to_id": "output2",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#222222"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#4FC3F7",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn9",
      "from_id": "output2",
      "to_id": "majority2",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#222222"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#B0B0B0",
        "width": 1.5
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "small"
      }
    },
    {
      "id": "conn10",
      "from_id": "majority2",
      "to_id": "final_output2",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#222222"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#B0B0B0",
        "width": 1.5
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "small"
      }
    },
    {
      "id": "conn11",
      "from_id": "final_output1",
      "to_id": "challenger2",
      "label": {
        "text": "Challenger training",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "curved_clockwise",
        "style": "solid",
        "color": "#000000",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "large"
      }
    },
    {
      "id": "conn12",
      "from_id": "final_output2",
      "to_id": "solver1",
      "label": {
        "text": "Solver training",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "curved_clockwise",
        "style": "solid",
        "color": "#000000",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "large"
      }
    }
  ],
  "layout_constraints": [
    {
      "type": "containment",
      "container_id": "container1",
      "element_ids": [
        "challenger1",
        "icon_flame1",
        "icon_star1",
        "input1",
        "solver1",
        "icon_star2",
        "output1",
        "majority1",
        "final_output1"
      ],
      "padding": "medium"
    },
    {
      "type": "containment",
      "container_id": "container2",
      "element_ids": [
        "challenger2",
        "icon_star3",
        "input2",
        "solver2",
        "icon_flame2",
        "output2",
        "majority2",
        "final_output2"
      ],
      "padding": "medium"
    },
    {
      "type": "alignment",
      "alignment_type": "horizontal_center",
      "element_ids": [
        "challenger1",
        "input1",
        "solver1",
        "output1",
        "majority1",
        "final_output1"
      ]
    },
    {
      "type": "alignment",
      "alignment_type": "horizontal_center",
      "element_ids": [
        "challenger2",
        "input2",
        "solver2",
        "output2",
        "majority2",
        "final_output2"
      ]
    },
    {
      "type": "distribution",
      "distribution_type": "vertical_equal_spacing",
      "element_ids": [
        "container1",
        "container2"
      ]
    }
  ]
}