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

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

Восстановить пароль Регистрация
 
Erisu
0 / 0 / 0
Регистрация: 15.12.2010
Сообщений: 14
10.05.2014, 09:47     Функция стандартного нормального отклонения (аналог NORMSDIST из Excel) #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)
Посмотрите здесь:

Функция-аналог Readkey в С# C++
C++ Функция Нормального закона распределения
Вычисление нормального веса человека C++
C++ Работа стандартного входного потока
C++ Функция size() стандартного класса string
C++ Считывание из стандартного потока ввода
C++ Зерно генерации для нормального распределения
Написать программу, которая имитирует поведение Нормального Алгоритма Маркова C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
volvo
Супер-модератор
 Аватар для volvo
21677 / 14150 / 3937
Регистрация: 22.10.2011
Сообщений: 25,002
Записей в блоге: 2
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)));
}
Yandex
Объявления
10.05.2014, 10:34     Функция стандартного нормального отклонения (аналог NORMSDIST из Excel)
Ответ Создать тему
Опции темы

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