0

関数を使用した CPLEX に関する小さな作業例を見つけようとしています。ここでの悪い例は、物事をしない方法です。関数は CPLEX でどのように定義されていますか?

Ps 私はすでに線形最適化コース 2.3140 に提出済みの作業を行っています。こちら、アールト大学にあります。

4

1 に答える 1

1

数学の問題のように書くと、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];

関連している

  1. CPLEX でのこの forall ステートメントの何が問題になっていますか?

  2. IBM はここで助けを提供します。

于 2012-11-08T08:54:28.657 に答える