Hello,
The write.matrix.csr() function of the e1071 package contains a bug.
Try the following:
 	library(e1071)
 	m <- 1 - diag(10)
 	sm <- as.matrix.csr(m)
 	write.matrix.csr(sm)
The resulting file (out.dat) contains only the two lines below:
2:1 3:1 4:1 5:1 6:1 7:1 8:1 9:1 10:1
1:1 3:1 4:1 5:1 6:1 7:1 8:1 9:1 10:1
This is obviously wrong as the matrix m has 90 non-zero entries.
The function is implemented as
 	write.matrix.csr <- function (x, file="out.dat", y=NULL) {
 		on.exit(sink())
 		if(!require("methods")) stop("Could not load package
'methods'.")
 		if (!is.null(y) & (length(y) != nrow(x)))
 			stop(paste("Length of y (=", length(y),
 				") does not match number of rows of x (=",
 				nrow(x), ")!", sep=""))
 		sink(file)
 		for (i in 1:nrow(x)) {
 			if (!is.null(y)) cat (y[i],"")
 			if (x at ia[i] <= nrow(x))
 				for (j in x at ia[i]:(x at ia[i+1] - 1))
 					cat(x at ja[j], ":", x at ra[j], " ",
sep="")
 			cat("\n")
 		}
 	}
The bug is caused by the line
 	if (x at ia[i] <= nrow(x))
that is completely meaningless. In the above example nrow(x) is 10
and x at ia is the vector
 	1 10 19 28 37 46 55 64 73 82 91
Entries of x at ia has nothing to do with the number of rows in the matrix.
To fix the bug this line must be removed.
Best regards,
Peter
Peter:
Yes, this is a bug. The line
if (x at ia[i] <= nrow(x))
should actually read
if ((x at ia[i] <= length(x at ra)) && (x at ia[i] < x at ia[i +
1]))
--> fixed upstream.
Thanks
David
--------
Hello,
The write.matrix.csr() function of the e1071 package contains a bug.
Try the following:
  	library(e1071)
  	m <- 1 - diag(10)
  	sm <- as.matrix.csr(m)
  	write.matrix.csr(sm)
The resulting file (out.dat) contains only the two lines below:
2:1 3:1 4:1 5:1 6:1 7:1 8:1 9:1 10:1
1:1 3:1 4:1 5:1 6:1 7:1 8:1 9:1 10:1
This is obviously wrong as the matrix m has 90 non-zero entries.
The function is implemented as
  	write.matrix.csr <- function (x, file="out.dat", y=NULL) {
  		on.exit(sink())
  		if(!require("methods")) stop("Could not load package
'methods'.")
  		if (!is.null(y) & (length(y) != nrow(x)))
  			stop(paste("Length of y (=", length(y),
  				") does not match number of rows of x (=",
  				nrow(x), ")!", sep=""))
  		sink(file)
  		for (i in 1:nrow(x)) {
  			if (!is.null(y)) cat (y[i],"")
  			if (x at ia[i] <= nrow(x))
  				for (j in x at ia[i]:(x at ia[i+1] - 1))
  					cat(x at ja[j], ":", x at ra[j], " ",
sep="")
  			cat("\n")
  		}
  	}
The bug is caused by the line
  	if (x at ia[i] <= nrow(x))
that is completely meaningless. In the above example nrow(x) is 10
and x at ia is the vector
  	1 10 19 28 37 46 55 64 73 82 91
Entries of x at ia has nothing to do with the number of rows in the matrix.
To fix the bug this line must be removed.
Best regards,