25-01-02 Cutting plane algorithm
이 절에서는 integer linear program을 풀 수 있는 cutting plane 알고리즘에 대해 살펴보도록 하겠다.
Valid Inequality
Cutting plane을 정의하기 위해 먼저 valid inequality가 무엇인지 살펴보자.
집합
for all
부등식이 Valid해야 cutting plane이 될 수 있다.
Cutting plane algorithm
이제 다음과 같은 integer programming이 있을 때 cutting plane algorithm을 살펴보도록 하자.
Cutting plane algorithm
다음 알고리즘에서 Convex Problem은 CP로 Integer Program은 IP로 표기한다.
으로 두고 를 계산- for
if 가 (IP) feasible이면 는 optimal solution이므로 Stop함
else
에 대해 valid하면서 를 잘라내는 부등식 ( , )을 찾음
end if
end for
이와 같은 valid inequality를 cutting plane 또는 cut이라고 한다.
알고리즘의 1단계는 convex relaxation을 하여 CP 문제를 푸는 단계이다. 이떄 feasible set은
알고리즘 2단계에서는 구한 해가 IP에서 feasible하다면 이를 해로 본다. 만일 feasible하지 않다면 해인
아래 그림에서 polygon은 집합
이와 같이 집합