[R] if syntax error :(

Gabor Grothendieck ggrothendieck at gmail.com
Tue Jun 13 22:29:09 CEST 2006


On 6/13/06, Rolf Turner <rolf at erdos.math.unb.ca> wrote:
> H. Paul Benton wrote:
>
> > Umm sorry to bother everyone again but I'm having trouble with my if
> > statement. I come from a perl background so that's probably my problem! :)
> > So here is my code:
> >
> > if (any(lgAB>4) | any(lgAB<-4)){
> >       freq_AB<-hist(lgAB, type="o", plot=F)
> >       else
> >       freq_AB<-hist(lgAB, breaks=br,type ="o", plot=F)
> > }
> >
> > And I get
> > > source("E:/R/GMDA-1.1.R")
> > Error in parse(file, n = -1, NULL, "?") : syntax error at
> > 11:             freq_AB<-hist(lgAB, type="o", plot=F)
> > 12:             else
> > >
>
> No-one yet has pointed out the following problem, which, while not be
> a syntax error as such, will cause you headaches:
>
>        if (any(lgAB>4) | any(lgAB<-4)){
>                              ^^^^^^^
>
> This assigns the value 4 to lgAB (which is presumably NOT what
> you want to do).  You want ``any(lgAB < -4)''.
>
> General rule:  Put in spaces around operators --- it makes the
> code (much) more readable and avoids unintended consequences.
>
> Another infelicity in your code: ``plot=F''.  Use ``plot=FALSE''.
> (Note that the symbols ``F'' and ``T'' are assignable, *unlike*
> ``TRUE'' and ``FALSE''.)
>

In fact if we are going to improve the code we could write it more
compactly and in a way which shows more clearly that the if
is only involved in setting breaks like this:

freq_AB <-  hist(lgAB,  type = "o", plot = FALSE,
  breaks = if (any(abs(lgAB) > 4)) "Sturges" else br)



More information about the R-help mailing list