Hello,

This seems elegant to me but it's also the slowest, courtesy sort.

apply(x, 1, sort) |> t() |> unique()


(My tests show that for small inputs Greg's base apply is fastest, with nrow(x) > 700, Eric's dplyr is fastest)


Hope this helps,

Rui Barradas

Às 15:13 de 20/08/21, Greg Minshall escreveu:
Eric,

x %>% transmute( a=pmin(Source,Target), b=pmax(Source,Target)) %>%
   unique() %>% rename(Source=a, Target=b)

ah, very nice.  i have trouble remembering, e.g., unique().

fwiw, (hopefully) here's a baser version.
----
   x = data.frame(Source=rep(1:3,4), 
Target=c(rep(1,3),rep(2,3),rep(3,3),rep(4,3)))

   y <- apply(x, 1, function(y) return (c(A=min(y), B=max(y))))
   unique(t(y))
----

cheers, Greg

______________________________________________
R-help@r-project.org mailing list -- To UNSUBSCRIBE and more, see
https://stat.ethz.ch/mailman/listinfo/r-help
PLEASE do read the posting guide http://www.R-project.org/posting-guide.html
and provide commented, minimal, self-contained, reproducible code.


______________________________________________
R-help@r-project.org mailing list -- To UNSUBSCRIBE and more, see
https://stat.ethz.ch/mailman/listinfo/r-help
PLEASE do read the posting guide http://www.R-project.org/posting-guide.html
and provide commented, minimal, self-contained, reproducible code.

Reply via email to