{
  "schema_version": "2.0",
  "metadata": {
    "diagram_id": "policy_gradients_optimization_ppo"
  },
  "global_properties": {
    "topic": "Policy Gradients Optimization with Control and Guide Actions",
    "purpose": "architecture_overview",
    "target_audience": "researcher",
    "complexity_level": "publication_quality",
    "domain": "Computer Science",
    "visual_format": "block_diagram",
    "diagram_type": "architecture_diagram",
    "layout_grid": "3-tier_horizontal",
    "style_theme": "professional_light",
    "background_color": "#FFFFFF",
    "font_family": "Helvetica, Arial, sans-serif",
    "title": {
      "text": "Policy Gradients Optimization",
      "is_present": true
    }
  },
  "components": [
    {
      "id": "c1",
      "type": "shape_node",
      "label": "Source Code",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#1A4A6A",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#1A4A6A"
      }
    },
    {
      "id": "c2",
      "type": "shape_node",
      "label": "Policy Pre-trained Model (Actor)",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#F6F1EB",
        "border_color": "#D28B4C",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#D28B4C"
      }
    },
    {
      "id": "c3",
      "type": "shape_node",
      "label": "Reference Pre-trained Model (Critic)",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#D3E6E3",
        "border_color": "#4B7B7B",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#4B7B7B"
      }
    },
    {
      "id": "c4",
      "type": "shape_node",
      "label": "Active Translated Code",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#1A4A6A",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#1A4A6A"
      }
    },
    {
      "id": "c5",
      "type": "shape_node",
      "label": "Compliable Reference Target Code",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#1A4A6A",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#1A4A6A"
      }
    },
    {
      "id": "c6",
      "type": "shape_node",
      "label": "− KL-div",
      "sub_label": "Control Actions",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#D6E3F3",
        "border_color": "#7CA6C7",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#1A4A6A"
      }
    },
    {
      "id": "c7",
      "type": "shape_node",
      "label": "Compiler Feedback",
      "sub_label": "Guide Actions",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#E6C6D1",
        "border_color": "#B36B8B",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#B36B8B"
      }
    },
    {
      "id": "c8",
      "type": "shape_node",
      "label": "DFG Edge Match Percentage\n(Semantic Match Score)",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#FFF9D6",
        "border_color": "#D6C96B",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#B3A13B"
      }
    },
    {
      "id": "c9",
      "type": "shape_node",
      "label": "AST Sub-tree Match Percentage\n(Syntactic Match Score)",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#D6F3D6",
        "border_color": "#7BC77B",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#4A7B4A"
      }
    },
    {
      "id": "c10",
      "type": "shape_node",
      "label": "Reward",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#E6E6E6",
        "border_color": "#A6A6A6",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#666666"
      }
    },
    {
      "id": "c11",
      "type": "shape_node",
      "label": "PPO",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#E6E6E6",
        "border_color": "#A6A6A6",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#666666"
      }
    },
    {
      "id": "op1",
      "type": "operator_node",
      "label": "+",
      "geometry": {
        "shape": "circle"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#A6A6A6",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#A6A6A6"
      }
    },
    {
      "id": "op2",
      "type": "operator_node",
      "label": "+",
      "geometry": {
        "shape": "circle"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#A6A6A6",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#A6A6A6"
      }
    },
    {
      "id": "op3",
      "type": "operator_node",
      "label": "+",
      "geometry": {
        "shape": "circle"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#A6A6A6",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#A6A6A6"
      }
    },
    {
      "id": "g1",
      "type": "group_container",
      "label": "Control Actions",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#A6A6A6",
        "border_width": 2,
        "border_style": "dashed"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#B22222"
      }
    },
    {
      "id": "g2",
      "type": "group_container",
      "label": "Guide Actions",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#A6A6A6",
        "border_width": 2,
        "border_style": "dashed"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#B22222"
      }
    },
    {
      "id": "g3",
      "type": "group_container",
      "label": "Control and Guide Actions",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#F6F6F6",
        "border_color": "#A6A6A6",
        "border_width": 2,
        "border_style": "dashed"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#B22222"
      }
    },
    {
      "id": "t1",
      "type": "text_node",
      "label": "logprob^C",
      "geometry": {
        "shape": "none"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#FFFFFF",
        "border_width": 0,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#666666"
      }
    },
    {
      "id": "t2",
      "type": "text_node",
      "label": "logprob^A",
      "geometry": {
        "shape": "none"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#FFFFFF",
        "border_width": 0,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#666666"
      }
    },
    {
      "id": "t3",
      "type": "text_node",
      "label": "Data Flow Graph (DFG)",
      "geometry": {
        "shape": "none"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#FFFFFF",
        "border_width": 0,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#666666"
      }
    },
    {
      "id": "t4",
      "type": "text_node",
      "label": "Abstract Syntax Tree (AST)",
      "geometry": {
        "shape": "none"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#FFFFFF",
        "border_width": 0,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#666666"
      }
    },
    {
      "id": "t5",
      "type": "text_node",
      "label": "Policy Gradients Optimization",
      "geometry": {
        "shape": "none"
      },
      "styling": {
        "fill_color": "#FFFFFF",
        "border_color": "#FFFFFF",
        "border_width": 0,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    }
  ],
  "connections": [
    {
      "id": "conn1",
      "from_id": "c1",
      "to_id": "c2",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#1A4A6A",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn2",
      "from_id": "c2",
      "to_id": "c4",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#1A4A6A",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn3",
      "from_id": "c1",
      "to_id": "c3",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#4B7B7B",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn4",
      "from_id": "c3",
      "to_id": "c6",
      "label": {
        "text": "logprob^C",
        "position": "middle_above",
        "text_color": "#666666"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#7CA6C7",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "small"
      }
    },
    {
      "id": "conn5",
      "from_id": "c2",
      "to_id": "c6",
      "label": {
        "text": "logprob^A",
        "position": "middle_above",
        "text_color": "#666666"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#D28B4C",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "small"
      }
    },
    {
      "id": "conn6",
      "from_id": "c6",
      "to_id": "op1",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#7CA6C7",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "none",
        "size": "small"
      }
    },
    {
      "id": "conn7",
      "from_id": "c7",
      "to_id": "op1",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#B36B8B",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "none",
        "size": "small"
      }
    },
    {
      "id": "conn8",
      "from_id": "op1",
      "to_id": "op2",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#A6A6A6",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "none",
        "size": "small"
      }
    },
    {
      "id": "conn9",
      "from_id": "c4",
      "to_id": "c8",
      "label": {
        "text": "Data Flow Graph (DFG)",
        "position": "middle_above",
        "text_color": "#666666"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#D6C96B",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "small"
      }
    },
    {
      "id": "conn10",
      "from_id": "c4",
      "to_id": "c9",
      "label": {
        "text": "Abstract Syntax Tree (AST)",
        "position": "middle_above",
        "text_color": "#666666"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#7BC77B",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "small"
      }
    },
    {
      "id": "conn11",
      "from_id": "c5",
      "to_id": "c8",
      "label": {
        "text": "Data Flow Graph (DFG)",
        "position": "end",
        "text_color": "#666666"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#D6C96B",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "small"
      }
    },
    {
      "id": "conn12",
      "from_id": "c5",
      "to_id": "c9",
      "label": {
        "text": "Abstract Syntax Tree (AST)",
        "position": "end",
        "text_color": "#666666"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#7BC77B",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "small"
      }
    },
    {
      "id": "conn13",
      "from_id": "c8",
      "to_id": "op2",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#D6C96B",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "none",
        "size": "small"
      }
    },
    {
      "id": "conn14",
      "from_id": "c9",
      "to_id": "op2",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#7BC77B",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "none",
        "size": "small"
      }
    },
    {
      "id": "conn15",
      "from_id": "op2",
      "to_id": "op3",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#A6A6A6",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "none",
        "size": "small"
      }
    },
    {
      "id": "conn16",
      "from_id": "op3",
      "to_id": "c10",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#A6A6A6",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "small"
      }
    },
    {
      "id": "conn17",
      "from_id": "c10",
      "to_id": "c11",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#A6A6A6",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "small"
      }
    },
    {
      "id": "conn18",
      "from_id": "c11",
      "to_id": "c2",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#A6A6A6",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "small"
      }
    },
    {
      "id": "conn19",
      "from_id": "c7",
      "to_id": "op3",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#B36B8B",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "none",
        "size": "small"
      }
    }
  ],
  "layout_constraints": [
    {
      "type": "relative_arrangement",
      "element_ids": [
        "c1",
        "c2",
        "c4"
      ],
      "description": "Left-to-right horizontal sequence: Source Code → Policy Pre-trained Model (Actor) → Active Translated Code"
    },
    {
      "type": "relative_arrangement",
      "element_ids": [
        "c1",
        "c3"
      ],
      "description": "Source Code branches upward to Reference Pre-trained Model (Critic)"
    },
    {
      "type": "relative_arrangement",
      "element_ids": [
        "c4",
        "c5"
      ],
      "description": "Active Translated Code and Compliable Reference Target Code are horizontally aligned"
    },
    {
      "type": "containment",
      "container_id": "g1",
      "element_ids": [
        "c6"
      ],
      "padding": "medium"
    },
    {
      "type": "containment",
      "container_id": "g2",
      "element_ids": [
        "c7"
      ],
      "padding": "medium"
    },
    {
      "type": "containment",
      "container_id": "g3",
      "element_ids": [
        "c8",
        "c9",
        "op2"
      ],
      "padding": "medium"
    },
    {
      "type": "alignment",
      "alignment_type": "horizontal_center",
      "element_ids": [
        "c6",
        "c7",
        "op1"
      ]
    },
    {
      "type": "alignment",
      "alignment_type": "horizontal_center",
      "element_ids": [
        "c8",
        "c9",
        "op2"
      ]
    },
    {
      "type": "alignment",
      "alignment_type": "horizontal_center",
      "element_ids": [
        "c10",
        "c11"
      ]
    },
    {
      "type": "distribution",
      "distribution_type": "horizontal_equal_spacing",
      "element_ids": [
        "c1",
        "c2",
        "c4",
        "c5"
      ]
    }
  ]
}