[R] prblem with NA
Erik Iverson
iverson at biostat.wisc.edu
Tue Jan 6 02:29:18 CET 2009
Hello -
kayj wrote:
>
> Hi all
>
> I have a data set with the total number of columns =ncol, and the total
> number of rows=nrow. I am trying to loop over the values and id the value is
> less than or equal to 100 to be changed to 1. if the value is greater than
> 100 , to be changed to 0. if NA , let X[i,j]=NA. I ran into a problem where
> if one row in my data set had all values =NA, then the program does not
> continue working past that row!
>
> At some point I get the following error message:
>
> “Error in if (data [i, j] <= 100) { : missing value where TRUE/FALSE needed”
>
> Here is the program
>
> data<-read.table("fileName.txt", header=F, sep='\t')
>
> X=data
> for(i in ncol)
> {
> for(j in nrow)
> {
> if(data[i,j]<=100) {X[i,j]=1}
> if(data[i,j]>100) {X[i,j]=0}
>
> if(is.na(data[i,j])) {X[i,j]=NA}
> }
> }
An alternate, vectorized solution may be:
X <- ifelse(data <= 100, 1, 0)
And as 'data' is a function in the utils package include with R, you
might consider not naming your variables 'data'.
More information about the R-help
mailing list