{
  "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,
  "rank_profile": [
    1,
    3,
    3,
    3,
    1
  ],
  "rank_tolerance": 0.0001,
  "lyap_inner_prod_coords": [
    [
      [
        -0.025583942049932203,
        0.025583942049932203,
        0.0,
        0.0,
        0.0,
        0.0,
        1.0842021724855044e-19
      ],
      [
        0.025583942049932203,
        -0.025583942049932203,
        0.0,
        0.0,
        0.0,
        0.0,
        -1.0842021724855044e-19
      ],
      [
        0.0,
        0.0,
        0.0,
        6.288372600415926e-18,
        3.2742905609062234e-17,
        5.898059818321144e-17,
        1.3660947373317356e-17
      ],
      [
        0.0,
        0.0,
        6.288372600415926e-18,
        5.9631119486702744e-18,
        9.69276742202041e-17,
        3.252606517456513e-17,
        3.946495907847236e-17
      ],
      [
        0.0,
        0.0,
        3.2742905609062234e-17,
        9.69276742202041e-17,
        6.711211447685272e-17,
        5.4643789493269423e-17,
        -5.551115123125783e-17
      ],
      [
        0.0,
        0.0,
        5.898059818321144e-17,
        3.252606517456513e-17,
        5.4643789493269423e-17,
        6.071532165918825e-17,
        4.640385298237959e-17
      ],
      [
        1.0842021724855044e-19,
        -1.0842021724855044e-19,
        1.3660947373317356e-17,
        3.946495907847236e-17,
        -5.551115123125783e-17,
        4.640385298237959e-17,
        3.2634485391813683e-17
      ]
    ],
    [
      [
        -0.025583942049932203,
        0.025583942049932203,
        0.051167884099864405,
        0.0,
        0.0,
        0.0,
        1.0842021724855044e-19
      ],
      [
        0.025583942049932203,
        -0.025583942049932203,
        -0.051167884099864405,
        0.0,
        0.0,
        0.0,
        -1.0842021724855044e-19
      ],
      [
        0.051167884099864405,
        -0.051167884099864405,
        -0.10233576819972881,
        -0.03162349150613152,
        3.2742905609062234e-17,
        5.898059818321144e-17,
        1.3660947373317356e-17
      ],
      [
        0.0,
        0.0,
        -0.03162349150613152,
        -0.051167884099864405,
        9.69276742202041e-17,
        3.252606517456513e-17,
        3.946495907847236e-17
      ],
      [
        0.0,
        0.0,
        3.2742905609062234e-17,
        9.69276742202041e-17,
        6.711211447685272e-17,
        5.4643789493269423e-17,
        -5.551115123125783e-17
      ],
      [
        0.0,
        0.0,
        5.898059818321144e-17,
        3.252606517456513e-17,
        5.4643789493269423e-17,
        6.071532165918825e-17,
        4.640385298237959e-17
      ],
      [
        1.0842021724855044e-19,
        -1.0842021724855044e-19,
        1.3660947373317356e-17,
        3.946495907847236e-17,
        -5.551115123125783e-17,
        4.640385298237959e-17,
        3.2634485391813683e-17
      ]
    ],
    [
      [
        -0.025583942049932203,
        0.025583942049932203,
        0.051167884099864405,
        0.08279137560599593,
        0.0,
        0.0,
        1.0842021724855044e-19
      ],
      [
        0.025583942049932203,
        -0.025583942049932203,
        -0.051167884099864405,
        -0.08279137560599593,
        0.0,
        0.0,
        -1.0842021724855044e-19
      ],
      [
        0.051167884099864405,
        -0.051167884099864405,
        -0.10233576819972881,
        -0.16558275121199187,
        -0.02332676192696383,
        5.898059818321144e-17,
        1.3660947373317356e-17
      ],
      [
        0.08279137560599593,
        -0.08279137560599593,
        -0.16558275121199187,
        -0.2679185194117207,
        -0.13655724286287732,
        3.252606517456513e-17,
        3.946495907847236e-17
      ],
      [
        0.0,
        0.0,
        -0.02332676192696383,
        -0.13655724286287732,
        -0.13395925970586028,
        5.4643789493269423e-17,
        -5.551115123125783e-17
      ],
      [
        0.0,
        0.0,
        5.898059818321144e-17,
        3.252606517456513e-17,
        5.4643789493269423e-17,
        6.071532165918825e-17,
        4.640385298237959e-17
      ],
      [
        1.0842021724855044e-19,
        -1.0842021724855044e-19,
        1.3660947373317356e-17,
        3.946495907847236e-17,
        -5.551115123125783e-17,
        4.640385298237959e-17,
        3.2634485391813683e-17
      ]
    ],
    [
      [
        -0.025583942049932203,
        0.025583942049932203,
        0.051167884099864405,
        0.08279137560599593,
        0.11223813967213275,
        0.0,
        1.0842021724855044e-19
      ],
      [
        0.025583942049932203,
        -0.025583942049932203,
        -0.051167884099864405,
        -0.08279137560599593,
        -0.11223813967213275,
        0.0,
        -1.0842021724855044e-19
      ],
      [
        0.051167884099864405,
        -0.051167884099864405,
        -0.10233576819972881,
        -0.16558275121199187,
        -0.2244762793442655,
        -0.0186079152091675,
        1.3660947373317356e-17
      ],
      [
        0.08279137560599593,
        -0.08279137560599593,
        -0.16558275121199187,
        -0.2679185194117207,
        -0.36321024964713755,
        -0.10893263301379502,
        3.946495907847236e-17
      ],
      [
        0.11223813967213275,
        -0.11223813967213275,
        -0.2244762793442655,
        -0.36321024964713755,
        -0.4923947987559861,
        -0.3032535291688243,
        -5.551115123125783e-17
      ],
      [
        0.0,
        0.0,
        -0.0186079152091675,
        -0.10893263301379502,
        -0.3032535291688243,
        -0.246197399377993,
        4.640385298237959e-17
      ],
      [
        1.0842021724855044e-19,
        -1.0842021724855044e-19,
        1.3660947373317356e-17,
        3.946495907847236e-17,
        -5.551115123125783e-17,
        4.640385298237959e-17,
        3.2634485391813683e-17
      ]
    ],
    [
      [
        -0.025583942049932203,
        0.025583942049932203,
        0.051167884099864405,
        0.08279137560599593,
        0.11223813967213275,
        0.14070100459009374,
        0.11310159603191328
      ],
      [
        0.025583942049932203,
        -0.025583942049932203,
        -0.051167884099864405,
        -0.08279137560599593,
        -0.11223813967213275,
        -0.14070100459009374,
        -0.11310159603191328
      ],
      [
        0.051167884099864405,
        -0.051167884099864405,
        -0.10233576819972881,
        -0.16558275121199187,
        -0.2244762793442655,
        -0.2814020091801875,
        -0.22620319206382655
      ],
      [
        0.08279137560599593,
        -0.08279137560599593,
        -0.16558275121199187,
        -0.2679185194117207,
        -0.36321024964713755,
        -0.4553180153560533,
        -0.36600445312299185
      ],
      [
        0.11223813967213275,
        -0.11223813967213275,
        -0.2244762793442655,
        -0.36321024964713755,
        -0.4923947987559861,
        -0.6172629290033191,
        -0.496182828580346
      ],
      [
        0.14070100459009374,
        -0.14070100459009374,
        -0.2814020091801875,
        -0.4553180153560533,
        -0.6172629290033191,
        -0.7737968079361734,
        -0.622011578644712
      ],
      [
        0.11310159603191328,
        -0.11310159603191328,
        -0.22620319206382655,
        -0.36600445312299185,
        -0.496182828580346,
        -0.622011578644712,
        -0.5
      ]
    ]
  ],
  "lyap_func_coords": [
    [
      -1.0000000000000002,
      0.0,
      -1.235990476633475e-17,
      7.22078646875346e-17,
      1.218643241873707e-16,
      1.0
    ],
    [
      -0.8976642318002714,
      0.0,
      -0.10233576819972882,
      7.22078646875346e-17,
      1.218643241873707e-16,
      1.0
    ],
    [
      -0.7320814805882796,
      0.0,
      0.0,
      -0.2679185194117206,
      1.218643241873707e-16,
      1.0
    ],
    [
      -0.5076052012440141,
      0.0,
      0.0,
      0.0,
      -0.492394798755986,
      1.0
    ],
    [
      0.0,
      0.0,
      0.0,
      0.0,
      0.0,
      0.0
    ]
  ],
  "grouping_code": "# Reverse-tail partial sums for OGM.\n# Requires: setup, ctx, obj, sp, pf, L, N_int, lambda_row_names, lambda_col_names,\n# theta_ogm_value, lamb.\ntheta_N = theta_ogm_value(N_int, N_int)\nz_N = ctx[f\"z_{N_int}\"]\nx_N = ctx[f\"x_{N_int}\"]\nx_star = ctx[\"x_star\"]\nS_guess = L / (2 * theta_N ** 2) * (z_N - theta_N / L * obj.grad(x_N) - x_star) ** 2\n\n\ndef step_terms(step):\n    terms = [(f\"x_{step}\", f\"x_{step + 1}\"), (\"x_star\", f\"x_{step}\")]\n    if step == N_int - 1:\n        terms.append((\"x_star\", f\"x_{N_int}\"))\n    return terms\n\n\nlyap = []\nfor k in range(N_int + 1):\n    tail = -S_guess\n    for step in range(k, N_int):\n        for ri, ci in step_terms(step):\n            coeff = lamb(ri, ci, N_int)\n            if coeff != 0:\n                tail += coeff * obj.interp_ineq(ri, ci, pep_context=ctx)\n    lyap.append(tail)\n",
  "grouping_description": "V_k is the reverse-tail certificate: -S plus active chain and star interpolation terms from steps k through N-1.",
  "extra_duals": {},
  "coverage_rank": 1,
  "basis_templates": [
    "1 <= k < N: [x_k-x_star, grad_f(x_k), z_{k+1}-x_star]",
    "k == N: [z_N - theta_N/L*grad_f(x_N) - x_star]"
  ],
  "basis_by_k_labels": {
    "1": [
      "x_1-x_star",
      "grad_f(x_1)",
      "z_2-x_star"
    ],
    "2": [
      "x_2-x_star",
      "grad_f(x_2)",
      "z_3-x_star"
    ],
    "3": [
      "x_3-x_star",
      "grad_f(x_3)",
      "z_4-x_star"
    ],
    "4": [
      "z_4-theta_N/L*grad_f(x_4)-x_star"
    ]
  },
  "basis_code": "def V_k_basis(k):\n    if 1 <= k < N_int:\n        return [ctx[f\"x_{k}\"] - ctx[\"x_star\"], obj.grad(ctx[f\"x_{k}\"]), ctx[f\"z_{k + 1}\"] - ctx[\"x_star\"]]\n    if k == N_int:\n        theta_N = theta_ogm_value(N_int, N_int)\n        return [ctx[f\"z_{N_int}\"] - theta_N / L * obj.grad(ctx[f\"x_{N_int}\"]) - ctx[\"x_star\"]]\n    return []\n\n\ndef V_k_basis_labels(k):\n    if 1 <= k < N_int:\n        return [f\"x_{k}-x_star\", f\"grad_f(x_{k})\", f\"z_{k + 1}-x_star\"]\n    if k == N_int:\n        return [f\"z_{N_int}-theta_N/L*grad_f(x_{N_int})-x_star\"]\n    return []\n",
  "coeff_by_k": {
    "1": [
      [
        -1.4016220359701403e-16,
        -0.08279137560599548,
        1.249000902703301e-16
      ],
      [
        -0.08279137560599548,
        0.2167506353118552,
        -3.5041414214731503e-16
      ],
      [
        1.249000902703301e-16,
        -3.5041414214731503e-16,
        -0.025583942049932314
      ]
    ],
    "2": [
      [
        -3.01420628366221e-16,
        -0.11223813967213234,
        9.71445146547012e-17
      ],
      [
        -0.11223813967213234,
        0.3584355390501259,
        -1.3877787807814457e-16
      ],
      [
        9.71445146547012e-17,
        -1.3877787807814457e-16,
        -0.025583942049932258
      ]
    ],
    "3": [
      [
        -8.631930011853939e-16,
        -0.1407010045900921,
        4.579669976578771e-16
      ],
      [
        -0.1407010045900921,
        0.5275994085581805,
        -6.349087922075114e-16
      ],
      [
        4.579669976578771e-16,
        -6.349087922075114e-16,
        -0.02558394204993243
      ]
    ],
    "4": [
      [
        -0.025583942049932203
      ]
    ]
  },
  "coeff_code": "def coeff_pattern(k, N=N_int):\n    theta_N = theta_ogm_value(N, N)\n    if 1 <= k < N:\n        theta_k = theta_ogm_value(k, N)\n        C = sp.zeros(3, 3)\n        C[0, 1] = C[1, 0] = -theta_k / theta_N**2\n        C[1, 1] = theta_k * (theta_k + 1) / theta_N**2\n        C[2, 2] = -sp.Rational(1, 2) / theta_N**2\n        return C\n    if k == N:\n        return sp.Matrix([[-sp.Rational(1, 2) / theta_N**2]])\n    return sp.zeros(0, 0)\n",
  "coeff_residuals": {
    "1": 1.0824674490095276e-15,
    "2": 4.163336342344337e-16,
    "3": 1.6375789613221059e-15,
    "4": 0.0
  },
  "coeff_formula": {
    "interior_basis_order": [
      "x_k-x_star",
      "grad_f(x_k)",
      "z_{k+1}-x_star"
    ],
    "interior_nonzero_entries": {
      "(0,1)": "-theta_k/theta_N**2",
      "(1,0)": "-theta_k/theta_N**2",
      "(1,1)": "theta_k*(theta_k + 1)/theta_N**2",
      "(2,2)": "-1/(2*theta_N**2)"
    },
    "terminal_basis_order": [
      "z_N - theta_N/L*grad_f(x_N) - x_star"
    ],
    "terminal_nonzero_entries": {
      "(0,0)": "-1/(2*theta_N**2)"
    }
  },
  "step_identity_valid": true,
  "base_identity_valid": true,
  "boundary_identity_valid": true,
  "initial_identity_valid": true,
  "lyapunov_formula_latex": "For 1 \\le k < N, with \\alpha_k=2\\theta_{k-1}^2/\\theta_N^2,\\nV_k=f(x_N)-\\alpha_k f(x_k)-(1-\\alpha_k)f(x_*) - \\frac{2\\theta_k}{\\theta_N^2}\\langle x_k-x_*,\\nabla f(x_k)\\rangle + \\frac{\\theta_k(\\theta_k+1)}{L\\theta_N^2}\\|\\nabla f(x_k)\\|^2 - \\frac{L}{2\\theta_N^2}\\|z_{k+1}-x_*\\|^2.\\nAlso V_0=f(x_N)-f(x_*)-\\frac{L}{2\\theta_N^2}\\|x_0-x_*\\|^2 and V_N=-\\frac{L}{2\\theta_N^2}\\|z_N-\\frac{\\theta_N}{L}\\nabla f(x_N)-x_*\\|^2.",
  "theorem_latex": "If f is convex and L-smooth, \\nabla f(x_*)=0, and \\|x_0-x_*\\|\\le R, then OGM satisfies f(x_N)-f(x_*)\\le \\frac{L R^2}{2\\theta_N^2}.",
  "step_identity_latex": "V_{k+1}-V_k+\\frac{2\\theta_k^2}{\\theta_N^2}I_f(x_k,x_{k+1})+\\frac{2\\theta_k}{\\theta_N^2}I_f(x_*,x_k)=0,\\quad 1\\le k<N-1.",
  "base_identity_latex": "V_1-V_0+\\frac{2}{\\theta_N^2}I_f(x_0,x_1)+\\frac{2}{\\theta_N^2}I_f(x_*,x_0)=0.",
  "boundary_identity_latex": "V_N+\\frac{L}{2\\theta_N^2}\\left\\|z_N-\\frac{\\theta_N}{L}\\nabla f(x_N)-x_*\\right\\|^2=0."
}