swh:1:snp:a4c99a50dc49f82b591f268001b320f8c3ca0041
Tip revision: 635622b024294f87a1442a50ad662642f5586aa7 authored by jmc on 14 July 2008, 00:00:00 UTC
version 1.0-4
version 1.0-4
Tip revision: 635622b
triDiag3.R
triDiag3 <- function(diagonal, upper, lower,
nrow = length(diagonal), ncol = nrow) {
value <- matrix(0, nrow = nrow, ncol = ncol)
r <-max(nrow, ncol)
if(r > 1) {
nu <- min(nrow, ncol-1)
nl <- min(nrow-1, ncol)
index <- outer((0:nu)*(nrow+1), 0:2, `+`)
value[index[1:min(nrow, ncol), 2]] <- diagonal
if(nu > 0)
value[index[-1, 1]] <- upper
if(nl > 0)
value[index[1:nl, 3]] <- lower
}
value
}