{
  "algo_name": "proximal_gradient_descent",
  "problem_type": "composite_convex_minimization",
  "obj_tag": "h=f+g",
  "params_json": "{\"L\": 1, \"R\": 1}",
  "performance_metric": "h(x_N) - h(x_star)",
  "initial_condition": "||x_0 - x_star||^2 <= R^2",
  "conjectured_rate": "L * R^2 / (4 * N)",
  "setup_file": "examples/proximal_gradient_descent/proximal_gradient_descent_setup.py",
  "sweep_results": [
    {
      "N": 1,
      "opt_value": 0.24998476565221175,
      "expected": 0.25
    },
    {
      "N": 2,
      "opt_value": 0.1250001921749428,
      "expected": 0.125
    },
    {
      "N": 3,
      "opt_value": 0.08332796104103286,
      "expected": 0.08333333333333333
    },
    {
      "N": 4,
      "opt_value": 0.06249988977748486,
      "expected": 0.0625
    },
    {
      "N": 5,
      "opt_value": 0.049994914582988104,
      "expected": 0.05
    },
    {
      "N": 6,
      "opt_value": 0.041663383690341255,
      "expected": 0.041666666666666664
    },
    {
      "N": 7,
      "opt_value": 0.03571110091014559,
      "expected": 0.03571428571428571
    }
  ],
  "N_verify": 4,
  "rate_note": "For L=R=1, opt_value matches 1/(4N) within solver tolerance. Scaling gives L R^2/(4N).",
  "composite_note": "get_pep_setup returns f for pep_runner multiplier extraction; the performance metric is still h(x_N)-h(x_star), and g is available as a module-level object."
}
