関数を使用した CPLEX に関する小さな作業例を見つけようとしています。ここでの悪い例は、物事をしない方法です。関数は CPLEX でどのように定義されていますか?
Ps 私はすでに線形最適化コース 2.3140 に提出済みの作業を行っています。こちら、アールト大学にあります。
数学の問題のように書くと、index-out-of-bound でエラーが発生しました。
// Decision variables
dvar float+ z[0..4];
dvar float a[0..4];
dvar float+ x[0..5];
dvar float+ v[0..5];
minimize sum(myZ in 0..4) z[myZ];
subject to {
startX: x[0]==0;
startV: v[0]==0;
endX: x[4]==1;
x[5]==1;
endV: v[4]==0;
v[5]==0;
forall(t in 0..4){
a[t]<=z[t];
-a[t]<=z[t];
x[t+1]==x[t]+v[t];
v[t+1]==v[t]+a[t];
}
}
そして、これが解決策です:
// solution (optimal) with objective 0.666666666666667
// Quality There are no bound infeasibilities.
// There are no reduced-cost infeasibilities.
// Maximum Ax-b residual = 1.11022e-016
// Maximum c-B'pi residual = 1.11022e-016
// Maximum |x| = 1
// Maximum |slack| = 0.666667
// Maximum |pi| = 1.66667
// Maximum |red-cost| = 1
// Condition number of unscaled basis = 2.1e+001
//
z = [0.33333
0 0 0.33333 0];
x = [0 0 0.33333 0.66667 1 1];
v = [0 0.33333 0.33333 0.33333 0 0];
a = [0.33333 0 0 -0.33333 0];
関連している
IBM はここで助けを提供します。