С Новым годом! Форум программистов, компьютерный форум, киберфорум
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Kostas94
0 / 0 / 0
Регистрация: 19.09.2013
Сообщений: 1
#1

Метод Пирсона - C++

22.09.2013, 16:51. Просмотров 325. Ответов 0
Метки нет (Все метки)

Ребят, завтра сдавать работу по методу Симпсона. Уже который день мучаюсь, но не могу добиться требуемой точности, а завтра сдавать, помоги пожалуйста.
Информацию брал отсюда:
http://www.cleverstudents.ru/definit...parabolas.html
Делал по примерам.
Необходимо с помощью этого метода найти интеграл от 0 до 10 от cos(x^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
#include "stdafx.h"
#include <Math.h>
#include <iostream>
using namespace std;
    
double pr (double y){
        double perem=8*y* ( 20*(pow(y,2)) * cos (pow (y,2)) + (15-4*pow(y,4)) * sin(pow(y,2)) );//производная 5 степени для нахождения максимума
        return perem;
    }
int _tmain(int argc, _TCHAR* argv[]){
 
 
    double b=10;//границы
    double a=0;
    int par1=-9;
    double par2=10;
    double eps=pow (par2, par1); // точность по заданию
    double max=0;
    for (double y=0; y<=10;y=y+0.000001){ //поиск максимума через 5 производную
            if (pr (y) > max){
                max=pr (y);
            }
        }
 
    printf ("max %f\n", max);
    double step=0.25;
    double argument=(max*pow((b-a),5))/(eps*180); 
    
    double n=pow (argument,step); // формула нахождения количества отрезков разбиения
    double h=(b-a)/n;//нахождения шага
    printf ("h %f\n", h);
    double z=0;//то что нужно посчитать
    long double x=0;//итоговый результат
    n=36300;//поскольку хз как округлить нормально задал +1 количество шагов, при прохождение программы выдаёт 36299.123.....
 
    for (int i=0; i<=n; i++){                   //сам алгоритм подсчёта
        if ((i==0) || (i==n)){
        x=x+cos (z*z);
        z=z+h;
        } else 
            if (i%2==0){
                x=x+2*(cos (z*z));
                z=z+h;
            } 
            else{
            x=x+4*(cos(z*z));
            z=z+h;
            }
    }
 
 
    double ans=x*(h/3);//конечный результат
    
    printf ("kol-vo otrezkov %.9f\n", n);
    printf ("ans %.9f\n", ans);
    getchar();
    return 0;
}
Понятия не имею что неверно, выдаёт значение 0.601139903, а должен 0.601125185.
Второе (верное) значение получил в Scilabе, и считал онлайн, тоже самое получилось. Помогите пожалуйста.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
22.09.2013, 16:51
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Метод Пирсона (C++):

Критерии Пирсона - C++
Здравствуйте. Есть алгоритм генератора случайных чисел на заданном интервале, элементарный. Нужно всунуть сюда проверку равномерного...

Вычисление критерия Пирсона: исправить программу - C++
Листинг программы: // генератор-псевдочисел.cpp: определяет точку входа для консольного приложения. // #include &quot;stdafx.h&quot; ...

СЛАУ. Метод обратной матрицы, метод Гаусса, метод Крамера, метод Зейделя - C++
Помогите ребят. Не могу построить алгоритмы для этих методов Язык C++

Метод медиан из трех элементов VS улучшенный быстрый метод сортировки(метод Бентли-Макилроя) - C++
Здравствуйте! Дали весьма интересное задание. Сравнить два вышеуказанных метода сортировки для массива из 10000 элементов, результаты...

Мой код - метод бисекции, метод секущих (метод хорд) - C++
Всем привет!!! Изучаем в институте С++. Сделал код, и там, и там одна и та же проблема - при любых вбиваемых значениях программа делает...

Исследовать итерационный метод- метод касательных для решения нелинейных уравнений - C++
прочитал много всего , но сам пример реализовать никак не могу , кто может помогите F(x) = x5+5x+1=0 с...

0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
22.09.2013, 16:51
Привет! Вот еще темы с ответами:

Не сходится теория и практика метод Шелла и метод простого выбора - C++
Здравствуйте! Помогите пожулуйста найти ошибке в коде, Я уже не знаю где ее искать. У меня метод простого выбора работает по показателям...

Метод деления отрезка пополам для решения нелинейных уравнений (метод дихотомии) - C++
Здравствуйте. Помогите пожалуйста дописать программу. Вот что вымучал, но на сдаче завалили, типо нет вывода корней, не рассмотрены...

Нахождения корней уравнения: метод половинного деления (бисекции) или метод хорд - C++
Разработать программу нахождения корней уравнения f(x) =0 на интервале с точностью e = 0,001 (интервал или подобрать самостоятельно). При...

Производный класс: метод возведения в произвольную степень, и метод для вычисления логарифма числа - C++
Реализовать класс-оболочку Number для числового типа float. Реализовать методы сложения и деления. Создать производный класс Real, в...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.