Курсовая работа: Рішення задач цілочисленного програмування
3. Додамо умови (18, 19) до умов (£k , C) – задачі. Одержимо нову (£k+1, C) – задачу. Тому що оптимальне рішення x(£k , C) (£k , C) – задачі визначало одну з вершин багатогранника умов, то воно може бути обране в якості первісного опорного рішення для знову отриманої задачі. А це означає, що останню симплексну таблицю (£k , C) – задачі можна взяти в якості вихідної для (£k+1, C) – задачі, доповнивши її умовою (18).
Отже, симплексна таблиця для (£k+1, C) – задачі виходить із останньої симплексної таблиці для (£k , C) – задачі шляхом облямівки (i+1) – й рядком з елементами:
де – небазисні змінні (£k , C) задачі.
Одержимо нову задачу, змінними якої є . Умови цієї задачі дозволені відносно xsl ,…,xsm змінних і нова змінної xn+k+1 , а лінійна форма виражена через небазисні змінні (£k , C) – задачі. Тому що ми займаємося максимізацією F(x) і рішення х* для (£k , C) – задачі оптимально, те всі Di > 0. Тому процес переходу до нового рішення (£k+1, C) – задачі не може бути здійснений по методу уточнення плану. У той же час і тому вектор А0 симплексної таблиці не є опорним рішенням для (£k+1, C) – задачі, тому що рішенням називається вектор, всі координати якого ненегативні й задовольняють умові приналежності області £k+l . Тому назвемо отриманий вектор псевдо рішенням задачі (£k+1, C) і перейдемо до подальшого перетворення симплекса-таблиці.
Позначимо через k номер псевдо рішення (£k , C) – задачі; тоді напрямним рядком є i+k+ 1-я рядок, k =0, 1, 2,…... Тому на кожному етапі перетворення таблиці вектор Ai+k+i буде виводитися з таблиці. Можна довести, що через кінцеве число кроків або буде знайдене цілочисленне рішення, або буде виявлена її нерозв'язність, а тим самим нерозв'язність (£ц , C) – задачі.
Якщо рішення (£k , C) – задачі завершується побудовою оптимального цілочисленного рішення x*, те m , перших його компонентів визначають рішення цілочисленної задачі; якщо серед координат х* є дробові, те один із дробових компонентів (раніше певним правилом) породжує додаткове обмеження й процес рішення повинен бути продовжений з новим рядком, що облямовує. Рядок, використовуваний раніше для облямівки, викреслюється й більше для побудови розширених задач не відновлюється.
Процедуру рішення (£k , C) – задачі (k=0, 1,…)і аналізу отриманого рішення назвемо великою ітерацією. Номер великої ітерації збігається з номером розв'язуваної (£k , C) – задачі.
Результатом великої ітерації є перехід до нового (£k+1, C) – задачі або закінчення рішення задачі.
Уведемо: 1) осередок i, у якій будемо запам'ятовувати номер рядка, на підставі якої будується чергове додаткове лінійне обмеження, 2) лічильник r, що відповідає номеру проведеної великої ітерації. Позначимо x*(£r , C) оптимальне рішення (£r , C) – задачі. Помітимо, що позначення (£r , C) – задача, еквівалентне (£r , C), уведено в блок-схемі для зручності запису.
При деяких умовах вдається довести теорему про кінцівку першого алгоритму Гомори, що ми приведемо без доказу.
Теорема. Нехай множина оптимальних планів задачі (£0 , C) обмежено й виконуються наступні умови:
1) сi – цілі коефіцієнти цільової функції F(x) (i =1,2,…,n),рядок цільової функції в симплексній таблиці враховується при виборі рядка для побудови правильного відсікання;
2) справедливо одне із двох тверджень: або цільова функція обмежена знизу на Сo , або задача (£ц , C) має хоча б один план х'.
Тоді перший алгоритм Гомори вимагає кінцевого числа більших ітерацій.
4. Другий алгоритм Гомори
Другий алгоритм Р. Гомори призначається для рішення задач, у яких вимога цілочисленності накладена на деякі змінні (зокрема й на все). Ми його розглянемо стосовно до задач частково цілочисленного типу, розуміючи, що обчислювальна схема буде справедливої й для задач, повністю цілочисленних.
Нехай в області, певної умовами:
(20)
(21)
– цілі, (22)
потрібно максимізувати функцію
(23)
Метод рішення задачі (20–23) ґрунтується на тій же ідеї, що й метод рішення повністю цілочисленних задач. А саме: будується область £k , що при k = 0 визначається умовами (20–21); вирішується отримана при цьому задача лінійного програмування (20–21, 23). Якщо задача (20–21, 23) виявляється розв'язної, то отримане оптимальне рішення її аналізується на допустимість для вихідної задачі цілочисленного програмування (20–23). Якщо знайдене рішення виявляється целочисленным, то одночасно воно буде оптимальним для (20–23). Якщо оптимальне рішення (£k , C) – задачі виявляється неприпустимим для вихідної задачі (20–23), те здійснюється побудова правильного відсікання й перехід до рішення нової задачі,
Другий алгоритм Р. Гомори формулюється у вигляді наступної теореми:
Теорема. Нехай х(£k , C) – оптимальне рішення (£k , C) – задачі, – елементи відповідної йому симплексної таблиці. Якщо – неціле , то
(24)