Доброго времени суток. В этой статье мы разберем решение простых нелинейных уравнений с помощью средств Matlab. Посмотрим в действии как стандартные функции, так и сами запрограммируем три распространенных метода для решения нелинейных уравнений.
- Общая информация
- Стандартные функции Matlab
- Метод перебора Matlab
- Метод простых итераций Matlab
- Метод половинного деления Matlab
- Заключение
- Задание 2: Вычислить корень функции методом хорд
- Численные методы решения нелинейных уравнений. Метод хорд.
- Численные методы решения нелинейных уравнений. Метод хорд.
- Пример решения уравнений методом хорд
- 📽️ Видео
Общая информация
Уравнения, которые содержат переменные, находящиеся в степенях, отличающихся от единицы, или имеющие нелинейные математические выражения (корень, экспонента, логарифм, синус, косинус и т.д.), а также имеющие вид f(x) = 0 называются нелинейными. В зависимости от сложности такого уравнения применяют методы для решения нелинейных уравнений.
В этой статье, помимо стандартных функций Matlab, мы рассмотрим следующие методы:
- Метод перебора
- Метод простых итераций
- Метод половинного деления
Рассмотрим коротко их алгоритмы и применим для решения конкретной задачи.
Стандартные функции Matlab
Для решения нелинейных уравнений в Matlab есть функция fzero. Она принимает в качестве аргументов саму функцию, которую решаем, и отрезок, на котором происходит поиск корней нелинейного уравнения.
И сразу же разберем пример:
Решить нелинейное уравнение x = exp(-x), предварительно определив интервалы, на которых существуют решения уравнения.
Итак, для начала следует привести уравнение к нужному виду: x — exp(-x) = 0 , а затем определить интервалы, в которых будем искать решение уравнения. Методов для определения интервалов множество, но так как пример достаточно прост мы воспользуемся графическим методом.
Здесь задали примерные границы по оси x, чтобы можно было построить график и посмотреть как ведет себя функция. Вот график: 
Из графика видно, что на отрезке [0;1] есть корень уравнения (там, где y = 0), соответственно в дальнейшем будем использовать этот интервал. Чем точнее выбран интервал, тем быстрее метод придет к решению уравнения, а для сложных уравнений правильный выбор интервала определяет погрешность, с которой будет получен ответ.
С помощью стандартной функции Matlab находим корень нелинейного уравнения и выводим. Теперь для проверки отобразим все это графически:
Как вы видите, все достаточно точно просчиталось. Теперь мы исследуем эту же функцию с помощью других методов и сравним полученные результаты.
Метод перебора Matlab
Самый простой метод, который заключается в том, что сначала задается какое то приближение x (желательно слева от предполагаемого корня) и значение шага h. Затем, пока выполняется условие f(x) * f(x + h) > 0, значение x увеличивается на значение шага x = x + h. Как только условие перестало выполняться — это значит, что решение нелинейного уравнения находится на интервале [x; x + h].
Теперь реализуем метод перебора в Matlab:
Лучше всего создать новый m-файл, в котором и прописать код. После вызова получаем такой вывод:
Функцию объявляем с помощью очень полезной команды inline, в цикле пока выполняется условие отсутствия корней (или их четного количества), прибавляем к x значение шага. Очевидно, что чем точнее начальное приближение, тем меньше итераций необходимо затратить.
Метод простых итераций Matlab
Этот метод заключается в том, что функцию преобразуют к виду: x = g(x). Эти преобразования можно сделать разными способами, в зависимости от вида начальной функции. Помимо этого следует задать интервал, в котором и будет производиться итерационный процесс, а также начальное приближение. Сам процесс строится по схеме xn= g(xn-1). То есть итерационно проходим от предыдущего значения к последующему.
Процесс заканчивается как только выполнится условие: , то есть, как только будет достигнута заданная точность. И сразу же разберем реализацию метода простых итераций в Matlab для примера, который был приведен выше.
Здесь должно быть все понятно, кроме одного: зачем задавать число итераций? Это нужно для того, чтобы программа не зацикливалась и не выполняла ненужные итерации, а также потому что не всегда программа может просчитать решение с нужной точностью — поэтому следует ограничивать число итераций.
А вот и вывод программы:
Очевидно, что метод простых итераций работает гораздо быстрее и получает точное решение.
Метод половинного деления Matlab
Метод достаточно прост: существует отрезок поиска решения [a;b], сначала находят значение функции в точке середины c, где c = (a+b)/2. Затем сравнивают знаки f(a) и f(c). Если знаки разные — то решение находится на отрезке [a;c], если нет — то решение находится на отрезке [c;b]. Таким образом мы сократили область в 2 раза. Такое сокращение происходит и дальше, пока не достигнем заданной точности.
Перейдем к реализации метода в Matlab:
Все самое важное происходит в цикле: последовательно сокращаем область нахождения решения, пока не будет достигнута заданная точность.
Вот что получилось в выводе:
Этот метод хорошо работает, когда правильно определен интервал, на котором находится решение. Тем не менее, метод простых итераций считается наиболее точным и быстрым.
Заключение
Сегодня мы рассмотрели решение нелинейных уравнений в Matlab. Теперь нам известны методы перебора, половинного деления, простых итераций. А также, когда нам не важно реализация метода, то можно использовать стандартную функцию в Matlab.
На этом все — спасибо за внимание. В следующей статье мы разберем решение систем нелинейных уравнений в matlab.
Видео:Решение произвольных уравнений. Методы вычислений в MATLAB. Часть 1. Урок 61Скачать

Задание 2: Вычислить корень функции методом хорд
| Ввод x,y, epsilon |
| abs(y-x)>epsilon |
| Начало |
| z=x-(y-x)*f(x)/(f(y)-f(x)), x=y, y=z |
| Вывод результата Z |
| конец |
// Hords.cpp : Defines the entry point for the console application.
double f (double x);
printf(«enter a,b,eps n»);
fprintf(tabfun1,»%15.5le %15.5len»,’a=’,a,’ b=’,b,’ ‘,’eps=’,eps);
double f (double x)
Вывод: При вычислении корня методом хорд на промежутке между 0 и 2 получено значение 2.1
Нахождение корня в MatLab:
Задание 1: Вычислить корень функции:
Видео:Алгоритмы. Нахождение корней уравнения методом хордСкачать

Численные методы решения нелинейных уравнений. Метод хорд.
Видео:Метод Ньютона (метод касательных) Пример РешенияСкачать

Численные методы решения нелинейных уравнений. Метод хорд.
Метод хорд ( метод также известен как Метод секущих ) один из методов решения нелинейных уравнений и основан на последовательном сужении интервала, содержащего единственный корень уравнения 

В отличие от метода половинного деления, метод хорд предлагает, что деление рассматриваемого интервала будет выполняться не в его середине, а в точке пересечения хорды с осью абсцисс (ось — Х). Следует отметить, что под хордой понимается отрезок, который проведен через точки рассматриваемой функции по концам рассматриваемого интервала. Рассматриваемый метод обеспечивает более быстрое нахождение корня, чем метод половинного деления, при условии задания одинакового рассматриваемого интервала.
Геометрически метод хорд эквивалентен замене кривой 


Рис.1. Построение отрезка (хорды) к функции 
Уравнение прямой (хорды), которая проходит через точки А и В имеет следующий вид:
Данное уравнение является типовым уравнением для описания прямой вы декартовой системе координат. Наклон кривой задается по ординате и абсциссе с помощью значений в знаменателе 

Для точки пресечения прямой с осью абсцисс 
В качестве нового интервала для прохождения итерационного процесса выбираем один из двух 




Итерационный процесс уточнения корня заканчивается, когда условие близости двух последовательных приближений станет меньше заданной точности, т.е.

Рис.2. Пояснение к определению погрешности расчета.
Следует отметить, что сходимость метода хорд линейная, однако более быстрая, чем сходимость метода половинного деления.
Алгоритм нахождения корня нелинейного уравнения по методу хорд
1. Найти начальный интервал неопределенности 


2. Найти точку пересечения хорды с осью абсцисс:
3. Необходимо найти значение функции 



— если выполняется условие 


— если выполняется условие 


В результате находится новый интервал неопределенности, на котором находится искомых корень уравнения:
4. Проверяем приближенное значение корня уравнения на предмет заданной точности, в случае:
— если разность двух последовательных приближений станет меньше заданной точности 
— если разность двух последовательных приближений не достигает необходимой точности 

Видео:Решение нелинейного уравнения методом хорд (секущих) (программа)Скачать

Пример решения уравнений методом хорд
В качестве примера, рассмотрим решение нелинейного уравнения 


Вариант решения нелинейного уравнения в программном комплексе MathCAD .
Результаты расчетов, а именно динамика изменения приближенного значения корня, а также погрешности расчета от шага итерации представлены в графической форме (см. рис.1).
Рис.1. Результаты расчета по методу хорд
Для обеспечения заданной точности 


Примечание:
Модификацией данного метода является метод ложного положения ( False Position Method ), который отличается от метода секущих только тем, что всякий раз берутся не последние 2 точки, а те точки, которые находятся вокруг корня.
Следует отметить, что в случае если от нелинейной функции можно взять вторую производную 

Случай №1: 
f»(a)>0″ width=»158″ height=»20″ border=»0″ />
Из первого условия получается, что неподвижной стороной отрезка является – сторона a .
Случай №2: 
Из второго условия получается, что неподвижной стороной отрезка является – сторона b .
В общем виде, для выявления неподвижного конца можно записать следующее условие: 


Рис. 3. Примеры убывающей или возрастающей функции
Таким образом, в зависимости от вида функции получаются два выражения для упрощения поиска корня функции:
— если функция соответствует первому случаю (см. рис. 3), тогда формула будет иметь следующий вид:

— если функция соответствует второму случаю (см. рис. 3), тогда формула будет иметь следующий вид:

Случай 

Для того, чтобы добавить Ваш комментарий к статье, пожалуйста, зарегистрируйтесь на сайте.
📽️ Видео
Численное решение уравнений, урок 3/5. Метод хордСкачать

Метод хорд для приближённого решения алгебраических уравненийСкачать

1 - Решение систем нелинейных уравнений в MatlabСкачать

Метод хордСкачать

Метод Ньютона | Лучший момент из фильма Двадцать одно 21Скачать

1,2 Решение нелинейных уравнений методом хордСкачать

Метод Хорд - ВизуализацияСкачать

Решение нелинейных уравнений методом хордСкачать

Метод хорд для вогнутой функцииСкачать

Метод Ньютона для решения нелинйеных уравнений в MS ExcelСкачать

метод хордСкачать

Алгоритмы С#. Метод секущих(хорд)Скачать

Решение нелинейного уравнения методом Ньютона (касательных) (программа)Скачать

Метод Ньютона (касательных) и хорд Численное решение уравнения c++Скачать

Численное решение уравнений, урок 5/5. Комбинированный метод хорд и касательныхСкачать

МЗЭ 2021 Лекция 11 Метод Ньютона для решения систем нелинейных уравненийСкачать

















