0

我是编程新手,但我正在研究 Cplex 优化中的护士分配模型。第一个分配应该提供一个初始可行的解决方案。

为此,我已经定义了护士、病例和角色的变量。

int i =  ... ;
range nurses = 1..n ;               // Set of available nurses

{string} roles  = ... ;             // Set of roles that are required for each surgery

int c = ... ;
range cases = 1..c ;                    // Set of cases scheduled for surgery n the current day

int cc = ... ;
range overlapcases = 1..cc ;            // Overlapping cases

现在我想定义参数(E等于epsilon):

P10 [i][c][k] : 1 如果护士 iEI 可以为案例 cEC 执行角色 kEK,否则为 O

ST [c] : 案例 cEC 的开始时间

ET [c] : 案例cEC的结束时间

P11 [c][cc] : 如果 case cEC 和 case ccEC 重叠,则为 1,否则为 0

如何制定/定义这些参数以从 CPLEX 获取结果?还是我必须在数据文件中写入结果?

实际上我没有任何关于这个问题的数据。所有数据都是虚构的。我想,我必须写开始和结束时间的数据,但我不知道如何处理P10,P11。

我的想法是(而且我知道它不起作用):

boolean P10 [nurses][roles][cases] ;            // Amount of suitable nurses
int ST [cases] = ... ;
int ET [cases] = ... ;
boolean P11 [cases][overlapcases] ;

这里有人可以帮助我吗?非常感谢您提前。问候。

4

1 回答 1

0

要从 .dat 中阅读,让我举一个小例子。

.mod

{string} nurses=...;
{string} roles=...;
{string} cases=...;
{string} overlapcases=...;

int P10 [nurses][roles][cases]=... ;            // Amount of suitable nurses
int ST [cases] = ... ;
int ET [cases] = ... ;
int P11 [cases][overlapcases] =...;

.dat

nurses={"Ann","Mary"};
roles={"A","B"};
cases={"C1","C2"};
overlapcases={"D1"};

P10= [[[1 0][0 1]][[1 0][0 1]]];            
ST  =[1,10] ;
ET  = [4,12];
P11 =[[1]];

PS:您在 CPLEX 产品中有很多示例,甚至还有一个护士示例。

于 2018-05-31T09:51:21.980 回答