matrix() can't handle NaN (PR#193)

Bill Simpson Bill Simpson <wsi@gcal.ac.uk>
Tue, 11 May 1999 13:48:57 +0000 (GMT)



On Tue, 11 May 1999, Kurt Hornik wrote:

> >>>>> wsi  writes:
> 
> > Full_Name: Bill Simpson
> > Version: 0.64.1
> > OS: linux
> > Submission from: (NULL) (193.62.250.209)
> 
> 
> > Here is the data file:
> > x y z
> > 1 1 1
> > 1 2 2
> > 2 1 NaN
> > 2 2 4
> 
> >> data<-read.table("~/junk.dat",header=TRUE)
> 
> >> data
> >   x y   z
> > 1 1 1   1
> > 2 1 2   2
> > 3 2 1 NaN
> > 4 2 2   4
> 
I forgot these steps:
x<-unique(data$x)
y<-unique(data$y)

> >> matrix(data$z,length(y),length(x)) 
> >      [,1] [,2]
> > [1,]    1    4
> > [2,]    2    3
> 
> > This is not the correct matrix.  It seems that NaNs screw up matrix().
> 
> Actually, data$z is a factor with one level NaN.
Geez, I why is data$z a factor?  That seems bizarre. It is supposed to be
the measured value (IV) at each combination of x and y. So what is the
right way to convert my original file?

I go through all this just to produce an image or contour or persp plot.

> R> data$z
> [1] 1   2   NaN 4  
> Levels:  1 2 4 NaN
Weird! Is this because matrix() interprets NaN as a character string
instead of as an NaN (which is a "number", isn't it?)?

Why then isn't everything converted to a factor?
> data$x
[1] 1 1 2 2
> data$y
[1] 1 2 1 2

Also, why does matrix() work as I expect when the NaN in the file is
changed to a 0:
> matrix(data$z,length(y),length(x))
     [,1] [,2]
[1,]    1    0
[2,]    2    4

It also works as I expect when the NaN is changed to an NA:
> matrix(data$z,length(y),length(x))
     [,1] [,2]
[1,]    1   NA
[2,]    2    4


> What you get is the codes of that, which I think is what you want.
NOPE! I want a matrix:
1	NaN
2	4

Bill

-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-
r-devel mailing list -- Read http://www.ci.tuwien.ac.at/~hornik/R/R-FAQ.html
Send "info", "help", or "[un]subscribe"
(in the "body", not the subject !)  To: r-devel-request@stat.math.ethz.ch
_._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._