{
  "algo_name": "ogm",
  "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/(2*theta_N**2)",
  "setup_file": "examples/ogm/ogm_setup.py",
  "sweep_results": [
    {
      "N": 1,
      "opt_value": 0.12499891224858557,
      "rate_value": 0.125
    },
    {
      "N": 2,
      "opt_value": 0.0618918527616518,
      "rate_value": 0.06189418239776468
    },
    {
      "N": 3,
      "opt_value": 0.03769204376644394,
      "rate_value": 0.03769239720788239
    },
    {
      "N": 4,
      "opt_value": 0.025583626393635102,
      "rate_value": 0.025583942049932206
    },
    {
      "N": 5,
      "opt_value": 0.01858694825943362,
      "rate_value": 0.01858813666365106
    },
    {
      "N": 6,
      "opt_value": 0.014155392931958322,
      "rate_value": 0.014155965863218723
    },
    {
      "N": 7,
      "opt_value": 0.01115684589824191,
      "rate_value": 0.01116041688775744
    }
  ],
  "N_verify": 4,
  "opt_value": 0.025582264054418824,
  "tau_sol": 0.025583894665493986,
  "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"
  ],
  "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.10233584665669788,
      0.0,
      0.0,
      0.0,
      0.0
    ],
    [
      0.0,
      0.0,
      0.2679186735624241,
      0.0,
      0.0,
      0.0
    ],
    [
      0.0,
      0.0,
      0.0,
      0.4923950332797394,
      0.0,
      0.0
    ],
    [
      0.0,
      0.0,
      0.0,
      0.0,
      0.773797411768181,
      0.0
    ],
    [
      0.0,
      0.0,
      0.0,
      0.0,
      0.0,
      0.0
    ],
    [
      0.10233584665652273,
      0.16558282690530243,
      0.2244763597168497,
      0.2814023784890278,
      0.22620258823221184,
      0.0
    ]
  ],
  "S_matrix": [
    [
      0.025583934336764588,
      -0.0255839343367647,
      -0.051167878332676664,
      -0.0827913725201954,
      -0.11223814205901374,
      -0.1407010630376479,
      -0.11310147124848584
    ],
    [
      -0.0255839343367647,
      0.025583934336764643,
      0.05116787833267652,
      0.08279137252019557,
      0.11223814205901379,
      0.14070106303764782,
      0.11310147124848594
    ],
    [
      -0.051167878332676664,
      0.05116787833267652,
      0.10233577598365098,
      0.16558277629805587,
      0.22447632649324295,
      0.28140217919661226,
      0.22620298519813478
    ],
    [
      -0.0827913725201954,
      0.08279137252019557,
      0.16558277629805587,
      0.2679185802133572,
      0.36321035333604196,
      0.45531832479720474,
      0.3660041460182891
    ],
    [
      -0.11223814205901374,
      0.11223814205901379,
      0.22447632649324295,
      0.36321035333604196,
      0.492394968148295,
      0.6172633846382354,
      0.4961824412920335
    ],
    [
      -0.1407010630376479,
      0.14070106303764782,
      0.28140217919661226,
      0.45531832479720474,
      0.6172633846382354,
      0.773797684098794,
      0.6220113382997486
    ],
    [
      -0.11310147124848584,
      0.11310147124848594,
      0.22620298519813478,
      0.3660041460182891,
      0.4961824412920335,
      0.6220113382997486,
      0.4999990474565022
    ]
  ],
  "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)"
  ],
  "lamb_code": "def idx(tag, N=N_int):\n    return N + 1 if tag == \"x_star\" else int(tag.split(\"_\")[1])\n\n\ndef theta_ogm_value(i, N=N_int):\n    return sp.N(setup.theta_ogm(i, N), 17)\n\n\ndef lamb(ri, ci, N=N_int):\n    i, j = idx(ri, N), idx(ci, N)\n    theta_N = theta_ogm_value(N, N)\n    if 0 <= i < N and j == i + 1:\n        return 2 * theta_ogm_value(i, N) ** 2 / theta_N ** 2\n    if ri == \"x_star\" and 0 <= j < N:\n        return 2 * theta_ogm_value(j, N) / theta_N ** 2\n    if ri == \"x_star\" and j == N:\n        return 1 / theta_N\n    return sp.S(0)\n",
  "S_code": "theta_N = theta_ogm_value(N_int, N_int)\ntau = 1 / (2 * theta_N ** 2)\nell = obj.grad(ctx[f\"x_{N_int}\"])\nfor i in range(N_int):\n    ell += (2 * theta_ogm_value(i, N_int) / theta_N) * obj.grad(ctx[f\"x_{i}\"])\nell += -(L / theta_N) * (ctx[\"x_0\"] - ctx[\"x_star\"])\nS_guess = (1 / (2 * L)) * ell ** 2\n",
  "S_decomp_type": "direct_rank_one",
  "S_formula": "S_guess = (1/(2*L)) * (grad f(x_N) + sum_{i=0}^{N-1} (2 theta_i/theta_N) grad f(x_i) - (L/theta_N)(x_0-x_star))^2",
  "proof_identity_code": "IC = (ctx[\"x_0\"] - ctx[\"x_star\"]) ** 2\nperf = obj(ctx[f\"x_{N_int}\"]) - obj(ctx[\"x_star\"])\nproof_residual = perf - tau * IC\nfor ri in lambda_row_names:\n    for ci in lambda_col_names:\n        coeff = lamb(ri, ci, N_int)\n        if coeff != 0:\n            proof_residual -= coeff * obj.interp_ineq(ri, ci, pep_context=ctx)\nproof_residual += S_guess\n",
  "proof_valid": true
}