Nothing
setMethod("restModel", signature("linearGel"),
function(object, R, rhs=NULL)
{
mod <- callNextMethod()
gmmToGel(mod, object@gelType$name, object@gelType$rhoFct)
})
setMethod("restModel", signature("nonlinearGel"),
function(object, R, rhs=NULL)
{
mod <- callNextMethod()
gmmToGel(mod, object@gelType$name, object@gelType$rhoFct)
})
setMethod("restModel", signature("formulaGel"),
function(object, R, rhs=NULL)
{
mod <- callNextMethod()
gmmToGel(mod, object@gelType$name, object@gelType$rhoFct)
})
setMethod("restModel", signature("functionGel"),
function(object, R, rhs=NULL)
{
mod <- callNextMethod()
gmmToGel(mod, object@gelType$name, object@gelType$rhoFct)
})
## printRestrict
setMethod("printRestrict", signature("rgelModels"),
function(object)
{
cl <- strsplit(class(object)[1],"Gel")[[1]][1]
cl <- paste(cl, "Gmm", sep="")
getMethod("printRestrict", cl)(object)
})
## print
setMethod("print", "rgelModels",
function(x)
{
cl <- class(x)[1]
getMethod("print", "gelModels")(x)
printRestrict(x)
})
## modelDims
setMethod("modelDims", "rgelModels",
function(object)
{
cl <- strsplit(class(object)[1],"Gel")[[1]][1]
cl <- paste(cl, "Gmm", sep="")
getMethod("modelDims", cl)(object)
})
## model.matrix and modelResponse
setMethod("model.matrix", "rlinearGel",
function(object, type=c("regressors","instruments"))
{
type <- match.arg(type)
getMethod("model.matrix", "rlinearGmm")(object, type)
})
setMethod("modelResponse", "rlinearGel",
function(object)
{
getMethod("modelResponse", "rlinearGmm")(object)
})
## getRestrict
setMethod("getRestrict", "rgelModels",
function(object, theta)
{
cl <- strsplit(class(object)[1],"Gel")[[1]][1]
cl <- paste(cl, "Gmm", sep="")
getMethod("getRestrict", cl)(object, theta)
})
setMethod("getRestrict", "gelModels",
function(object, theta, R, rhs=NULL) {
getMethod("getRestrict", "gmmModels")(object)
})
## coef
setMethod("coef", "rgelModels",
function(object, theta)
{
cl <- strsplit(class(object)[1],"Gel")[[1]][1]
cl <- paste(cl, "Gmm", sep="")
getMethod("coef", cl)(object, theta)
})
## subset
setMethod("[", c("rfunctionGel", "numeric", "missing"),
function(x, i, j){
callNextMethod()
})
## modelFit
setMethod("modelFit", signature("rlinearGel"), valueClass="gelfit",
definition = function(model, gelType=NULL, rhoFct=NULL,
initTheta=c("gmm", "modelTheta0"), theta0=NULL,
lambda0=NULL, vcov=FALSE, ...)
{
Call <- try(match.call(call=sys.call(sys.parent())), silent=TRUE)
if (inherits(Call,"try-error"))
Call <- NULL
met <- getMethod("modelFit", "rgelModels")
obj <- met(model, gelType, rhoFct, initTheta, theta0, lambda0, vcov, ...)
obj@call <- Call
obj
})
setMethod("modelFit", signature("rnonlinearGel"), valueClass="gelfit",
definition = function(model, gelType=NULL, rhoFct=NULL,
initTheta=c("gmm", "modelTheta0"), theta0=NULL,
lambda0=NULL, vcov=FALSE, ...)
{
Call <- try(match.call(call=sys.call(sys.parent())), silent=TRUE)
if (inherits(Call,"try-error"))
Call <- NULL
met <- getMethod("modelFit", "rgelModels")
obj <- met(model, gelType, rhoFct, initTheta, theta0, lambda0, vcov, ...)
obj@call <- Call
obj
})
setMethod("modelFit", signature("rformulaGel"), valueClass="gelfit",
definition = function(model, gelType=NULL, rhoFct=NULL,
initTheta=c("gmm", "modelTheta0"), theta0=NULL,
lambda0=NULL, vcov=FALSE, ...)
{
Call <- try(match.call(call=sys.call(sys.parent())), silent=TRUE)
if (inherits(Call,"try-error"))
Call <- NULL
met <- getMethod("modelFit", "rgelModels")
obj <- met(model, gelType, rhoFct, initTheta, theta0, lambda0, vcov, ...)
obj@call <- Call
obj
})
setMethod("modelFit", signature("rfunctionGel"), valueClass="gelfit",
definition = function(model, gelType=NULL, rhoFct=NULL,
initTheta=c("gmm", "modelTheta0"), theta0=NULL,
lambda0=NULL, vcov=FALSE, ...)
{
Call <- try(match.call(call=sys.call(sys.parent())), silent=TRUE)
if (inherits(Call,"try-error"))
Call <- NULL
met <- getMethod("modelFit", "rgelModels")
obj <- met(model, gelType, rhoFct, initTheta, theta0, lambda0, vcov, ...)
obj@call <- Call
obj
})
setMethod("modelFit", signature("rgelModels"), valueClass="gelfit",
definition = function(model, gelType=NULL, rhoFct=NULL,
initTheta=c("gmm", "modelTheta0"), theta0=NULL,
lambda0=NULL, vcov=FALSE, ...)
{
Call <- try(match.call(call=sys.call(sys.parent())), silent=TRUE)
if (inherits(Call,"try-error"))
Call <- NULL
k <- modelDims(model)$k
if (k == 0)
{
if (!is.null(gelType))
model@gelType$name <- gelType
if (!is.null(rhoFct))
model@gelType$rhoFct <- rhoFct
return(evalModel(model, numeric(), ...))
}
initTheta <- match.arg(initTheta)
if (is.null(theta0))
{
if (initTheta == "gmm")
{
theta0 <- modelFit(as(model, "rgmmModels"))@theta
} else {
theta0 <- modelDims(model)$theta0
}
}
obj <- getMethod("modelFit", "gelModels")(model=model, gelType=gelType,
rhoFct=rhoFct, initTheta=initTheta, theta0=theta0,
lambda0=lambda0, vcov=vcov, ...)
obj@call <- Call
obj
})
Any scripts or data that you put into this service are public.
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.