3次方程式
整数上の3次方程式は PyQBPP を使って解くことができます。例えば、次の方程式を考えます:
\[\begin{aligned} x^3 -147x +286 &=0. \end{aligned}\]この方程式には3つの整数解があります: $x = -13, 2, 11$。
3次方程式を解く PyQBPP プログラム
以下の PyQBPP プログラムでは、$[-100, 100]$ の値を取る整数変数 x を定義し、全探索ソルバーを使ってすべての最適解を列挙します:
import pyqbpp as qbpp
x = qbpp.between(qbpp.var_int("x"), -100, 100)
f = x * x * x - 147 * x + 286 == 0
f.simplify_as_binary()
solver = qbpp.ExhaustiveSolver(f)
result = solver.search({"best_energy_sols": 0})
seen = set()
for sol in result.sols():
xv = sol(x)
if xv not in seen:
seen.add(xv)
print(f"x = {xv}")
式 f は以下の目的関数に対応します:
整数変数 x はバイナリ変数の線形式として実装されるため、f は6次の多項式になります。
Python の整数は任意精度であるため、特別な整数型を指定する必要はありません(C++版では INTEGER_TYPE_CPP_INT が必要です)。
最上位のバイナリ変数の係数が2の冪ではないため、同じ整数値が複数の異なるバイナリ変数の割り当てで表現される可能性があります。 そのため、set を使って x の重複する値を除去しています。
このプログラムは以下の出力を生成します:
x = 11
x = 2
x = -13