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

Метод хорд в решении простецкой параболы - C++

Восстановить пароль Регистрация
 
takeN
3 / 3 / 1
Регистрация: 22.05.2013
Сообщений: 13
03.07.2013, 17:24     Метод хорд в решении простецкой параболы #1
Доброго времени суток. При решении, например на промежутке [0,1] выводит количество итераций, равное 9ти, хотя находит корень за 4 итерации. Подскажите что делать и где таится подлянка. Может зацикливается? Хотя показывается один и тот же результат... Вот файлы:
1) файл chords.cpp
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
#include "stdafx.h"
#include "description.h"
#include <iostream>
#include <iomanip>
#include <cmath>
 
using namespace std;
 
void chords(){ 
    int iteration = 0;
    double leftBorder = 0;
    double rightBorder = 0;
    double point = 0;
    double epsilon = 0;
    double radical = 0;
    double border = 0;
    while(true){
        cout<<" Укажите промежуток с корнями уравнения:\n";
            cout<<" Левая граница: "; cin>>leftBorder;
            cout<<" Правая граница: "; cin>>rightBorder;/// correct entry
        if((function(leftBorder))*(function(rightBorder))>=0){
            cout<<" На заданном промежутке либо 2 корня, либо их нет!\n";
            cout<<" Повторите ввод с другими данными...\n\n";
            continue;
        }
        else break;
    }
    border = leftBorder;
    cout<<" Введите точность измерений: "; cin>>epsilon; /// correct entry
    while(fabs(rightBorder-leftBorder)>=epsilon){//!
        iteration++;
        point = leftBorder-(((rightBorder-leftBorder)*(function(leftBorder)))
            /(function(rightBorder)-function(leftBorder)));// !
        cout<<" Point: "<<point;
        if((function(point))*(function(leftBorder))<0)
            rightBorder = point;
        if((function(point))*(function(rightBorder))<0)
            leftBorder = point;
        radical = point;
    }
    double absErr = fabs(test(border)-radical);
    double relErr = (fabs(absErr)/radical)*100;
    cout<<" Корень: "<<radical<<endl;// tmp
    cout<<" Количество итераций: "<<iteration<<endl;// tmp
    cout<<" Абсолютная погрешность: "<<absErr<<endl;// tmp
    cout<<" Относительная погрешность: "<<relErr<<" %"<<endl;//tmp
}
2) файл test.cpp
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
#include "stdafx.h"
#include "description.h"
#include <iostream>
#include <cmath>
#include "description.h"
 
// значения, подсчитанные калькулятором:
double test(double border){
    double x1 = pow(35,0.5) - 5;
    double x2 = -pow(35,0.5) - 5;
    if(border>x2) return x1;
    if(border<x2) return x2;
}
3) файл equation.cpp
C++
1
2
3
4
5
6
7
#include "stdafx.h"
#include "description.h"
#include <cmath>
 
double function(double x){
    return (x*x + 10*x - 10);
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
03.07.2013, 17:24     Метод хорд в решении простецкой параболы
Посмотрите здесь:

МЕТОД ХОРД И КАСАТЕЛЬНЫХ C++
метод хорд C++
C++ МЕтод хорд
метод хорд C++
Метод хорд C++
C++ Метод хорд
C++ Метод хорд
C++ Метод хорд в С++

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

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

Текущее время: 21:30. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru