Как инициировать границы переменной интервала в docplex (python)? - PullRequest
0 голосов
/ 05 февраля 2020

У меня есть следующий код OPL, и мне нужно реализовать его в docplex (python), я новичок ie в этом поле ...

using CP;
dvar interval I1 in 0..20;
dvar interval I2 in 0..20;
dvar interval I3 in 0..20;

dvar int over1;
dvar int start1;
dvar int end1;

dvar interval artificialInterval;

maximize over1;

subject to
{

    over1==overlapLength(I1,I2);

    start1==maxl(startOf(I1),startOf(I2));

    end1==minl(endOf(I1),endOf(I2));

    startOf(artificialInterval)==start1;
    endOf(artificialInterval)==end1;

    over1==overlapLength(I3,artificialInterval);
} 

Проблема возникает со строками startOf (artificialInterval) == start1; и endOf (tificialInterval) == end1;

Вот что я сделал:

mdl=CpoModel()

   I1=mdl.interval_var(define its parameters)
   I2=mdl.interval_var(define its parameters)
   I3=mdl.interval_var(define its parameters)

   over1=mdl.integer_var()
   start1=mdl.integer_var()
   end1=mdl.integer_var()

   artificialInterval=mdl.interval_var()

   over1=mdl.overlapLength(I1,I2)
   start1=mdl.max(mdl.start_of(I1),mdl.start_of(I2))
   end1=mdl.min(mdl.end_of(I1),mdl.end_of(I2))

   mdl.start_of(artificialInterval) =start1
   mdl.end_of(artificialInterval) =end1

   over1=mdl.overlapLength(I3,artificialInterval)

   obj = mdl.maximize(over1)
   mdl.solve()

С этим у меня есть ошибка синтаксиса "SyntaxError: невозможно назначить вызову функции" Итак, я попытался использовать set_start (start1), но я думаю, что я не использовал его также хорошо ...

Любые советы приветствуются. Спасибо,

1 Ответ

1 голос
/ 05 февраля 2020
from docplex.cp.model import CpoModel 
mdl=CpoModel()

I1=mdl.interval_var(0,10)
I2=mdl.interval_var(0,10)
I3=mdl.interval_var(0,10)

over1=mdl.integer_var()
start1=mdl.integer_var()
end1=mdl.integer_var()

artificialInterval=mdl.interval_var()

mdl.add(over1==mdl.overlap_length(I1,I2))
start1=mdl.max(mdl.start_of(I1),mdl.start_of(I2))
end1=mdl.min(mdl.end_of(I1),mdl.end_of(I2))

mdl.add(mdl.start_of(artificialInterval) ==start1)
mdl.add(mdl.end_of(artificialInterval) ==end1)

mdl.add(over1==mdl.overlap_length(I3,artificialInterval))

obj = mdl.maximize(over1)
mdl.solve()

работает намного лучше

...