Архитектура Аудит Военная наука Иностранные языки Медицина Металлургия Метрология
Образование Политология Производство Психология Стандартизация Технологии


Технология решения вычислительных задач средствами Matlab



ФЕДЕРАЛЬНОЕ АГЕНТСТВО СВЯЗИ

Федеральное государственное образовательное бюджетное учреждение

высшего профессионального образования

Московский технический университет связи и информатики

Т.И.Семенова, И.Б.Юскова, И.О.Юсков

 

Технология решения вычислительных задач средствами Matlab

Учебное пособие

Москва 2015

ФЕДЕРАЛЬНОЕ АГЕНТСТВО СВЯЗИ

Федеральное государственное образовательное бюджетное учреждение

высшего профессионального образования

Московский технический университет связи и информатики

Т.И.Семенова, И.Б.Юскова, И.О.Юсков

 

Технология решения вычислительных задач средствами Matlab

Учебное пособие

для направления

 

11.03.02 – Инфокоммуникационные технологии
и системы связи

Москва 2015

УДК 32.973.26018.2

Семенова Т.И., И.Б.Юскова, И.О.Юсков Технология решения вычислительных задач средствами Matlab. Учебное пособие / МТУСИ. – М., 2015. – 133 с.

 

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

 

 

Ил. 119, табл. 22, список лит 4 назв.

Издание утверждено советом факультета.

Протокол № от

 

Рецензенты:

 

 

© Московский технический университет

связи и информатики, 2015

 

Содержание

Тема 1. Решение нелинейных уравнений ……………………….90

1.1. Численное решение нелинейных уравнений………….. 90

1.2. Лабораторная работа по теме …………………………. 94

1.3. Контрольные вопросы по теме………………………… 96

 

Тема 2. Технология аппроксимации и интерполяции

функций в среде пакета Matlab ………………………… 97

2.1. Аппроксимация и интерполяция функций…………….. 97

2.2. Лабораторная работа по теме …………………………. 102

2.3. Контрольные вопросы по теме………………………… 104

 

Тема 3. Технология интегрирования в среде Matlab …….... 105

3.1. Вычисление неопределенных и определенных

интегралов……………………………………………. 105

3.2. Лабораторная работа по теме ………………………. 109

3.3. Контрольные вопросы по теме……………………… 112

 

Тема 4. Технология решения обыкновенных

дифференциальных уравнений ………………. 113

4.1. Численное решение обыкновенных

дифференциальных уравнений……………………… 113

4.2. Лабораторная работа по теме……………………..... 118

4.3. Контрольные вопросы по теме……………………… 120

 

Тема 5. Технология решения задач одномерной

оптимизации ………………………………………….. 121

5.1. Решение задач одномерной оптимизации …………. 121

5.2. Лабораторная работа по теме………………………. 124

5.3. Контрольные вопросы по теме ……………………… 125

 

Тема 6. Технология решения задач многомерной

оптимизации …………………………………………… 126

6.1. Решение задач многомерной оптимизации………… 126

6.2. Лабораторная работа по теме……..………………... 129

6.3. Контрольные вопросы по теме……………………... 131

Список литературы ……………………………………………….. 131

 

Тема 1. Решение нелинейных уравнений

1.1. Численное решение нелинейных уравнений

1.2. Лабораторная работа по теме

1.3. Контрольные вопросы по теме

Лабораторная работа по теме

«Технология решения нелинейных уравнений
средствами пакета MatLab»

 

 

1. Вопросы, подлежащие изучению

 

1) Задание функций и их производных с использованием средств пакета Matlab.

2) Получение таблиц значений функций в заданных границах изменения аргумента.

3) Построение графиков функций средствами Matlab.

4) Этапы решения нелинейных уравнений: отделение и уточнение корня.

5) Решение нелинейных уравнений с использованием встроенных функций пакета Matlab: fzero() и solve().

 

 

2. Общее задание

 

1) Изучите материал Темы 1 ( п..1.1 ).

2) Выберите индивидуальный вариант задания из табл. 1.2-1.

3) Отделите корень нелинейного уравнения f(x)=0 с использованием средств пакета Matlab, для чего:

· Постройте графики функции f(x) и ее первой производной;

· на выбранном отрезке пересечения графика с осью ОХ получить таблицы значений функции f(x) и ее первой производной;

· проверить условие существования единственного корня на выбранном отрезке;

4) Решите нелинейное уравнение с использованием функций fzero() и solve ();

5) Предъявите результаты выполнение задания на ПК преподавателю.

3. Варианты индивидуальных заданий

Таблица 1.2-1

 

Уравнение Уравнение
=0
=0
=0
=0
=0

 

Содержание отчета

 

1) В форме комментариев:

· Название лабораторной работы

· ФИО студента, номер группы

· № варианта

· Индивидуальное задание

2) Протокол вычислений (сессии) в окне Command Window, снабженный необходимыми комментариями.

1.3. Контрольные вопросы по теме

1) Что называется, нелинейным уравнением?

2) Этапы решения нелинейного уравнения.

3) Графическое отделение корней нелинейного уравнения средствами Matlab.

4) Аналитическое отделение корней нелинейного уравнения средствами Matlab.

5) Способы задания функции нелинейного уравнения.

6) Назначение и формат функции fzero().

7) Назначение и формат функции solve().

8) Назначение и формат функции roots().

Тема 2.2. Технология аппроксимации
интерполяции функций в среде пакета MatLab

2.2.1. Аппроксимация и интерполяция функций

2.2.2. Лабораторная работа по теме «Технология аппроксимации

интерполяции функций в среде пакета MatLab»

2.2.3. Контрольные вопросы по теме

 

 

Пример 2.2.1-2. Используя значения интерполирующей функции, заданной таблично,

выполнить сплайн-интерполяцию с использованием полиномов нулевой, первой и третьей степени, и получить значения функции в точке х=0.58.

Рис. 2.2.1-5. Вычисление функции в точке х=0.58

На рис. 2.2.1-6 и 2.2.1-7 приведены команды, необходимые для проведения интерполяции таблично заданной функции и построения графиков интерполируемой функции и интерполирующих ее интерполяционных многочленов различных степеней.

 

 

Рис. 2.2.2-6. Команды построения графиков интерполяционных функций

 

Рис. 2.2.2-7. Графики интерполирующих функций

 


 

Лабораторная работа по теме

«Технология аппроксимации интерполяции функций»

 

Вопросы, подлежащие изучению

 

1) Задание векторов и матриц в пакете Matlab.

2) Технология аппроксимации функции, заданной таблично, с использованием функций polyfit ().

3) Технология линейной, кубической и сплайн-интерполяции таблично заданной функции с использованием функций interp1().

4) Получение интерполяционных многочленов в явном виде.

5) Построение графиков аппроксимирующих и интерполирующих функций.

 

 

2. Общее задание

 

1) Изучите материал Темы 2.2. ( п. 2.2.1 ).

2) Выберите индивидуальное задание : номера узлов и номер аппроксимируемой функции из табл. 2.2.2-1; узлы аппроксимации и значения функции в узлах из табл. 2.2.2-2.

3) Задайте в виде векторов значения узлов и значения функции в выбранных узлах.

4) Вычислите коэффициенты аппроксимирующих функций для линейной, квадратичной и кубической аппроксимации с использованием функции polyfit() и получите три аппроксимирующие функции в явном виде.

5) Получите с использованием этих функций значение аппроксимирующей функции в произвольной точке, принадлежащей отрезку, но не совпадающей с узлами аппроксимации, и сравните полученные результаты.

6) Постройте графики табличной и трех аппроксимирующих функций в одном шаблоне, снабдив их легендой.

7) Проведите линейную и кубическую интерполяцию функции с использованием функции interp1(), заданной таблично. Получив значения интерполирующей функции в точке, не совпадающей с узлами интерполяции, сравните полученные результаты.

8) Постройте графики табличной и двух интерполирующих функций в одном шаблоне, снабдив их легендой.

9) Представьте результаты работы преподавателю, ответьте на поставленные вопросы.

10) Выполните команду clear all .

11) Оформите отчет по выполненной работе.

3. Варианты заданий

Таблица 2.2.2-1

 

Вариант № Номера узлов xi Номер функции
1 3 5 7 9 10 13
1 2 4 5 7 10 12
1 3 6 7 10 11 13
1 2 4 7 9 11 13
3 6 7 9 10 11 12
2 3 6 8 9 10 13
1 4 5 7 9 11 12
1 2 4 7 9 12 13
2 3 5 7 8 11 12
1 3 6 7 9 10 13
1 3 7 8 10 11 13
1 2 5 6 7 10 12
1 4 5 8 10 12 13
1 3 5 7 9 10 13
1 3 6 7 8 10 13
1 4 5 7 9 11 12
2 4 5 6 8 12 13
1 4 5 7 9 11 12
1 4 5 8 10 11 12
2 4 5 6 8 12 13
1 4 5 8 10 12 13
2 3 6 8 9 10 13
1 3 5 8 10 12 13
1 4 5 7 9 11 12
2 4 5 6 8 12 13
3 4 5 7 8 9 12
3 5 8 10 11 12 13
2 4 7 9 10 11 13
2 4 5 7 8 10 12
1 4 5 7 9 11 13

 

Таблица 2.2.2-2

 

i xi
-5 1.38 2.44 1.676
-4.5 1.221 2.359 2.025
-4 1.511 1.751 1.736
-3.5 1.501 2.13 1.203
-3 1.455 1.511
-2.5 0.728 1.482 1.362
-2 0.976 1.437 0.75
-1.5 1.065 0.803 0.976
-1 0.599 1.175 0.957
-0.5 0.192 0.49 0.272
0.3 0.375 0.3
0.5 0.319 -6.51*10-3 0.165
-0.405 -1.965 -1.185

 

Содержание отчета

1) В форме комментариев:

· Название лабораторной работы

· ФИО студента, номер группы

· № варианта

· Индивидуальное задание

2) Протокол вычислений (сессии) в окне Command Window, снабженный необходимыми комментариями.

2.2.3. Контрольные вопросы по теме

1) Что такое аппроксимация функции и в каких случаях она используется?

2) В чем отличие аппроксимации от интерполяции?

3) Какой метод аппроксимации реализован в функции polyfit()?

4) Что служит результатом выполнения функции polyfit()?

5) Для чего предназначена функция polyval()?

6) Назначение и формат функции interp1()?

7) Каким параметром определяется тип интерполяции в функции interp1()?

 


Тема 2.3. Технология интегрирования
в среде MatLab

2.3.1. Вычисление неопределенных и определенных интегралов

2.3.2. Лабораторная работа по теме «Технология интегрирования

в среде MatLab»

2.3.3. Контрольные вопросы по теме

 

 

2.3.1. Вычисление неопределенных и
определенных интегралов

 

При вычислении определенных интегралов первообразную функцию F(x) не всегда удается выразить аналитически, а кроме того иногда подынтегральная функция f(x) задана в виде таблицы ( xi и yi, где i = 1, 2, …, n ). Это приводит к необходимости использования численных методов интегрирования.

Существует ряд методов численного интегрирования. Во всех этих методах вычисление осуществляется по приближенным формулам, называемым квадратурами.

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

Формулы прямоугольников:

где:

h – шаг интегрирования;

yi – значение подынтегральной функции от аргумента xi, k=0, 1, …, n;

n – число разбиений интервала интегрирования a, b.

Формула трапеций:

где:

h – шаг интегрирования;

y0 – значение подынтегральной функции при х = a;

yn – значение подынтегральной функции при х = b;

 

Формула Симпсона:

 

Для символьного вычисления неопределенных и определенных интегралов используется функция Matlab int(), которая может иметь один из следующих форматов:

· int(S) – возвращает символьное значение неопределенного инте­грала от символьного выражения или массива символьных выражений S по переменной, которая автоматически определяется функцией findsym(). Если S – скаляр или матрица, то вычисляется интеграл по переменной 'х'.

· int(S, v) – возвращает неопределенный интеграл от S по символьной перемен­ной v.

· int(S, a, b) – возвращает определенный интеграл от S с пределами интегрирования от а до b, причем пределы интегрирования могут быть как символьными, так и числовыми.

· int(S, v, a, b) – возвращает определенный интеграл от S по пере­менной v с пределами от а до b.

 

Ниже приведены примеры использования функции Matlab int()
(рис. 2.3.1-1).

 

 

Рис. 2.3.1-1. Примеры вычисления интегралов

 

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

Для вычисления интеграла по формуле трапеции в MatLab используется функция trapz(x, y). Эта функция возвращает значение интеграла от функции y(x), которая может быть представлена вектором или матрицей. Если y(x) – матрица, то функция возвращает вектор значений интеграла каждого столбца матрицы. Если вектор узлов не задан - trapz(y), то в качестве ординат x используются индексы вектора y ( x=1: length(y )), где функция определяет длину вектора y. Важно, что узлы по оси x могут быть как равноотстоящими, так и неравноотстоящими.

Рассмотрим несколько примеров вычисления значений определенных интегралов методом трапеций при различных способах задания узлов подынтегральной функции (рис. 2.3.1-2).

 

Рис. 2.3.1-2. Вычисление определенных интегралов с использованием

ФункцииMatlab trapz()

 

Для вычисления интеграла по формуле Симпсона в MatLab применяется функция quad(). При обращении к этой функции шаг интегрирования не задается, а используется параметр – требуемая точность вычисления интеграла.

Минимальная форма обращения к функции – q=quad('f', a, b), где f – имя функции, взятое в одинарные кавычки, второй и третий аргументы – пределы интегрирования.

 

Рис. 2.3.1-3. Вычисление определенных интегралов
с использованием функции quad()

Допускается задание четвертого входного параметра eps – абсолютной погрешности: q=quad('f', a, b, eps). По умолчанию eps =10-6.

Рассмотрим примеры вычисления определенного интеграла с использованием функции Matlab quad() (рис. 2.3.1-3).

 

 


Лабораторная работа по теме

«Технология интегрирования в среде Matlab»

 

 

Вопросы, подлежащие изучению

 

1) Получение символьного выражения неопределенного интеграла средствами пакета Matlab.

2) Вычисление значения определенного интеграла с использованием функций.

3) Вычисление значения определенного интеграла с использованием функций Matlab int(), trapz(), quad().

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

 

 

2. Общее задание

 

1) Изучите материал Темы 2.3 ( п. 2.3.1 ).

2) Выберите из табл. 2.3.2-1 вариант индивидуального задания.

3) Получить символьное выражение неопределенного интеграла с использованием функций int( S) и int( S, x ), где S – символьное выражение, а х - переменная.

4) Вычислите значение определенного интеграла с использованием функции int() формата int( S, a, b ), где a, b – пределы интегрирования.

5) Вычислите определенный интеграл с использованием функции Matlab, реализующей формулу трапеций, - trapz(x, y), предварительно получив таблицу значений подынтегральной функции с шагом h и задав значения аргумента и функции в виде векторов.

6) Вычислите значение определенного интеграла с использованием функции Matlab, реализующей формулу Симпсона, – quad('f', a, b), где f – имя функции, взятое в одинарные кавычки.

7) Представьте результаты работы преподавателю, ответьте на поставленные вопросы.

8) Выполните команду clear all.

9) Оформите отчет по выполненной работе.

Варианты индивидуальных заданий

 

Таблица 2.3.2-1

 

Интеграл 1 Интеграл 2

 

 

Содержание отчета

 

1) В форме комментариев:

· Название лабораторной работы

· ФИО студента, номер группы

· № варианта

· Индивидуальное задание

2) Протокол вычислений (сессии) в окне Command Window, снабженный необходимыми комментариями.

2.3.3. Контрольные вопросы по теме

1) Какой функцией в Matlab определяется символьное значение определенного интеграла?

2) Назначение функции trap(x, y).

3) Что возвращает функция trap(x, y), если y(x) – матрица?

4) Можно ли использовать функцию trap(x, y), если узлы по оси х - не равноотстоящие?

5) Какая функция Matlab позволяет вычислить определенный интеграл с заданной точностью?

6) Способы задания подынтегральной функции при вычислении определенного интеграла с использованием функции quad().

7) Какова точность вычисления определенного интеграла по умолчанию?

Тема 2.4. Технология решения обыкновенных
дифференциальных уравнений

2.4.1. Численное решение обыкновенных дифференциальных уравнений

2.4.2. Лабораторная работа по теме

2.4.3. Контрольные вопросы по теме

2.4.1. Численное решение обыкновенных
дифференциальных уравнений

Представим обыкновенное дифференциальное уравнение (ОДУ) первого порядка в виде, разрешенном относительно производной , и пусть – начальные условия его решения.

Тогда решением ОДУ является функция , которая, будучи подставленной в исходное уравнение, обратит его в тождество, и одновременно будут выполняться начальные условия. Эта задача в математике называется задачей Коши.

Задача Коши при решении ОДУ n-го порядка формулируется аналогично, при этом начальными условиями должны быть: При решении ОДУ n-го порядка уравнение путем выполнения ряда обозначений представляется в виде системы дифференциальных уравнений:

 

Результатом решения ОДУ численными методами является таблица значений y = j(x) на некотором множестве значений аргументов. Поэтому при постановке задачи численного решения ОДУ наряду с начальными условиями x0, y0 необходимо задать область решения – отрезок [a; b] и шаг изменения аргумента h (шаг интегрирования).

Для получения численного решения ОДУ используются методы Рунге-Кутты [1]. Методы различаются порядком. Чем выше порядок метода, тем точнее решение, полученное при равном шаге интегрирования.

 

В Matlab имеется несколько функций для решения задачи Коши. Рассмотрим две функции, используемые для решения обыкновенных дифференциальных уравнений (ОДУ): ode23() – использует метод Рунге-Кутты второго и третьего порядка; ode45() – использует метод Рунге-Кутты четвёртого и пятого порядка точности с автоматическим выбором шага.

В MatLab обращением к функциям, предназначенным для решения ОДУ, является:

[x, y] = ode23('fun', t0, tf, x0)

[x, y] = ode45('fun', t0, tf, x0)

 

Входными параметрами функций являются:

· 'fun' – имя функции (в виде строчной переменной) или ссылка на функцию, задающую правую часть дифференциального уравнения (уравнение должно быть записано в нормальной форме
y' = fun(x, y));

· t0 – начальное значение аргумента;

· tf – конечное значение аргумента;

· х0 – вектор начальных условий.

 

Выходными параметрами функций являются:

· x – вектор, содержащий отсчёты аргумента в точках решения;

· y – вектор, содержащий вычисленные значения результата решения ОДУ в точках, соответствующих отсчетам независимой перемен-ной x.

 

Требования к точности и другие параметры численного решения задаются в Matlab по умолчанию. Изменить эти настройки позволяет дополнительный аргумент OPTIONS.

 

 

Рис. 2.4.1-1. Решение ОДУ методом Рунге-Кутты второго порядка

 

Рассмотрим примеры использования функций ode23() и ode45() для решения ОДУ вида: на отрезке [1; 10] с шагом интегрирования 1 при начальных условиях y(1)=1. Решение ОДУ с использованием функции ode23() приведено на рис. 2.4.1-1.

На рис. 2.4.1-2 приведено решение того же ОДУ, но с использованием функции ode45(). Вывод таблицы решения дополнен графиком функции y(x) (рис. 2.4.1-3).

 

Рис. 2.4.1-2. Решение ОДУ методом Рунге-Кутты четвертого порядка

 

 

Рис. 2.4.1-3. Графическое решение ОДУ

 

При решении ОДУ высокого порядка вводят обозначения (новые функции) для всех производных, кроме самой старшей. В этих обозначениях самая старшая производная становится записанной, как первая. Исходное уравнение дополняется тождествами, определяющими правила введения новых функций. Проиллюстрируем описанный подход при решении ОДУ второго порядка.

Требуется решить с начальными условиями: и . Сведем заданное ОДУ к равноценной системе ОДУ первого порядка. Для этого переобозначим функцию , как , и введем функцию . Запишем исходное уравнение в новых обозначениях: (здесь учтено, что ). Дополним это уравнение тождеством и получим нужную систему ОДУ. Эту систему следует дополнить начальными условиями:

Решение системы ОДУ в Matlab начинается с определения векторной функции (рис. 2.4.1-4).

 

 

Рис. 2.4.1-4. Определение векторной функции

 

Для решения дифференциального уравнения (системы уравнений) используем команды, где решение системы ОДУ записывается в переменную y. При этом элемент y(1) содержит значение функции y(x), а y(2) значение производной y'(x). Команда plot(x, y) строит график функции решения ОДУ и ее производной (рис. 2.4.1-6).

 

 

Рис. 2.4.1-5. Решение ОДУ второго порядка

 

 

 

Рис. 2.4.1-6. Графики функций решения ОДУ и производной


Лабораторная работа по теме

«Технология решения обыкновенных

Вопросы, подлежащие изучению

 

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

2) Вычисление числовых значений производных в точках.

3) Функции Matlab, предназначенные для решения ОДУ ( ode23(), ode45() ).

4) Вывод результатов решения ОДУ в виде таблицы.

5) Получение графического решения ОДУ.

 

 

2. Общее задание

 

1) Изучите материал Темы 2.4 ( п. 2.4.1 ).

2) Выберите индивидуальный вариант задания из табл. 2.4.2-1.

3) Найдите символьное выражение производной от функции f(x) и вычислите значение производной от функции f(x) в произвольной точке с.

4) Найдите решение ОДУ на отрезке [a; b] с шагом h с использованием функций ode23() и ode45().

5) Создайте матрицу решений, записав в первый столбец аргумент, во второй и третий - решение, полученное с использованием функций ode23() и ode45(), а в четвертый столбец – погрешность метода (модуль разности решений ОДУ с использованием функций ode23() и ode45()).

6) Выведите полученную таблицу по столбцам.


Поделиться:



Последнее изменение этой страницы: 2017-03-17; Просмотров: 735; Нарушение авторского права страницы


lektsia.com 2007 - 2024 год. Все материалы представленные на сайте исключительно с целью ознакомления читателями и не преследуют коммерческих целей или нарушение авторских прав! (0.192 с.)
Главная | Случайная страница | Обратная связь