[go: up one dir, main page]

File: norm.c

package info (click to toggle)
r-cran-actuar 3.3-5-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 2,960 kB
  • sloc: ansic: 7,899; makefile: 18; sh: 13
file content (61 lines) | stat: -rw-r--r-- 1,494 bytes parent folder | download | duplicates (3)
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
59
60
61
/*  actuar: Actuarial Functions and Heavy Tailed Distributions
 *
 *  Functions to calculate raw moments and the moment generating
 *  function for the normal distribution. See ../R/NormalSupp.R for
 *  details.
 *
 *  AUTHORS: Christophe Dutang and Vincent Goulet <vincent.goulet@act.ulaval.ca>
 */

#include <R.h>
#include <Rmath.h>
#include "locale.h"
#include "dpq.h"

double mnorm(double order, double mean, double sd, int give_log)
{
#ifdef IEEE_754
    if (ISNAN(order) || ISNAN(mean) || ISNAN(sd))
	return order + mean + sd;
#endif
    if (!R_FINITE(mean)  ||
        !R_FINITE(sd)    ||
        !R_FINITE(order) ||
        sd <= 0.0 ||
        ACT_nonint(order))
        return R_NaN;

    /* Trivial case */
    if (order == 0.0)
        return 1.0;

    /* Odd moments about 0 are equal to 0 */
    if ((int) order % 2 == 1 && mean == 0.0)
        return 0.0;

    int i, n = order;
    double res = 0.0;

    for (i = 0; i <= n/2; i++)
        res += R_pow_di(sd, 2 * i) * R_pow_di(mean, n - 2 * i) /
            (R_pow_di(2.0, i) * gammafn(i + 1) * gammafn(order - 2.0 * i + 1.0));

    return gammafn(order + 1.0) * res;
}

double mgfnorm(double t, double mean, double sd, int give_log)
{
#ifdef IEEE_754
    if (ISNAN(t) || ISNAN(mean) || ISNAN(sd))
	return t + mean + sd;
#endif
    if (!R_FINITE(mean) ||
        !R_FINITE(sd)   ||
        sd <= 0.0)
        return R_NaN;

    if (t == 0.0)
        return ACT_D__1;

    return ACT_D_exp(t * mean + 0.5 * t * t * sd * sd) ;
}