R/getModelData.R

Defines functions ..getModelData getModelData

Documented in getModelData

getModelData <- function(x, na.rm=TRUE) {
  model <- x
  if (!is.quantmod(model)) 
      stop(sQuote("x"), "must be of class", dQuote("quantmod"), 
          "\n")
  if (length(model@model.inputs) == 0) {
      build.vars <- c(model@model.target, model@build.inputs)
  }
  else {
      build.vars <- c(model@model.target, model@model.inputs)
  }
  model.symbols <- vars <- all.vars(model@model.spec)
  env <- new.env()
  lapply(vars, 
         function(V) {
           if(!exists(V)) {
             getSymbols(V, env=env) 
           } else {
             assign(V, get(V), env) 
           } 
         }
        )
    target.data <- get(model.symbols[[1]], env)
    total.columns = NULL
    for (j in 1:length(model.symbols)) {
        if (j == 1) {
            m <- as.xts(target.data)
        }
        else {
            m <- merge(m, as.xts(get(model.symbols[[j]], env)), 
                join = "inner")
        }
        total.columns[j] <- NCOL(m)
    }
    fullIndex <- index(m)
#    m <- as.data.frame(m)
    from.col = 1
    for (i in 1:length(model.symbols)) {
        assign(model.symbols[[i]], m[, from.col:(total.columns[i])], env)
        from.col = total.columns[i] + 1
    }
    mf <- xts(model.frame(model@model.spec, data = env, na.action = NULL), fullIndex)
    if (na.rm) 
        mf <- rbind(na.exclude(mf[-NROW(mf), ]), mf[NROW(mf),
            ])
    colnames(mf) <- lapply(colnames(mf), function(x) {
        gsub("[) ]", "", gsub("[(,=^:'\"]", ".", x))
    })
    model@model.data <- mf
    model@build.inputs <- colnames(mf)[-1]
    model@model.formula = as.formula(paste(colnames(mf)[1], "~", 
        paste(colnames(mf)[-1], collapse = "+"), sep = ""))
    return(model)
  #model.frame(spec, data=env)
}
..getModelData <- function(x, na.rm=TRUE) {
    model <- x
    if (!is.quantmod(model)) 
        stop(sQuote("x"), "must be of class", dQuote("quantmod"), 
            "\n")
    if (length(model@model.inputs) == 0) {
        build.vars <- c(model@model.target, model@build.inputs)
    }
    else {
        build.vars <- c(model@model.target, model@model.inputs)
    }
    model.symbols <- model@symbols
    missing.symbols = NULL
    for (i in 1:length(model.symbols)) {
        if (!exists(model.symbols[[i]], 1)) {
            missing.symbols <- c(missing.symbols, model.symbols[[i]])
        }
        else {
            assign(model.symbols[[i]], get(model.symbols[[i]], 
                1), environment())
        }
    }
    if (length(missing.symbols > 0)) 
        getSymbols(missing.symbols, env = environment())
    target.data <- get(model.symbols[[1]], environment())
    total.columns = NULL
    for (j in 1:length(model.symbols)) {
        if (j == 1) {
            m <- as.xts(target.data)
        }
        else {
            m <- merge(m, xts(get(model.symbols[[j]], environment())), 
                join = "inner")
        }
        total.columns[j] <- NCOL(m)
    }
    fullIndex <- index(m)
#    m <- as.data.frame(m)
    from.col = 1
    for (i in 1:length(model.symbols)) {
        assign(model.symbols[[i]], m[, from.col:(total.columns[i])], 
            environment())
        from.col = total.columns[i] + 1
    }
    mf <- xts(model.frame(model@model.spec, data = environment(), 
        na.action = NULL), fullIndex)
    if (na.rm) 
        mf <- rbind(na.exclude(mf[-NROW(mf), ]), mf[NROW(mf),
            ])
    colnames(mf) <- lapply(colnames(mf), function(x) {
        gsub("[) ]", "", gsub("[(,=^:'\"]", ".", x))
    })
    model@model.data <- mf
    model@build.inputs <- colnames(mf)[-1]
    model@model.formula = as.formula(paste(colnames(mf)[1], "~", 
        paste(colnames(mf)[-1], collapse = "+"), sep = ""))
    return(model)
}


".getModelData" <-
function(x,na.rm=TRUE)
{
    as.POSIXorDate <- function(x) {
      if(inherits(x, "POSIXt")) {
        return(x)
      } else {
        x <- as.Date(x,origin='1970-01-01')
        return(x)
      }
    }
    model <- x
    if(!is.quantmod(model)) 
        stop(sQuote('x'),"must be of class",dQuote("quantmod"),"\n");
    if(length(model@model.inputs) == 0) {
        #if model.inputs is not yet defined, create full zoo object for building
        build.vars <- c(model@model.target,model@build.inputs);
    } else {
        #else create data object with only relevant model.inputs
        build.vars <- c(model@model.target,model@model.inputs);
    }
    

    model.symbols <- model@symbols;
    missing.symbols = NULL
    for(i in 1:length(model.symbols)) {
        if(!exists(model.symbols[[i]],1)) {
            ## create vector of symbols to retrieve from getSymbols call
            missing.symbols <- c(missing.symbols,model.symbols[[i]])
        } else {
            ## get symbols from GlobaEnv and place in this environment
            assign(model.symbols[[i]],get(model.symbols[[i]],1),environment())
            ## NEED to coerce to quantmod.OHLC and zoo object
        }
    }

    if(length(missing.symbols > 0)) getSymbols(missing.symbols,env=environment())

    target.data <- get(model.symbols[[1]],environment())
    if(inherits(target.data, "zoo")) {
        target.dates <- index(target.data)
    } else {
        target.dates  <- rownames(target.data)
    }
    #price.level <- paste(c("Op(","Hi(","Lo(","Cl("),model@product,")",sep="");
    total.columns = NULL
    for(j in 1:length(model.symbols)) { # build single zoo object
        if(j == 1) {
            m <- merge(zoo(as.matrix(target.data),as.POSIXorDate(target.dates)))     #target columns
        } else {
            m <- merge(m,
                       zoo(as.matrix(get(model.symbols[[j]],environment())), #input columns from symbol i
                       as.POSIXorDate(index(get(model.symbols[[j]],environment()))))) 
        }            
        total.columns[j] <- NCOL(m)
    }

    fullIndex <- index(m) 
    m <- as.data.frame(m)

    from.col = 1
    for(i in 1:length(model.symbols)) { # assign portions of 
        assign(model.symbols[[i]],m[,from.col:(total.columns[i])],environment())
        from.col = total.columns[i] + 1
    }

    mf <- zoo(model.frame(model@model.spec,data=environment(),na.action=NULL),fullIndex);

    #pl.formula <- as.formula(paste('Op(',model@product,') ~ ',
    #                paste(c('Hi(',' + Lo(',' + Cl('),model@product,
    #                ')',collapse=''),sep=''));
    #pl.mf <- zoo(model.frame(pl.formula,data=environment()),as.Date(target.dates))

    if(na.rm) mf <- rbind(na.exclude(mf[-NROW(mf),]),mf[NROW(mf),]);

    colnames(mf) <- lapply(colnames(mf),function(x) 
                        { gsub("[) ]","",gsub("[(,=^:'\"]",".",x)) });
    #colnames(pl.mf) <- lapply(price.level,function(x) 
    #                    { gsub("[) ]","",gsub("[(,=:'\"]",".",x)) });
    #colnames(pl.mf) <- paste(model@product,c('.Open','.High','.Low','.Close'),sep='')

    model@model.data <- mf;
    #model@price.levels <- pl.mf;
    model@build.inputs <- colnames(mf)[-1]
    model@model.formula = as.formula(paste(colnames(mf)[1],'~',
                                        paste(colnames(mf)[-1],collapse='+'),
                                        sep=''))

    ##removeSymbols()
    return(model);
}
"stripModelData" <-
function(model) {
    if(!inherits(model, "quantmod")) stop("model must be of class 'quantmod'");
    model@model.data <- zoo(0,0);
    model@price.levels <- zoo(0,0);
    return(model);
}

Try the quantmod package in your browser

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

quantmod documentation built on Aug. 22, 2023, 9:09 a.m.