ommx.v1.Instance#
ommx.v1.Instance は最適化問題自体(数理モデル)を記述するためのデータ構造です。次のコンポーネントから構成されます。
決定変数 (
decision_variables)目的関数(
objective)制約条件(
constraints)最大化・最小化(
sense)
例えば簡単な最適化問題を考えましょう
これに対応する ommx.v1.Instance は次のようになります。
from ommx.v1 import Instance, DecisionVariable
x = DecisionVariable.binary(1, name='x')
y = DecisionVariable.binary(2, name='y')
instance = Instance.from_components(
decision_variables=[x, y],
objective=x + y,
constraints={0: x * y == 0},
sense=Instance.MAXIMIZE
)
これらのコンポーネントはそれぞれに対応するプロパティが用意されています。目的関数については前節で説明した ommx.v1.Function の形に変換されます。
instance.objective
sense は最大化問題を表す Instance.MAXIMIZE または最小化問題を表す Instance.MINIMIZE が設定されます。
instance.sense == Instance.MAXIMIZE
決定変数#
決定変数と制約条件については pandas.DataFrame の形式で取得できます
instance.decision_variables
まず kind と lower, upper は数理モデルとして必須の情報です。
kindはその決定変数の種類でBinary, Integer, Continuousに加えてSemiInteger, SemiContinuousがあります。lowerとupperはその決定変数の下限と上限です。Binaryの場合は \([0, 1]\) になります。
加えてOMMXは数理最適化を実務上のデータ分析に統合した時に必要になるようなメタデータを統合的に扱う事を目指して設計されているので、決定変数のメタデータを保持することができます。これらは数理モデル自体には影響を与えないので必須の情報ではありませんがデータ分析や可視化の際に有用です。
nameは人間が読める形の決定変数の名前です。OMMXでは決定変数は常にIDで識別されるのこの名前は重複することがあります。後述するsubscriptsと合わせて利用することが想定されています。descriptionはその決定変数についてのより詳細な説明です。多くの数理最適化問題を扱う際、多次元配列として決定変数を扱うことが多いです。例えば \(x_i + y_i \leq 1, \forall i \in [1, N]\) のような添字 \(i\) を持った制約条件を考えるのが普通でしょう。この時
xとyはそれぞれの決定変数の名前なのでnameに保存し、\(i\) に相当する部分をsubscriptsに保存します。subscriptsは整数のリストであり、もし添字が整数で表現できない倍はdict[str, str]型として保存できるparametersというプロパティが用意されています。
なお直接 ommx.v1.DecisionVariable のリストが欲しい場合は decision_variables プロパティを使うことができます
for v in instance.decision_variables:
print(f"{v.id=}, {v.name=}")
決定変数のIDから ommx.v1.DecisionVariable を取得するには get_decision_variable_by_id メソッドを使うことができます
x1 = instance.get_decision_variable_by_id(1)
print(f"{x1.id=}, {x1.name=}")
制約条件#
次に制約条件を見てみましょう
instance.constraints_df
OMMXでは制約条件もIDで管理されます。このIDは決定変数のIDとは独立です。制約条件のIDは Instance に登録する際に決まります: Instance.from_components に渡す constraints 辞書のキーがそのまま制約条件のIDになります。
制約条件に必須の情報は equality です。equality はその制約条件が等式制約 (Constraint.EQUAL_TO_ZERO) か不等式制約 (Constraint.LESS_THAN_OR_EQUAL_TO_ZERO) かを表します。\(f(x) \geq 0\)のタイプの制約条件は \(-f(x) \leq 0\) として扱われることに注意してください。
制約条件にも決定変数と同様にメタデータを保存することができます。決定変数と同様に name, description, subscripts, parameters が利用できます。これらは add_name, add_description, add_subscripts, add_parameters メソッドで設定できます。
c = (x * y == 0).add_name("prod-zero")
print(f"{c.name=}")
また constraints プロパティを使うことで制約条件IDをキーとする dict[int, ommx.v1.Constraint] を直接取得できます。制約条件のIDから ommx.v1.Constraint を取得するには get_constraint_by_id メソッドを使うことができます。
for cid, c in instance.constraints.items():
print(f"id={cid}: {c}")