{
  "algo_name": "bppm",
  "problem_type": "composite_convex_minimization",
  "obj_tag": "f",
  "params_json": "{\"stepsize\": 1, \"R\": 1}",
  "performance_metric": "f(x_N) - f(x_star)",
  "initial_condition": "D_h(x_star, x_0) <= R",
  "conjectured_rate": "R/(stepsize*N)",
  "setup_file": "examples/bppm/bppm_setup.py",
  "sweep_results": [
    {
      "N": 1,
      "opt_value": 0.999999433171909,
      "rate_value": 1.0
    },
    {
      "N": 2,
      "opt_value": 0.49999429001860696,
      "rate_value": 0.5
    },
    {
      "N": 3,
      "opt_value": 0.33332395148468097,
      "rate_value": 0.3333333333333333
    },
    {
      "N": 4,
      "opt_value": 0.250005743584715,
      "rate_value": 0.25
    },
    {
      "N": 5,
      "opt_value": 0.1999991645331413,
      "rate_value": 0.2
    },
    {
      "N": 6,
      "opt_value": 0.16666665835283603,
      "rate_value": 0.16666666666666666
    },
    {
      "N": 7,
      "opt_value": 0.1428579747978089,
      "rate_value": 0.14285714285714285
    }
  ],
  "N_verify": 4,
  "dense_opt_value": 0.250005743584715,
  "opt_value": 0.24999854770492272,
  "tau_sol": 0.2500002757603839,
  "relaxed_constraints": [
    "f:x_1,x_3",
    "f:x_1,x_4",
    "f:x_1,x_star",
    "f:x_2,x_1",
    "f:x_2,x_4",
    "f:x_2,x_star",
    "f:x_3,x_1",
    "f:x_3,x_2",
    "f:x_3,x_star",
    "f:x_4,x_1",
    "f:x_4,x_2",
    "f:x_4,x_3",
    "f:x_4,x_star",
    "h:x_0,x_1",
    "h:x_0,x_2",
    "h:x_0,x_3",
    "h:x_0,x_4",
    "h:x_0,x_star",
    "h:x_1,x_3",
    "h:x_1,x_4",
    "h:x_1,x_star",
    "h:x_2,x_0",
    "h:x_2,x_4",
    "h:x_2,x_star",
    "h:x_3,x_0",
    "h:x_3,x_1",
    "h:x_3,x_star",
    "h:x_4,x_0",
    "h:x_4,x_1",
    "h:x_4,x_2",
    "h:x_4,x_star",
    "h:x_star,x_0",
    "h:x_star,x_1",
    "h:x_star,x_2",
    "h:x_star,x_3"
  ],
  "lambda_row_names": [
    "x_1",
    "x_2",
    "x_3",
    "x_4",
    "x_star"
  ],
  "lambda_col_names": [
    "x_1",
    "x_2",
    "x_3",
    "x_4",
    "x_star"
  ],
  "lambda_matrix": [
    [
      0.0,
      0.24999951278941854,
      0.0,
      0.0,
      0.0
    ],
    [
      0.0,
      0.0,
      0.4999996243673937,
      0.0,
      0.0
    ],
    [
      0.0,
      0.0,
      0.0,
      0.7499995975704338,
      0.0
    ],
    [
      0.0,
      0.0,
      0.0,
      0.0,
      0.0
    ],
    [
      0.24999951279814672,
      0.2500001115705355,
      0.24999997321070505,
      0.25000040242734056,
      0.0
    ]
  ],
  "h_lambda_row_names": [
    "x_0",
    "x_1",
    "x_2",
    "x_3",
    "x_4",
    "x_star"
  ],
  "h_lambda_col_names": [
    "x_0",
    "x_1",
    "x_2",
    "x_3",
    "x_4",
    "x_star"
  ],
  "h_lambda_matrix": [
    [
      0.0,
      0.0,
      0.0,
      0.0,
      0.0,
      0.0
    ],
    [
      0.250000275760179,
      0.0,
      0.24999883738690887,
      0.0,
      0.0,
      0.0
    ],
    [
      0.0,
      0.4999991131433653,
      0.0,
      0.5000001871168147,
      0.0,
      0.0
    ],
    [
      0.0,
      0.0,
      0.7500004628824761,
      0.0,
      0.749999342808677,
      0.0
    ],
    [
      0.0,
      0.0,
      0.0,
      0.9999996185640456,
      0.0,
      0.0
    ],
    [
      0.0,
      0.0,
      0.0,
      0.0,
      0.2500002757573558,
      0.0
    ]
  ],
  "S_matrix": [
    [
      -2.6539594171402402e-21,
      -3.127721168089601e-22,
      -1.5638605840448005e-22,
      5.72702850602344e-26,
      1.2510884672358404e-21,
      6.255442336179202e-22,
      2.8253340629715637e-24,
      1.2510884672358404e-21,
      -3.7225685289152357e-25,
      1.0947024088313606e-21,
      -6.108830406425002e-25,
      0.0
    ],
    [
      -3.127721168089601e-22,
      1.5073923311347575e-15,
      -3.689610020494562e-16,
      1.8832384479607662e-16,
      -2.276668238252421e-16,
      2.3572508464270817e-16,
      8.711579215056605e-17,
      5.508792738932853e-16,
      -1.3323591740674808e-16,
      -5.739393365213764e-16,
      -2.972185849842842e-16,
      0.0
    ],
    [
      -1.5638605840448005e-22,
      -3.689610020494562e-16,
      4.638130249645407e-16,
      6.661795870337404e-17,
      3.113859107872629e-16,
      -4.868235443708103e-17,
      5.636904197977804e-17,
      1.742315843011321e-16,
      8.199133378876804e-17,
      4.0995666894384025e-16,
      -5.534415030741843e-16,
      0.0
    ],
    [
      5.72702850602344e-26,
      1.8832384479607662e-16,
      6.661795870337404e-17,
      -6.377429093262435e-16,
      1.9720438350863343e-17,
      3.0746750170788016e-17,
      -2.4597400136630413e-16,
      -1.7935604266293012e-17,
      2.331628554618091e-16,
      -1.2298700068315207e-16,
      2.3572508464270817e-16,
      0.0
    ],
    [
      1.2510884672358404e-21,
      -2.276668238252421e-16,
      3.113859107872629e-16,
      1.9720438350863343e-17,
      1.563323641197849e-16,
      6.402445231079414e-19,
      4.5545875649720773e-17,
      1.3135365480779176e-16,
      1.478836611811453e-16,
      6.397866247289331e-16,
      9.886101068097613e-18,
      0.0
    ],
    [
      6.255442336179202e-22,
      2.3572508464270817e-16,
      -4.868235443708103e-17,
      3.0746750170788016e-17,
      6.402445231079414e-19,
      -7.247078515070949e-16,
      3.5871208532586023e-17,
      -1.0248916723596006e-16,
      1.5181207896826585e-16,
      3.2796533515507214e-16,
      5.995616283303664e-16,
      0.0
    ],
    [
      2.8253340629715637e-24,
      8.711579215056605e-17,
      5.636904197977804e-17,
      -2.4597400136630413e-16,
      4.5545875649720773e-17,
      3.5871208532586023e-17,
      -2.8988314060283795e-16,
      3.5871208532586023e-17,
      1.6398266757753607e-16,
      8.199133378876804e-17,
      -2.306006262809101e-16,
      0.0
    ],
    [
      1.2510884672358404e-21,
      5.508792738932853e-16,
      1.742315843011321e-16,
      -1.7935604266293012e-17,
      1.3135365480779176e-16,
      -1.0248916723596006e-16,
      3.5871208532586023e-17,
      -6.377429093262435e-16,
      2.1714892308119037e-16,
      5.329436696269923e-16,
      -4.663257109236182e-16,
      0.0
    ],
    [
      -3.7225685289152357e-25,
      -1.3323591740674808e-16,
      8.199133378876804e-17,
      2.331628554618091e-16,
      1.478836611811453e-16,
      1.5181207896826585e-16,
      1.6398266757753607e-16,
      2.1714892308119037e-16,
      4.638130249645407e-16,
      -1.0505139641685907e-16,
      3.894588354966482e-16,
      0.0
    ],
    [
      1.0947024088313606e-21,
      -5.739393365213764e-16,
      4.0995666894384025e-16,
      -1.2298700068315207e-16,
      6.397866247289331e-16,
      3.2796533515507214e-16,
      8.199133378876804e-17,
      5.329436696269923e-16,
      -1.0505139641685907e-16,
      -1.3914390748936223e-15,
      6.149350034157603e-16,
      0.0
    ],
    [
      -6.108830406425002e-25,
      -2.972185849842842e-16,
      -5.534415030741843e-16,
      2.3572508464270817e-16,
      9.886101068097613e-18,
      5.995616283303664e-16,
      -2.306006262809101e-16,
      -4.663257109236182e-16,
      3.894588354966482e-16,
      6.149350034157603e-16,
      -2.087158612340433e-15,
      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
    ]
  ],
  "S_row_names": [
    "x_0",
    "x_star",
    "x_1",
    "grad_f(x_1)",
    "grad_h(x_0)",
    "x_2",
    "grad_f(x_2)",
    "x_3",
    "grad_f(x_3)",
    "x_4",
    "grad_f(x_4)",
    "grad_h(x_star)"
  ],
  "S_col_names": [
    "x_0",
    "x_star",
    "x_1",
    "grad_f(x_1)",
    "grad_h(x_0)",
    "x_2",
    "grad_f(x_2)",
    "x_3",
    "grad_f(x_3)",
    "x_4",
    "grad_f(x_4)",
    "grad_h(x_star)"
  ],
  "basis_vectors": [
    "x_0",
    "x_star",
    "x_1",
    "grad_f(x_1)",
    "grad_h(x_0)",
    "x_2",
    "grad_f(x_2)",
    "x_3",
    "grad_f(x_3)",
    "x_4",
    "grad_f(x_4)",
    "grad_h(x_star)"
  ],
  "lamb_code": "\ndef idx(tag, N=N_int):\n    if tag == \"x_star\":\n        return N + 1\n    return int(tag.split(\"_\")[1])\n\n\ndef lamb(ri, ci, N=N_int):\n    if ri == \"x_star\" and ci.startswith(\"x_\") and ci != \"x_0\":\n        j = idx(ci, N)\n        if 1 <= j <= N:\n            return sp.Rational(1, N)\n    if ri.startswith(\"x_\") and ci.startswith(\"x_\"):\n        i, j = idx(ri, N), idx(ci, N)\n        if 1 <= i < N and j == i + 1:\n            return sp.Rational(i, N)\n    return sp.S(0)\n",
  "h_lamb_code": "\ndef h_lamb(ri, ci, N=N_int, stepsize=stepsize_value):\n    if ri == \"x_star\" and ci == f\"x_{N}\":\n        return sp.Rational(1, 1) / (stepsize * N)\n    if ri.startswith(\"x_\") and ci.startswith(\"x_\"):\n        i, j = idx(ri, N), idx(ci, N)\n        if 1 <= i <= N and j == i - 1:\n            return sp.Rational(i, 1) / (stepsize * N)\n        if 1 <= i < N and j == i + 1:\n            return sp.Rational(i, 1) / (stepsize * N)\n    return sp.S(0)\n",
  "S_code": "S_guess = pf.Scalar.zero()\n",
  "S_decomp_type": "zero",
  "proof_identity_code": "\nIC = bregman_distance(h, ctx[\"x_star\"], ctx[\"x_0\"])\nperf = f(ctx[f\"x_{N_int}\"]) - f(ctx[\"x_star\"])\nproof_residual = perf - sp.Rational(1, 1) / (stepsize_value * N_int) * 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 * f.interp_ineq(ri, ci, pep_context=ctx)\nfor ri in h_lambda_row_names:\n    for ci in h_lambda_col_names:\n        coeff = h_lamb(ri, ci, N_int, stepsize_value)\n        if coeff != 0:\n            proof_residual -= coeff * h.interp_ineq(ri, ci, pep_context=ctx)\n",
  "proof_valid": true,
  "proof_residual_inner_max": 0.0,
  "proof_residual_func_max": 0.0,
  "rate_note": "For PEPFlow f.bregman_prox(x, stepsize, h), the verified rate is R/(stepsize*N).",
  "rank_profile": [
    2,
    2,
    2,
    2,
    2
  ],
  "rank_tolerance": 1e-08,
  "lyap_inner_prod_coords": [
    [
      [
        0.0,
        0.0,
        0.0,
        0.0,
        0.5,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        0.0,
        0.0,
        -0.5,
        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.5,
        -0.5,
        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.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,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        0.0,
        0.5,
        -0.5,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        0.0,
        -0.5,
        0.5,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        0.5,
        -0.5,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        -0.5,
        0.5,
        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.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,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        0.0,
        0.5,
        -0.5,
        0.0,
        0.5,
        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.5,
        0.0,
        0.0,
        0.0,
        -0.5,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        -0.5,
        0.0,
        0.0,
        0.0,
        0.5,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        0.0,
        -0.5,
        0.5,
        0.0,
        -0.5,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        0.5,
        0.0,
        0.0,
        0.0,
        -0.5,
        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.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.5,
        -0.5,
        0.0,
        0.5,
        0.0,
        0.5,
        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.5,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        -0.5,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        -0.5,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.5,
        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.5,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        -0.5,
        0.0,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        0.0,
        -0.5,
        0.5,
        0.0,
        -0.5,
        0.0,
        -0.5,
        0.0,
        0.0,
        0.0
      ],
      [
        0.0,
        0.5,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        -0.5,
        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.0,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        0.0,
        0.5,
        -0.5,
        0.0,
        0.5,
        0.0,
        0.5,
        0.0,
        0.5,
        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.5,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        -0.5,
        0.0,
        0.0
      ],
      [
        0.0,
        -0.5,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.5,
        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.5,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        -0.5,
        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.5,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        -0.5,
        0.0,
        0.0
      ],
      [
        0.0,
        0.0,
        0.0,
        -0.5,
        0.5,
        0.0,
        -0.5,
        0.0,
        -0.5,
        0.0,
        -0.5,
        0.0
      ],
      [
        0.0,
        0.5,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        0.0,
        -0.5,
        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
      ]
    ]
  ],
  "lyap_func_coords": [
    [
      0.0,
      0.0,
      -1.0,
      0.0,
      0.0,
      0.0,
      0.0,
      0.0,
      0.0,
      0.0,
      1.0
    ],
    [
      -1.0,
      1.0,
      0.0,
      -1.0,
      0.0,
      0.0,
      0.0,
      0.0,
      0.0,
      0.0,
      1.0
    ],
    [
      -2.0,
      0.0,
      0.0,
      0.0,
      2.0,
      -1.0,
      0.0,
      0.0,
      0.0,
      0.0,
      1.0
    ],
    [
      -3.0,
      0.0,
      0.0,
      0.0,
      0.0,
      0.0,
      3.0,
      -1.0,
      0.0,
      0.0,
      1.0
    ],
    [
      -4.0,
      0.0,
      0.0,
      0.0,
      0.0,
      0.0,
      0.0,
      0.0,
      4.0,
      -1.0,
      1.0
    ]
  ],
  "grouping_code": "\ndef triplet_value(fun, tag):\n    return ctx.get_triplet_by_point_tag(tag, func=fun).expand()[1]\n\n\ndef triplet_grad(fun, tag):\n    return ctx.get_triplet_by_point_tag(tag, func=fun).expand()[2]\n\n\ndef bregman_distance_by_tag(kernel, x_tag, y_tag):\n    return (\n        triplet_value(kernel, x_tag)\n        - triplet_value(kernel, y_tag)\n        - triplet_grad(kernel, y_tag) * (ctx[x_tag] - ctx[y_tag])\n    )\n\n\nlyap = []\nfor k in range(N_int + 1):\n    xk = f\"x_{k}\"\n    gap = pf.Scalar.zero() if k == 0 else f(ctx[xk]) - f(ctx[\"x_star\"])\n    lyap.append(\n        sp.S(k) * gap\n        + bregman_distance_by_tag(h, \"x_star\", xk) / stepsize_value\n    )\n",
  "decrement_code": "\n# For k = 1, ..., N_int:\n# V_k - V_{k-1} equals\n#   f.interp_ineq(\"x_star\", f\"x_{k}\")\n# + (k-1) * f.interp_ineq(f\"x_{k-1}\", f\"x_{k}\")\n# + (k-1)/stepsize * h.interp_ineq(f\"x_{k-1}\", f\"x_{k}\")\n# + k/stepsize * h.interp_ineq(f\"x_{k}\", f\"x_{k-1}\").\n# The terms with coefficient k-1 vanish at k = 1.\n",
  "extra_duals": {},
  "lyap_formula": "V_k = k*(f(x_k)-f(x_star)) + D_h(x_star,x_k)/stepsize",
  "decrement_identity_max_residual": 0.0,
  "coverage_rank_final": 2,
  "coverage_note": "V_N = N*(f(x_N)-f(x_star)) + D_h(x_star,x_N)/stepsize; the nonnegative Bregman boundary term gives the final rate.",
  "basis_templates": [
    "[grad_h(x_k), x_k - x_star] for k = 0..N"
  ],
  "basis_by_k": {
    "0": [
      "grad_h(x_0)",
      "x_0-x_star"
    ],
    "1": [
      "grad_h(x_1)",
      "x_1-x_star"
    ],
    "2": [
      "grad_h(x_2)",
      "x_2-x_star"
    ],
    "3": [
      "grad_h(x_3)",
      "x_3-x_star"
    ],
    "4": [
      "grad_h(x_4)",
      "x_4-x_star"
    ]
  },
  "basis_labels_by_k": {
    "0": [
      "grad_h(x_0)",
      "x_0-x_star"
    ],
    "1": [
      "grad_h(x_1)",
      "x_1-x_star"
    ],
    "2": [
      "grad_h(x_2)",
      "x_2-x_star"
    ],
    "3": [
      "grad_h(x_3)",
      "x_3-x_star"
    ],
    "4": [
      "grad_h(x_4)",
      "x_4-x_star"
    ]
  },
  "basis_code": "\ndef h_grad_by_tag(tag):\n    return ctx.get_triplet_by_point_tag(tag, func=h).expand()[2]\n\n\ndef V_k_basis(k):\n    return [h_grad_by_tag(f\"x_{k}\"), ctx[f\"x_{k}\"] - ctx[\"x_star\"]]\n\n\ndef V_k_basis_labels(k):\n    return [f\"grad_h(x_{k})\", f\"x_{k}-x_star\"]\n",
  "coeff_by_k": {
    "0": [
      [
        0.0,
        0.5
      ],
      [
        0.5,
        0.0
      ]
    ],
    "1": [
      [
        0.0,
        0.4999999999999999
      ],
      [
        0.4999999999999999,
        0.0
      ]
    ],
    "2": [
      [
        0.0,
        0.5000000000000001
      ],
      [
        0.5000000000000001,
        0.0
      ]
    ],
    "3": [
      [
        0.0,
        0.5
      ],
      [
        0.5,
        0.0
      ]
    ],
    "4": [
      [
        0.0,
        0.49999999999999994
      ],
      [
        0.49999999999999994,
        0.0
      ]
    ]
  },
  "coeff_code": "\ndef coeff_pattern(k, N, stepsize=stepsize_value):\n    return sp.Matrix([\n        [0, sp.Rational(1, 2) / stepsize],\n        [sp.Rational(1, 2) / stepsize, 0],\n    ])\n",
  "function_coeff_code": "\ndef function_coefficients(k, stepsize=stepsize_value):\n    # V_k = k*(f(x_k)-f(x_star)) + (h(x_star)-h(x_k))/stepsize\n    return {\n        f\"f(x_{k})\": sp.S(k),\n        \"f(x_star)\": -sp.S(k),\n        \"h(x_star)\": sp.Rational(1, 1) / stepsize,\n        f\"h(x_{k})\": -sp.Rational(1, 1) / stepsize,\n    }\n",
  "coefficient_formula": "C_k = [[0, 1/(2*stepsize)], [1/(2*stepsize), 0]] in basis [grad_h(x_k), x_k-x_star]",
  "function_coefficient_formula": "k*f(x_k)-k*f(x_star)+(h(x_star)-h(x_k))/stepsize",
  "coefficient_formula_max_residual": 1.1102230246251565e-16,
  "selected_basis_reason": "The Bregman term contributes only <grad_h(x_k), x_k-x_star>/stepsize to the quadratic coordinates; all remaining terms are function-value coordinates."
}