[go: up one dir, main page]

File: lnorm.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 (50 lines) | stat: -rw-r--r-- 1,395 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
/*  actuar: Actuarial Functions and Heavy Tailed Distributions
 *
 *  Fonctions to calculate raw and limited moments for the lognormal
 *  distribution. See ../R/LognormalMoments.R for details.
 *
 *  AUTHORS: Mathieu Pigeon and Vincent Goulet <vincent.goulet@act.ulaval.ca>
 */

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

double mlnorm(double order, double logmean, double logsd, int give_log)
{
#ifdef IEEE_754
    if (ISNAN(order) || ISNAN(logmean) || ISNAN(logsd))
	return order + logmean + logsd;
#endif
    if (!R_FINITE(logmean) ||
        !R_FINITE(logsd)   ||
        !R_FINITE(order)   ||
        logsd <= 0.0)
        return R_NaN;

    return exp(order * (logmean + 0.5 * order * R_pow_di(logsd, 2)));
}

double levlnorm(double limit, double logmean, double logsd, double order,
                int give_log)
{
#ifdef IEEE_754
    if (ISNAN(limit) || ISNAN(logmean) || ISNAN(logsd) || ISNAN(order))
	return limit + logmean + logsd + order;
#endif
    if (!R_FINITE(logmean) ||
        !R_FINITE(logsd)   ||
        !R_FINITE(order)   ||
        logsd <= 0.0)
        return R_NaN;

    if (limit <= 0.0)
        return 0.0;

    double u = (log(limit) - logmean)/logsd;

    return exp(order * (logmean + 0.5 * order * R_pow(logsd, 2.0))) *
        pnorm(u - order * logsd, 0., 1.0, 1, 0) +
        ACT_DLIM__0(limit, order) * pnorm(u, 0., 1.0, 0, 0);
}