私は世界の cp オプティマイザーに不慣れで、これは小さなテストを開始しています。次の質問があります。あなたの助けが必要です。これは私のコードです:
データ
const IloInt nbPair = 6;
const IloInt nbPairElements = 15;
const IloInt nbElement = 2;
IloIntVarArray SolPair(env, nbPair,0,1);
IloIntArray PairCost(env, nbPair,100,150,200,300,350,133);
IloIntArray2 PairElements(env, nbPairElements);
PairElements[0] = IloIntArray(env, nbElement, 0,1);
PairElements[1] = IloIntArray(env, nbElement, 0,2);
PairElements[2] = IloIntArray(env, nbElement, 1,1);
PairElements[3] = IloIntArray(env, nbElement, 1,2);
PairElements[4] = IloIntArray(env, nbElement, 1,3);
PairElements[5] = IloIntArray(env, nbElement, 2,3);
PairElements[6] = IloIntArray(env, nbElement, 2,4);
PairElements[7] = IloIntArray(env, nbElement, 2,5);
PairElements[8] = IloIntArray(env, nbElement, 3,1);
PairElements[9] = IloIntArray(env, nbElement, 3,2);
PairElements[10] = IloIntArray(env, nbElement, 3,3);
PairElements[11] = IloIntArray(env, nbElement, 4,2);
PairElements[12] = IloIntArray(env, nbElement, 5,2);
PairElements[13] = IloIntArray(env, nbElement, 5,4);
PairElements[14] = IloIntArray(env, nbElement, 5,5);
// build model
//Objective
IloExpr Obj_Func_1(env);
for (int i = 0; i < nbPair; ++i)
{
Obj_Func_1 += PairCost[i] * SolPair[i];
}
model.add(IloMinimize(env, Obj_Func_1));
Obj_Func_1.end();
IloCP cp(model);
.....
PairElements はタプル [Par, element] であり、次の制限で最低コストのカップルを取得する必要があります::
- There should be a single time all elements.
制限の作成方法がわからない
結果は次のとおりです。
パー: 0 と 2。
2 つのペアにはすべての要素が一度に含まれ、低コストで表されるため
どうもありがとう フアン・カルロス