https://github.com/cran/tgp
Revision e2440d43ce37a7adb76d184432e9bbdb537ace2c authored by Robert B. Gramacy on 24 February 2006, 18:06:09 UTC, committed by cran-robot on 24 February 2006, 18:06:09 UTC
1 parent 5456136
Tip revision: e2440d43ce37a7adb76d184432e9bbdb537ace2c authored by Robert B. Gramacy on 24 February 2006, 18:06:09 UTC
version 1.1
version 1.1
Tip revision: e2440d4
tgp.R
#*******************************************************************************
#
# Bayesian Regression and Adaptive Sampling with Gaussian Process Trees
# Copyright (C) 2005, University of California
#
# This library is free software; you can redistribute it and/or
# modify it under the terms of the GNU Lesser General Public
# License as published by the Free Software Foundation; either
# version 2.1 of the License, or (at your option) any later version.
#
# This library is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
# Lesser General Public License for more details.
#
# You should have received a copy of the GNU Lesser General Public
# License along with this library; if not, write to the Free Software
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
#
# Questions? Contact Robert B. Gramacy (rbgramacy@ams.ucsc.edu)
#
#*******************************************************************************
"tgp" <-
function(X, Z, XX=NULL, BTE=c(2000,7000,2), R=1, m0r1=FALSE,
linburn=FALSE, params=NULL, pred.n=TRUE, ds2x=FALSE, ego=FALSE)
{
# get names
Xnames <- names(X)
response <- names(Z)
# check X and Z
XZ <- check.matrix(X, Z)
X <- XZ$X; Z <- XZ$Z
n <- dim(X)[1]; d <- dim(X)[2]
# check XX
XX <- check.matrix(XX)$X
if(is.null(XX)) { nn <- 0; XX <- matrix(0); nnprime <- 1 }
else {
nn <- dim(XX)[1]; nnprime <- nn
if(dim(XX)[2] != d) stop("mismatched column dimension of X and XX");
}
# check the sanity of input arguments
if(nn > 0 && sum(dim(XX)) > 0 && dim(XX)[2] != d) stop("XX has bad dimensions")
if(length(Z) != n) stop("Z does not have length == dim(Z)[1]")
if(BTE[1] < 0 || BTE[2] <= 0 || BTE[1] >= BTE[2]) stop("bad B and T args")
if(BTE[3] <= 0 || BTE[3] >= BTE[2]) stop("bad E arg")
if(R < 0) stop("R must be positive")
# deal with params
if(is.null(params)) params <- tgp.default.params()
dparams <- tgp.check.params(params, d+1);
if(is.null(dparams)) stop("Bad Parameter List")
# might scale Z to mean of 0 range of 1
if(m0r1) { Zm0r1 <- mean0.range1(Z); Z <- Zm0r1$X }
state <- sample(seq(0,1000), 3)
#state <- c(123,456,789)
#print(params)
# run the C code
ll <- .C("tgp",
state = as.integer(state),
X = as.double(t(X)),
n = as.integer(n),
d = as.integer(d),
Z = as.double(Z),
XX = as.double(t(XX)),
nn = as.integer(nn),
BTE = as.integer(BTE),
R = as.integer(R),
linburn = as.integer(linburn),
dparams = as.double(dparams),
Zp.mean = double(pred.n * n),
ZZ.mean = double(nnprime),
Zp.q = double(pred.n * n),
ZZ.q = double(nnprime),
Zp.q1 = double(pred.n * n),
Zp.median = double(pred.n * n),
Zp.q2 = double(pred.n * n),
ZZ.q1 = double(nnprime),
ZZ.median = double(nnprime),
ZZ.q2 = double(nnprime),
Ds2x = double(ds2x * nnprime),
ego = double(ego * nnprime),
PACKAGE = "tgp"
)
# deal with X, and names of X
ll$X <- framify.X(ll$X, Xnames, d)
# deal with Z, and names of Z
if(is.null(response)) ll$response <- "z"
else ll$response <- response
# deal with predictive data locations (ZZ)
if(nn == 0) {
ll$XX <- NULL; ll$ZZ.mean <- NULL; ll$ZZ.q <- NULL;
ll$ZZ.q1 <- NULL; ll$ZZ.median <- NULL; ll$ZZ.q2 <- NULL;
ll$Ds2x <- NULL; ll$ego <- NULL
} else {
# do predictive input/output processing
# replace NaN's in ego with zeros
# shouldn't happen because check have been moved to C code
if(sum(is.nan(ll$ego) > 0)) {
warning(paste("encountered", sum(is.nan(ll$ego)),
"NaN in EGO, replaced with zeros"), call.=FALSE)
ll$ego[is.nan(ll$ego)] <- 0
}
# make sure XX has the correct output format
ll$XX <- framify.X(ll$XX, Xnames, d)
}
if(pred.n == FALSE) { ll$Zpredm <- NULL; ll$Zpredq <- NULL; }
# remove from the list if not requested
if(ds2x == FALSE) { ll$Ds2x <- NULL; }
if(ego == FALSE) { ll$ego <- NULL; }
# gather information about partitions
if(file.exists(paste("./", "parts_1.out", sep=""))) {
ll$parts <- read.table("parts_1.out")
unlink("parts_1.out")
} else { ll$parts <- NULL }
# gather information about MAP trees as a function of height
ll$trees <- tgp.get.trees()
ll$posts <- read.table("tree_m0_posts.out", header=TRUE)
unlink("tree_m0_posts.out")
# store params
ll$params <- params
# undo mean0.range1
if(m0r1) {
ll$Z <- undo.mean0.range1(ll$Z,Zm0r1$undo)
ll$Zp.mean <- undo.mean0.range1(ll$Zp.mean,Zm0r1$undo)
ll$ZZ.mean <- undo.mean0.range1(ll$ZZ.mean,Zm0r1$undo)
ll$Zp.q <- undo.mean0.range1(ll$Zp.q,Zm0r1$undo)
ll$ZZ.q <- undo.mean0.range1(ll$ZZ.q,Zm0r1$undo)
ll$Zp.q1 <- undo.mean0.range1(ll$Zp.q1,Zm0r1$undo)
ll$Zp.median <- undo.mean0.range1(ll$Zp.median,Zm0r1$undo)
ll$Zp.q2 <- undo.mean0.range1(ll$Zp.q2,Zm0r1$undo)
ll$ZZ.q1 <- undo.mean0.range1(ll$ZZ.q1,Zm0r1$undo)
ll$ZZ.median <- undo.mean0.range1(ll$ZZ.median,Zm0r1$undo)
ll$ZZ.q2 <- undo.mean0.range1(ll$ZZ.q2,Zm0r1$undo)
}
# set class information and return
class(ll) <- "tgp"
return(ll)
}
![swh spinner](/static/img/swh-spinner.gif)
Computing file changes ...