向量笛卡尔积_julia-lang – Julia中两个向量的笛卡尔积

Julia通常在嵌套循环中非常快,所以如果它们对你正常工作,你应该可以检查性能,或者只是坚持下去.

其他选项是使用repmat(这个比使用repeat更快一点):

[repmat(x,1,length(y))'[:] repmat(y,length(x),1)[:]]

对这两种方法进行了一些快速测试:

x=rand(1000)

y=rand(1000)

function withrepeat(x,y)

[repeat(x, inner=[size(y,1)]) repeat(y, outer=[size(x,1)])]

end

function withrepmat(x,y)

[repmat(x,1,length(y))'[:] repmat(y,length(x),1)[:]]

end

withrepeat(x,y)

elapsed time: 0.21556302 seconds (95986112 bytes allocated)

with repmat(x,y)

elapsed time: 0.075604488 seconds (56000560 bytes allocated)

不知道为什么会有这么大的差异,我认为还有改进的余地.

没有尝试过Iterators.jl包中的产品功能.

希望这可以帮助.

尝试了几个嵌套循环,确实更快:

function withloops (x,y)

leny=length(y)

lenx=length(x)

m=leny*lenx

OUT = zeros(Float64, m,2)

c=1

for i = 1:lenx

for j = 1:leny

OUT[c,1] = x[i]

OUT[c,2] = y[j]

c+=1

end

end

return OUT

end

并且,对于x和y,相同的兰特(1000).

withloops(x,y)

elapsed time: 0.011350679 seconds (16000128 bytes allocated)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值