Форум программистов, компьютерный форум CyberForum.ru

Ошибка вычисления синуса разложением в ряд Тейлора - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Программирование циклических алгоритмов. Табулирование функций http://www.cyberforum.ru/cpp-beginners/thread1220701.html
Написать программу вычисления функции на заданном промежутке с шагом 0.2 и построить график этой функции
C++ Двухмерный массив, найти сумму элементов по условию Условие: Дана целочисленная матрица размера 8х5. Определить: А) сумму всех элементов второго столбца массива Б) сумму всех элементов 3-й строки массива )) http://www.cyberforum.ru/cpp-beginners/thread1220697.html
C++ Одномерный массив, найти сумму элементов по условию
: В заданном целочисленном массиве Z(15) положительных, отрицательных и нулевых чисел определить сумму и вывести последовательность значений элементов, которые расположены между первым отрицательным и нулевым элементами.помогите пожалуйста))
Корректное удаление вектора векторов C++
Привет. Есть вектор векторов std::vector<std::vector<wchar_t>> data; Как правильно очистить это дело? При вызове data.clear() будет вызван clear() каждого подвектора? Если нет, тогда следует же в цикле очищать? for(auto it = data.begin(); it != data.end(); it++) it->clear(); data.clear(); Или это лишние? Или же очищать то и ничего не надо (для избежания мемори ликсов), т.к. в...
C++ Автоматический сдвиг в выделенной области http://www.cyberforum.ru/cpp-beginners/thread1220616.html
Подскажите, пожалуйста У меня есть класс окна-прямоугольника Window, у которого заданы координаты верхнего левого угла и ширина-высота И для него реализована функция print, которая выводит строку посимвольно в этот прямоугольник в .hpp class Window { public: Window (int x,int y,int w,int h):x_(x),y_(y),w_(w),h_(h), cur_x_(0), cur_y_(0), color_(15), bg_(4){}; //... void print (const...
C++ В одномерном массиве, состоящем из n вещественных элементов, вычислить: • сумму положительных элементов массив В одномерном массиве, состоящем из n вещественных элементов, вычислить: • сумму положительных элементов массива; • произведение элементов массива, расположенных между максимальным по модулю и минимальным по модулю элементами. подробнее

Показать сообщение отдельно
murrderr
Сообщений: n/a
01.07.2014, 16:13     Ошибка вычисления синуса разложением в ряд Тейлора
Помогите пожалуйста! Программа считает синус 2-мя разными способами, вычисляет разницу и выводит результат ввиде таблицы. Так вот, при разложении в ряд Тейлора, результат не такой, как он должен был быть. Подскажите, где ошибка в коде.

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
// Sinus_table.cpp: определяет точку входа для консольного приложения.
//
 
#include "stdafx.h"
#include <iostream>
#define _USE_MATH_DEFINES
#include <math.h>
#include <iomanip>
#include <locale>
 
using namespace std;
 
int main()
{
    setlocale(LC_ALL,"RUSSIAN");
    double sinus1(0), sinus2(0), r(0);
    double x1(0), x2(0), dx(0), eps(0);
    char con;
    do
    {
        system("cls");
        cout << " Программа выводит таблицу значений синусов. \n";
        cout << " Введите границу диапазона - х1: " << endl;
        cin >> x1;
        cout << " Введите границу диапазона - x2: " <<endl;
        cin >> x2;
        cout << " Введите шаг изменения аргумента (в градусах) - dx: " << endl;
        cin >> dx;
        system("cls");
        cout << " *sin(x) - табличное значение; \n *sin(x)2 - расчитаны с разложения функции в ряд Тейлора. \n";
 
            {
            cout.fill('_');
            cout << setw(45) << "" << endl;
            cout.fill('_');
            cout << "|" << setw(10) << "градусы" << "|" << setw(10) << "sin(x)" << "|" << "sin(x)2" << "|" << setw(10) << "разница| \n";
            cout.fill('_');
            cout << setw(45) << "" << endl;
 
            for(double x = x1; x < x2; x = x+dx)
{
    double x2=x*M_PI/180;
    sinus1=sin(x2);
    double an;
    int n;
    n=0;
    an=1;
    sinus2=0;
    while(fabs(an)>eps)
    {
         sinus2+=an;
         n++;
         an*=-x2*x2/(2.*n-1.0)/(2.0*n); 
    }
    r = fabs(sinus1-sinus2);
    cout.flags(ios::fixed);
    cout << "|" << setw(10) << setprecision(3) << x;
    cout << "|" << setw(10) << setprecision(3) << sinus1;
    cout << "|" << setw(10) << setprecision(3) << sinus2;
    cout << "|" << setw(10) << setprecision(8) << r << "|" << endl;
}
 
 
        }
        cout << " Для продолжения программы введите - у: " << endl;
        cout << " Для завершения программы введите любой символ... " << endl;
        cin >> con;
    }
    while(con);
    return 0;
}
Добавлено через 45 секунд
писал в Visual C++ 2010
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 17:30. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru