Лабораторная работа №4. Организация циклов Задача 3.2. Вычисление суммы ряда ……………………………………………………………………………………………………………………………..

advertisement
Лабораторная работа №4.
Тема: Организация циклов.(продолжение)
Задача 3.2. Вычисление суммы ряда
……………………………………………………………………………………………………………………………..
Написать программу вычисления значения функции sin с помощью степенного ряда с точностью
 по формуле
x3 x5 x7
y  x     ...
3! 5! 7!
Этот ряд сходится на всей числовой оси. Для достижения заданной точности требуется
суммировать члены ряда до тех пор, пока абсолютная величина очередного члена не станет
меньше или равна  .
Запишем в общем виде формулу для вычисления n – го члена ряда:
x 2 n1
Cn  (1) n
(2n  1)!
На первый взгляд может показаться, что придется организовать циклы для расчета факториала и
степеней. При этом можно получить очень большие числа, при делении которых друг на друга
произойдет потеря точности, поскольку количество значащих цифр, хранимых в ячейке памяти,
ограничено. Кроме того, большие числа могут переполнить разрядную сетку.
Мы поступим по-другому. Легко заметить, что (n+1) – й член ряда вычисляется после n-го,
поэтому программа получится более простой и эффективной, если находить член ряда не «с нуля»,
а умножением предыдущего члена на некоторую величину.
Найдем эту величину. Для этого сначала запишем формулу для (n+1)-го члена ряда, подставив в
предыдущее выражение (n+1) вместо n:
x 2n11
n1
Cn1   1
.
2n  1  1!
Теперь найдем выражение, на которое надо будет умножить C n , чтобы получить С n 1 :
Cn1  Cn
 
x2
Сn1  1 x 2 n1 2n  1!


=
2n  1!  1n x 2 n1 2n2n  1
Cn
n 1

Cn1  Cn
x2
2n2n  1
Запишем алгоритм вычисления суммы ряда в словесной форме:
1. Ввести исходные данные (аргумент и точность).
2. Задать начальные значения номеру члена ряда, первому члену ряда и сумме ряда.
3. Организовать цикл в котором:
1) Вычислить очередной член ряда;
2) Добавить его к сумме ряда;
3) Перейти к следующему члену ряда;
4) Проверить, достигнута ли точность вычислений.
4. Вывести значение функции.
Определить заранее, сколько членов ряда потребуется просуммировать для достижения
точности, невозможно, поскольку при анализе условия выхода используется переменная,
вычисляемая на каждой итерации цикла. Такие циклы потенциально опасны, поэтому для
предотвращения зацикливания полезно предусмотреть аварийный выход из цикла по
достижении некоторого максимально допустимого количества итераций с печатью
предупреждающего сообщения.
Ниже приведен текст программы с комментариями. На каждой итерации требуется хранить
значение одного члена ряда, поэтому все члены ряда формируются в одной и той же
переменной с:
program sinus;
const MaxIter=500; {максимально допустимое количество итераций}
var x,eps:double;
{аргумент и точность}
c,y:double;
{член ряда и его сумма}
n:integer;
{номер члена ряда}
done:boolean;
{признак достижения точности}
begin
writeln('Введите аргумент и точность:');
readln(x,eps);
done:=true;
c:=x;
{первый член ряда}
y:=c;
{начальное значение суммы}
n:=1;
while abs(c)>eps do begin
c:=-c*sqr(x)/2/n/(2*n+1); {очередной член ряда}
y:=y+c;
{добавление члена ряда к сумме}
inc(n);
{переход к следующему члену ряда}
if n<=MaxIter then continue;
writeln('ryd rasxoditsya');
done:=false;break
{аварийный выход из цикла}
end;
if done then
writeln('Аргумент:',x:10:6,#13#10,
'Значение функции:',y:10:6,#13#10,
'Вычислено с точностью',eps:8:6,'за',n,'итераций');
readln;
end.
Первый член ряда равен х, поэтому, чтобы при первом проходе цикла значение второго члена
вычислялось правильно, начальное значение n должно быть равно 1.Максимально допустимое
количество итераций удобно задать с помощью именованной константы. Для аварийного
выхода изх цикла применяется процедура break, которая обеспечивает переход к первому после
цикла оператору. Символы #13#10 при выводе вызывают переход на следующую строку.
Контрольный пример для х=7.5 и eps=0,00001.
Индивидуальное задание
Вычислить и вывести на экран в виде таблицы значения функции, заданной с помощью ряда
Тейлора, на интервале от хнач до хкон с шагом dx с точностью  . Таблицу снабдить
заголовком и шапкой. Каждая строка таблицы должна содержать значение аргумента, значение
функции и количество просуммированных членов ряда.
1. ln
2. e

x 1
1
1
1
1

 2
 2  3  5  ...,
2 n 1
x 1
 x 3x 5 x

n 0 2n  1x
x

 1n x n
n 0
n!

x 2 x3 x 4
 1  x     ...,
2! 3! 4!
x  1.
x  .

3. e x  
n0
xn
x 2 x3 x 4
 1  x     ...,
n!
2! 3! 4!


4. ln( x  1) 
 1n x n1  x  x 2  x3  x 4  ...,
n 1
n 0
5. ln
x  .
2
3



1 x
x 2 n1
x3 x5
 2
 2 x    ...,
1 x
3 5
n0 2n  1



6. ln( 1  x)   
n1
7. arcctgx 

x  1.


xn
x2 x4

  x    ...,
n
2
4


 1n1 x 2n1  

2
 1  x  1.
4

2n  1
n 0
2
x
 1  x  1.
x3 x5
  ...,
3 5
x  1.
8.
n 1

 1
 1 1
1
arctgx   
   3  5  ...,
2 n 1
2 n0 2n  1x
2 x 3x 5 x
9.
n

 1 x 2 n1
x3 x5 x7
arctgx  
 x     ...,
3 5 7
n0 2n  1



x 2 n1
x3 x5 x7
 x     ...,
3 5 7
n0 2n  1

10. arthx= 

11.
1
1
1
1
  3  5  ...,
2 n 1
x 3x 5 x
n 0 2n  1x
arthx= 
12.
arctgx  
13.
ex  
2
x  1.
x  1.
x  1.
 1n1     1  1  1  ...,
2 n1
2 x 3x 3 5 x 5
n0 2n  1x

2


 1n x 2n
n 0
n!
 1  x2 
n

 1 x 2 n
cos x  
2n!
n 0

14.

x>1.
1
x 4 x 6 x8
   ...,
2! 3! 4!
x 2 x 4 x 6 x8
    ...,
2! 4! 6! 4!
x  1.
x  .
x  .
sin x   1 x 2 n
x2 x4 x6

 1


 ...,
x
3! 5! 7!
n  0 2n  1!
n
15.
3
5


(
x

1
)
 x  1 ( x 1)

 2


 ..., x  0.
2 n1
3
5
 x  1 3( x 1) 5( x 1)



( x 1)
ln x  2 
(2n 1)( x 1)
2 n1

16.
x  .
n 0

17. ln x 
(1) ( x 1)
n1
n

(n  1)
n0
( x 1)  ( x 1)
 ( x  1) 
2
2
( x 1)

(n 1)( x 1)
n1

18. ln x 
n 0
3
3
 ...,0  x  2.
x  1 ( x 1) ( x 1)
1



 ..., x  .
n1
2
3
x
2
2x
3x
2
2 n 1
3
1  3...(2n  1)  x
1 3  x 1 3  5  x 1 3  5  7  x
 x x 


..., x  1.
19. arcsinx = x  
2 3 2  4 5 2  4  6  7 2  4  6 89
n 1 2  4...2n  ( 2n  1)

3
5
7
9
20.
2 n1
3
5
7
9


1  3...(2n  1)  x   
1  3  x 1  3  5  x 1  3  5  7  9  x 
x

arccosx   x  
  x



... ,
 2 

2 
2

3
2

4

5
2

4

6

7
2

4

6

8

9
n1 2  4...2n  ( 2n  1) 



x  1.
21. ln

x 1
1
1
1
1

 2
 2  3  5  ...,
2 n 1
x 1
 x 3x 5 x

n 0 2n  1x

 1n x n
n 0
n!
22. e  x  

23. e x  
n0
x 2 x3 x 4
   ...,
2! 3! 4!
xn
x 2 x3 x 4
 1  x     ...,
n!
2! 3! 4!
24. ln( x  1) 


n 0
25. ln
1 x 
x  1.
x  .
x  .
 1n x n1  x  x 2  x3  x 4  ...,
n 1
2
3
 1  x  1.
4



1 x
x 2 n1
x3 x5
 2
 2 x    ...,
1 x
3 5
n0 2n  1


x  1.


xn
x2 x4
  x    ...,
n
2
4



26. ln( 1  x)   
n1

27. arcctgx 

2
28. arctgx 

 1n1 x 2n1  
n 0
x3 x5
 x    ...,
2
3 5
2n  1


2
 1n x 2n1  x  x3  x5  x 7  ...,
3 5 7
n0 2n  1

x 2 n1
x3 x5 x7
 x     ...,
3 5 7
n0 2n  1

30. arthx= 

32.
33.
1
1
1
1
  3  5  ...,
2 n 1
x 3x 5 x
n 0 2n  1x
arthx= 
arctgx  
e
 x2


n 0
x  1.
 1n1    1  1  1  ...,
2 n 1
2 x 3x 3 5 x 5
n 0 2n  1x

29. arctgx  
31.
 1  x  1.

x>1.
x  1.
x  1.
x  1.
 1n1     1  1  1  ...,
2 n1
2 x 3x 3 5 x 5
n0 2n  1x

2

 1n x 2n
n!
x 4 x 6 x8
 1  x     ...,
2! 3! 4!
2
x  .
x  1.
Download