Revision e903a69b2aa125d9836cba37a3b46895643f8344 authored by Doug and Martin on 07 March 2008, 00:00:00 UTC, committed by Gabor Csardi on 07 March 2008, 00:00:00 UTC
1 parent eb1f7fc
lsCMatrix.R
#### Logical Symmetric Sparse Matrices in Compressed column-oriented format
### contains = "lsparseMatrix"
setAs("lsCMatrix", "matrix",
function(from) as(as(from, "generalMatrix"), "matrix"))
setAs("lsCMatrix", "lgCMatrix",
function(from) .Call(Csparse_symmetric_to_general, from))
## needed for indexing (still ?)
setAs("lsCMatrix", "lgTMatrix",
function(from) as(as(from, "generalMatrix"), "lgTMatrix"))
aslsC.by.lgC <- function(from) as(as(from, "lgCMatrix"), "symmetricMatrix")
setAs("lgTMatrix", "lsCMatrix", aslsC.by.lgC) # <-> needed for Matrix()
setAs("matrix", "lsCMatrix", aslsC.by.lgC)
## Specific conversions, should they be necessary. Better to convert as
## as(x, "TsparseMatrix") or as(x, "denseMatrix")
setAs("lsCMatrix", "lsTMatrix",
function(from) .Call(Csparse_to_Tsparse, from, FALSE))
setAs("lsCMatrix", "dsCMatrix",
function(from) new("dsCMatrix", i = from@i, p = from@p,
x = as.double(from@x), uplo = from@uplo,
Dim = from@Dim, Dimnames = from@Dimnames))
if(FALSE) # needed ?
setAs("lsCMatrix", "dgTMatrix",
function(from) as(as(from, "dsCMatrix"), "dgTMatrix"))
## have rather tril() and triu() methods than
## setAs("lsCMatrix", "ltCMatrix", ....)
setMethod("tril", "lsCMatrix",
function(x, k = 0, ...) {
if(x@uplo == "L" && k == 0)
## same internal structure + diag
new("ltCMatrix", uplo = x@uplo, i = x@i, p = x@p,
x = x@x, Dim = x@Dim, Dimnames = x@Dimnames)
else tril(as(x, "lgCMatrix"), k = k, ...)
})
setMethod("triu", "lsCMatrix",
function(x, k = 0, ...) {
if(x@uplo == "U" && k == 0)
new("ltCMatrix", uplo = x@uplo, i = x@i, p = x@p,
x = x@x, Dim = x@Dim, Dimnames = x@Dimnames)
else triu(as(x, "lgCMatrix"), k = k, ...)
})
## FIXME: generalize to "lsparseMatrix" or (class union) "symmetric sparse"
setMethod("image", "lsCMatrix",
function(x, ...) {
x <- as(as(x, "dsCMatrix"), "dgTMatrix")
callGeneric()
})
setMethod("chol", signature(x = "lsCMatrix", pivot = "missing"),
function(x, pivot, ...) chol(as(x, "dgCMatrix"), pivot = FALSE))
## .Call(lsCMatrix_chol, x, FALSE))
setMethod("chol", signature(x = "lsCMatrix", pivot = "logical"),
function(x, pivot, ...) chol(as(x, "dgCMatrix"), pivot = pivot))
## .Call(lsCMatrix_chol, x, pivot))
## Use more general method from CsparseMatrix class
## setMethod("t", signature(x = "lsCMatrix"),
## function(x)
## .Call(lsCMatrix_trans, x),
## valueClass = "lsCMatrix")
![swh spinner](/static/img/swh-spinner.gif)
Computing file changes ...