Chapel 域有两组方法
domain.low, domain.high
和
domain.first, domain.last
这些返回不同结果的各种情况是什么(即何时domain.first != domain.low
和domain.last != domain.high
?
首先,请注意,这些查询不仅在域上受支持,而且在范围(一种更简单的类型,表示许多域及其域查询所基于的整数序列)上也受支持。 出于这个原因,为了简单起见,我的答案最初将侧重于范围,然后再返回到密集矩形域(使用每个维度的范围定义)。
作为背景,对某个范围first
和last
旨在指定在该范围进行迭代时将获得的索引。 相反,low
和high
指定定义范围的最小和最大索引。
-
对于一个简单的范围,如
1..10
,first
和low
将是相同的,计算结果为1
,而last
和high
的计算结果均为10
-
在教堂中以相反的顺序迭代范围的方式是使用负步幅,如
1..10 by -1
. 对于此范围,low
和high
仍将分别1
和10
,但first
将10
,last
将1
,因为范围表示整数 10、9、8、...、1。 -
教堂还支持非单位步幅,它们也可能导致差异。 例如,对于范围
1..10 by 2
,low
和high
仍将分别1
和10
,first
仍将1
但last
9
,因为此范围仅表示 1 到 10 之间的奇数值。
以下程序演示了这些案例以及我将留给读者的练习1..10 by -2
(您也可以在线尝试 (TIO)):
proc printBounds(r) {
writeln("For range ", r, ":");
writeln(" first = ", r.first);
writeln(" last = ", r.last);
writeln(" low = ", r.low);
writeln(" high = ", r.high);
writeln();
}
printBounds(1..10);
printBounds(1..10 by -1);
printBounds(1..10 by 2);
printBounds(1..10 by -2);
密集矩形域是使用每个维度的范围定义的。 此类域上的low
、high
、first
和last
等查询返回一个值元组,每个维度一个,对应于相应范围的查询结果。 例如,下面是根据上述范围 (TIO) 定义的 4D 域:
const D = {1..10, 1..10 by -1, 1..10 by 2, 1..10 by -2};
writeln("low = ", D.low);
writeln("high = ", D.high);
writeln("first = ", D.first);
writeln("last = ", D.last);