70、Cadmium:ACD 项重写的实现

Cadmium:ACD 项重写的实现

1. 引言

Cadmium 是一种基于规则的编程语言,用于将独立于求解器的约束模型编译到各种依赖于求解器的后端。它基于约束处理规则(CHR)和模结合律、交换律以及一种受限形式的分配律(ACD)的项重写的混合,其中 ACD 被称为合取上下文(CC)。在 G12 项目中使用 Cadmium 的经验表明,CC 是一个强大的语言特性,因为局部模型映射可能依赖于一些非局部上下文,如变量声明或其他约束。然而,CC 显著地使 Cadmium 归一化算法变得复杂,因为一个项的范式可能取决于它出现的上下文。

2. 相关概念
2.1 结合交换(AC)项重写

AC 项重写允许在应用规则之前隐式地重新排序 AC 运算符。一个 AC 运算符 ⊕ 满足结合律和交换律公理:
- 结合律:$(X ⊕ Y) ⊕ Z = X ⊕ (Y ⊕ Z)$
- 交换律:$X ⊕ Y = Y ⊕ X$

例如,重写规则 $r = (X ∧ ¬X → false)$ 在非 AC 项重写中不会匹配项 $T = ¬a ∧ a$,因为合取的顺序不同。但由于 ∧ 是可交换的,$T$ 等价于 $T’ = a ∧ ¬a$。由于 $T ≡_{AC} T’$ 且 $T’$ 匹配 $r$(即 AC 匹配),所以在 AC 项重写中 $T$ 可以被重写为 false。

2.2 ACD 项重写

ACD 项重写通过以下公理将 AC 项重写扩展为 ∧ - 分配律:
- 分配律:$P ∧ f(Q1, …, Qi, … Qn) = P ∧ f(Q1, …, P ∧ Qi, …, Qn)$

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值