次のproduct-pluso
関数が予期しない結果を返す理由を理解しようとしています。バグを見つけましたか、それともこれがどのように機能するかを誤解していますか? CLP/FD で core.logic を使用しています。私はまだ勉強中なので、やり方が間違っているかもしれません。この関数は、数値と合計の 2 つの因数を取る必要があります。合計は、係数と数値の積でなければなりません。両方の要素が新鮮でない限り、うまく機能します。その後、奇妙な結果が得られます。これは、core.logic v0.8.2 で発生しています。
(ns strang-result
(:refer-clojure :exclude [==])
(:use
clojure.test
[clojure.core.logic :exclude [is]])
(:require
[clojure.core.logic.fd :as fd]))
(defn product-pluso [factor1 factor2 number sum]
(fd/eq (= sum (+ number (* factor1 factor2)))))
(run* [x y]
(fd/in x y (fd/interval 1 38))
(product-pluso x y 2 40))
;=> ([1 38] [2 19] [3 13] [4 10] [5 8] [6 7] [7 6] [8 5] [9 5] [10 4] [11 4]
; [12 4] [13 3] [14 3] [15 3] [16 3] [17 3] [18 3] [19 2] [38 1])