{
  "algo_name": "gd_recover",
  "problem_type": "smooth_convex",
  "obj_tag": "f",
  "params_json": "{\"L\": 1, \"R\": 1}",
  "performance_metric": "f(x_N) - f(x_star)",
  "initial_condition": "||x_0 - x_star|| <= R",
  "conjectured_rate": "L*R**2/(4*N + 2)",
  "setup_file": "examples/gd_recover/gd_recover_setup.py",
  "sweep_results": [
    {
      "N": 1,
      "opt_value": 0.16666647215955557,
      "rate_value": 0.16666666666666666
    },
    {
      "N": 2,
      "opt_value": 0.09999778825848792,
      "rate_value": 0.1
    },
    {
      "N": 3,
      "opt_value": 0.07142958122711231,
      "rate_value": 0.07142857142857142
    },
    {
      "N": 4,
      "opt_value": 0.05555562600367351,
      "rate_value": 0.05555555555555555
    },
    {
      "N": 5,
      "opt_value": 0.04545413917119227,
      "rate_value": 0.045454545454545456
    },
    {
      "N": 6,
      "opt_value": 0.03846167786261405,
      "rate_value": 0.038461538461538464
    },
    {
      "N": 7,
      "opt_value": 0.03333327804360977,
      "rate_value": 0.03333333333333333
    }
  ],
  "N_verify": 4,
  "opt_value": 0.05555554834030343,
  "tau_sol": 0.055555555839900225,
  "relaxed_constraints": [
    "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_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_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_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_star"
  ],
  "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"
  ],
  "lambda_matrix": [
    [
      0.0,
      0.12499999813215341,
      0.0,
      0.0,
      0.0,
      0.0
    ],
    [
      0.0,
      0.0,
      0.2857142985284252,
      0.0,
      0.0,
      0.0
    ],
    [
      0.0,
      0.0,
      0.0,
      0.5000000375065803,
      0.0,
      0.0
    ],
    [
      0.0,
      0.0,
      0.0,
      0.0,
      0.8000000625764394,
      0.0
    ],
    [
      0.0,
      0.0,
      0.0,
      0.0,
      0.0,
      0.0
    ],
    [
      0.12499999813214815,
      0.16071430039626722,
      0.21428573897815764,
      0.3000000250698725,
      0.19999993742355707,
      0.0
    ]
  ],
  "S_matrix": [
    [
      0.055555555977177436,
      -0.05555555597717735,
      -0.06250000142972477,
      -0.08035715078018899,
      -0.10714286931040144,
      -0.15000001222946618,
      -0.0999999679309514
    ],
    [
      -0.05555555597717735,
      0.055555555977177276,
      0.06250000142972478,
      0.080357150780189,
      0.10714286931040144,
      0.15000001222946616,
      0.0999999679309513
    ],
    [
      -0.06250000142972477,
      0.06250000142972478,
      0.12499999707629786,
      0.0803571495383015,
      0.10714286899862777,
      0.15000001207979144,
      0.0999999683353153
    ],
    [
      -0.08035715078018899,
      0.080357150780189,
      0.0803571495383015,
      0.28571429826461064,
      0.1071428693946085,
      0.1500000124766774,
      0.09999996872943995
    ],
    [
      -0.10714286931040144,
      0.10714286931040144,
      0.10714286899862777,
      0.1071428693946085,
      0.5000000375810588,
      0.15000001264994547,
      0.09999996889127162
    ],
    [
      -0.15000001222946618,
      0.15000001222946616,
      0.15000001207979144,
      0.1500000124766774,
      0.15000001264994547,
      0.8000000627516851,
      0.09999996884873545
    ],
    [
      -0.0999999679309514,
      0.0999999679309513,
      0.0999999683353153,
      0.09999996872943995,
      0.09999996889127162,
      0.09999996884873545,
      0.5000000005428368
    ]
  ],
  "S_row_names": [
    "x_0",
    "x_star",
    "grad_f(x_0)",
    "grad_f(x_1)",
    "grad_f(x_2)",
    "grad_f(x_3)",
    "grad_f(x_4)"
  ],
  "S_col_names": [
    "x_0",
    "x_star",
    "grad_f(x_0)",
    "grad_f(x_1)",
    "grad_f(x_2)",
    "grad_f(x_3)",
    "grad_f(x_4)"
  ],
  "basis_vectors": [
    "x_0",
    "x_star",
    "grad_f(x_0)",
    "grad_f(x_1)",
    "grad_f(x_2)",
    "grad_f(x_3)",
    "grad_f(x_4)"
  ],
  "lambda_formula": {
    "chain_forward": "lambda(x_i,x_{i+1}) = (i+1)/(2N-i), 0 <= i < N",
    "star_row": "lambda(x_star,x_j) = a_j-a_{j-1} for 0 <= j < N, lambda(x_star,x_N)=1-a_{N-1}, a_i=(i+1)/(2N-i)"
  },
  "lamb_code": "def idx(tag, N=N_int):\n    return N + 1 if tag == \"x_star\" else int(tag.split(\"_\")[1])\n\ndef chain_weight(i, N=N_int):\n    return sp.Rational(i + 1, 2 * N - i)\n\ndef lamb(ri, ci, N=N_int):\n    i, j = idx(ri, N), idx(ci, N)\n    if 0 <= i < N and j == i + 1:\n        return chain_weight(i, N)\n    if ri == \"x_star\" and 0 <= j < N:\n        prev = chain_weight(j - 1, N) if j > 0 else sp.S(0)\n        return chain_weight(j, N) - prev\n    if ri == \"x_star\" and j == N:\n        return 1 - chain_weight(N - 1, N)\n    return sp.S(0)\n",
  "S_code": "# With L=R=1 at fixed N, build the PSD residual from the closed-form multipliers.\ninterp_sum = pf.Scalar.zero()\nfor ri, ci in itertools.product(row_names, col_names):\n    c = lamb(ri, ci, N_int)\n    if c != 0:\n        interp_sum += c * obj.interp_ineq(ri, ci)\ntau = sp.Rational(1, 4 * N_int + 2)\nx_N, x_0, x_star = ctx[f\"x_{N_int}\"], ctx[\"x_0\"], ctx[\"x_star\"]\nLHS = obj(x_N) - obj(x_star) - tau * (x_0 - x_star) ** 2\nS_guess = interp_sum - LHS\n",
  "S_decomp_type": "ldl_numeric_reversed_basis",
  "S_ldl_diag": [
    0.500000001,
    0.780000075,
    0.458333377,
    0.234693892,
    0.070312497,
    0.0,
    0.0
  ],
  "S_ldl_ell": [
    "grad_f(x_4) + (grad_f(x_0)+grad_f(x_1)+grad_f(x_2)+grad_f(x_3)+x_star-x_0)/5",
    "grad_f(x_3) + (grad_f(x_0)+grad_f(x_1)+grad_f(x_2)+x_star-x_0)/6",
    "grad_f(x_2) + (grad_f(x_0)+grad_f(x_1)+x_star-x_0)/7",
    "grad_f(x_1) + (grad_f(x_0)+x_star-x_0)/8",
    "grad_f(x_0) + (x_star-x_0)/9"
  ],
  "lambda_max_residual": 6.257644294405118e-08,
  "S_max_residual": 6.275168507041684e-08,
  "proof_valid": true
}