Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:

DiVM / DiVM / 12_116608_1_52629

.pdf
Скачиваний:
15
Добавлен:
11.05.2015
Размер:
466.36 Кб
Скачать

Министерство образования Республики Беларусь Учреждение образования

"Белорусский государственный университет информатики и радиоэлектроники"

Факультет компьютерных систем и сетей

Кафедра программного обеспечения информационных технологий

МЕТОДИЧЕСКИЕ УКАЗАНИЯ к проведению лабораторных работ по курсу

"Дискретная и вычислительная математика"

Автор: Смолякова Ольга Георгиевна, ассистент кафедры ПОИТ

Минск 2009

 

СОДЕРЖАНИЕ

 

Лабораторная работа № 1.

Решение систем линейных алгебраических

 

уравнений..................................................................................................................

 

3

Лабораторная работа № 2.

Приближение функций................................................

9

Лабораторная работа №3,4. Численное интегрирование и дифференцирование

.................................................................................................................................

 

17

2

Лабораторная работа № 1. Решение систем линейных алгебраических уравнений

Метод Гаусса.

Входные параметры: n—целое положительное число, равное порядку n системы; а — массив из nхn действительных чисел, содержащий матрицу коэффициентов системы (а(1) = а11, а(2) = a12…а(n) = аn1, а(n + 1) = а12, .... а(nх n) = аnn); b — массив из n действительных чисел, содержащий столбец свободных членов системы (b(1) = b1, b(2)=b2,b(n)=bn).

Выходные параметры: b—массив из n действительных чисел (он же входной); при выходе из программы содержит решение системы b(l) = x1, b(2) = x2, … b(n) = хn; error—признак правильности решения (код ошибки): если ks = 0, то в массиве b содержится решение системы, если error= 1, исходная система

не имеет единственного решения (определитель системы равен нулю).

 

Перед обращением к подпрограмме SIMQ необходимо:

 

 

1.

описать массивы а и b. Если система содержит n уравнений, то

массив а

 

должен содержать n2 элементов, а массив b n элементов;

 

2.

присвоить

значение

параметру

n,

который

равен

числу

 

уравнений системы;

 

 

 

 

 

3.

присвоить элементам массивов а и b значения коэффициентов

системы

 

следующим

образом:

a(l) = a11,

а(2) = а21, а(3) = а31,…а(n) = аn1

а(n+1) = а12, а(n+2) = а22а(n x n) = аnn. b(1) = b1, b(2)=b2,b(n)=bn

4.проверить соответствие фактических параметров по типу и порядку следования формальным параметрам подпрограммы SIMQ. Параметры а и b - величины вещественного типа, n и error - целого типа.

Задание. Используя программу SIMQ, решить заданную систему трех линейных уравнений. Схема алгоритма приведена на рисунке 1.

Порядок выполнения лабораторной работы:

1.Составить головную программу, содержащую обращение к SIMQ и печать результатов;

2.Произвести вычисления на ЭВМ.

Пример. Решить систему уравнений

x1 x2 x3 6

x1 x3 2x1 2x2 x3 8

3

Procedure

SIMQ(Nn:integer;

var Aa:Tmatr:var

Bb:TVector;var

Ks:integer);

I

I>Nn

Aa[i,Nn+1]=Bb[i]

I=I+1

I

I

I>Nn

max=abs(aa[i,i])

k1=I

L

J>Nn

+

abs(aa[l,i])>max

 

max=abs(aa[l,i])

 

K1=L

L=L+1

 

L

 

Max<eps

+

-

 

KS=0

KS=1

K1<>I

+

 

J

 

I>Nn+1

 

U=Aa[i,j]

 

Aa[i,j]=Aa[k1,j]

 

Aa[k1,j]=U

 

J=J+1

 

J

V=Aa[i,i]

 

A

 

A

J

I>Nn+1

Aa[i,j]=Aa[i,j] /V

J=J+1

J

L

J>Nn

V=Aa[i,i]

J

I>Nn+1

Aa[l,j]=Aa[l,j]-Aa[i,j]*V

J=I+1

J

L=L+1

L

I=I+1

I

Bb[nn]=Aa[Nn,Nn+1]

I

I<Nn-1

Bb[i]=Aa[i,Nn+1]

J

I>Nn+1

Bb[i]=Bb[i]-Aa[i,j]*Bb[j]

J=I+1

J

I=Nn-1

I

M1

Возврат

Рисунок 1 – Схема алгоритма метода Гаусса

4

Текст программы:

PROCEDURE SIMQ(Nn:Integer;Var Aa:TMatr;Var Bb:TVector;Var Ks:Integer); Label M1;

Const Eps=1e-21;

Var Max,U,V : Real; I,J,K1,L : Integer; Begin

For I:=1 To Nn Do Aa[i,Nn+1]:=Bb[i]; For I:=1 To Nn Do

Begin

Max:=Abs(Aa[i,i]); K1:=I; {запоминает номер строки с максимальным элементом}

For L:=I+1 To Nn Do If (Abs(Aa[l,i])>Max) Then Begin

Max:=Abs(Aa[l,i]); K1:=L;

End;

I

f(Max<Eps) Then Begin Ks:=1; Goto M1;

 

End Else Ks:=0;

 

If K1<>I Then

For J:=I To Nn+1 Do {обмен местами элементов строк с максимальным элементом}

Begin U:=Aa[i,j]; Aa[i,j]:=Aa[k1,j]; Aa[k1,j]:=U;

End;

V:=Aa[i,i]; {элемент на главной диагонали, являющийся максимальным } For J:=I To Nn+1 Do Aa[i,j]:=Aa[i,j]/V;

For L:=i+1 To Nn Do {все последующие строки после строки с максимальным элементом}{при I=1: L=2 (2,2),(2,3)..(2,Nn+1)

L=3

(3,2),(3,3),..(3,Nn+1)

L=Nn

(Nn,2),

(Nn,3),.. (Nn,Nn+1)}

Begin

V:=Aa[l,i];

For J:=I+1 To Nn+1 Do Aa[l,j]:=Aa[l,j]-Aa[i,j]*V;

 

End;

End;

Bb[nn]:=Aa[Nn,Nn+1]; {находим n-ый элемент решения}

For I:=Nn-1 Downto 1 Do {находим в обратном порядке все элементы решения}

Begin Bb[i]:=Aa[i,nn+1];

For J:=I+1 To Nn Do Bb[i]:=Bb[i]-Aa[i,j]*Bb[j];

End;

M1:End;

Вычисления по программе привели к следующим результатам: X(1)= .100000E+01 Х(2)= .200000Е+01 Х(3)= .З00000Е + 01

признак выхода 0

5

Варианты заданий для решения систем линейных алгебраических уравнений методом Гаусса приведены в таблице 1.

Метод квадратных корней Холецкого

Входные параметры: n—целое положительное число, равное порядку n системы; а — массив из n х n действительных чисел, содержащий матрицу коэффициентов системы (а(1) = а11, а(2) = a12…а(n) = аn1, а(n + 1) = а12, .... а(n х n) = аnn); b — массив из n действительных чисел, содержащий столбец свободных членов системы (b(1) = b1, b(2)=b2,b(n)=bn).

Выходные параметры: b—массив из n действительных чисел (он же входной); при выходе из программы содержит решение системы b(l) = x1, b(2) = x2, … b(n) = хn; p—количество операций.

Схема алгоритма приведена на рисунке 2.

Пример. Решить систему уравнений

x1 x2 x3 6

x1 x3 2x1 2x2 x3 8

Текст программы:

Procedure Holets(n:integer;a:TMatr;b:TVector;var x:TVector;var p:integer); Var i,j,k:integer; a11:real;

Begin Out_Slau_T(n,a,b); For i:=1 To n Do Begin

If i<>1 Then Begin If a[i,i]=0 Then Begin

p:=0; error:=2; MessageDlg('!!!!',mtError,[mbOk],0); Exit; End;

a[1,i]:=a[1,i]/a[1,1];

End;

For j:=1 To i Do Begin For k:=1 To j-1 Do Begin a[i,j]:=a[i,j]-a[i,k]*a[k,j]; End;

For i:=1 To n Do Begin

For j:=1 To i-1 Do b[i]:=b[i]-a[i,j]*b[j]; If a[i,i]=0 Then Begin

p:=0; error:=2; MessageDlg('!!!!',mtError,[mbOk],0); Exit; End;

b[i]:=b[i]/a[i,i];

End;

For i:=n DownTo 1 Do Begin

For j:=n DownTo i+1 Do b[i]:=b[i]-a[i,j]*b[j];

6

End;

x:=b;

p:=2*n*n;

End;

Вычисления по программе привели к следующим результатам: X(1)= .100000E+01 Х(2)= .200000Е+01 Х(3)= .З00000Е + 01

procedure Xolets(n:integer;a:tmatr;b:t Vector;;var x:tvector;var p:integer)

Out_Slau_T(n,a,b)

I

I>N

+

i<>1

+

a[i,i]=0

a[1,i]=a[1,i] / a[1,1]

 

p=0

 

 

 

 

 

 

 

 

 

 

I=I+1

Возврат

I

J

J>I

K

K>J-1

a[i,j]=a[i,j]-a[i,k]*a[k,i]

+

j<>i

a[,j,i]=a[j,i]-a[j,k]*a[k,i]

K=K+1

K

+

j>1and j<i

a[i,i]=0

 

 

 

 

 

a[j,i]=a[j,i] / a[j,j]

 

p=0

 

 

 

 

 

 

 

 

 

 

J=J+1

Возврат

J

I

I>N

A

J

J>I-1

b[i]=b[i]-a[i,j]*b[j]

J=J+1

J

+

a[i,i]=0

 

 

 

 

 

b[i]=b[i]/ a[i,i]

 

p=0

 

 

 

 

 

 

 

 

 

 

I=I+1

Возврат

I

I

I<1

J

J<I+1

b[i]=b[i]-a[i,j]*b[j]

J=J-1

J

J=J-1

I

x=b

p=2*n*n

Возврат

A

Рисунок 2 - Схема алгоритма метода Холецкого

7

Варианты заданий. Решить систему линейных уравнений вида Ах=b. [1] Таблица 1

Номер

Матрица А

 

 

Столбец

 

 

свободных

варианта

коэффициентов системы

 

 

членов b

 

 

 

 

1

2

 

 

3

1

1,84

2,25

2,53

-6,09

 

2,32

2,60

2,82

.-6,98

 

1,83

2,06

2,24

-5,52

2

2,58

2,93

3,13

-6,66

 

1,32

1,55

1,58

-3,58

 

2,09

2,25

2,34

-5,01

3

2,18

2,44

2,49

-4,34

 

2,17

2,31

2,49

-3,91

 

3,15

3,22

3,17

-5,27

4

1,54

1,70

1,62

-1,97

 

3,69

3,73

3,59

-3,74

 

2,45

2,43

2,25

-2,26

5

1,53

1,61

1,43

-5,13

 

2,35

2,31

2,07

-3,69

 

3,83

3,73

3,45

-5,98

6

2,36

2,37

2,13

1,48

 

2,51

2,40

2,10

1,92

 

2,59

2,41

2,06

2,16

7

3,43

3,38

3,09

5,52

 

4,17

4,00

3,65

6,93

 

4,30

4,10

3,67

7,29

8

3,88

3,78

3,45

10,41

 

3,00

2,79

2,39

8,36

 

2,67

'2,37

1,96

7,62

9

3,40

3,26

2,90

13,05

 

2,64

2,39

1,96

10,30

 

4,64

4,32

3,85

17,89

10

2,53

2,36

1,93

12,66

 

3,95

4,11

3,66

21,97

 

2,78

2,43

1,94

13,93

8

Лабораторная работа № 2. Приближение функций

Интерполяционный полином Лагранжа

Входные параметры: N - число узлов интерполяции; y - массив размерности n, содержащий значения функции в узлах интерполяции; x-массив размерности n, содержащий значения узлов интерполяции; q-точка в которой вычисляем значения функции интерполяции.

Выходные параметры: приближенное значение функции в точке q; графическая интерпретация результата.

Схема алгоритма приведена на рисунке 3.

Задание. Аппроксимировать табличную функцию с помощью интерполяционного полинома Лагранжа.

xi

yi

xi

yi

1

2,05

6

1,88

2

1,94

7

1,71

3

1,92

8

1,60

4

1,87

9

1,56

5

1,77

10

1,40

Текст программы:

function Lagran(n:integer;x,y:TVector;q:real):real; var i,j:integer; l,s:real;

begin L:=0;

for i:=1 to n do begin s:=1; for j:=1 to N do if j<>i then

s:=s*(q-x[j])/(x[i]-x[j]); L:=L+y[i]*s;

end;

Lagran:=l end

Вычисления по программе привели к следующим результатам:

X=1

Y=2,05

X=4,5 Y=1,78

X=8

Y=1,6

X=1,5 Y=2,38

X=5

Y=1,77

X=8,5

Y=1,67

X=2

Y=1,94

X=5,5 Y=1,83

X=9

Y=1,56

X=2,5 Y=1,83

X=6

Y=1,88

X=9,5

Y=1,09

X=3

Y=1,92

X=6,5 Y=1,83

X=10

Y=1,4

X=3,5 Y=1,94

X=7

Y=1,71

 

 

X=4

Y=1,87

X=7,5 Y=1,59

 

 

9

Function

Lagran(n:integer;x,y,TV

ector;r,q:real)

L=0

I

I>n

s=1

J

J>n

+

I<>J

s=s*(q-x[j]) / (x[i]-x[j])

J=J+1

J

L=L+y[i]*s

I=I+1

I

Lagran=1

Возврат

Рисунок 3 - Схема алгоритма приближения функций формулой Лагранжа

Варианты заданий для решения задачи приближения функций приведены в таблице 2.

Аппроксимация функций с помощью кубического сплайна

Входные параметры: N - число узлов интерполяции; y - массив размерности n, содержащий значения функции в узлах интерполяции; x-массив размерности n, содержащий значения узлов интерполяции; q-точка в которой вычисляем значения функции интерполяции.

Соседние файлы в папке DiVM