Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.72/25: Рейтинг темы: голосов - 25, средняя оценка - 4.72
192 / 166 / 82
Регистрация: 01.07.2016
Сообщений: 943
1

-nan(ind)

08.04.2020, 00:20. Показов 4779. Ответов 3
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Что такое -nan(ind) и как это исправить?
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
#define _CRT_SECURE_NO_WARNINGS
#include <iostream>
#include <fstream>
#include <iomanip>
#include <cmath>
 
long double powDouble(long double a, long double b) {
    long double k = a;
    for(int i = 2; i <= b; ++i) {
        a *= k;
    }
    return a;
}
 
int main() {
    std::ofstream out("c:\\out.txt");
    long double lambda = 2., tetta = 400., PiConst = 0.04, beta = 0.6, So = 0.02, L = 750., alpha = 0.5;
    long double y, PiSave, S = 1000000.;
    int VSave, ESave;
    for(int V = 1; V <= 200; ++V) {
        y = lambda * tetta / (long double)V;
        for(int E = 1; E <= 200; ++E) {
            long double Pi;
            if(y != 1.L) {
                Pi = powDouble(y, (long double)E) * (1.L - y) / (1.L - powDouble(y, long double(E + 1)));
            } else {
                Pi = 1.L / (long double)(E + 1);
            }
            out  << std::setprecision(10) << E << "     " << V << "     " << Pi << "   " << PiConst << std::endl;
            if(Pi >= PiConst) {
                
                continue;
            }
            long double STemp = alpha * powDouble((long double)V, (long double)beta) + So * E * L; // S = Sн + Sп = alpha * V^beta + So*E*L
            if(STemp < S) {
                S = STemp;
                PiSave = Pi;
                VSave = V;
                ESave = E;
            }
            //out << E << " " << V << std::endl;
        }
    }
    //out << ESave << " " << VSave << " " << PiSave << " " << S << std::endl;
    return 0;
}
Начиная с E = 106 и V = 1 появляется -nan(ind) а потом исчезает и опять по кругу.
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
08.04.2020, 00:20
Ответы с готовыми решениями:

Ошибка -nan(ind) и nan
Доброго времени суток форумчане! Решаю задачу, в которой необходимо найти площадь треугольника по...

-nan(ind)
нужно вычислить значение функции, вроде сделал все проверки, но все равно при вводе отрицательного...

Ошибка -nan<ind>
#include &quot;pch.h&quot; #include &lt;iostream&gt; #include &lt;math.h&gt; using namespace std; int main() {...

Ошибка nan(ind)
Помогите, пожалуйста. Что за ошибка nan(ind) в момент когда y должен быть равен 0 #include...

3
Заклинатель змей
705 / 560 / 219
Регистрация: 30.04.2016
Сообщений: 2,600
08.04.2020, 00:35 2
Лучший ответ Сообщение было отмечено no swear как решение

Решение

no swear, я конечно сто лет не писал не крестах, но зачем pow велосипед, если есть powl()?
https://en.cppreference.com/w/c/numeric/math/pow
1
Вездепух
Эксперт CЭксперт С++
12641 / 6548 / 1758
Регистрация: 18.10.2014
Сообщений: 16,513
08.04.2020, 00:53 3
Лучший ответ Сообщение было отмечено no swear как решение

Решение

Цитата Сообщение от no swear Посмотреть сообщение
Начиная с E = 106 и V = 1 появляется -nan(ind) а потом исчезает и опять по кругу.
Так а что вы ожидали произойдет, когда вы начнете вычислять такие гигантские степени, которые не помещаются в диапазон вашего плавающего типа? 800 в 107 степени - это уже чересчур, учитывая, что вы, очевидно, запускаете код в реализации, в которой long double совпадает с double. Функция powDouble возвращает inf, а деление на inf дает вам nan.

В реализации с 80-битным long double у вас был бы шанс "проскочить". А в 64-битный long double вы не помещаетесь.
1
192 / 166 / 82
Регистрация: 01.07.2016
Сообщений: 943
08.04.2020, 01:33  [ТС] 4
Цитата Сообщение от DobroAlex Посмотреть сообщение
я конечно сто лет не писал не крестах, но зачем pow велосипед, если есть powl()?
Та это просто для себя написал так powl тоже можно использовать конечно.

TheCalligrapher, Как я раньше не заметил что переполнение может произойти.

Спасибо за ответы.
0
08.04.2020, 01:33
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
08.04.2020, 01:33
Помогаю со студенческими работами здесь

Ошибка -nan (ind)
Не пойму, как избавится от этой ошибки #include &quot;pch.h&quot; #include &lt;iostream&gt; #include &lt;fstream&gt;...

Выдаёт -nan(ind)
Header.h файл#pragma once double f(double x); double h(double a, double b, int n); double hi(int...

Ошибка -nan(ind)
Как исправить? #include &lt;iostream&gt; #include &lt;cmath&gt; using namespace std; int main() { int...

Почему выдает -nan(ind)
#include &lt;iostream&gt; #include &lt;math.h&gt; using namespace std; int main() { ...

Программа выводит nan ind
Исходные данные: a=4; b=5; eps=0.0001; Выводит: xz=-nan(ind); k=5; f(x)=-nan(ind);

Что значит -nan(ind)?
Здравствуйте, объясните пожалуйста, что значит -nan(ind)? Вот код программы: #include &quot;pch.h&quot;...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru