- •Е.В. Макарова
- •Введение
- •Практическое задание № 1. Задача распределения ресурсов
- •Элементы теории.
- •Элементы теории.
- •Контрольные вопросы
- •Практическое задание № 2. Транспортная задача
- •Контрольные вопросы
- •Практическое задание № 3. Задача о назначениях
- •Контрольные вопросы
- •Практическое задание № 4. Определение наикратчайшего пути между вершинами ориентированного графа с циклами
- •Контрольные вопросы
- •Практическое задание № 5. Размещение проектируемого объекта
- •Контрольные вопросы
- •Практическое задание № 6. Задача об изготовлении стержней
- •Контрольные вопросы
- •Практическое задание № 7. Определение границ интервала поиска оптимума одномерной функции
- •Элементы теории.
- •Контрольные вопросы
- •Практическое задание № 8. Определение оптимума одномерной функции. Методы исключения интервалов. Метод деления интервала пополам
- •Элементы теории
- •Контрольные вопросы
- •Практическое задание № 9. Определение оптимума одномерной функции. Методы исключения интервалов. Метод золотого сечения
- •Элементы теории.
- •Контрольные вопросы
- •Индивидуальные задания для самостоятельной работы Задание 1
- •Задание 2
- •Задание 3
- •Задание 4
- •Задание 5
- •Задание 6
- •Задание 7
- •Задание 8
- •Задание 9
- •Задание 10
- •Заключение
- •Список рекомендуемой литературы
Контрольные вопросы
Какая типовая задача оптимизации положена в основу задачи об изготовлении стержней?
К какому классу задач относится задача об изготовлении стержней и почему?
С помощью какой модели решаются задачи этого класса?
Что является исходными переменными математической модели задачи об изготовлении стержней?
Какой вид имеет математическая постановка данной задачи?
Какая система ограничений типа неравенств формирует множество допустимых альтернатив решения задачи?
Практическое задание № 7. Определение границ интервала поиска оптимума одномерной функции
Задание.
Определить знак начального шага (D).
Определить интервал поиска минимума функции по заданным исходным данным (табл. 7.1).
Таблица 7.1
Вариант |
Вид функции |
х0 |
|D| |
0 |
3x·(x-1) |
10 |
5 |
1 |
x2+5 |
22 |
1 |
2 |
x2+2x+1 |
-20 |
2 |
3 |
(1-x)4 |
25 |
3 |
4 |
(x2+1)/x |
-20 |
4 |
5 |
3x·(x-1) |
10 |
5 |
6 |
x2+5 |
-20 |
2 |
7 |
x2+2x+1 |
25 |
3 |
8 |
(1-x)4 |
-20 |
4 |
9 |
(x2+1)/x |
10 |
1 |
Решить задачу с помощью определения границ интервала поиска оптимума одномерной функции.
Работа рассчитана на 2 аудиторных часа.
Элементы теории.
Все методы одномерной оптимизации основаны на предположении, что исследуемая целевая функция в допустимой области по крайней мере обладает свойством унимодальности, так как для унимодальной функции сравнение значений f(х(1)) и f(x(2)) в двух различных точках интервала поиска позволяет определить в каком из заданных двумя указанными точками подынтервалов точки оптимума отсутствуют.
Функция называется унимодальной на определенном промежутке, если она обладает только одним экстремумом.
Экстремум функции находится в точке, где значение первой производной и, соответственно, тангенс угла наклона касательной к графику и сам угол равны 0.
В процессе применения одномерных методов поиска оптимума функции можно выделить два этапа:
Установления границ интервала;
Уменьшения интервала.
Пусть функция f(х) унимодальна на замкнутом интервале a £ x £ b, а ее минимум достигается в точке х* (рис. 7.1).
Рис. 7.1
Рассмотрим точки х(1) и х(2), для которых а < х(1) < х(2) < b.
Если f(x(1)) > f(x(2)), то x*Î (x1, b);
Если f(x1) < f(x2), то x*Î (a, x2);
Если f(x1) = f(x2), то x*Î (х1, x2).
Поиск граничных точек проводится с помощью эвристических методов поиска. Одним из таких методов является метод, предложенный Свенном. Выбирается исходная точка, а затем на основе правила исключения строится относительно широкий интервал, содержащий точку оптимума (k+1). Пробная точка определяется по рекуррентной формуле:
x(k+1)= x(k)+2k·D , k=0,1,2...
где D - подбираемая величина шага.
Знак подбирается путем сравнения значений f(x(0)), f(x(0)+) и f(x(0) – ).
Если f(x(0)–) f(x(0)) f(x(0)+)то, согласно предположению об унимодальности, точка минимума должна располагаться правее точки х(0) и величина выбирается положительной.
Если f(x(0)–) f(x(0)) f(x(0)+), то выбирается отрицательной.
Если f(x(0)–) f(x(0)) f(x(0)+), то точка минимума лежит между x(0) – и x(0)+и поиск граничных точек завершен.
Алгоритм метода Свенна.
Шаг 1. Выбрать произвольную начальную точку х(0) и D – начальный положительный шаг (подбираемая величина).
Шаг 2. Вычислить f(x(0)), f(x(0)+ D)
Шаг 3. Сравнить f(x(0)), f(x(0)+ D):
а) если f(x(0)) > f(x(0)+ D) то, согласно предположению об унимодальности функции, точка минимума должна лежать правее, чем точка х(0). Положить а = х(0), х(1) = х(0) + D, f(x(1)) = f(x(0)+ D), k = 2 и перейти на шаг 5.
б) если f(x(0)) ≤ f(x(0)+ D), то вычислить f(x(0)- D).
Шаг 4. Сравнить f(x(0) - D), f(x(0)):
а) если f(x(0) - D) ≥ f(x(0)), то точка минимума лежит между точками x(0) - D и x(0) + D, которые и образуют границы начального отрезка локализации минимума. Положить а = х(0) - D, b = x(0) + D и завершить поиск.
б) если f(x(0) - D) < f(x(0)) то, согласно предположению об унимодальности функции, точка минимума должна лежать левее, чем точка х(0).
Положить b = x(0), x(1) = x(0) - D, f(x(1)) = f(x(0) - D), D = - D, k=2 и перейти на шаг 5.
Шаг 5. Вычислить х(k) = х(0) + 2(k-1)· D, f(x(k))..
Шаг 6. Сравнить f(x(k)), f(x(k-1)):
а) если f(x(k-1)) ≤ f(x(k)), то
при D > 0 положить b = x(k),
при D < 0 положить а = x(k)
и завершить поиск.
б) если f(x(k-1)) > f(x(k)), то
при D > 0 положить а = x(k-1)
при D < 0 положить b = x(k-1),
положить k = k+1 и перейти на шаг 5.
Выполнение работы в среде MS EXCEL
Работа начинается с формирования блока исходных данных. В данном случае исходными данными являются вид минимизируемой функции, начальная точка поиска х(0) и величина шага D.
Определение знака D.
Для этого необходимо подсчитать значения функции в точках х(0), х(0) + |D|, х(0) ‑ |D|, затем сравнить эти значения. Для сравнения значений функции и выбора в зависимости от этого знака D необходимо использовать логическую функцию MS EXCEL ЕСЛИ(). Аргумент этой функции имеет следующую размерность: ЕСЛИ (логическое выражение; значение, если истина; значение, если ложь). Для записи условий сравнения значений функции в этих точках используется также логическая функция И(), имеющая размерность И (логическое выражение 1; логическое выражение 2). Данная функция возвращает значение ИСТИНА, если хотя бы одно логическое выражение ИСТИНА, или ЛОЖЬ, если оба логических выражения ЛОЖЬ. Любая функция EXCEL может быть использована в качестве аргумента другой функции. В этом случае она называется вложенной. В MS EXCEL может быть использовано до 9 уровней вложения функций.
Для задачи функция должна быть записана таким образом:
=ЕСЛИ(И(f(х(0)) <= f(х(0) -|D|);f(х(0)) >= f(х(0) +|D|));D;
(ЕСЛИ(И(f(х(0))>=f(х(0) -|D|);f(х(0))<=f(х(0) +|D|));‑D;
«Поиск границ завершен»)).
Данная функция возвращает значение D или ‑ D в зависимости от значений функции в точках х(0), х(0) +|D|, х(0) ‑ |D|, либо признает точки х(0) +|D|, х(0) ‑ |D| границами интервала. В последнем случае, кроме того, что границы интервала найдены, необходимо вывести их в виде а = х(0) ‑ |D|, b= х(0) +|D|. Для этого необходимо составить новую функцию, которая не возвращает ничего, если
f(х(0) ‑ |D|) >= f(х(0)) >= f(х(0) +|D|, f(х(0) -|D|) <= f(х(0)) <= f(х(0) +|D|,
и возвращает в одной ячейке значение «а=», в смежной с ней – значение х(0) - |D|, еще в одной ячейке – «b=» и в смежной с ней ‑ х(0) + |D|, если
f(х(0) -|D|) >= f(х(0)) <= f(х(0) +|D|.
Данная функция составляется аналогично предыдущей с использованием функций ЕСЛИ() и И().
Таким образом, если границы интервала не найдены при выполнении I этапа работы, определился, как минимум, знак D. Теперь можно приступить к определению границ интервала.
Начальная точка х(0) задана, следующие пробные точки определить по алгоритму Свенна. В расчетном блоке для их определения необходимо выделить отдельную графу для индекса х, так как этот индекс используется в формуле для расчета пробных точек. Сам расчет пробных точек и значений функции в этих точках очевиден и не требует подробного рассмотрения.
Вывести на экран результаты сравнения значений функции в пробных точках. Предлагается выводить эти результаты в двух графах. В левой графе выводится текст «x>» или «x<» в зависимости от значения функции в пробной точке и знака D, а в правой графе выводятся значение х в пробной точке. Если f(x(k+1)) < f(x(k)), то выводится «x>», если f(x(k+1)) > f(x(k)) – «x<» для D положительной. Для D отрицательной наоборот – «x<», если f(x(k+1)) < f(x(k)) и «x>», если f(x(k+1)) > f(x(k)). Для этого в левой графе составляется следующее выражение: =ЕСЛИ (f(x(k+1)) < f(x(k));ЕСЛИ(D > 0; «x>»; «x<»);ЕСЛИ(D > 0; «x<»; «x>»)). Для копирования выражения во все ячейки левой графы следует не забыть присвоить ячейке, содержащей D, абсолютный адрес.
Для вывода необходимых значений х в правой графе также составляются логические функции. Границами интервала поиска будут значения x, соответствующие последнему «x>» – а, и первому «x<» – b для D > 0, и наоборот, последнему «x<» – а и первому «x>» – b для D<0.
Пример 7. Определение интервала поиска минимума функции.
Исходные данные | ||
f(x) |
х(0) |
D |
(100-x)2 |
30 |
5 |
Определение знака D
х(0) -D |
25 |
f(х(0) - D) |
5625 |
D=5 |
х(0) |
30 |
f(х(0)) |
4900 | |
х(0) +D |
35 |
f(х(0) + D) |
4225 |
x |
Индекс х |
f(x) |
Границы интервала |
30 |
0 |
4900 |
|
35 |
1 |
4225 |
x>30 |
45 |
2 |
3025 |
x>35 |
65 |
3 |
1225 |
x>45 |
105 |
4 |
25 |
x>65 |
185 |
5 |
7225 |
x<185 |
345 |
6 |
60025 |
x<345 |
Выводы: для D = 5 границами интервала поиска минимума функции y = (100 - x)2 являются 65 < x < 185.