有几篇关于计算向量之间的成对差异的帖子,但我找不到如何计算向量中的所有差异。
假设我有一个向量,v。
v<-c(1:4)我想生成第二个向量,它是向量中所有成对差的绝对值。类似于:
abs(1-2) = 1
abs(1-3) = 2
abs(1-4) = 3
abs(2-3) = 1
abs(2-4) = 2
abs(3-4) = 1输出将是一个包含6个值的向量,这是我的6个比较的结果:
output<- c(1,2,3,1,2,1)在R中有一个函数可以做到这一点吗?
发布于 2014-06-20 03:38:52
as.numeric(dist(v))似乎是可行的;它将v视为列矩阵,并计算行之间的欧几里德距离,在本例中为sqrt((x-y)^2)=abs(x-y)
如果我们在打高尔夫球,那么我会提供c(dist(v)),它是等同的,而且我猜它将是无与伦比的。
@AndreyShabalin提出了一个很好的观点,使用method="manhattan"可能会更有效一些,因为它避免了平方/平方根的东西。
发布于 2014-06-20 03:40:31
我们去打高尔夫球吧
abs(apply(combn(1:4,2), 2, diff))@Ben,你的是个杀手!
> system.time(apply(combn(1:1000,2), 2, diff))
user system elapsed
6.65 0.00 6.67
> system.time(c(dist(1:1000)))
user system elapsed
0.02 0.00 0.01
> system.time({
+ v <- 1:1000
+ z = outer(v,v,'-');
+ z[lower.tri(z)];
+ })
user system elapsed
0.03 0.00 0.03 谁知道优雅的(可读的/灵活的)代码会这么慢。
发布于 2014-06-20 03:36:42
一种可能的解决方案是:
z = outer(v,v,'-');
z[lower.tri(z)];
[1] 1 2 3 1 2 1https://stackoverflow.com/questions/24314878
复制相似问题