Оптимизация функции
Использование программы MatLab, которая позволяет решать задачи одномерной оптимизации функций (нахождение минимума и максимума) различными методами с помощью различных операторов. Метод "золотого" сечения. Блок-схема основного модуля. Листинг программы.
Рубрика | Программирование, компьютеры и кибернетика |
Вид | курсовая работа |
Язык | русский |
Дата добавления | 31.10.2017 |
Размер файла | 100,0 K |
Отправить свою хорошую работу в базу знаний просто. Используйте форму, расположенную ниже
Студенты, аспиранты, молодые ученые, использующие базу знаний в своей учебе и работе, будут вам очень благодарны.
Размещено на http://www.allbest.ru/
Оптимизация функции
Введение
В данной курсовой работе требуется оптимизировать функцию, т. е. найти минимум и максимум функции. Для этого была использована программа MatLab, которая позволяет решать задачи одномерной оптимизации функций (нахождение минимума и максимума) различными методами с помощью таких операторов как plot, grad и т.д.
В курсовой работе задача оптимизации была решена методом дихотомии.
Описание метода.
Метод "золотого" сечения заключается в построении последовательности отрезков [a0, b0], [a1, b1],…, стягивающихся к точке минимума функции f(x). На каждом шаге, за исключением первого, вычисление значения функции f(x) проводится один раз. Эта точка, называемая "золотым" сечением, выбирается специальным образом.
В начале оптимизации внутри отрезка [a0, b0] необходимо выбрать две внутренние точки x1 и x2 и вычислить значения целевой функции f(x1) и f(x2). Поскольку в данном случае f(x1) <f(x2), очевидно, что минимум расположен на одном из прилегающих к точке x1 отрезков, [a0, x1] или [x1, x2]. Поэтому отрезок [x2, b0] можно отбросить, сузив тем самым первоначальный интервал поиска.
Затем, на отрезке [a1, b1], где a1 = a0, b1 = x2,необходимо снова выбрать две внутренние точки, одной из них следует взять точку x1, поэтому достаточно выбрать одну точку x3, вычислить значение f(x3) и провести сравнение. Т.к.f(x3) >f(x1), ясно, что минимум находится на отрезке [x3, b1]. Обозначим данный отрезок [a2, b2], снова выберем одну внутреннюю точку и повторим процедуру сужения интервала поиска. Процесс оптимизации повторяется до тех пор, пока длина очередного отрезка [an, bn] не станет меньше заданной величины точности е.
Алгоритм метода.
1. Вводим границы a, b и . h=100*
2. Делим отрезок пополам c=(b+a)/2
3. Вычисляем приращение функции .Если ,то a=c, иначе , то b=c.
4. Проверяем условие , если нет, то переходим на п.2, да - п.5.
1. 5. Печать: ?точка минимума ?, c, .Конец.
Блок-схема основного модуля.
Блок-схема подпрограммы для задания функции.
Описание программы.
В основном модуле программы вычисляется минимум данной функции методом дихотомии. Входными данными являются начало и конец отрезка, точность. Выходными данными является точка х, в которой функция принимает экстремальное значение.
В данной программе вычисляется функция:
.
В ходе оптимизации функции, построили ее график, по которому установили, что требуется найти минимум функции, определили отрезок оптимизации, на котором располагается минимум и вычислили значение точки минимума.
Таблица 1. Основные подпрограммы.
Подпрограмма |
Входные данные |
Выходные данные |
|
kurs |
a, b, ? |
x |
|
y1=f(x) |
x |
y1 |
Листинг программы.
function kurs; % функция, реализующая метод дихотомии
x=-2:0.01:1; % диапазон изменения х с шагом для построения графика
y1=f(x); % вызов подпрограммы для построения графика
plot(x,y1); % построение графика
grid on; % наложение сетки
xlabel('x'); % подпись оси x
ylabel('y'); % подпись оси y
a=-2; % левая граница поиска
b=1; % правая граница поиска
eps=1e-5; % точность
h=100*eps;
while (abs(b-a)>eps) %начало итерационного цикла
c=(b+a)/2;
df=f(c)-f(c+h);%вычисление приращения функции
if df>0% проверка условия
a=c;
else b=c;
end
end
x_opt=c% значение точки минимума
y=f(x_opt) % значение функции в точке минимума
function y=f(x) % подпрограмма для вычисления значения функции
y=0.87.*sin(1.4.*x).*exp(-0.89.*x)+0.78.*x.^2-2.06;
end
end
Результаты работы.
Рисунок 3. График функции.
По графику функции видно, что при x=0 и y=-2.35, что соответствует результатам расчетов программы. программа оптимизация оператор
Результаты расчетов программы:
x0 =1.4072e-006
y0 =-2.3500
Список литературы
1. Конспект лекций по курсу "Прикладное программирование" для студентов 2-ого курса направления 260100.62-Технология продуктов питания.
2. Оптимизация технологических процессов и В.С. Асламова, И.В. Васильев, О.А. Засухина. - Ангарск, АГТА, 2005 г., 104 с
Размещено на Allbest.ru
...Подобные документы
Создание программы в среде программирования MatLab для решения задачи одномерной оптимизации (нахождение минимума и максимума заданных функций) методом золотого сечения, построение блок-схемы алгоритма и графическое изображение исследованных функций.
реферат [112,0 K], добавлен 14.06.2010Метод установления границ начального отрезка локализации минимума. Метод золотого сечения. Оценивание точки минимума внутри найденного отрезка локализации. Программная реализация метода Свенна на языке C++. Текст программы нахождения точки минимума.
контрольная работа [47,3 K], добавлен 27.01.2011Решение задачи по методу Адамса. Блок-схема функции main. Блок-схема функции Adams. Листинг программы. Блок-схема функции MMinor. Блок-схема функции MatrixMultiply. Блок-схема функции Determinant. Результат решения задачи на ЭВМ.
курсовая работа [68,9 K], добавлен 16.04.2004Разработка программы на языке VBA, которая вводит исходные данные, выполняет расчеты и выводит на экран заданную информацию. Типы блок-схем и их использование при написании программы. Описание входных данных и результат вычислений, листинг программы.
курсовая работа [680,3 K], добавлен 03.08.2009Определение минимума функции на заданном отрезке методами перебора, поразрядного поиска, дихотомии, золотого сечения и методом парабол. Нахождение и расчет нулей функции методом Ньютона. Построение графика данной функции, ее минимальное значение.
реферат [55,6 K], добавлен 09.04.2013Описание и функциональное назначение программы по оптимизации функции, ее логическая структура и используемые технические средства. Практическое применение программы, вызов и загрузка, входные и выходные данные, выполнение контрольного примера и листинг.
курсовая работа [337,4 K], добавлен 26.02.2012Одномерная оптимизация, метод "золотого сечения". Условная нелинейная оптимизация, применение теоремы Джона-Куна-Таккера. Исследование функции на выпуклость и овражность. Безусловная оптимизация неквадратичной функции, метод Дэвидона-Флетчера-Пауэлла.
курсовая работа [2,1 M], добавлен 12.01.2013Исследование типовых примеров задач оптимизации. Реализация программы в среде MatLab для их решения. Изучение функций нелинейной оптимизации. Определение оптимума целевой функции одной или нескольких переменных. Поиск оптимальных настроек регулятора.
лабораторная работа [188,8 K], добавлен 07.12.2016Методика разработки, практической апробации программы в среде Turbo Pascal по построению графика прямой линии регрессии. Формирование блок-схемы данной программы, ее листинг. Построение графика с помощью математических формул и графического модуля Graph.
контрольная работа [46,2 K], добавлен 22.07.2011Описание функций, использующихся в программах. Основы 32-битного программирования на языке Assembler для ОС WINDOWS. Использование функции invoke, которая позволяет намного сократить текст программы и делает приложения похожими на программы для "ЯВы".
курсовая работа [252,6 K], добавлен 20.02.2015Характеристика программы на языке VBA, которая вводит исходные данные, выполняет расчеты и выводит результаты на экран. Описание переменных в программе, ее блок-схема и алгоритм работы. Листинг программы. Описание входных данных и результат вычислений.
курсовая работа [721,4 K], добавлен 10.11.2010Классификация задач нелинейного программирования. Сущность методов безусловной одномерной оптимизации. Построение алгоритма случайного поиска, правило исключения интервалов. Понятие золотого сечения и квадратичной аппроксимации, метод хорд и касательных.
презентация [377,0 K], добавлен 30.10.2013Программирование игр с использованием визуальных компонентов. Описание операторов, используемых при практической реализации разработанной программы. Работа над созданием программы "Морской бой", постановка задачи, алгоритм реализации работы, блок-схема.
курсовая работа [175,9 K], добавлен 10.05.2010Формулировка задачи о замочной скважине, подойдет ли ключ к замку. Составление блок-схемы, которая позволяет наглядно увидеть ход выполнения поставленной задачи. Описание использованных переменных. Анализ результатов вычислений, листинг программы.
курсовая работа [134,1 K], добавлен 07.05.2012Решения алгебраических уравнений методом выделения корней. Аппроксимация функций методом наименьших квадратов; дихотомия, бисекция. Одномерная оптимизация многоэкстремальных функций; метод золотого сечения. Многомерная оптимизация градиентным методом.
курсовая работа [956,7 K], добавлен 04.03.2013Разработка программы на языке Turbo Pascal, обеспечивающей работу пользователя в диалоговом режиме с возможностью выбора функций с помощью одноуровневого меню вертикального типа. Блок-схема и листинг программы, описание руководства пользователя.
курсовая работа [1,5 M], добавлен 17.03.2014Математическая постановка задачи для алгоритмизации, рекуррентная зависимость. Алгоритм решения задачи, блок-схема программы. Тестовые данные для тестирования программы. Результаты, соответствующие для первых вводимых данных и листинг программы.
контрольная работа [27,0 K], добавлен 09.05.2012Математические основы оптимизации. Постановка задачи оптимизации. Методы оптимизации. Решение задачи классическим симплекс методом. Графический метод. Решение задач с помощью Excel. Коэффициенты целевой функции. Линейное программирование, метод, задачи.
реферат [157,5 K], добавлен 21.08.2008"Рой частиц" как наиболее простой метод эволюционного программирования, основанный на идеи о возможности решения задач оптимизации с помощью моделирования поведения групп животных. Схема работы алгоритма, составление кода программы и блок-схемы.
курсовая работа [38,5 K], добавлен 18.05.2013C++ как универсальный язык программирования, его сущность, назначение, классы и возможности. Блок-схема и листинг программы KURS.EXE, ее принцип работы, системные требования, возможные неполадки и способы их устранения. Листинг заставки VOVA777.EXE.
курсовая работа [422,3 K], добавлен 31.05.2010