Оптимизация функции

Использование программы 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.2013

  • C++ как универсальный язык программирования, его сущность, назначение, классы и возможности. Блок-схема и листинг программы KURS.EXE, ее принцип работы, системные требования, возможные неполадки и способы их устранения. Листинг заставки VOVA777.EXE.

    курсовая работа [422,3 K], добавлен 31.05.2010

Работы в архивах красиво оформлены согласно требованиям ВУЗов и содержат рисунки, диаграммы, формулы и т.д.
PPT, PPTX и PDF-файлы представлены только в архивах.
Рекомендуем скачать работу.