{
  "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,
  "rank_tolerance": 0.0001,
  "rank_profile": [
    0,
    3,
    3,
    3,
    1
  ],
  "interior_rank_constant": true,
  "boundary_rank": 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.0008680559319481372,
        0.0008680559319481395,
        -0.05468749845313295,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0008680559319481395,
        -0.0008680559319481418,
        0.05468749845313293,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        -0.05468749845313295,
        0.05468749845313293,
        0.05468750264418831,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        0.0,
        0.0625,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ]
    ],
    [
      [
        -0.004535150039706888,
        0.004535150039706893,
        -0.051020404499590805,
        -0.05102039817583965,
        0.0,
        0.0,
        0.0
      ],
      [
        0.004535150039706893,
        -0.004535150039706898,
        0.051020404499590784,
        0.05102039817583963,
        0.0,
        0.0,
        0.0
      ],
      [
        -0.051020404499590805,
        0.051020404499590784,
        0.05102040884486277,
        0.05102039940957217,
        0.0,
        0.0,
        0.0
      ],
      [
        -0.05102039817583965,
        0.05102039817583963,
        0.05102039940957217,
        0.05102039370997609,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        0.0,
        0.0,
        0.14285714285714285,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ]
    ],
    [
      [
        -0.013888895951258615,
        0.013888895951258626,
        -0.041666658638642204,
        -0.04166665227715595,
        -0.041666648088507716,
        0.0,
        0.0
      ],
      [
        0.013888895951258626,
        -0.013888895951258633,
        0.04166665863864218,
        0.04166665227715593,
        0.04166664808850769,
        0.0,
        0.0
      ],
      [
        -0.041666658638642204,
        0.04166665863864218,
        0.041666663034517305,
        0.0416666535614916,
        0.04166664844272956,
        0.0,
        0.0
      ],
      [
        -0.04166665227715595,
        0.04166665227715593,
        0.0416666535614916,
        0.04166664782416042,
        0.0416666481785839,
        0.0,
        0.0
      ],
      [
        -0.041666648088507716,
        0.04166664808850769,
        0.04166664844272956,
        0.0416666481785839,
        0.041666622905126446,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.25,
        0.0
      ],
      [
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ]
    ],
    [
      [
        -0.05555555597717744,
        0.05555555597717743,
        1.4297247830086235e-09,
        7.92304612889927e-09,
        1.2167544308910871e-08,
        1.2229466179319859e-08,
        -3.206904861108306e-08
      ],
      [
        0.05555555597717743,
        -0.05555555597717742,
        -1.4297247864780704e-09,
        -7.923046132368716e-09,
        -1.2167544315849765e-08,
        -1.2229466158503177e-08,
        3.2069048708227577e-08
      ],
      [
        1.4297247830086235e-09,
        -1.4297247864780704e-09,
        2.9237021519079587e-09,
        -6.6811586436898995e-09,
        -1.1855770632590579e-08,
        -1.2079791434499443e-08,
        3.1664684707610746e-08
      ],
      [
        7.92304612889927e-09,
        -7.923046132368716e-09,
        -6.6811586436898995e-09,
        -1.2550324914734068e-08,
        -1.2251751387720722e-08,
        -1.2476677444667184e-08,
        3.127056005802764e-08
      ],
      [
        1.2167544308910871e-08,
        -1.2167544315849765e-08,
        -1.1855770632590579e-08,
        -1.2251751387720722e-08,
        -3.7581058789232236e-08,
        -1.2649945476533864e-08,
        3.110872838496537e-08
      ],
      [
        1.2229466179319859e-08,
        -1.2229466158503177e-08,
        -1.2079791434499443e-08,
        -1.2476677444667184e-08,
        -1.2649945476533864e-08,
        -6.275168511551965e-08,
        3.115126455399686e-08
      ],
      [
        -3.206904861108306e-08,
        3.2069048708227577e-08,
        3.1664684707610746e-08,
        3.127056005802764e-08,
        3.110872838496537e-08,
        3.115126455399686e-08,
        -5.428367755300201e-10
      ]
    ]
  ],
  "lyap_func_coords": [
    [
      0.0,
      0.0,
      0.0,
      0.0,
      0.0,
      0.0
    ],
    [
      -0.125,
      0.0,
      0.125,
      0.0,
      0.0,
      0.0
    ],
    [
      -0.2857142857142857,
      0.0,
      2.7755575615628914e-17,
      0.2857142857142857,
      0.0,
      0.0
    ],
    [
      -0.5,
      0.0,
      2.7755575615628914e-17,
      -2.7755575615628914e-17,
      0.5,
      0.0
    ],
    [
      -1.0,
      0.0,
      2.7755575615628914e-17,
      -2.7755575615628914e-17,
      -5.551115123125783e-17,
      1.0
    ]
  ],
  "grouping_terms": [
    [
      {
        "kind": "S",
        "index": 4,
        "coeff": 0.07031249735581169
      },
      {
        "kind": "interp",
        "ri": "x_0",
        "ci": "x_1",
        "coeff": "1/8"
      },
      {
        "kind": "interp",
        "ri": "x_star",
        "ci": "x_0",
        "coeff": "1/8"
      }
    ],
    [
      {
        "kind": "S",
        "index": 3,
        "coeff": 0.23469389200430962
      },
      {
        "kind": "interp",
        "ri": "x_1",
        "ci": "x_2",
        "coeff": "2/7"
      },
      {
        "kind": "interp",
        "ri": "x_star",
        "ci": "x_1",
        "coeff": "9/56"
      }
    ],
    [
      {
        "kind": "S",
        "index": 2,
        "coeff": 0.45833337709487354
      },
      {
        "kind": "interp",
        "ri": "x_2",
        "ci": "x_3",
        "coeff": "1/2"
      },
      {
        "kind": "interp",
        "ri": "x_star",
        "ci": "x_2",
        "coeff": "3/14"
      }
    ],
    [
      {
        "kind": "S",
        "index": 1,
        "coeff": 0.7800000752339025
      },
      {
        "kind": "interp",
        "ri": "x_3",
        "ci": "x_4",
        "coeff": "4/5"
      },
      {
        "kind": "interp",
        "ri": "x_star",
        "ci": "x_3",
        "coeff": "3/10"
      },
      {
        "kind": "interp",
        "ri": "x_star",
        "ci": "x_4",
        "coeff": "1/5"
      },
      {
        "kind": "S",
        "index": 0,
        "coeff": 0.5000000005428368
      }
    ]
  ],
  "grouping_code": "lyap = [pf.Scalar.zero()]\npartial_sum = pf.Scalar.zero()\nfor step in range(N_int):\n    s_idx = N_int - step\n    if 0 <= s_idx < len(ell) and abs(float(d[s_idx, s_idx])) > 1e-8:\n        partial_sum = partial_sum - float(d[s_idx, s_idx]) * ell[s_idx] ** 2\n\n    for ri, ci in itertools.product(row_names, col_names):\n        coeff = lamb(ri, ci, N_int)\n        if coeff == 0:\n            continue\n        include = (ri == f\"x_{step}\" and ci == f\"x_{step + 1}\")\n        include = include or (ri == \"x_star\" and ci == f\"x_{step}\")\n        include = include or (step == N_int - 1 and ri == \"x_star\" and ci == f\"x_{N_int}\")\n        if include:\n            partial_sum = partial_sum + coeff * obj.interp_ineq(ri, ci)\n\n    if step == N_int - 1 and abs(float(d[0, 0])) > 1e-8:\n        partial_sum = partial_sum - float(d[0, 0]) * ell[0] ** 2\n\n    lyap.append(partial_sum)\n",
  "extra_duals": {},
  "basis_templates": [
    "x_0-x_star",
    "grad_f(x_k)",
    "x_k-x_star"
  ],
  "terminal_basis_templates": [
    "x_0-x_star"
  ],
  "basis_by_k_labels": {
    "1": [
      "x_0-x_star",
      "grad_f(x_1)",
      "x_1-x_star"
    ],
    "2": [
      "x_0-x_star",
      "grad_f(x_2)",
      "x_2-x_star"
    ],
    "3": [
      "x_0-x_star",
      "grad_f(x_3)",
      "x_3-x_star"
    ],
    "4": [
      "x_0-x_star"
    ]
  },
  "basis_code": "def V_k_basis(k):\n    if 1 <= k < N_int:\n        return [ctx[\"x_0\"] - ctx[\"x_star\"], obj.grad(ctx[f\"x_{k}\"]), ctx[f\"x_{k}\"] - ctx[\"x_star\"]]\n    if k == N_int:\n        return [ctx[\"x_0\"] - ctx[\"x_star\"]]\n    return []\n\ndef V_k_basis_labels(k):\n    if 1 <= k < N_int:\n        return [\"x_0-x_star\", f\"grad_f(x_{k})\", f\"x_{k}-x_star\"]\n    if k == N_int:\n        return [\"x_0-x_star\"]\n    return []\n",
  "coeff_by_k": {
    "1": [
      [
        -0.05555555019402565,
        2.0816681711721685e-17,
        -4.191055395091903e-09
      ],
      [
        2.0816681711721685e-17,
        0.0625,
        -1.3877787807814457e-17
      ],
      [
        -4.191055395091903e-09,
        -1.3877787807814457e-17,
        0.0546875026441883
      ]
    ],
    "2": [
      [
        -0.05555555237164152,
        -2.914335439641036e-16,
        9.942194394152448e-10
      ],
      [
        -2.914335439641036e-16,
        0.14285714285714282,
        1.8041124150158794e-16
      ],
      [
        9.942194394152448e-10,
        1.8041124150158794e-16,
        0.05102040034349575
      ]
    ],
    "3": [
      [
        -0.055555553717527593,
        4.85722573273506e-17,
        4.764833652637357e-09
      ],
      [
        4.85722573273506e-17,
        0.25,
        -2.7755575615628914e-17
      ],
      [
        4.764833652637357e-09,
        -2.7755575615628914e-17,
        0.04166664823660164
      ]
    ],
    "4": [
      [
        -0.055555555977177436
      ]
    ]
  },
  "coeff_code": "def coeff_pattern(k, N):\n    if 1 <= k < N:\n        return [\n            [sp.Rational(-1, 4 * N + 2), sp.S(0), sp.S(0)],\n            [sp.S(0), sp.Rational(k, 2 * (2 * N - k + 1)), sp.S(0)],\n            [sp.S(0), sp.S(0), sp.Rational(2 * N - 2 * k + 1, 2 * (2 * N - k + 1) ** 2)],\n        ]\n    if k == N:\n        return [[sp.Rational(-1, 4 * N + 2)]]\n    return []\n",
  "coeff_formula_residuals": {
    "1": 5.3615299006049e-09,
    "2": 7.819769554107125e-09,
    "3": 1.8430065022723152e-08,
    "4": 4.2162188323979777e-10
  },
  "coeff_formula": {
    "interior_basis_order": [
      "x_0-x_star",
      "grad_f(x_k)",
      "x_k-x_star"
    ],
    "interior_diagonal": [
      "-1/(4*N+2)",
      "k/(2*(2*N-k+1))",
      "(2*N-2*k+1)/(2*(2*N-k+1)^2)"
    ],
    "terminal_basis_order": [
      "x_0-x_star"
    ],
    "terminal_diagonal": [
      "-1/(4*N+2)"
    ]
  }
}