R/call.value.R

Defines functions BlackScholesMerton call.value

Documented in call.value

BlackScholesMerton <- function(type=c('ec','ep'), S, X, b, r, Time, v) {
  S <- as.numeric(S)
  X <- as.numeric(X)
  b <- as.numeric(b)
  r <- as.numeric(r)
  Time <- as.numeric(Time)
  v <- as.numeric(v)

  d1 <- (log(S/X) + (b + (v^2)/2) * Time)/(v * sqrt(Time))
  d2 <- d1 - v * (sqrt(Time))
  if('ec' %in% type) {
    cp <- (S * exp( (b-r) * Time) * pnorm(d1)) - (X * exp(-r * Time) *
          pnorm(d2))
    delta.c <- exp(-b * Time) * pnorm(d1) ###### FIXME/CHECKME
  } else cp <- delta.c <- NA

  if('ep' %in% type) {
    pp <- exp(-r * Time) * X * pnorm(-d2) - exp((b-r) * Time) * 
          S * pnorm(-d1)
    delta.p <- -exp(-b * Time) * pnorm(-d1)  #### FIXME/CHECKME
  } else pp <- delta.p <- NA

  if(identical(pp, NaN)) {
    pp <- delta.p <- 0  
  }
  if(identical(cp, NaN)) {
    cp <- delta.c <- 0  
  }
  list(call=list(value=cp, delta=delta.c),
       put=list(value=pp, delta=delta.p))
}

call.value <-
function(S, X, b, r, Time, v) {
  S <- as.numeric(S)
  X <- as.numeric(X)
  b <- as.numeric(b)
  r <- as.numeric(r)
  Time <- as.numeric(Time)
  v <- as.numeric(v)

  d1 <- (log(S/X) + (b + (v^2)/2) * Time)/(v * sqrt(Time))
  d2 <- d1 - v * (sqrt(Time))
  cp <- (S * exp( (b-r) * Time) * pnorm(d1)) - (X * exp(-r * Time) *
        pnorm(d2))
  delta.c <- exp(-b * Time) * pnorm(d1) ###### FIXME/CHECKME
  if(identical(cp, NaN)) {
    cp <- delta.c <- 0  
  }
  list(value=cp, delta=delta.c)
}
joshuaulrich/greeks documentation built on May 19, 2019, 8:54 p.m.