Численное интегрирование-методом Гаусса

Автор работы: Пользователь скрыл имя, 15 Ноября 2009 в 19:38, Не определен

Описание работы

В этой работе указан метод численного интегрирования

Файлы: 1 файл

КУРСОВАЯ РАБОТА (некоторые методы численного интегрирования).doc

— 112.00 Кб (Скачать файл)

2.6 Метод Гаусса-Кронрода

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

,

где - узлы метода Гаусса по точкам, а параметров , , подобраны таким образом, чтобы порядок точности метода был равен .

Тогда для оценки погрешности  можно использовать эмпирическую формулу:

,

где - приближённое значение интеграла, полученное методом Гаусса по точкам.

3. Описание методов  вычислительной математики, которые будут использованы при решении поставленной задачи

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

Аппроксимация, или приближение - математический метод, состоящий в замене одних математических объектов другими, в  том или ином смысле близкими к исходным, но более простыми. Аппроксимация позволяет исследовать числовые характеристики и качественные свойства объекта, сводя задачу к изучению более простых или более удобных объектов (например, таких, характеристики которых легко вычисляются или свойства которых уже известны). В теории чисел изучаются диофантовы приближения, в частности приближения иррациональных чисел рациональными. В геометрии рассматриваются аппроксимации кривых ломаными. Некоторые разделы математики в сущности целиком посвящены аппроксимации, например, теория приближения функций, численные методы анализа.

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

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

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

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

На  практике чаще всего  применяют интерполяцию полиномами. Это связано  прежде всего с тем, что полиномы легко вычислять, легко аналитически находить их производные и множество полиномов плотно в пространстве непрерывных функций.

3.1. Разработка алгоритма  решения задачи  и описание его  особенностей

Пусть функция задана на стандартном интервале . Задача состоит в том, чтобы подобрать точки и коэффициенты так, чтобы квадратурная формула

(1.1)

была  точной для всех полиномов  наивысшей возможной  степени.

Ввиду того, что имеется  параметров и , а полином  степени определяется коэффициентами, эта наивысшая степень в общем случае .

Запишем полином в виде и подставим в (1.1). Получим

,

.

Приравнивая выражения при  одинаковых коэффициентах  получим

, ,

, .

Итак, и находят из системы  уравнений

,

,

, (1.2)

... ... .

.

Система (1.2) нелинейная, и ее решение найти довольно трудно. Рассмотрим еще один прием нахожденияи . Свойства полиномов Лежандра

,

таковы:

1) , ;

2) ;

3) полином Лежандра  имеет различных  и действительных  корней, расположенных  на интервале .

Составим  по узлам интегрирования многочлен -й степени

.

Функция при есть многочлен  степени не выше . Значит для этой функции  формула Гаусса справедлива:

, (4.3)

так как .

Разложим  в ряд по ортогональным  многочленам Лежандра:

,

,

,

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

Зная , из линейной теперь системы первых (4.2) легко найти коэффициенты . Определитель этой системы  есть определитель Вандермонда.

Формулу , в которой - нули полинома Лежандра , а определяют из (3.3), называют квадратурной формулой Гаусса.

Таким образом, алгоритм решения  нашей задачи будет  таким:

Ввод  данных - пределы  интегрирования, количество узлов, точность и  подынтегральная  функция

Подпрограмма вычисления интеграла с заданной точностью, которая использует подпрограмму вычисления функции десятиточечным методом

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

3.2 Разработка программы  по схеме алгоритма

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

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

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

3.3 Разработка инструкции  пользования программой

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

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

3.4 Распечатка программы

{$N+}

{ Вычисление интегpала  десятиточечным методом  Гаусса }

uses crt,graph;

var aaa,bbb,kkk: real;

{константы  десятиточечного  метода Гаусса}

const

g10c1=0.9739065285/6. 2012983932;

g10c2=0.8650633667/6. 2012983932;

g10c3=0.6794095683/6. 2012983932;

g10c4=0.4333953941/6. 2012983932;

g10c5=0.1488743390/6. 2012983932;

g10x1=0.0666713443/6. 2012983932;

g10x2=0.1494513492/6. 2012983932;

g10x3=0.2190863625/6. 2012983932;

g10x4=0.2692667193/6. 2012983932;

g10x5=0.2955242247/6. 2012983932;

function F(x: real): real; {интегрируемая функция}

begin

F: = kkk*(exp(-aaa*x) - exp(-bbb*x));

end;

function gauss_calc(a,b: real): real; {сам десятиточечный метод Гаусса}

var n,m,s,s1,s2,s3,s4,s5: real;

begin

m: =(b+a) /2; n: =(b-a) /2;

s1: =g10c1*(f(m+n*g10x1) +f(m-n*g10x1));

s2: =g10c2*(f(m+n*g10x2) +f(m-n*g10x2));

s3: =g10c3*(f(m+n*g10x3) +f(m-n*g10x3));

s4: =g10c4*(f(m+n*g10x4) +f(m-n*g10x4));

s5: =g10c5*(f(m+n*g10x5) +f(m-n*g10x5));

s: =s1+s2+s3+s4+s5;

gauss_calc: =s*(b-a);

end;

{рекурсивная  ф-ция подсчета  с заданной точностью}

{ gc - ранее посчитаный  интеграл на интервале  (a,b) }

function gauss(a,b,eps,gc: real): real;

var t,ga,gb: real;

begin

t: =(a+b) /2; {разбиваем  интервал на две половинки}

ga: =gauss_calc(a,t); {в  каждой половинке  считаем интеграл}

gb: =gauss_calc(t,b);

if abs(ga+gb-gc) >eps then {проверяем точность вычислений}

begin

ga: =gauss(a,t,eps/2,ga); {рекурсия  для первой половинки}

gb: =gauss(t,b,eps/2,gb); {рекурсия для второй половинки}

end; {при  этом точность  повышаем, чтобы }

{при  сложении ошибка  не накапливалась}

gauss: =ga+gb; {интеграл = сумме интегралов  половинок}

end;

procedure inputnum(prm: string; var num: real; lb,ub: real); {процедура ввода данных}

var q: boolean;

begin

repeat

write('Введите ',prm,' '); readln(num);

q: =(lb>=num) or (num>ub);

if q then writeln('Число должно быть от ', lb: 0: 0,' до ',ub: 0: 0);

until not q;

end;

procedure titul; {Вывод титульного листа}

var f: text; s: string;

i: integer;

begin

clrscr;

assign(f,'f42. txt');

reset(f);

while not eof(f) do begin

readln(f,s);

while length(s) <79 do s: =' '+s+' ';

writeln(s);

end;

close(f);

end;

function main_menu: integer; {Главное меню}

var i: integer;

begin

Writeln('==========================================================');

Writeln('Что  будем делать? ');

Writeln('----------------------------------------------------------');

Writeln('0 - выход');

Writeln('1 - решать тестовый  пример a=1,5 b=6 k=10 eps = 0.0001');

Writeln('2 - решать пример  с произвольными  a, b, k, eps');

Writeln('----------------------------------------------------------');

Write('Выбор >>> '); readln(i);

Writeln('==========================================================');

main_menu: =i;

end;

procedure outputgraph(a,b,a1,b1: real; n: integer); {Вывод графика}

var i,j,j1,k: integer; t,y1,y2,x1,x2,x,y: double; s: string;

begin

clearviewport;

x1: =a1-1; x2: =b1+1;

if x1<0.5 then x1: =-0.5;

y2: =f(ln(bbb/aaa) /(bbb-aaa)) *1.2;

y1: =-y2;

{Линия y=0}

setcolor(15);

y: =0;

j: =trunc(480*(y-y2) /(y1-y2));

line(0,j,639,j);

{Линии x=a,x=b}

setcolor(5);

j: =trunc(480*(-y2) /(y1-y2));

i: =trunc(640*(a-x1) /(x2-x1));

j1: =trunc(480*(f(a) - y2) /(y1-y2));

line(i,j, i,j1);

i: =trunc(640*(b-x1) /(x2-x1));

j: =trunc(480*(-y2) /(y1-y2));

j1: =trunc(480*(f(b) - y2) /(y1-y2));

line(i,j, i,j1);

{Сам график}

Информация о работе Численное интегрирование-методом Гаусса