以下是一些可以通过逻辑编程解决的例子 -
匹配数学表达式
实际上,我们可以通过使用逻辑编程以非常有效的方式找到未知值。 以下 Python 代码用于匹配数学表达式 -
考虑先导入下列软件包 -
from kanren import run, var, fact
from kanren.assoccomm import eq_assoccomm as eq
from kanren.assoccomm import commutative, associative
需要定义要使用的数学运算 -
add = 'add'
mul = 'mul'
加法和乘法都是交互进程。 因此,我们需要指定它,这可以按照以下方式完成 -
fact(commutative, mul)
fact(commutative, add)
fact(associative, mul)
fact(associative, add)
定义变量是强制性的; 这可以如下完成 -
a, b = var('a'), var('b')
需要将表达式与原始模式相匹配。有以下原始模式,基础是(5 + a)* b
-
Original_pattern = (mul, (add, 5, a), b)
有以下两个表达式来匹配原始模式 -
exp1 = (mul, 2, (add, 3, 1))
exp2 = (add,5,(mul,8,1))
输出可以使用以下命令打印 -
print(run(0, (a,b), eq(original_pattern, exp1)))
print(run(0, (a,b), eq(original_pattern, exp2)))
运行此代码后,将得到以下输出 -
((3,2))
()
第一个输出表示a
和b
的值。 第一个表达式匹配原始模式并返回a
和b
的值,但第二个表达式与原始模式不匹配,因此没有返回任何内容。