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

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

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

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

22.09.2013, 16:51. Просмотров 290. Ответов 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е, и считал онлайн, тоже самое получилось. Помогите пожалуйста.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
22.09.2013, 16:51     Метод Пирсона
Посмотрите здесь:

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

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

метод деления отрезка пополам и метод итерации - C++
Методом деления отрезка пополам и методом итерации найти приближенное значение корня 2*x^3+3*x-1=0 абсолютная погрешность 10^-5; Люди...

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

Вызвать метод через указатель на метод - C++
class MenuItem { public: MenuItem(string name, MenuItem *parent = nullptr, void(MenuItem::*EventHadler)() = nullptr, bool isSelected...

Метод парных перестановок и метод подсчета - C++
Помогите пожалуйста! задача:Переставить строки матрицы так, чтобы убывало кол-во нулей в строках. код задачи: // седьмая.cpp :...

Метод Пирсона - Методы оптимизации
Всем привет. Ищу хороший теоретический материал по методу Пирсона. Продолжаю гуглить, но ничего полезного пока не найдено. Если у кого есть...

Критерий Пирсона - Алгоритмы
Для того, чтобы проверить соответствие закона, который мы получили нормальному можно применить критерий Пирсона. Искать его так: 1....

Кривые Пирсона - Теория вероятностей
Добрый день. пишу небольшую программку, которая должна рисовать кривые Пирсона. имеются входные параметры x = np.array(, 'float')...


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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Ответ Создать тему
Опции темы

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