{
  "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.",
  "opt_value": 0.06250824514463979,
  "tau_sol": 0.0625001152798159,
  "relaxed_constraints": [
    "f:x_0,x_0",
    "f:x_0,x_2",
    "f:x_0,x_3",
    "f:x_0,x_4",
    "f:x_0,x_star",
    "f:x_1,x_0",
    "f:x_1,x_1",
    "f:x_1,x_3",
    "f:x_1,x_4",
    "f:x_1,x_star",
    "f:x_2,x_0",
    "f:x_2,x_1",
    "f:x_2,x_2",
    "f:x_2,x_4",
    "f:x_2,x_star",
    "f:x_3,x_0",
    "f:x_3,x_1",
    "f:x_3,x_2",
    "f:x_3,x_3",
    "f:x_3,x_star",
    "f:x_4,x_0",
    "f:x_4,x_1",
    "f:x_4,x_2",
    "f:x_4,x_3",
    "f:x_4,x_4",
    "f:x_4,x_star",
    "g:x_1,x_1",
    "g:x_1,x_3",
    "g:x_1,x_4",
    "g:x_1,x_star",
    "g:x_2,x_1",
    "g:x_2,x_2",
    "g:x_2,x_4",
    "g:x_2,x_star",
    "g:x_3,x_1",
    "g:x_3,x_2",
    "g:x_3,x_3",
    "g:x_3,x_star",
    "g:x_4,x_1",
    "g:x_4,x_2",
    "g:x_4,x_3",
    "g:x_4,x_4",
    "g:x_4,x_star"
  ],
  "relaxation_type": "structural-relaxed",
  "sparsity_tolerance": 1e-05,
  "f_lambda_row_names": [
    "x_0",
    "x_1",
    "x_2",
    "x_3",
    "x_4",
    "x_star"
  ],
  "f_lambda_col_names": [
    "x_0",
    "x_1",
    "x_2",
    "x_3",
    "x_4",
    "x_star"
  ],
  "f_lambda_matrix": [
    [
      0.0,
      0.1250007913491814,
      0.0,
      0.0,
      0.0,
      0.0
    ],
    [
      0.0,
      0.0,
      0.28570370863093464,
      0.0,
      0.0,
      0.0
    ],
    [
      0.0,
      0.0,
      0.0,
      0.4999405697490669,
      0.0,
      0.0
    ],
    [
      0.0,
      0.0,
      0.0,
      0.0,
      0.7998992084770675,
      0.0
    ],
    [
      0.0,
      0.0,
      0.0,
      0.0,
      0.0,
      0.0
    ],
    [
      0.12500079134801778,
      0.16070291728082267,
      0.214236861117968,
      0.2999586387291828,
      0.20010079152359092,
      0.0
    ]
  ],
  "g_lambda_row_names": [
    "x_1",
    "x_2",
    "x_3",
    "x_4",
    "x_star"
  ],
  "g_lambda_col_names": [
    "x_1",
    "x_2",
    "x_3",
    "x_4",
    "x_star"
  ],
  "g_lambda_matrix": [
    [
      0.0,
      0.14285509437527366,
      0.0,
      0.0,
      0.0
    ],
    [
      0.0,
      0.0,
      0.3333082288634107,
      0.0,
      0.0
    ],
    [
      0.0,
      0.0,
      0.0,
      0.5998884368751854,
      0.0
    ],
    [
      0.0,
      0.0,
      0.0,
      0.0,
      0.0
    ],
    [
      0.14285509437383903,
      0.19045313448740026,
      0.2665802080131556,
      0.40011156312546525,
      0.0
    ]
  ],
  "lambda_matrix": [
    [
      0.0,
      0.1250007913491814,
      0.0,
      0.0,
      0.0,
      0.0
    ],
    [
      0.0,
      0.0,
      0.28570370863093464,
      0.0,
      0.0,
      0.0
    ],
    [
      0.0,
      0.0,
      0.0,
      0.4999405697490669,
      0.0,
      0.0
    ],
    [
      0.0,
      0.0,
      0.0,
      0.0,
      0.7998992084770675,
      0.0
    ],
    [
      0.0,
      0.0,
      0.0,
      0.0,
      0.0,
      0.0
    ],
    [
      0.12500079134801778,
      0.16070291728082267,
      0.214236861117968,
      0.2999586387291828,
      0.20010079152359092,
      0.0
    ]
  ],
  "lambda_row_names": [
    "x_0",
    "x_1",
    "x_2",
    "x_3",
    "x_4",
    "x_star"
  ],
  "lambda_col_names": [
    "x_0",
    "x_1",
    "x_2",
    "x_3",
    "x_4",
    "x_star"
  ],
  "S_matrix": [
    [
      0.06249948545478952,
      -0.06249948545478998,
      4.2913943288778364e-07,
      -0.062499239871493084,
      -0.07142590898983944,
      -0.0803503770714288,
      -0.09522450280708576,
      -0.10711676904896586,
      -0.1332872666630385,
      -0.14997772952571464,
      -0.20006039881243723,
      -0.10005439089277479
    ],
    [
      -0.06249948545478998,
      0.06249948545479002,
      -4.2913943291731444e-07,
      0.06249923987149304,
      0.07142590898983944,
      0.08035037707142874,
      0.09522450280708562,
      0.10711676904896583,
      0.13328726666303847,
      0.14997772952571456,
      0.20006039881243726,
      0.10005439089277485
    ],
    [
      4.2913943288778364e-07,
      -4.2913943291731444e-07,
      0.5000000921151618,
      -0.06250023090986288,
      2.3760146762689063e-07,
      -0.08035130130044886,
      2.8021825465801593e-07,
      -0.10711821523837402,
      3.5748686595745276e-07,
      -0.14997911120339721,
      -3.878092972413161e-07,
      -0.10005074596837749
    ],
    [
      -0.062499239871493084,
      0.06249923987149304,
      -0.06250023090986288,
      0.12500102873321517,
      0.07142789372814863,
      0.08035168859982103,
      0.0952269563897556,
      0.10711871847738541,
      0.13329057038612174,
      0.1499796001352183,
      0.20005550291158114,
      0.10005011837357032
    ],
    [
      -0.07142590898983944,
      0.07142590898983944,
      2.3760146762689063e-07,
      0.07142789372814863,
      0.14285559988035187,
      0.14285218971806599,
      0.09522713666205035,
      0.10711885290760337,
      0.133290789285445,
      0.14997973098948544,
      0.20005534920592744,
      0.10004997007991662
    ],
    [
      -0.0803503770714288,
      0.08035037707142874,
      -0.08035130130044886,
      0.08035168859982103,
      0.14285218971806599,
      0.2857039311652102,
      0.1666544924381774,
      0.10711871105181849,
      0.1332905592463347,
      0.14997959270884456,
      0.20005549178450432,
      0.10005011095568637
    ],
    [
      -0.09522450280708576,
      0.09522450280708562,
      2.8021825465801593e-07,
      0.0952269563897556,
      0.09522713666205035,
      0.1666544924381774,
      0.3333088621888907,
      0.24997074981776277,
      0.13329085317724554,
      0.14997977359049938,
      0.20005541320639822,
      0.10005001276828199
    ],
    [
      -0.10711676904896586,
      0.10711676904896583,
      -0.10711821523837402,
      0.10711871847738541,
      0.10711885290760337,
      0.10711871105181849,
      0.24997074981776277,
      0.4999409081832833,
      0.29994476058743724,
      0.14997965065942606,
      0.20005557889714756,
      0.10005016906669804
    ],
    [
      -0.1332872666630385,
      0.13328726666303847,
      3.5748686595745276e-07,
      0.13329057038612174,
      0.133290789285445,
      0.1332905592463347,
      0.13329085317724554,
      0.29994476058743724,
      0.5998893018498194,
      0.39995013568371124,
      0.20005552934297155,
      0.10005009024835933
    ],
    [
      -0.14997772952571464,
      0.14997772952571456,
      -0.14997911120339721,
      0.1499796001352183,
      0.14997973098948544,
      0.14997959270884456,
      0.14997977359049938,
      0.14997965065942606,
      0.39995013568371124,
      0.7998995326312551,
      0.49999978651358273,
      0.10005016183680197
    ],
    [
      -0.20006039881243723,
      0.20006039881243726,
      -3.878092972413161e-07,
      0.20005550291158114,
      0.20005534920592744,
      0.20005549178450432,
      0.20005541320639822,
      0.20005557889714756,
      0.20005552934297155,
      0.49999978651358273,
      0.9999986281155782,
      0.4999989475992635
    ],
    [
      -0.10005439089277479,
      0.10005439089277485,
      -0.10005074596837749,
      0.10005011837357032,
      0.10004997007991662,
      0.10005011095568637,
      0.10005001276828199,
      0.10005016906669804,
      0.10005009024835933,
      0.10005016183680197,
      0.4999989475992635,
      0.4999992064536009
    ]
  ],
  "S_row_names": [
    "x_0",
    "x_star",
    "grad_f(x_star)",
    "grad_f(x_0)",
    "grad_g(x_1)",
    "grad_f(x_1)",
    "grad_g(x_2)",
    "grad_f(x_2)",
    "grad_g(x_3)",
    "grad_f(x_3)",
    "grad_g(x_4)",
    "grad_f(x_4)"
  ],
  "S_col_names": [
    "x_0",
    "x_star",
    "grad_f(x_star)",
    "grad_f(x_0)",
    "grad_g(x_1)",
    "grad_f(x_1)",
    "grad_g(x_2)",
    "grad_f(x_2)",
    "grad_g(x_3)",
    "grad_f(x_3)",
    "grad_g(x_4)",
    "grad_f(x_4)"
  ],
  "basis_vectors": [
    "x_0",
    "x_star",
    "grad_f(x_star)",
    "grad_f(x_0)",
    "grad_g(x_1)",
    "grad_f(x_1)",
    "grad_g(x_2)",
    "grad_f(x_2)",
    "grad_g(x_3)",
    "grad_f(x_3)",
    "grad_g(x_4)",
    "grad_f(x_4)"
  ],
  "lamb_code": "def lamb(tag_i, tag_j, N=N_int):\n    i = tag_to_index(tag_i, N)\n    j = tag_to_index(tag_j, N)\n    if i == N + 1:\n        if j == 0:\n            return lamb(\"x_0\", \"x_1\", N)\n        if j < N:\n            return lamb(f\"x_{j}\", f\"x_{j + 1}\", N) - lamb(f\"x_{j - 1}\", f\"x_{j}\", N)\n        if j == N:\n            return 1 - lamb(f\"x_{N - 1}\", f\"x_{N}\", N)\n    if i < N and i + 1 == j:\n        return sp.Rational(j, 2 * N + 1 - j)\n    return sp.S(0)\n",
  "gamm_code": "def gamm(tag_i, tag_j, N=N_int):\n    i = tag_to_index(tag_i, N)\n    j = tag_to_index(tag_j, N)\n    if i == N + 1 and 1 <= j <= N:\n        return sp.Rational(2 * N, (2 * N + 1 - j) * (2 * N - j))\n    if i < N and i + 1 == j:\n        return sp.Rational(j - 1, 2 * N + 1 - j)\n    return sp.S(0)\n",
  "S_code": "S_guess = S_guess1 + S_guess2 + S_guess3, where\nS_guess1 = sum_{i=1}^N N/((2N+1-i)(2N-i)L) * || i/(2N) grad f(x_i) + (2N-i)/(2N) grad f(x_{i-1}) - grad f(x_star) ||^2\nS_guess2 = sum_{i=1}^N ((i-1)/(2N-i)*(2N+2)/(2N+1) + 2N/((2N+1)(2N-i)^2))/(2L) * || grad f(x_{i-1}) + grad g(x_i) - L/(2N+1-i)*(x_{i-1}-x_star) ||^2\nS_guess3 = sum_{i=1}^N i/(2N+1-i)*2N/(2N+1)/(2L) * || (2N+1)/(2N)*(grad f(x_i)+grad g(x_i)) - 1/(2N)*(grad f(x_{i-1})+grad g(x_i)) - L/(2N-i)*(x_i-x_star) ||^2\n",
  "S_decomp_type": "three_square_sum",
  "closed_form_match_tolerance": 0.0002,
  "lambda_closed_form_matches": true,
  "gamma_closed_form_matches": true,
  "S_closed_form_matches": true,
  "proof_valid": true,
  "proof_residual_max_abs": 1.1102230246251565e-16,
  "S_residual_max_abs": 0.00011069815018049933,
  "lambda_residual_max_abs": 0.00010079152359090959,
  "gamma_residual_max_abs": 0.0001115631254652305,
  "rank_tolerance": 0.0001,
  "rank_profile": [
    0,
    4,
    4,
    4,
    1
  ],
  "lyap_inner_prod_coords": [
    [
      [
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ]
    ],
    [
      [
        -0.0012755102040816326,
        0.0012755102040816326,
        0.0,
        -0.061224489795918366,
        -0.061224489795918366,
        0.008928571428571426,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0012755102040816326,
        -0.0012755102040816326,
        0.0,
        0.061224489795918366,
        0.061224489795918366,
        -0.008928571428571426,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        -0.008928571428571425,
        0.0,
        0.0,
        0.008928571428571428,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        -0.061224489795918366,
        0.061224489795918366,
        0.0,
        0.061224489795918366,
        0.061224489795918366,
        -0.008928571428571428,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        -0.061224489795918366,
        0.061224489795918366,
        0.0,
        0.061224489795918366,
        0.061224489795918366,
        -0.00892857142857141,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.008928571428571426,
        -0.008928571428571426,
        0.008928571428571428,
        -0.008928571428571428,
        -0.00892857142857141,
        -0.008928571428571425,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ]
    ],
    [
      [
        -0.006944444444444444,
        0.006944444444444444,
        0.0,
        -0.05555555555555555,
        -0.05555555555555555,
        -0.055555555555555566,
        -0.05555555555555555,
        0.023809523809523808,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.006944444444444444,
        -0.006944444444444444,
        0.0,
        0.05555555555555555,
        0.05555555555555555,
        0.055555555555555566,
        0.05555555555555555,
        -0.023809523809523808,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        -0.023809523809523794,
        0.0,
        0.0,
        -1.3877787807814457e-17,
        0.0,
        0.023809523809523808,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        -0.05555555555555555,
        0.05555555555555555,
        0.0,
        0.05555555555555555,
        0.05555555555555555,
        0.055555555555555566,
        0.05555555555555555,
        -0.023809523809523808,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        -0.05555555555555555,
        0.05555555555555555,
        0.0,
        0.05555555555555555,
        0.05555555555555555,
        0.05555555555555558,
        0.05555555555555555,
        -0.023809523809523808,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        -0.055555555555555566,
        0.055555555555555566,
        -1.3877787807814457e-17,
        0.055555555555555566,
        0.05555555555555558,
        0.05555555555555558,
        0.05555555555555555,
        -0.023809523809523808,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        -0.05555555555555555,
        0.05555555555555555,
        0.0,
        0.05555555555555555,
        0.05555555555555555,
        0.05555555555555555,
        0.055555555555555525,
        -0.023809523809523808,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.023809523809523808,
        -0.023809523809523808,
        0.023809523809523808,
        -0.023809523809523808,
        -0.023809523809523808,
        -0.023809523809523808,
        -0.023809523809523808,
        -0.023809523809523808,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ]
    ],
    [
      [
        -0.0225,
        0.0225,
        0.0,
        -0.039999999999999994,
        -0.039999999999999994,
        -0.04000000000000001,
        -0.039999999999999994,
        -0.04,
        -0.04000000000000001,
        0.049999999999999996,
        0.0,
        0.0
      ],
      [
        0.0225,
        -0.0225,
        0.0,
        0.039999999999999994,
        0.039999999999999994,
        0.04000000000000001,
        0.039999999999999994,
        0.04,
        0.04000000000000001,
        -0.049999999999999996,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        -0.04999999999999999,
        0.0,
        0.0,
        -1.3877787807814457e-17,
        0.0,
        0.0,
        0.0,
        0.05,
        0.0,
        0.0
      ],
      [
        -0.039999999999999994,
        0.039999999999999994,
        0.0,
        0.039999999999999994,
        0.039999999999999994,
        0.04000000000000001,
        0.039999999999999994,
        0.04,
        0.04000000000000001,
        -0.049999999999999996,
        0.0,
        0.0
      ],
      [
        -0.039999999999999994,
        0.039999999999999994,
        0.0,
        0.039999999999999994,
        0.039999999999999994,
        0.04000000000000002,
        0.039999999999999994,
        0.04,
        0.04000000000000001,
        -0.049999999999999996,
        0.0,
        0.0
      ],
      [
        -0.04000000000000001,
        0.04000000000000001,
        -1.3877787807814457e-17,
        0.04000000000000001,
        0.04000000000000002,
        0.04000000000000002,
        0.039999999999999994,
        0.04,
        0.04000000000000001,
        -0.049999999999999996,
        0.0,
        0.0
      ],
      [
        -0.039999999999999994,
        0.039999999999999994,
        0.0,
        0.039999999999999994,
        0.039999999999999994,
        0.039999999999999994,
        0.039999999999999966,
        0.04,
        0.04000000000000001,
        -0.049999999999999996,
        0.0,
        0.0
      ],
      [
        -0.04,
        0.04,
        0.0,
        0.04,
        0.04,
        0.04,
        0.04,
        0.040000000000000036,
        0.03999999999999998,
        -0.05,
        0.0,
        0.0
      ],
      [
        -0.04000000000000001,
        0.04000000000000001,
        0.0,
        0.04000000000000001,
        0.04000000000000001,
        0.04000000000000001,
        0.04000000000000001,
        0.03999999999999998,
        0.040000000000000036,
        -0.04999999999999993,
        0.0,
        0.0
      ],
      [
        0.049999999999999996,
        -0.049999999999999996,
        0.05,
        -0.049999999999999996,
        -0.049999999999999996,
        -0.049999999999999996,
        -0.049999999999999996,
        -0.05,
        -0.04999999999999993,
        -0.04999999999999999,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ]
    ],
    [
      [
        -0.0625,
        0.0625,
        0.0,
        1.3877787807814457e-17,
        1.3877787807814457e-17,
        0.0,
        1.3877787807814457e-17,
        6.938893903907228e-18,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0625,
        -0.0625,
        0.0,
        -1.3877787807814457e-17,
        -1.3877787807814457e-17,
        0.0,
        -1.3877787807814457e-17,
        -6.938893903907228e-18,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        -1.3877787807814457e-17,
        0.0,
        0.0,
        0.0,
        1.3877787807814457e-17,
        0.0,
        0.0
      ],
      [
        1.3877787807814457e-17,
        -1.3877787807814457e-17,
        0.0,
        -1.3877787807814457e-17,
        -1.3877787807814457e-17,
        0.0,
        -1.3877787807814457e-17,
        -6.938893903907228e-18,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        1.3877787807814457e-17,
        -1.3877787807814457e-17,
        0.0,
        -1.3877787807814457e-17,
        -1.3877787807814457e-17,
        1.3877787807814457e-17,
        -1.3877787807814457e-17,
        -6.938893903907228e-18,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        -1.3877787807814457e-17,
        0.0,
        1.3877787807814457e-17,
        1.3877787807814457e-17,
        -1.3877787807814457e-17,
        -6.938893903907228e-18,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        1.3877787807814457e-17,
        -1.3877787807814457e-17,
        0.0,
        -1.3877787807814457e-17,
        -1.3877787807814457e-17,
        -1.3877787807814457e-17,
        -4.163336342344337e-17,
        -6.938893903907228e-18,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        6.938893903907228e-18,
        -6.938893903907228e-18,
        0.0,
        -6.938893903907228e-18,
        -6.938893903907228e-18,
        -6.938893903907228e-18,
        -6.938893903907228e-18,
        2.7755575615628914e-17,
        -2.7755575615628914e-17,
        -1.3877787807814457e-17,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        -2.7755575615628914e-17,
        2.7755575615628914e-17,
        5.551115123125783e-17,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        1.3877787807814457e-17,
        0.0,
        0.0,
        0.0,
        0.0,
        -1.3877787807814457e-17,
        5.551115123125783e-17,
        5.551115123125783e-17,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ]
    ]
  ],
  "lyap_func_coords": [
    [
      0.0,
      0.0,
      0.0,
      0.0,
      0.0,
      0.0,
      0.0,
      0.0,
      0.0,
      0.0,
      0.0
    ],
    [
      -0.125,
      -0.14285714285714285,
      0.0,
      0.14285714285714285,
      0.125,
      0.0,
      0.0,
      0.0,
      0.0,
      0.0,
      0.0
    ],
    [
      -0.2857142857142857,
      -0.3333333333333333,
      0.0,
      0.0,
      0.0,
      0.3333333333333333,
      0.2857142857142857,
      0.0,
      0.0,
      0.0,
      0.0
    ],
    [
      -0.5,
      -0.6,
      0.0,
      0.0,
      0.0,
      0.0,
      0.0,
      0.6,
      0.5,
      0.0,
      0.0
    ],
    [
      -1.0,
      -1.0,
      0.0,
      0.0,
      0.0,
      0.0,
      0.0,
      0.0,
      0.0,
      1.0,
      1.0
    ]
  ],
  "grouping_code": "lyap = [pf.Scalar.zero()]\npartial_sum = pf.Scalar.zero()\ns_terms = build_s_terms(ctx, f, g, N_int)\n\nfor step in range(N_int):\n    next_idx = step + 1\n\n    coeff = lamb(\"x_star\", f\"x_{step}\", N_int)\n    if coeff != 0:\n        partial_sum += coeff * f.interp_ineq(\"x_star\", f\"x_{step}\", pep_context=ctx)\n\n    coeff = lamb(f\"x_{step}\", f\"x_{next_idx}\", N_int)\n    if coeff != 0:\n        partial_sum += coeff * f.interp_ineq(\n            f\"x_{step}\", f\"x_{next_idx}\", pep_context=ctx\n        )\n\n    coeff = gamm(f\"x_{step}\", f\"x_{next_idx}\", N_int)\n    if coeff != 0:\n        partial_sum += coeff * g.interp_ineq(\n            f\"x_{step}\", f\"x_{next_idx}\", pep_context=ctx\n        )\n\n    coeff = gamm(\"x_star\", f\"x_{next_idx}\", N_int)\n    if coeff != 0:\n        partial_sum += coeff * g.interp_ineq(\"x_star\", f\"x_{next_idx}\", pep_context=ctx)\n\n    if step == N_int - 1:\n        coeff = lamb(\"x_star\", f\"x_{N_int}\", N_int)\n        if coeff != 0:\n            partial_sum += coeff * f.interp_ineq(\n                \"x_star\", f\"x_{N_int}\", pep_context=ctx\n            )\n\n    partial_sum -= s_terms[next_idx]\n    lyap.append(partial_sum)\n",
  "grouping_description": "Forward PGM partial sums: at step k add f-star(x_k), f(x_k,x_{k+1}), g(x_k,x_{k+1}) when nonzero, g-star(x_{k+1}), subtract S_{k+1}; at the final step also add f-star(x_N).",
  "extra_duals": {},
  "coverage_identity": "lyap[N] == h(x_N)-h(x_star)-1/(4N)||x_0-x_star||^2",
  "coverage_inner_residual_max_abs": 5.551115123125783e-17,
  "coverage_func_residual_max_abs": 0.0,
  "coverage_rank": 1,
  "interior_rank_constant": true,
  "S_terms_description": "S_i = S_guess1_i + S_guess2_i + S_guess3_i from Block 2 three-square decomposition.",
  "block3_scope": "lyap-define Block 3 for PGM from local Block 2 closed-form certificate.",
  "basis_templates": [
    "interior: [x_0-x_star, x_k-x_star, grad_f(x_k), grad_f(x_star)]",
    "terminal: [x_0-x_star]"
  ],
  "basis_code": "def V_k_basis(k):\n    if k == 0:\n        return []\n    if k < N_int:\n        return [\n            ctx[\"x_0\"] - ctx[\"x_star\"],\n            ctx[f\"x_{k}\"] - ctx[\"x_star\"],\n            f.grad(ctx[f\"x_{k}\"]),\n            f.grad(ctx[\"x_star\"]),\n        ]\n    return [ctx[\"x_0\"] - ctx[\"x_star\"]]\n\n\ndef V_k_basis_labels(k):\n    if k == 0:\n        return []\n    if k < N_int:\n        return [\"x_0-x_star\", f\"x_{k}-x_star\", f\"grad_f(x_{k})\", \"grad_f(x_star)\"]\n    return [\"x_0-x_star\"]\n",
  "coeff_code": "def coeff_pattern(k, N):\n    if k == 0:\n        return np.zeros((0, 0))\n    if k == N:\n        return np.array([[-float(sp.Rational(1, 4 * N))]])\n    C = np.zeros((4, 4), dtype=float)\n    A = float(sp.Rational(N - k, (2 * N - k) ** 2))\n    B = float(sp.Rational(k, 2 * (2 * N - k) * (2 * N - k + 1)))\n    C[0, 0] = -float(sp.Rational(1, 4 * N))\n    C[1, 1] = A\n    C[1, 2] = C[2, 1] = B\n    C[2, 2] = -B\n    C[2, 3] = C[3, 2] = B\n    C[3, 3] = -B\n    return C\n",
  "basis_by_k": {
    "1": [
      "x_0-x_star",
      "x_1-x_star",
      "grad_f(x_1)",
      "grad_f(x_star)"
    ],
    "2": [
      "x_0-x_star",
      "x_2-x_star",
      "grad_f(x_2)",
      "grad_f(x_star)"
    ],
    "3": [
      "x_0-x_star",
      "x_3-x_star",
      "grad_f(x_3)",
      "grad_f(x_star)"
    ],
    "4": [
      "x_0-x_star"
    ]
  },
  "basis_labels_by_k": {
    "1": [
      "x_0-x_star",
      "x_1-x_star",
      "grad_f(x_1)",
      "grad_f(x_star)"
    ],
    "2": [
      "x_0-x_star",
      "x_2-x_star",
      "grad_f(x_2)",
      "grad_f(x_star)"
    ],
    "3": [
      "x_0-x_star",
      "x_3-x_star",
      "grad_f(x_3)",
      "grad_f(x_star)"
    ],
    "4": [
      "x_0-x_star"
    ]
  },
  "candidate_scan": {
    "1": [
      "x_0-x_star",
      "x_1-x_star",
      "grad_f(x_1)",
      "grad_f(x_star)"
    ],
    "2": [
      "x_0-x_star",
      "x_2-x_star",
      "grad_f(x_2)",
      "grad_f(x_star)"
    ],
    "3": [
      "x_0-x_star",
      "x_3-x_star",
      "grad_f(x_3)",
      "grad_f(x_star)"
    ]
  },
  "independence_ranks": {
    "1": 4,
    "2": 4,
    "3": 4,
    "4": 1
  },
  "coeff_by_k": {
    "1": [
      [
        -0.062499999999999965,
        -6.938893903907228e-18,
        6.938893903907228e-18,
        0.0
      ],
      [
        -6.938893903907228e-18,
        0.06122448979591835,
        0.00892857142857142,
        0.0
      ],
      [
        6.938893903907228e-18,
        0.00892857142857142,
        -0.008928571428571425,
        0.008928571428571426
      ],
      [
        0.0,
        0.0,
        0.008928571428571426,
        -0.008928571428571425
      ]
    ],
    "2": [
      [
        -0.06250000000000001,
        -1.734723475976807e-17,
        -6.938893903907228e-18,
        -2.4532694666933983e-18
      ],
      [
        -1.734723475976807e-17,
        0.055555555555555594,
        0.02380952380952381,
        2.4532694666933975e-18
      ],
      [
        -6.938893903907228e-18,
        0.02380952380952381,
        -0.023809523809523808,
        0.023809523809523808
      ],
      [
        -2.4532694666933983e-18,
        2.4532694666933975e-18,
        0.023809523809523808,
        -0.02380952380952379
      ]
    ],
    "3": [
      [
        -0.06249999999999998,
        -3.469446951953614e-18,
        6.938893903907228e-18,
        -4.006172263299092e-18
      ],
      [
        -3.469446951953614e-18,
        0.03999999999999999,
        0.049999999999999975,
        4.006172263299091e-18
      ],
      [
        6.938893903907228e-18,
        0.049999999999999975,
        -0.04999999999999999,
        0.049999999999999996
      ],
      [
        -4.006172263299092e-18,
        4.006172263299091e-18,
        0.049999999999999996,
        -0.04999999999999999
      ]
    ],
    "4": [
      [
        -0.0625
      ]
    ]
  },
  "coeff_pattern_by_k": {
    "1": [
      [
        -0.0625,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        0.061224489795918366,
        0.008928571428571428,
        0.0
      ],
      [
        0.0,
        0.008928571428571428,
        -0.008928571428571428,
        0.008928571428571428
      ],
      [
        0.0,
        0.0,
        0.008928571428571428,
        -0.008928571428571428
      ]
    ],
    "2": [
      [
        -0.0625,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        0.05555555555555555,
        0.023809523809523808,
        0.0
      ],
      [
        0.0,
        0.023809523809523808,
        -0.023809523809523808,
        0.023809523809523808
      ],
      [
        0.0,
        0.0,
        0.023809523809523808,
        -0.023809523809523808
      ]
    ],
    "3": [
      [
        -0.0625,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        0.04,
        0.05,
        0.0
      ],
      [
        0.0,
        0.05,
        -0.05,
        0.05
      ],
      [
        0.0,
        0.0,
        0.05,
        -0.05
      ]
    ],
    "4": [
      [
        -0.0625
      ]
    ]
  },
  "coefficient_pattern_description": "For 1<=k<N, with basis [a,b,c,d]=[x0-x*, xk-x*, grad f(xk), grad f(x*)], C00=-1/(4N), C11=(N-k)/(2N-k)^2, B=k/(2(2N-k)(2N-k+1)), C12=C21=B, C22=-B, C23=C32=B, C33=-B.",
  "coefficient_pattern_residual_max_abs": 4.163336342344337e-17,
  "coefficient_pattern_residuals": {
    "1": 3.469446951953614e-17,
    "2": 4.163336342344337e-17,
    "3": 2.7755575615628914e-17,
    "4": 0.0
  },
  "block4_scope": "lyap-vectors Block 4 for PGM from local Block 3 partial sums.",
  "closed_form_rate": "L * R^2 / (4 * N)",
  "closed_form_lyapunov": "For \\(1\\le k<N\\), define\n\\[\n\\alpha_k=\\frac{k}{2N-k+1},\\qquad\n\\beta_k=\\frac{k}{2N-k},\\qquad\nB_k=\\frac{k}{2(2N-k)(2N-k+1)}.\n\\]\nThe recovered partial-sum Lyapunov certificate is\n\\[\n\\begin{aligned}\nV_k={}&\n\\alpha_k\\bigl(f(x_k)-f(x_0)\\bigr)\n+\\beta_k g(x_k)-\\beta_k g(x_1) \\\\\n&-\\frac{L}{4N}\\|x_0-x_\\star\\|^2\n+L\\frac{N-k}{(2N-k)^2}\\|x_k-x_\\star\\|^2\\\\\n&+2B_k\\langle x_k-x_\\star,\\nabla f(x_k)\\rangle\n-\\frac{B_k}{L}\\|\\nabla f(x_k)\\|^2\n+\\frac{2B_k}{L}\\langle \\nabla f(x_k),\\nabla f(x_\\star)\\rangle\n-\\frac{B_k}{L}\\|\\nabla f(x_\\star)\\|^2.\n\\end{aligned}\n\\]\nAt the terminal point,\n\\[\nV_N=(f+g)(x_N)-(f+g)(x_\\star)-\\frac{L}{4N}\\|x_0-x_\\star\\|^2.\n\\]",
  "theorem_latex": "Let \\(f\\) be convex and \\(L\\)-smooth, let \\(g\\) be closed, proper, and convex, and let \\(x_\\star\\in\\arg\\min (f+g)\\). If\n\\[\nx_{k+1}=\\operatorname{prox}_{g/L}\\left(x_k-\\frac{1}{L}\\nabla f(x_k)\\right),\n\\qquad \\|x_0-x_\\star\\|^2\\le R^2,\n\\]\nthen for every \\(N\\ge1\\),\n\\[\n(f+g)(x_N)-(f+g)(x_\\star)\\le \\frac{L R^2}{4N}.\n\\]",
  "proof_outline_latex": "Let \\(I_f(u,v)\\) denote the smooth-convex interpolation residual for \\(f\\), and \\(I_g(u,v)\\) the convex interpolation residual for \\(g\\). These residuals are nonpositive under the PEPFlow convention. Let \\(S_i\\) be the \\(i\\)-th nonnegative square contribution from the three-square decomposition of the Gram certificate.\n\nThe Block 3 partial sums verify, for \\(k=0,\\ldots,N-1\\),\n\\[\n\\begin{aligned}\nV_{k+1}-V_k={}&\n\\lambda_{\\star,k} I_f(x_\\star,x_k)\n+\\lambda_{k,k+1}I_f(x_k,x_{k+1})\n+\\gamma_{k,k+1}I_g(x_k,x_{k+1})\\\\\n&+\\gamma_{\\star,k+1}I_g(x_\\star,x_{k+1})\n-S_{k+1},\n\\end{aligned}\n\\]\nwith the additional terminal residual \\(\\lambda_{\\star,N}I_f(x_\\star,x_N)\\) included at the final step. All \\(\\lambda,\\gamma\\) coefficients are nonnegative and \\(S_i\\ge0\\), hence \\(V_N\\le V_0=0\\). The boundary identity is exactly\n\\[\nV_N=(f+g)(x_N)-(f+g)(x_\\star)-\\frac{L}{4N}\\|x_0-x_\\star\\|^2.\n\\]\nTogether with \\(\\|x_0-x_\\star\\|^2\\le R^2\\), this gives the claimed rate.",
  "symbolic_step_identity": "V_{k+1}-V_k equals the active residual increment minus S_{k+1}.",
  "symbolic_base_identity": "V_0=0 and the k=0 increment gives V_1.",
  "symbolic_boundary_identity": "V_N=(f+g)(x_N)-(f+g)(x_star)-L/(4N)||x_0-x_star||^2.",
  "step_identity_zero": true,
  "base_identity_zero": true,
  "boundary_identity_zero": true,
  "block5_scope": "lyap-closed-form Block 5 for PGM using exact Block 4 coefficient formulas."
}