【问题标题】:Julia - n-nested loopsJulia - n 嵌套循环
【发布时间】:2016-10-18 01:06:04
【问题描述】:

我试图在 Julia 中创建一个 n 嵌套循环方法

function fun(n::Int64)
    @nloops n i d->1:3 begin\n
        @nexprs n j->(print(i_j))\n
    end
end

但@nloops 的定义仅限于

_nloops(::Int64, ::Symbol, ::Expr, ::Expr...)

我得到了错误

_nloops(::Symbol, ::Symbol, ::Expr, ::Expr)

有什么办法可以使这个工作吗?非常感谢任何帮助

编辑:

我最终做的是使用组合方法

对于我的问题,我需要获取所有索引的 k 组合以从数组中提取值,因此循环必须看起来像

for i_1 in 1:100
    for i_2 in i_1:100
        ...
           for i_k in i_[k-1]:100

【问题讨论】:

  • 得到了完全相同的问题 :-)

标签: macros combinations julia nested-loops cartesian


【解决方案1】:

循环数需要是一个编译时常量——实际上是一个数字字面量:为函数体生成的代码不能依赖于函数参数。 Julia 生成的函数也无济于事,因为 n 只是一个普通值,而不是任何参数类型的一部分。让嵌套循环的数量取决于运行时值(如 n)的最佳选择是使用递归。

【讨论】:

    【解决方案2】:

    在 julia-0.4 及更高版本中,您现在可以这样做:

    function fun(n::Int)
        for I in CartesianRange(ntuple(d->1:3, n))
            @show I
        end
    end
    

    在大多数情况下,您不再需要 Base.Cartesian 宏(尽管仍有一些例外)。值得注意的是,正如 StefanKarpinski 的回答中所描述的,这个循环不会是“类型稳定的”,因为 n 不是编译时常量;如果性能很重要,您可以使用“功能障碍技术”。有关与这些事项相关的所有主题的更多信息,请参阅http://julialang.org/blog/2016/02/iteration

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2020-10-01
      • 2020-05-25
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2018-03-01
      • 1970-01-01
      相关资源
      最近更新 更多