{
  "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
}