tests/test_scoring.R

# Copyright (C) 2017 Markus Baaske. All Rights Reserved.
# This code is published under the L-GPL.
#
# File: 	test_scoring.R
# Date:  	12/04/2017
# Author: 	Markus Baaske
# 
# Testing quasi Fisher-scoring iteration

library(qle)
data(normal)

qsd$var.type <- "cholMean"

(S0 <- qscoring(qsd,
  x0=c("mu"=3.5,"sigma"=1.5), 
  opts=list("pl"=10,
		    "xscale"=c(1,1), "fscale"=c(1,1),
			"grad_tol"=1e-10,"score_tol"=1e-10),
 verbose=TRUE))

# monitor is 1/2 norm^2 of quasi-score 
S0$Qnorm
# quasi-deviance
S0$value

# quasi-devicance at solution
D <- quasiDeviance(S0$par,qsd)[[1]]
0.5*t(D$score)%*%D$score
D$value 

# use alternative optimizer
S2 <- searchMinimizer(c(3.5,1.5),qsd,
		method=c("bobyqa"),verbose=TRUE)
S2$Qnorm

x0 <- S0$par
Xs <- as.matrix(qsd$qldata[c(1,2)])
Tstat <- qsd$qldata[c(3,4)]
pred <- estim(qsd$covT,x0,Xs,Tstat,krig.type="var")[[1]]
q <- qsd$obs-pred$mean

D <- quasiDeviance(x0,qsd)[[1]]
S <- attr(D,"Sigma")
as.numeric(D$jac%*%solve(S)%*%cbind(q))
D$score

Try the qle package in your browser

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

qle documentation built on May 2, 2019, 5:26 p.m.