How to set stopping criteria in mixed integer programming?

Hi guys~
Recently, I am using mixed integer programming to solve a problem.
Actually, I want to let it stop when Relative gap is less than 2%.
options = optimoptions(@intlinprog,'RelativeGapTolerance',0.2,'Display','iter')
[x,fval]=intlinprog(f,iint,A,b,[],[],lb,ub,[],options);
Yet, it seems like this setting doesn't work. It have been running for 30min...
Any suggetions? Thank you very much!

댓글 수: 1

I assume 'RelativeGapTolerance',0.02, for the output underneath the setting of options.

댓글을 달려면 로그인하십시오.

 채택된 답변

Derya
Derya 2021년 5월 20일

2 개 추천

Hello Frank,
The stopping tolerance is automatically modified to
tolerance = min(1/(1+|L|), RelativeGapTolerance)
I estimate the lower bound, L, for your problem at around 96, so intlinprog tolerance for stopping on relative gap would be around 0.01, i.e. 1%. It looks like intlinprog cannot reduce the gap from 1.54% in the following 30 minutes.
You have couple of options:
  1. Increase AbsoluteGapTolerance, e.g. to 2.
  2. Divide the objective function by a factor 2 or more, perhaps 10.
  3. Set CutGeneration and/or Heuristics to 'intermediate' and see if this reduces the time to solution.
Kind Regards,
Derya

댓글 수: 1

Btw, how could I find the running time complexity of the solver
[x,fval]=intlinprog(f,iint,A,b,[],[],lb,ub,[],options);
Thank you very much!

댓글을 달려면 로그인하십시오.

추가 답변 (0개)

카테고리

도움말 센터File Exchange에서 Linear Programming and Mixed-Integer Linear Programming에 대해 자세히 알아보기

제품

릴리스

R2021a

질문:

2021년 5월 18일

댓글:

2021년 11월 25일

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by