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

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

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

Функция стандартного нормального отклонения (аналог NORMSDIST из Excel) - C++

10.05.2014, 09:47. Просмотров 633. Ответов 1
Метки нет (Все метки)

Добрый день.
Хочу написать функцию, которая работает подобно НОРМСТРАСП в Excel, т.е. возвращает функцию стандартного интегрального распределения. Ее формула http://www.cyberforum.ru/cgi-bin/latex.cgi?f(x)={1}/{\sqrt{2*\pi }}*{exp}^{-{x}^{2}/2}.
Пробую подручными методами
C++
1
2
x=-1.7930; 
fx=(1/(sqrt(2*M_PI)))*exp(-pow(x,2)/2);
, выводится совсем не то.
Догадываюсь, что пишу глупости, но прошу о помощи, ибо не знаю, как сделать иначе

Добавлено через 2 минуты
И еще. Пишу на borland'е 6
Лучшие ответы (1)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
10.05.2014, 09:47     Функция стандартного нормального отклонения (аналог NORMSDIST из Excel)
Посмотрите здесь:

Функция Нормального закона распределения - C++
подскажите функцию на с++ которая принимает аргументом а а на выводе Ф(а)

Функция size() стандартного класса string - C++
Добрый день. При поптыке посчитать количество символов в введённой строке на латыне - отображает верный результат, а кириллицу читает...

Функция-аналог Readkey в С# - C++
Помогите, пожалуйста: мне нужно, чтобы после вывода результатов программы в консоль, консоль не закрывалась. В C#, я знаю, пишется...

Дружественная функция, аналог strcmp - C++
Есть класс Stroka, с двумя полями: str - сама строка и maxlen - длина строки(без учета нуль символа). Вот объявление: class Stroka {...

Вычисление нормального веса человека - C++
Помогите написать программу, которая вычисляет нормальный вес человека по формуле v=k*r-100, k=1.08 где k – коэффициент коррекции v...

Зерно генерации для нормального распределения - C++
Seed для normal distribution Влияет ли на генерируемую последовательномть с помощью std::normal_distribution зерно генерации...

Написать программу, которая имитирует поведение Нормального Алгоритма Маркова - C++
Мне нужно написать программу, которая имитирует поведение Нормального Алгоритма Маркова. Мне нужно ввести два шестнацатиричных числа и их...

Наследование стандартного итератора - C++
Добрый день! Хочу сделать класс "Фильтрующий Итератор" - наследованный от std::vector<int>::iterator, который будет перечислять только...

Считывание из стандартного потока ввода - C++
Доброго времени суток . Столкнулся вот с такой проблемой . Есть функция , которая считывает со стандартного потока ввода код программы на...

Работа стандартного входного потока - C++
Здравствуйте. Допустим есть код: int number1, number2; std::cin >> number1 >> number2; Мы вводим, например, 1 2 и...

Вывести строку в поток стандартного вывода - C++
Суть в том, что мне нужно чтобы мой cout выводил мой ответ на строку ввода, например 2+2=4. #include <conio.h> #include <iostream> ...

Вывод логотипа вместо стандартного окна - C++
После запуска программы должен появляться на пару секунд логотип программы - картинка поверх всех остальных окон. Как такое можно...


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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
volvo
Супер-модератор
Эксперт Pascal/DelphiАвтор FAQ
23229 / 15220 / 4418
Регистрация: 22.10.2011
Сообщений: 27,054
Записей в блоге: 4
10.05.2014, 10:34     Функция стандартного нормального отклонения (аналог NORMSDIST из Excel) #2
Сообщение было отмечено автором темы, экспертом или модератором как ответ
Вот так вычисляется NORMSDIST:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
double erf(double x)
{
    double a1 = 0.254829592;
    double a2 = -0.284496736;
    double a3 = 1.421413741;
    double a4 = -1.453152027;
    double a5 = 1.061405429;
    double p = 0.3275911;
    x = fabs(x);
    double t = 1 / (1 + p * x);
    return 1 - ((((((a5 * t + a4) * t) + a3) * t + a2) * t) + a1) * t * exp(-1 * x * x);
}
 
double NORMSDIST(double z)
{
    double sign = 1;
    if (z < 0) sign = -1;
    return 0.5 * (1.0 + sign * erf(fabs(z) / sqrt(2)));
}
Ответ Создать тему
Опции темы

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