Попытка решить задачу, подобную задаче с би-объективной точки зрения.Я играю с этой моделью только для учебных и практических целей.У меня есть две функции стоимости, определенные как:
data:image/s3,"s3://crabby-images/fb7ae/fb7aed82f5e52330d4561a0b29b44c3417cdf89a" alt="F1 = Min\;\sum_v\;{Av} image"
data:image/s3,"s3://crabby-images/d0ae6/d0ae69fcbefce1684c0fb0ccefa21403362a39c0" alt="F2 = Max\;\sum_v\sum_j\sum_i\sum_t\;Y_{v,t}^{j,i}*P_{j,v} image"
is the profit that comes from machine j of vendor v.
I have these decision variables defined in the following high-level form:
= 1 if machine j of vendor v of type t is candidate for client machine i, 0 otherwise.
= 1 if machine i is of type t, 0 otherwise.
= 1 vendor v is selected, 0 otherwise.
Since I have the type of client machines (a total of 3) given as input, I set the values of
= 1,
= 1 and
= 1.
I would like to have a one-to-one mapping between machines candidates and client machines. One machine j from vendor v and type t should be candidate for machine client i :
data:image/s3,"s3://crabby-images/900e6/900e6778a9d66f4ef966e461df87284a7aca9f1a" alt="\sum_jy_{v,t}^{j,i}\;=1\;\forall i,\;\forall t,\;\forall v (C1) image")
Several machines from different vendors v and type t could be candidate for client machine i, only one should be taken:
data:image/s3,"s3://crabby-images/e9061/e90611a276a6a65aa68ef5199c0c6934653c2aa1" alt="\sum_iy_{v,t}^{j,i}\;=1\;\forall&j,\;\forall&t,\;\forall&v (C2) image")
I want to make sure that only one type t is selected per vendor v, machine j for each client machine i:
data:image/s3,"s3://crabby-images/274e4/274e477e31923e030c6f4b4e623d9e8f9663bd1f" alt="\sum_{v}\sum_{j}\sum_{t}Y_{v,t}^{j,i} = 1 \: \forall i \: (C3) image")
I want to make sure when a vendor v is selected then corresponding candidate machines comes from it otherwise no machine is candidate if a vendor is not selected :
data:image/s3,"s3://crabby-images/fd56b/fd56baa715ec67a508eb0d8f45b76c27d3877546" alt="Y_{v,t}^{j,i}\;$\leq $A_{v}\; \forall j,\;\forall t,\;\forall v, \forall i\;(C4) image")
I want to make sure when a candidate machine j from vendor v is candidate then its corresponding type matches the type t of client machine i:
data:image/s3,"s3://crabby-images/884df/884df755407a7160ecacbc71cba3fe3561094e0f" alt="Y_{v,t}^{j,i}\;$\leq $Z_{t}^{i}\; \forall i,\;\forall j,\;\forall t,\;\forall v (C5) image")
The specs values of the candidate machine j should be less than the ones requested by machine i:
![Y_{v,t}^{j,i}\; * Specs_{j}[k]$ \leq $Specs_{i}[k]$ $\forall i,\;\forall j,\;\forall t,\;\forall v, \;\forall k (C6) image](https://latex.codecogs.com/gif.latex?Y_%7Bv,t%7D%5E%7Bj,i%7D%5C;&space;*&space;Specs_%7Bj%7D[k]$&space;%5Cleq&space;$Specs_%7Bi%7D[k]$&space;$%5Cforall&space;i,%5C;%5Cforall&space;j,%5C;%5Cforall&space;t,%5C;%5Cforall&space;v,&space;%5C;%5Cforall&space;k&space;(C6))
I am not sure why it selects only one vendor and returns several Y variables instead of only some of them with the corresponding type of the client's machine.
I am not able to spot my mistake and how to handle this issue, any help would be appreciated. I attached the model in its lp format (vendors) and the output (gurobi_output) got from gurobi following this ссылка