任何人都可以在这里解释传递闭包运算符如何根据矩阵在合金中工作。我的意思是将闭包运算符转换为实际矩阵运算的转换规则。
问问题
1268 次
1 回答
8
为了计算传递闭包,Kodkod 使用迭代平方。
简而言之,如果您有一个二元关系r
(直接转换为二维布尔矩阵),则传递闭包r
可以迭代计算为
- r 1 = r 或 (r . r)
- r 2 = r 1或 (r 1 . r 1 )
- r 3 = r 1或 (r 2 . r 2 )
- ...
- ^r = r n = r n-1或 (r n-1 . r n-1 )
问题是我们什么时候停止,即应该停止什么n
。由于一切都是有界的,Kodkod 静态知道 中的最大行数r
,并且应该直观地清楚,如果n
设置为该行数,则该算法将产生语义上正确的翻译。然而,即使n/2
是足够的(因为我们每次都对矩阵进行平方),这是 Kodkod 使用的实际数字。
于 2013-01-23T16:44:30.477 回答