Решение уравнения методом хорд матлаб

Решение нелинейных уравнений в Matlab

Доброго времени суток. В этой статье мы разберем решение простых нелинейных уравнений с помощью средств Matlab. Посмотрим в действии как стандартные функции, так и сами запрограммируем три распространенных метода для решения нелинейных уравнений.

Общая информация

Уравнения, которые содержат переменные, находящиеся в степенях, отличающихся от единицы, или имеющие нелинейные математические выражения (корень, экспонента, логарифм, синус, косинус и т.д.), а также имеющие вид 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.

Видео:Алгоритмы. Нахождение корней уравнения методом хордСкачать

Алгоритмы. Нахождение корней уравнения методом хорд

Задание 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: Вычислить корень функции:

Видео:Решение произвольных уравнений. Методы вычислений в MATLAB. Часть 1. Урок 61Скачать

Решение произвольных уравнений. Методы вычислений в MATLAB. Часть 1. Урок 61

Численные методы решения нелинейных уравнений. Метод хорд.

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

Метод Ньютона (метод касательных) Пример Решения

Численные методы решения нелинейных уравнений. Метод хорд.

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

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

Геометрически метод хорд эквивалентен замене кривой Решение уравнения методом хорд матлабхордой, проходящей через точки Решение уравнения методом хорд матлаби Решение уравнения методом хорд матлаб(см. рис.1.).

Решение уравнения методом хорд матлаб

Рис.1. Построение отрезка (хорды) к функции Решение уравнения методом хорд матлаб.

Уравнение прямой (хорды), которая проходит через точки А и В имеет следующий вид:

Решение уравнения методом хорд матлаб

Данное уравнение является типовым уравнением для описания прямой вы декартовой системе координат. Наклон кривой задается по ординате и абсциссе с помощью значений в знаменателе Решение уравнения методом хорд матлаби Решение уравнения методом хорд матлаб, соответственно.

Для точки пресечения прямой с осью абсцисс Решение уравнения методом хорд матлабзаписанное выше уравнение перепишется в следующем виде:

Решение уравнения методом хорд матлаб

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

Решение уравнения методом хорд матлабили Решение уравнения методом хорд матлаб.

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

Решение уравнения методом хорд матлаб.

Решение уравнения методом хорд матлаб

Рис.2. Пояснение к определению погрешности расчета.

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

Алгоритм нахождения корня нелинейного уравнения по методу хорд

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

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

Решение уравнения методом хорд матлаб

3. Необходимо найти значение функции Решение уравнения методом хорд матлабв точках Решение уравнения методом хорд матлаб, Решение уравнения методом хорд матлаби Решение уравнения методом хорд матлаб. Далее необходимо проверить два условия:

— если выполняется условие Решение уравнения методом хорд матлаб, то искомый корень находится внутри левого отрезка положить Решение уравнения методом хорд матлаб, Решение уравнения методом хорд матлаб;

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

В результате находится новый интервал неопределенности, на котором находится искомых корень уравнения:

Решение уравнения методом хорд матлаб

4. Проверяем приближенное значение корня уравнения на предмет заданной точности, в случае:

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

Решение уравнения методом хорд матлаб

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

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

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

Пример решения уравнений методом хорд

В качестве примера, рассмотрим решение нелинейного уравнения Решение уравнения методом хорд матлабметодом хорд. Корень необходимо найти в рассматриваемом диапазоне Решение уравнения методом хорд матлабс точностью Решение уравнения методом хорд матлаб.

Вариант решения нелинейного уравнения в программном комплексе MathCAD .

Решение уравнения методом хорд матлаб

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

Решение уравнения методом хорд матлаб

Рис.1. Результаты расчета по методу хорд

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

Примечание:

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

Решение уравнения методом хорд матлаб

Решение уравнения методом хорд матлаб

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

Случай №1: Решение уравнения методом хорд матлаб0,

f»(a)>0″ width=»158″ height=»20″ border=»0″ />

Из первого условия получается, что неподвижной стороной отрезка является – сторона a .

Случай №2: Решение уравнения методом хорд матлаб0″ width=»158″ height=»20″ border=»0″ />

Из второго условия получается, что неподвижной стороной отрезка является – сторона b .

В общем виде, для выявления неподвижного конца можно записать следующее условие: Решение уравнения методом хорд матлаб0″ width=»122″ height=»20″ border=»0″ /> , где Решение уравнения методом хорд матлабили Решение уравнения методом хорд матлаб.

Решение уравнения методом хорд матлаб

Рис. 3. Примеры убывающей или возрастающей функции

Таким образом, в зависимости от вида функции получаются два выражения для упрощения поиска корня функции:

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

Решение уравнения методом хорд матлаб

Решение уравнения методом хорд матлаб, где k =0,1,2,…

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

Решение уравнения методом хорд матлаб

Решение уравнения методом хорд матлаб, где k =0,1,2,…

Случай Решение уравнения методом хорд матлабсводится к рассматриваемому , если уравнение записать в форме: Решение уравнения методом хорд матлаб.

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

🔥 Видео

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

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

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

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

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

Численное решение уравнений, урок 3/5. Метод хорд

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

Метод хорд

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

метод хорд

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

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

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

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