- •Работает
- •1.1. История создания эвм.
- •1.3. Размещение данных и программ в памяти пэвм.
- •1.4.Файловая система хранения информации
- •1.5.Операционная система.
- •Лекция 2. Как составляются и выполняются программы в системе delphi
- •2.1. Понятие алгоритма и способы его записи
- •2.2. Общая характеристика языка Паскаль
- •2.3. Как составляется программа в системе Delphi
- •2.4. Наша первая программа реализует линейный алгоритм
- •3.1. Данные и их типы.
- •3.2. Операции над переменными основных скалярных типов
- •Алгоритмов
- •4.1. Понятие разветвляющегося алгоритма
- •4.2. Оператор условия if
- •4.3. Оператор выбора Case
- •4.4. Некоторые возможности, предоставляемые Delphi для организации разветвлений
- •Лекция 5. Составление и програмирование циклических алгоритмов
- •5.1. Понятие цикла
- •5.2. Оператор Repeat...Until
- •5.3. Оператор While...Do
- •5.4. Оператор For...Do
- •5.5. Вложенные циклы
- •5.6. Примеры некоторых часто встречающихся циклических алгоритмов Вычисление заданного члена рекуррентной последовательности
- •Вычисления сумм с использованием рекуррентной последовательности
- •6.1. Ошибки на этапе компиляции
- •6.4. Защищенные блоки
- •6.5. Некоторые стандартные типы исключительных ситуаций
- •6.6. Инициирование собственных исключительных ситуаций
- •6.7. Примеры фрагментов программ
- •Лекция 7. Составление программ с использованием массивов
- •7.1. Понятие массива
- •7.2. Некоторые возможности ввода-вывода в Delphi
- •7.3. Примеры часто встречающихся алгоритмов работы с массивами Сумма n элементов одномерного массива:
- •Произведение диагональных элементов квадратной матрицы:
- •Нахождение максимального элемента одномерного массива:
- •8.1. Статическое и динамическое распределение оперативной памяти
- •8.2. Понятие указателя
- •8.3. Наложение переменных
- •8.4. Динамическое распределение памяти
- •8.5. Организация динамических массивов
- •9.1. Понятие подпрограммы
- •9.2. Описание подпрограмм
- •9.3. Передача данных между подпрограммой и вызывающей ее программой
- •9.4. Оформление подпрограмм в библиотечный модуль
- •9.5. Примеры подпрограмм, оформленных в отдельные библиотечные модули
- •Пример программы, использующей модуль RabMas:
- •Множества
- •10.1. Понятие множества
- •10.2. Операции над множествами
- •10.3. Примеры работы с множествами
- •Interface
- •11.1. Зачем нужны строки
- •11.2. Описание переменных строкового типа «Короткие строки»
- •11.3. Основные операции над переменными строкового типа
- •11.4. Некоторые процедуры и функции обработки строк
- •11.5. Примеры алгоритмов обработки строк
- •Лекция 12. Программирование с использованием записей
- •12.1. Понятие записи
- •12.2. Операции над записями
- •12.3. Использование записей для работы с комплексными числами
- •13.1. Понятие файла
- •13.2. Операции над файлами
- •13.2.1. Типизированные файлы
- •13.2.2. Текстовые файлы
- •13.3. Подпрограммы работы с файлами
- •13.4. Компоненты tOpenDialog и tSaveDialog
- •Лекция 14. Программирование с отображением графической информации
- •14.1. Как рисуются изображения
- •14.2. Построение графиков с помощью компонента tChart
- •Лекция 15. Программирование с использованием рекурсии
- •15.1. Понятие рекурсии
- •15.2. Примеры рекурсивных вычислений
- •16.1. Организация работы с базами данных
- •16.2. Поиск в массиве записей
- •16.3. Сортировка массивов
- •16.3.1. Метод пузырька
- •16.3.2. Метод прямого выбора
- •16.3.3. Метод Шелла
- •16.3.4. Метод Хоара (Hoare)
- •17.1. Работа со списками
- •17.2. Добавление нового элемента в список на заданную позицию
- •17.3. Удаления элемента с заданным номером
- •17.4. Пример программы
- •Лекция 18. Связанные списки на основе рекурсивных данных
- •18.1. Что такое стек и очередь
- •18.2. Понятие рекурсивных данных и однонаправленные списки
- •18.3. Процедуры для работы со стеками
- •18.4. Процедуры для работы с односвязными очередями
- •18.5. Работа с двухсвязными очередями
- •18.6. Процедуры для работы с двусвязными очередями
- •19.1. Основные понятия и определения
- •19.2. Прямые методы решения слау
- •19.3. Итерационные методы решения слау
- •20.1. Зачем нужна аппроксимация функций?
- •20.3. Какие бывают многочлены и способы интерполяции?
- •20.4. Что такое среднеквадратичная аппроксимация?
- •20.5. Метод наименьших квадратов (мнк)
- •21.1. Формулы численного дифференцирования
- •21.2. Формулы численного интегрирования
- •22.1. Как решаются нелинейные уравнения
- •22.2. Итерационные методы уточнения корней
- •22.2.2. Метод Ньютона
- •23.1. Постановка задач оптимизации, их классификация
- •23.2. Методы нахождения минимума функции одной переменной
- •24.1. Задачи для обыкновенных дифференциальных уравнений
- •24.2. Основные положения метода сеток для решения задачи Коши
- •24.3. Многошаговые схемы Адамса
- •Литература
и
ее определитель (это определитель
Вандермонда)
отличен
от нуля, если точки xi
разные.
Поэтому задача (20.2)
имеет
единственное решение, т.е. для заданной
системы различных точек существует
единственный интерполяционный
многочлен.
Погрешность
аппроксимации функции
f(x)
интерполяционным
многочленом степени n-1,
построенным
по n
точкам,
можно оценить, если известна ее
производная порядка n,
по
формуле
dnf
(x)
(h/2)n,
h
=
max
| xi
- xi-11.
(20.5)
i
С
<
Из
(20.5)
следует,
что при h—0
порядок
погрешностиp
при
интерполяции алгебраическим
многочленом равен количеству выбранных
узлов p=n.
Величина
s
может
быть сделана малой как за счет увеличения
n,
так
и уменьшения h.
В
практических расчетах используют, как
правило, многочлены невысокого
порядка (n
< 6), в
связи с тем что с ростом n
резко
возрастает погрешность вычисления
самого многочлена из-за погрешностей
округления.
Один
и тот же многочлен можно записать
по-разному, например,
2 2
1
-
2x
+ x = (x
-1)
. Поэтому
в зависимости от решаемых задач применяют
различные
виды представления интерполяционного
многочлена и способы интерполяции.
Наряду
с общим представлением (20.3)
наиболее
часто в приложениях используют
интерполяционные многочлены в форме
Лагранжа и Ньютона. Их особенность в
том, что не надо находить параметры с
,
так
как многочлены в этой форме
прямо записаны через значения
таблицы
{(xi,
Уг)
j
=
1
...
n}
.
20.3.1.
Интерполяционный
многочлен Ньютона
n-1
Nn-i(xt
)
=
y1
+
X
(xT
-
x1)(xT
-
x2)...(xT
-
xk)Ak (20.6)
k=1
Здесь
xT
-
текущая
точка, в которой надо вычислить значение
многочлена, Ak
-
разделенные
разности порядка k,
которые
вычисляются по следующим рекуррентным
формулам:
Ay(x,x,+1)
= ;A2y(x,xl+1xl+2)
=
xi
xi+1 xi
xi+2
20.3.2.
Линейная
и квадратичная интерполяция
Вычисления
по интерполяционной формуле (20.6)
для
n>3
используют
редко. Обычно при интерполяции по
заданной таблице из m>3
точек
применяют квадратичную n=3
или
линейную n=2
интерполяцию.
В этом случае для приближенного
вычисления значения функции f
в
точке x
находят
в таблице20.3. Какие бывают многочлены и способы интерполяции?
Ay(xixi+1]"A1
y(xi+1xi+22
.
HI f
(X)
-
Pn-\(X
С
(n
-
1)n
dXn
ближайший к этой точке /-узел из общей таблицы, строят интерполяционный многочлен Ньютона первой или второй степени по формулам
ЩxT)
=
yM
+
(xT
_ xi_l)y
^;
xM
<
xT
< xi;
(20.7)
Xi xi_1
;xi_1<xT<xi+1,
N2 (xt ) = Ni(xt ) +(xt _ xi_i)(xt _ xi)
I yi _1 |
_yi |
|
f _ yL |
_ yi+1 I |
|
_xi |
J |
V xi |
_xi+1J |
|
xi |
_1_ |
~ xi +1 |
|
и за значение f(x) принимают N1(x) (линейная интерполяция) или N2(x) (квадратичная интерполяция)
20.3.3. Интерполяционный многочлен Лагранжа Ln_1(xt) = tykek(xt); ek(xt) = f[-xT_^ . (20.8)
i *k
Многочлены e1_1(xj) выбраны так, что во всех узлах, кроме k-го, они обращаются в нуль, в k-ом узле они равны единице:
„ ! Г1, при j = k
enk_1(xi) = \
\0, при j фk.
Поэтому из выражения (20.8) видно, что Ln_1( xt) = yt.
20.3.4. Интерполяция общего вида, использующая прямое решение системы (20.2) методом Гаусса
Следует отметить, что ввиду громоздкости многочлены Ньютона и Лагранжа уступают по эффективности расчета многочлену общего вида (20.3), если предварительно найдены коэффициенты с .
Поэтому, когда требуется производить много вычислений многочлена, построенного по одной таблице, оказывается выгодно вначале один раз найти коэффициенты с и затем использовать формулу (20.3). Коэффициенты с находят прямым решением системы (20.2) c матрицей (20.4), затем вычисляют его значения по экономно программируемой формуле (алгоритм Горнера)
^n_1 (x) = С1 + x(c2 + ... x(cn_2 + x(cn_1 + xcn) ...). (20.9)
20.3.5. Интерполяция общего вида, использующая расчет коэффициентов многочлена (20.3) через многочлен Лагранжа
Находить коэффициенты с многочлена (20.3) можно не решая прямо систему (20.2), а используя разложение коэффициентов Лагранжа (20.8): e"-\x) = a^1 + a& ■ x + ... + cfc1 ■ xn-1, ct = £Ук ■ (20-10)
k=1
Рекуррентные формулы для нахождения коэффициентов akj-1:
оя = т-1 -xm . ат = ат-1 1 . (90 11)
xk-xm xk-xm
am-1 - am-1 _ x
am =^ J- ;1 < j <m; m = 2,..., n-1
xk- xm
получаются из вида многочленов ek. 1 (x), если использовать очевидное представление
em(x)
=
еГх
■
Х
-x"-m
;
e0
= = 1;
m = 1,2,..., n; m * k.
xk xn+m