R/FGMcop.R

Defines functions FGMicop

Documented in FGMicop

"FGMcop" <- function(u, v, para=c(NA, 1, 1), ...) {
    if(is.null(para)) {
      warning("self parameter estimation not supported")
      return(NULL)
    }
    if(length(para) == 1) {
      para <- c(para, 1,1)
    }
    para <- as.numeric(para)
    if(length(para) != 3) {
      warning("copula requires three parameters")
      return(NULL)
    }
    d <- para[1]; a <- para[2]
    n <- as.integer(para[3])
    lwr <- -min(c(1,1/(n*a^2))); upr <- 1/(n*a)
    if(is.na(d)) {
      warning("parameter Theta is NA")
      return(NULL)
    } else if(d < lwr) {
      warning("parameter Theta < ", lwr)
      return(NULL)
    } else if(d > upr) {
      warning("parameter Theta > ", upr)
      return(NULL)
    }
    if(a <= 0) {
      warning("parameter Alpha <= 0")
      return(NULL)
    }

    if(length(u) > 1 & length(v) > 1 & length(u) != length(v)) {
      warning("length u = ", length(u), " and length v = ", length(v))
      warning("longer object length is not a multiple of shorter object length, ",
              "no recycling")
      return(NA)
    }
    if(length(u) == 1) {
       u <- rep(u, length(v))
    } else if(length(v) == 1) {
       v <- rep(v, length(u))
    }

    return(u*v*(1+d*(1-u^a)*(1-v^a))^n)
}


FGMicop <- function(u,v, para=NULL, ...) {
    if(is.null(para)) {
      warning("self parameter estimation not supported")
      return(NULL)
    }
    if(length(u) > 1 & length(v) > 1 & length(u) != length(v)) {
      warning("length u = ", length(u), " and length v = ", length(v))
      warning("longer object length is not a multiple of shorter object length, ",
              "no recycling")
      return(NA)
    }
    if(length(u) == 1) {
      u <- rep(u, length(v))
    }
    else if(length(v) == 1) {
      v <- rep(v, length(u))
    }

    b <- para; r <- length(b)
    if(any(abs(b) > 1)) {
      warning("one of the Beta parameter is |beta| > 1")
      return(NULL)
    }
    uv <- u*v; uvp <- (1-u)*(1-v)
    tmp <- sapply(1:length(u), function(i) {
               sum(sapply(1:r, function(j) {
                k <- as.integer( j   /2) + 1
                l <- as.integer((j+1)/2)
                b[j] * uv[i]^k * uvp[i]^l })) })
    cop <- uv + tmp
    return(cop)
}

Try the copBasic package in your browser

Any scripts or data that you put into this service are public.

copBasic documentation built on Oct. 17, 2023, 5:08 p.m.