[R] a more elegant approach to getting the majority level
Uwe Ligges
ligges at statistik.uni-dortmund.de
Thu May 26 16:56:31 CEST 2005
Rajarshi Guha wrote:
> Hi, I have a factor and I would like to find the most frequent level.
>
> I think my current approach is a bit long winded and I was wondering if
> there was a more elegant way to do it:
>
> x <- factor(sample(1:0, 5,replace=TRUE))
>
> levels(x)[ which( as.logical((table(x) == max(table(x)))) == TRUE ) ]
(== TRUE) can ALWAYS be omitted, see also:
library(fortunes)
fortune("TRUE")
x == max(x) should be replaced by which.max(x)
as.logical() is superfluous
Hence we get:
names(which.max(table(x)))
Uwe Ligges
> (The length of x will always be an odd number, so I wont get a tie in
> max())
>
> Thanks,
>
> -------------------------------------------------------------------
> Rajarshi Guha <rxg218 at psu.edu> <http://jijo.cjb.net>
> GPG Fingerprint: 0CCA 8EE2 2EEB 25E2 AB04 06F7 1BB9 E634 9B87 56EE
> -------------------------------------------------------------------
> Alcohol, an alternative to your self
> - 'Alcohol' by the Bare Naked Ladies
>
> ______________________________________________
> R-help at stat.math.ethz.ch mailing list
> https://stat.ethz.ch/mailman/listinfo/r-help
> PLEASE do read the posting guide! http://www.R-project.org/posting-guide.html
More information about the R-help
mailing list