Министерство образования и науки Российской Федерации
Южно-Уральский государственный университет
Кафедра систем управления
Челябинск, 2005
Курсовая работа по дисциплине «Исследование операций»
Нормоконтроллёр:
Плотникова Н. В.
«____» ___________ 2005 г.
Руководитель:
Плотникова Н. В.
«____» ___________ 2005 г.
Автор:
Студент группы ПС-346
Нечаев Л. В.
«____» ___________ 2005 г.
Работа защищена
с оценкой
«____» ___________ 2005 г.
11
Оглавление
Решение 3
Ответ: 5
Решение 6
Ответ: 8
Примечание: 8
Решение 10
Ответ: 14
Решение 15
Ответ: 19
Список использованной литературы 22Задача 1
Условие
Оператор связи оказывает 2 вида услуг:
1. Предоставление одной линии телефонной сети общего пользования (ТСОП) и трёх линий цифровой связи (ЦС);
2. Предоставление одной линии ЦС и двух линий ТСОП.
Стоимость услуг указана в табл. 1:
Таблица 1
|
|
ТСОП
|
ЦС
|
Цена
|
|
Услуга 1
|
1
|
3
|
750
|
|
Услуга 2
|
2
|
1
|
600
|
|
|
Сети связи и эксплуатируемое оборудование накладывает следующие ограничения на количество используемых линий связи:
ТСОП ? 300
ЦС ? 120
ТСОП+2*ЦС ? 380
Определить оптимальное соотношение услуг 1 и 2, которые оператор должен предоставлять для получения максимальной выручки.
Решение
1. Обозначим за x1 количество оказанных услуг с номером `1, а x2 - количество оказанных услуг с номером `2.
2. Учтём ограничения задачи: .
3. Составим целевую функцию, которую нужно максимизировать:
4. Задача сведена к следующей задаче линейного программирования: «Найти значения аргументов x1 и x2, при которых функция принимает наибольшее значение при ограничениях:. Разумеется, x1?0, x2?0.
5. Решим выше представленную задачу графическим методом, так как в задаче присутствуют только 2 переменные x1 и x2. Для этого:
Изобразим многоугольник решений в плоскости x2Ox1:
График представлен на рис. 1.
В начале максимизации наибольшее значение целевой функции равно 0, также F проходит через начало координат (пунктирная линия на рис. 1). Вектор задаёт направление возрастания целевой функции.
Оптимальное решение находится в точке (0; 95), находящейся на
пересечении прямых . Следовательно, наибольшее значение целевой функции F будет равно , достигается при x1 = 0, x2 = 95.
Итак, для получения наибольшей прибыли (57000 ед.) оператор связи должен не предоставлять услуг 1, а услуг 2 предоставить в количестве 95 штук.
Ответ:
– Не предоставлять yслуг #1
– Yслуг #2 предоставить в количестве 95 штук.
Задача 2
Условие
Решение задачи линейного программирования.
С помощью симплекс-таблиц найти решение задачи линейного программирования: определить экстремальное значение целевой функции F=CTx при условии Ax ? B,
где CT = [ c1 c2 . . . c6 ]T , ВT = [ b1 b2 . . . b6 ]T , XT = [ x1 x2 . . . x6]T , А= [aij] (i=1,6; j=1,3).
Таблица 2
|
c1
|
c2
|
c3
|
c4
|
c5
|
c6
|
b1
|
b2
|
b3
|
Знаки ограничений
|
|
|
|
|
|
|
|
|
|
|
1
|
2
|
3
|
|
4
|
-1
|
12
|
2
|
-1
|
0
|
2
|
13
|
16
|
=
|
=
|
=
|
|
|
|
a11
|
a12
|
a13
|
a14
|
a15
|
a16
|
a21
|
a22
|
a23
|
a24
|
a25
|
a26
|
a31
|
a32
|
a33
|
a34
|
a35
|
a36
|
Ext
|
|
-1
|
1
|
1
|
0
|
0
|
0
|
4
|
3
|
2
|
1
|
1
|
0
|
3
|
2
|
0
|
0
|
1
|
0
|
max
|
|
|
Решение
Составляем систему:
Целевая функция имеет вид
Приведем систему ограничений к виду основной задачи линейного программирования:
Пусть х1, х2 - свободные переменные, х3, х4, х5 - базисные.
Приведем систему и целевую функцию к стандартному виду, для построения симплекс-таблицы:
Составляем симплекс-таблицу.
Это решение является допустимым, но не опорным, т.к. присутствует отрицательный свободный член во второй строке. Ликвидируем его путём замены базисных переменных на основные. В строке x4 находится отрицательный элемент a42=-2, следовательно, столбец x2 - разрешающий. Наименьшее отношение между свободным членом и эл-том разрешающего столбца (см. поле «оценка») будет в первой строке и элемент a32 - разрешающий. Получилась таблица 3 (верхние числа).
Таблица 3
|
Базис
|
Свободный член
|
Переменные
|
Оценка
|
|
|
|
x1
|
x2
|
|
|
x3
|
2
2
|
-1
-1
|
1
1
|
2
|
|
x4
|
-7
4
|
3
-2
|
-2
2
|
-
|
|
x5
|
16
-4
|
3
2
|
2
-2
|
8
|
|
F
|
6
18
|
13
-9
|
-9
9
|
-
|
|
|
Теперь преобразуем таблицу по следующему алгоритму:
1. Выделим разрешающий элемент aij;
2. Найдём обратную ему величину л=1/aij и запишем её в правом нижнем углу этой же ячейки;
3. Все элементы разрешающей строки, кроме разрешающего элемента, умножим на л и запишем внизу соответствующей ячейки;
4. Все элементы разрешающего столбца , кроме разрешающего элемента, умножим на -л и запишем внизу соответствующей ячейки;
5. Выделим все верхние числа в разрешающей строке, и все нижние - в разрешающем столбце;
6. Для каждого из остальных элементов запишем в нижнюю часть ячейки произведение выделенных чисел, стоящих в той же строке и в том же столбце, что и данный элемент;
7. Перепишем таблицу, заменив переменные: элементы разрешающих строки и столбца - значениями, стоящими в нижних частях этих ячеек; оставшиеся элементы - суммой чисел, стоящих в верхних и нижних частях ячеек.
Применительно к текущему шагу, разрешающий элемент a32, л = 1 / a32 = 1. После указанных выше преобразований, получим новую таблицу (табл. 4):
Таблица 4
|
Базис
|
Свободный член
|
Переменные
|
|
|
|
|
x1
|
x3
|
|
|
x2
|
2
|
-1
|
1
|
|
x4
|
-3
|
1
|
2
|
|
x5
|
12
|
5
|
-2
|
|
F
|
24
|
4
|
9
|
|
|
Решение снова не может быть опорным, т.к. присутствует отрицательный свободный член во второй строке. Попытаемся ликвидировать его путём замены базисных переменных на основные. Но в строке x4 больше нет отрицательных элементов, следовательно, невозможно выбрать разрешающий столбец. Заметим, что в строке целевой функции нет отрицательных элементов, значит оптимальное решение, в случае отмены ограничений на переменные, достигнуто. Ограничивающая система уравнений не имеет решений при неотрицательных значениях всех переменных.
Ответ:
Система уравнений несовместима в области положительных значений переменных.
Примечание:
Этот же результат получен и при решении данной задачи в пакете Mathematica:
Задача 3
Условие
Решение транспортной задачи:
1. Записать условия задачи в матричной форме.
2. Определить опорный план задачи.
3. Определить оптимальный план задачи.
4. Проверить решение задачи методом потенциалов.
Таблица 5
|
|
B1
|
B2
|
B3
|
ai
|
|
A1
|
10
|
20
|
32
|
700
|
|
A2
|
12
|
50
|
25
|
600
|
|
A3
|
21
|
18
|
50
|
200
|
|
A4
|
25
|
15
|
23
|
200
|
|
A5
|
21
|
30
|
40
|
100
|
|
bj
|
300
|
700
|
1000
|
|
|
|
Решение
Заметим, что общее количество запасов (700+600+200+200+100=1800) меньше количества заявок (300+700+1000=2000), следовательно имеем открытую транспортную задачу с избытком заявок. Добавим строку с фиктивными запасами для дополнения задачи до задачи закрытого типа. После корректировки получаем транспортную задачу с правильным балансом (табл. 6):
Таблица 6
|
|
B1
|
B2
|
B3
|
ai
|
|
A1
|
10
|
20
|
32
|
700
|
|
A2
|
12
|
50
|
25
|
600
|
|
A3
|
21
|
18
|
50
|
200
|
|
A4
|
25
|
15
|
23
|
200
|
|
A5
|
21
|
30
|
40
|
100
|
|
A6
|
0
|
0
|
0
|
200
|
|
bj
|
300
|
700
|
1000
|
2000
|
|
|
Найдём опорное решение методом наименьших затрат (табл. 7):
Таблица 7
|
|
B1
|
B2
|
B3
|
ai
|
|
|
A1
|
10
300
|
20
400
|
32
-
|
700
|
-10 (2)
|
|
A2
|
12
-
|
50
-
|
25
600
|
600
|
-7 (7)
|
|
A3
|
21
-
|
18
200
|
50
-
|
200
|
-8 (4)
|
|
A4
|
25
-
|
15
100
|
23
100
|
200
|
-5 (5)
|
|
A5
|
21
-
|
30
-
|
40
100
|
100
|
-22 (8)
|
|
A6
|
0
-
|
0
-
|
0
200
|
200
|
18 (9)
|
|
Bj
|
300
|
700
|
1000
|
2000
|
|
|
|
0 (1)
|
-10 (3)
|
-18 (6)
|
|
|
|
|
Выбранный план перевозок является допустимым, т.к. при нём все заявки удовлетворены и все запасы израсходованы, сумма перевозок по строке равна запасу соответствующего пункта отправления, а сумма перевозок по столбцу - заявке соответствующего пункта назначения. Сумма запасов равна сумме заявок, и выражается числом 2000, стоящим в правом нижнем углу таблицы. Данное распределение является базисным (заполнено m+n-1=8 ячеек таблицы), следовательно, задача готова к решению.
Первоначально затраты на перевозку составят:
Составим матрицу оценок методом потенциалов:
Начнём с первого столбца. Пусть потенциал этого столбца равен нулю. Рядом с потенциалом в скобках записываем номер шага. После прибавления потенциала к коэффициентам затрат первого столбца коэффициент затрат заполненной клетки (1;1) не изменится; чтобы полученный после сложения коэффициент стал равен 0, потенциал первой строки таблицы должен быть равен -10; для обнуления коэффициента затрат клетки (1;2) потенциал второго столбца должен быть -10 и т.д.
Изменённые коэффициенты выписываются в виде матрицы оценок:
Критерий оптимальности (базисное распределение поставок верно тогда и только тогда, когда оценки всех свободных клеток неотрицательны) на данном шаге не выполнен - присутствуют 2 свободные клетки с отрицательными оценками.
Продолжим оптимизацию (табл. 8). Составим цикл пересчёта для клетки (5;2) и дадим поставку неё:
Таблица 8
|
|
B1
|
B2
|
B3
|
ai
|
|
A1
|
10
300
|
20
400
|
32
-
|
700
|
|
A2
|
12
-
|
50
-
|
25
600
|
600
|
|
A3
|
21
-
|
18
200
|
50
-
|
200
|
|
A4
|
25
-
|
15 -
100
|
23 +
100
|
200
|
|
A5
|
21
-
|
30 +
-
|
40 -
100
|
100
|
|
A6
|
0
-
|
0
-
|
0
200
|
200
|
|
Bj
|
300
|
700
|
1000
|
2000
|
|
|
В верхнем правом углу знаком «+» отмечаются те клетки, поставки в которые увеличатся, а знаком «-» - те, в которые уменьшатся. Наибольшая возможная поставка, исходя из текущего цикла пересчёта равна min {100, 100, 100} = 100. Передвигаем её по циклу (табл. 9):
Таблица 9
|
|
B1
|
B2
|
B3
|
ai
|
|
|
A1
|
10
300
|
20
400
|
32
-
|
700
|
-10 (2)
|
|
A2
|
12
-
|
50
-
|
25
600
|
600
|
-7 (8)
|
|
A3
|
21
-
|
18
200
|
50
-
|
200
|
-8 (4)
|
|
A4
|
25
-
|
15
0
|
23
200
|
200
|
-5 (5)
|
|
A5
|
21
-
|
30
100
|
40
-
|
100
|
-20 (6)
|
|
A6
|
0
-
|
0
-
|
0
200
|
200
|
18 (9)
|
|
Bj
|
300
|
700
|
1000
|
2000
|
|
|
|
0 (1)
|
-10 (3)
|
-18 (7)
|
|
|
|
|
После передвижения освободились сразу 2 клетки, решение перестало быть базисным. Для того, чтобы оно осталось базисным, дадим фиктивную поставку в клетку (4;2).
Снова составляем матрицу оценок по вышеприведённому алгоритму:
На текущем шаге клеток с отрицательной оценкой нет, следовательно, критерий оптимальности выполнен.
Проверим решение с помощью метода потенциалов (табл. 10). Примем a1 = 0, тогда bj = cij - ai (для заполненных клеток). Если найденное решение справедливо, то во всех пустых клетках таблицы Дij = cij - (ai + bj ) ? 0, и Дij = 0 в заполненных клетках. Получим следующую таблицу (в скобках показаны оценки клеток):
Таблица 9
|
|
B1
|
B2
|
B3
|
ai
|
|
|
A1
|
10 (0)
300
|
20 (0)
400
|
32 (4)
-
|
700
|
-10 (2)
|
|
A2
|
12 (5)
-
|
50 (33)
-
|
25 (0)
600
|
600
|
-7 (8)
|
|
A3
|
21 (13)
-
|
18 (0)
200
|
50 (24)
-
|
200
|
-8 (4)
|
|
A4
|
25 (20)
-
|
15 (0)
0
|
23 (0)
200
|
200
|
-5 (5)
|
|
A5
|
21 (1)
-
|
30 (0)
100
|
40 (2)
-
|
100
|
-20 (6)
|
|
Bj
|
300
|
700
|
1000
|
|
|
|
|
0 (1)
|
-10 (3)
|
-18 (7)
|
|
|
|
|
Условие Дij ? 0 выполняется, следовательно, решение верное.
Ответ:
Таблица 10
|
|
B1
|
B2
|
B3
|
ai
|
|
A1
|
10
300
|
20
400
|
32
-
|
700
|
|
A2
|
12
-
|
50
-
|
25
600
|
600
|
|
A3
|
21
-
|
18
200
|
50
-
|
200
|
|
A4
|
25
-
|
15
-
|
23
200
|
200
|
|
A5
|
21
-
|
30
100
|
40
-
|
100
|
|
Bj
|
300
|
700
|
1000
|
1800/2000
|
|
|
Суммарные затраты на перевозку составляют:
Задача 4
Условие
Решение задачи нелинейного программирования
Определить экстремум целевой функции вида
F = c11x12+c22x22+c12x1x2+b1x1+b2x2
при условиях
a11x1+a12x2<=>p1
a21x1+a22x2<=>p2 .
Данные располагаются в табл. 11.
Найти стационарную точку целевой функции и исследовать ее (функцию) на выпуклость (вогнутость) в окрестностях стационарной точки.
Составить функцию Лагранжа.
Получить систему неравенств в соответствии с теоремой Куна-Таккера.
Используя метод искусственных переменных составить симплекс-таблицу и найти решение полученной задачи линейного программирования.
Дать ответ с учетом условий дополняющей нежёсткости.
Таблица 11
|
b1
|
b2
|
c11
|
c12
|
c22
|
extr
|
a11
|
a12
|
a21
|
a22
|
p1
|
p2
|
Знаки огр.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1
|
2
|
|
1
|
8
|
-1
|
0.5
|
-1
|
max
|
1
|
1
|
0
|
1
|
7
|
5
|
?
|
?
|
|
|
Решение
Целевая функция имеет вид:
Ограничения:
,
1. Определим относительный максимум функции. Для этого необходимы координаты стационарной точки .
,
Получили стационарную точку (1.6;4.4).
2. Исследуем стационарную точку на максимум, для чего и определим вогнутость функции f.
,
Условия выполняются, следовательно целевая функция является строго вогнутой в окрестности стационарной точки.
3. Составим функцию Лагранжа:
Составим систему неравенств в соответствии с теоремой Куна-Таккера.
А)Б)
Перепишем систему А:
A1).Вводим дополнительные переменные v1, v2, w1, w2, превращающие неравенства системы А1 в равенства:
A2)
перепишем систему Б:
Б2)- условия дополняющей нежёсткости
Решим систему А2 с помощью метода искусственных переменных. в первое и второе уравнение системы А2.
Вводим псевдоцелевую функцию
базисные переменные: y1, y2, w1, w2
свободные переменные: x1, x2, v1, v2, u1, u2
Решаем эту задачу симплекс-методом с помощью таблиц и небольшой программы на языке Си, текст которой приведён в Приложении 1.
Таблица 12
|
|
bi
|
x1
|
x2
|
u1
|
u2
|
v1
|
v2
|
|
y1
|
1
0.5
|
2
0.5
|
-0.5
-0.25
|
1
0.5
|
0
0
|
-1
-0.5
|
0
0
|
|
y2
|
8
0.25
|
-0.5
0.25
|
2
-0.125
|
1
0.25
|
1
0
|
0
-0.25
|
-1
0
|
|
w1
|
7
-0.5
|
1
-0.5
|
1
0.25
|
0
-0.5
|
0
0
|
0
0.5
|
0
0
|
|
w2
|
5
0
|
0
0
|
1
0
|
0
0
|
0
0
|
0
0
|
0
0
|
|
Y
|
9M
0.75M
|
-1.5M
0.75M
|
-1.5M
-0.375M
|
-2M
0.75M
|
-1M
0M
|
1M
-0.75M
|
1M
0M
|
|
|
Таблица 13
|
|
bi
|
y1
|
x2
|
u1
|
u2
|
v1
|
v2
|
|
x1
|
0.5
1.1
|
0.5
0.03333
|
-0.25
0.1333
|
0.5
0.1667
|
0
0.1333
|
-0.5
-0.03333
|
0
-0.1333
|
|
y2
|
8.25
4.4
|
0.25
0.1333
|
1.875
0.5333
|
1.25
0.6667
|
1
0.5333
|
-0.25
-0.1333
|
-1
-0.5333
|
|
w1
|
6.5
-5.5
|
-0.5
-0.1667
|
1.25
-0.6667
|
-0.5
-0.8333
|
0
-0.6667
|
0.5
0.1667
|
0
0.6667
|
|
w2
|
5
-4.4
|
0
-0.1333
|
1
-0.5333
|
0
-0.6667
|
0
-0.5333
|
0
0.1333
|
0
0.5333
|
|
Y
|
9.75M
8.25M
|
0.75M
0.25M
|
-1.875M
1M
|
-1.25M
1.25M
|
-1M
1M
|
0.25M
-0.25M
|
1M
-1M
|
|
|
Таблица 14
|
|
bi
|
y1
|
y2
|
u1
|
u2
|
v1
|
v2
|
|
x1
|
1.6
|
0.5333
|
0.1333
|
0.6667
|
0.1333
|
-0.5333
|
-0.1333
|
|
x2
|
4.4
|
0.1333
|
0.5333
|
0.6667
|
0.5333
|
-0.1333
|
-0.5333
|
|
w1
|
1
|
-0.6667
|
-0.6667
|
-1.333
|
-0.6667
|
0.6667
|
0.6667
|
|
w2
|
0.6
|
-0.1333
|
-0.5333
|
-0.6667
|
-0.5333
|
0.1333
|
0.5333
|
|
Y
|
18M
|
1M
|
1M
|
0M
|
0M
|
0M
|
0M
|
|
|
Оптимальное решение:
y1=y2=u1=u2=v1=v2=0
x1=1.6
x2=4.4
w1=1
w2=0.6
Проверим условие дополняющей нежёсткости:
xi*vi=0
ui*wi=0
Условия выполняются, следовательно, x1=1.6, x2=4.4 являются решением исходной задачи kвадратичного программирования. Координаты стационарной точки совпадают с координатами, полученных в качестве ответа. Стационарная точка удовлетворяет условиям ограничений.
Значение функции в точке (x1;x2) равно 0.
Ответ:
x1=1.6
x2=4.4
f(x1;x2) = 0
Приложение 1
Для решения задачи #4 использована следующая программа на языке Си, скомпилированная gcc (GCC) 4.0.0 20050519 (Red Hat 4.0.0-8). Её текст приведён ниже:
#include <stdio.h>
#define x 7
#define y 5
double mc[x*y] =
{
1, 2, -0.5, 1, 0, -1, 0,
8, -0.5, 2, 1, 1, 0, -1,
7, 1, 1, 0, 0, 0, 0,
5, 0, 1, 0, 0, 0, 0,
9, -1.5, -1.5, -2, -1, 1, 1
};
double mt[x*y];
void mprint (double* m, int xs, int ys)
{
int i, j;
printf ("n");
for (j = 0; j < ys; j++)
{
for (i = 0; i < xs; i++)
{
printf ("%10.4lg ", m[j*xs+i]);
}
printf ("n");
}
}
int main (void)
{
int i, j, i1, j1, it, jt;
double msx, msx1;
// Выбираем разрешающий эл-т
nextmtx:
printf ("nИсходная матрица коэффициентов:"); mprint (mc, x, y);
getch ();
msx = 10000.;
for (i = 0; i < x; i++)
{
if (mc[(y-1)*x+i] < 0)
{
// Возможно, найден разрешающий столбец
for (j = 0; j < y; j++)
{
// Ищем наименьшее отношение своб. члена к эл-ту разр. столбца
if (mc[j*x+i] < 1e-32)
continue; // Нулевой или отрицательный
msx1 = mc[j*x] / mc[j*x+i];
if (msx > msx1) // Частное св.ч / р.эл
{
msx = msx1; // наименьшее ищем
it = i; jt = j; // координаты р.эл.
}
}
if (msx > 9999.) continue; // Нет положительных эл-тов
else // найден р.эл., mx != 0
{
i = it; j = jt; // его координаты
}
printf ("n Разрешающий элемент: a(%d;%d) = %lg", j+1, i+1, mc[j*x+i]);
if (mc[j*x+i] > 0)
{
// Это и есть разрешающий элемент (s_el), находим обратную величину
mt[j*x+i] = 1. / mc[j*x+i];
for (i1 = 0; i1 < x; i1++)
{
// Разрешающая строка ( 1/s_el)
if (i1 == i) continue; // Пропустить сам s_el
mt[j*x+i1] = mt[j*x+i] * mc[j*x+i1];
}
for (j1 = 0; j1 < y; j1++)
{
// Разрешающий столбец (-1/s_el)
if (j1 == j) continue; // Пропустить сам s_el
mt[j1*x+i] = - mt[j*x+i] * mc[j1*x+i];
}
// успешно составлены разр. строка и столбец.
// теперь составляем остальные коэфф-ты
for (j1 = 0; j1 < y; j1++)
{
if (j1 == j) continue; // Пропустить всю разреш. строку
for (i1 = 0; i1 < x; i1++)
{
if (i1 == i) continue; // И столбец тоже
// Произведение нижней части столбца
// на верхнюю часть строки
mt[j1*x+i1] = mt[j1*x+i] * mc[j*x+i1];
}
}
/*
* Всё. Готова матрица нижних значений, теперь нужно
* поместить всё на свои места в mc
*/
printf ("nМатрица нижних значений:"); mprint (mt, x, y);
getch ();
for (j1 = 0; j1 < y; j1++)
{
for (i1 = 0; i1 < x; i1++) < ...........
Страницы: [1] | 2 |
|