- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
根据我正在阅读的一本书中的示例代码对简单的贝叶斯概率推理网络进行实验,似乎存在涉及更新节点概率的问题。更新节点 POPULARITY
没有问题,但是一旦它出于某种原因尝试更新 ELEGANCE
时,就会出现问题中的错误。我试过在 allegro 中输入调试器,它把 nil nil
作为 prior-prob
和 current-prob
的 CAR它试图更新的弧线。不过,我不明白为什么,因为这不是第一个节点的问题。这是代码:
;;Network representation
(defun odds (prob)
(/ prob (- 1.0 prob)))
(defun prob (odds)
(/ odds (1+ odds)))
(defmacro define-node (name prior-prob current-prob arcs)
`(progn
(setf (get ',name 'prior-prob) ,prior-prob)
(setf (get ',name 'prior-odds) (odds ,prior-prob))
(setf (get ',name 'current-prob) ,current-prob)
(setf (get ',name 'current-odds) (odds ,current-prob))
(setf (get ',name 'arcs) ',arcs)))
(defun current-prob (n) (get n 'current-prob))
(defun prior-prob (n) (get n 'prior-prob))
(defun current-odds (n) (get n 'current-odds))
(defun prior-odds (n) (get n 'prior-odds))
(defun sufficiency (arc) (cadr arc))
(defun necessity (arc) (car (cddr arc)))
;Primary evidential variables
(define-node decor 0.5 0.9 ())
(define-node table-setting 0.5 0.8 ())
(define-node surface-cleanliness 0.8 0.8 ())
(define-node air 0.6 0.6 ())
(define-node sounds 0.5 0.5 ())
(define-node clientele 0.5 0.9 ())
(define-node menu 0.5 0.5 ())
(define-node prices 0.5 0.9 ())
(define-node services 0.3 0.9 ())
;Lumped evidential variables
(define-node popularity 0.5 0.6 (indep
(arc sounds 1.5 1.0)
(arc clientele 1.0 0.24)))
(define-node elegance 0.5 0.5 (indep
(arc decor 3.0 0.5)
(arc table-setting 1.0 0.74)
(arc sounds 1.5 0.74)
(arc clientele 1.0 0.5)
(arc menu 1.24 0.74)
(arc prices 1.24 0.74)
(arc service 1.0 0.5)))
(define-node artistry 0.5 0.9 (indep
(arc decor 1.0 0.5)
(arc table-setting 1.0 0.5)
(arc menu 1.5 0.74)
(arc service 1.0 0.5)))
(define-node cleanliness 0.7 0.7 (indep
(arc surface-cleanliness 1.5 0.2)
(arc air 1.5 0.5)))
(define-node taste 0.6 0.6 (indep
(arc popularity 1.5 0.7)
(arc elegance 1.5 0.8)))
(define-node texture 0.6 0.6 (indep
(arc popularity 1.5 0.7)
(arc elegance 1.5 0.8)))
(define-node appearance 0.5 0.5 (indep
(arc artistry 3.0 0.4)))
(define-node quantity 0.5 0.5 (indep
(arc popularity 1.5 0.5)))
(define-node correctness 0.5 0.5 (indep
(arc elegance 1.0 0.7)))
(define-node nutrition 0.6 0.6 (indep
(arc popularity 1.1 0.7)
(arc elegance 1.8 0.8)))
(define-node hygiene 0.8 0.8 (indep
(arc cleanliness 1.0 0.1)))
(define-node overall-food-quality 0.5 0.5
(indep
(and
(arc taste 3.0 0.3)
(arc texture 1.0 0.5))
(and
(arc appearence 1.0 0.3)
(arc correctness 1.3 0.8))
(arc quantity 1.2 0.8)
(arc nutrition 1.0 0.3)
(arc hygiene 1.5 0.2)))
;Update-prob computes P(H|E') for a single arc
(defun update-prob (h arc)
(cond
((> (current-prob (car arc))
(prior-prob (car arc)))
(report-progress 'supportive h arc)
(+ (prior-prob h)
(* (/ (- (prob (* (sufficiency arc)
(prior-odds h)))
(prior-prob h))
(- 1.0 (prior-prob (car arc))))
(- (current-prob (car arc))
(prior-prob (car arc))))))
(t (report-progress 'inhibitive h arc)
(+ (prob (* (necessity arc) (prior-odds h)))
(* (/ (- (prior-prob h)
(prob (* (necessity arc)
(prior-odds h))))
(prior-prob (car arc)))
(current-prob (car arc)))))))
;Report-porgres describes the progress of the updating
(defun report-progress (supp-inhib h arc)
(cond
((null reporting) nil)
(t
(format t "~%~a probability updating for node ~a" supp-inhib h)
(format t " along arc:~%~s with prior odds ~s." arc (prior-odds h))
(format t "~%Prior and current probabilities of E are ~s and ~s."
(prior-prob (car arc)) (current-prob (car arc))))))
(proclaim '(special *node*))
(defun effective-arc-lambda (arc)
(/ (odds (update-prob *node* arc))
(prior-odds *node*)))
(defun combine-indep-lambdas (arc-exp)
(apply #'*
(mapcar #'eval-arc-exp
(cdr arc-exp))))
(defun combine-conjunctive-lambdas (arc-exp)
(apply #'min
(mapcar #'eval-arc-exp
(cdr arc-exp))))
(defun combine-disjunctive-lambdas (arc-exp)
(apply #'max
(mapcar #'eval-arc-exp
(cdr arc-exp))))
(defun update-nodes (nodes)
(cond ((null nodes) nil)
(t (update-node (car nodes))
(update-nodes (cdr nodes)))))
;;Evaluates arc expression, finding odds updating factor
(defun eval-arc-exp (arc-exp)
(cond ((eq (car arc-exp) 'arc)
(effective-arc-lambda (cdr arc-exp)))
((eq (car arc-exp) 'indep)
(combine-indep-lambdas arc-exp))
((eq (car arc-exp) 'and)
(combine-conjunctive-lambdas arc-exp))
((eq (car arc-exp) 'or)
(combine-disjunctive-lambdas arc-exp))
(t (print '(illegal arc expression)) (print arc-exp))))
;;Update nde computes the new probability for a given node
(defun update-node (h)
(setq *node* h)
(setf (get h 'current-odds)
(* (prior-odds h)
(eval-arc-exp (get h 'arcs))))
(setf (get h 'current-prob) (prob (current-odds h)))
(format t "~%Current probability of a node ~a is ~s.~%" h (current-prob h)))
(defun test ()
(update-nodes '(popularity elegance artistry cleanliness
taste texture appearance quantity
correctness nutrition hygiene
overall-food-quality)))
(defmacro sp (name current-prob)
'(progn
(setf (get (car l) 'current-prob) (cadr l))
(setf (get (car l) 'current-odds) (odds (cadr l)))))
感谢您提供的任何帮助!
最佳答案
你的问题的原因是图的节点名称中至少有两个不一致:
服务
,有时您使用服务
。appearance
,有时使用appearance
(我不再关注这两个名字了)。
如果您需要经常更改此程序,请考虑编写一个函数来检查图形的一致性。另请注意,宏 sp
(未使用)的定义存在错误。引号 (') 可能应该是反引号 (`)(这是从其他 Material 复制粘贴时的典型错误)。
最后,如果您想继续使用 Common Lisp 编程,请强烈考虑学习使用调试器,因为通过适当使用调试器几乎可以立即找到错误原因。
关于lisp - `NIL 不是 Lisp 中预期的 REAL 类型,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34804391/
你们能帮帮我吗,这是我们的讲师给我们的教程问题,无论我们尝试了多少,我们实际上似乎都无法破解它。请帮忙 ; perform some type/error checking, ; then ca
在 Common Lisp 中编写、编译和测试一个函数,该函数接受一个列表并计算列表中正整数的总数。必须编译然后执行包含函数的 .lisp 文件。在编译该文件后开始传递它,列出要生成的结果的结果,从而
我是 Lisp 初学者,我很难理解为什么下面的代码会给我一个错误。 (dolist (elem '(mapcar mapcon)) (when (fboundp `
我听说 Lisp 可以让你重新定义语言本身,我也试图研究它,但没有任何地方明确的解释。有人有一个简单的例子吗? 最佳答案 Lisp 用户将 Lisp 称为 可编程编程语言 .用于符号计算 - 用符号计
Closed. This question is off-topic. It is not currently accepting answers. Learn more。 想改进这个问题吗Updat
这些是 cons 参数的不同组合的输出。我刚开始学习 lisp。有人可以帮我理解这些吗? Break 80 [81]> (CONS '(A) 'B) ((A) . B) Break 80 [81]>
这个问题不太可能帮助任何 future 的访问者;它只与一个小的地理区域、一个特定的时间点或一个非常狭窄的情况有关,这些情况并不普遍适用于互联网的全局受众。为了帮助使这个问题更广泛地适用,visit
我想问一下为什么这个功能不起作用... (defun nenum(ls) (cond ((null ls) nil) ((listp car(ls)) (nenum (rest ls)
如果我有一个原子,例如“a4”,我需要能够将 1 添加到“4”部分以使其成为 a5,但是因为它被认为是一个字符串,所以这是不可能的,所以如果我可以拆分 (a4 ) 到 ((a)(4)) 中,然后我可以
我有一个关于动态构建函数(或类似的东西)的问题。在 Java 中,我可以通过编程将一些 Source 写入字符串,编译该字符串并像函数一样执行它多次。 假设我有一些遗传算法来创建最佳代码以获取 n 个
我是 Common Lisp 的新手,正在学习教程,但无法全神贯注 (equal '(reverse (a b)) '(b a))) 返回零。 非常感谢您的协助。 M. 最佳答案 在 lisp 中引
我有一个使用列表表示的树。例如: (1 ((2 (3)) (3 (2)))) (2 ((1 (3)) (3 (1)))) (3 ((1 (2)) (2 (1)))))` 现在我需要在维护层次结构树的同
在此站点:http://www.gigamonkeys.com/book/practical-a-simple-database.html有如下列出的用户入口函数: (defun prompt-rea
我对 lisp 比较陌生,对在以下上下文中使用嵌套列表的最佳方法很好奇: 所以,我有以下功能: (defun get-p0 (points) (loop for (label x y) in
我正在为 CLOS 类编写一个函数,该函数反转所述类对象的列表元素。 我有一个返回反向列表的方法,但如何让它将对象的列表设置为该列表?我可以在存储列表的函数中有一个实例变量,然后将元素设置为那个吗?或
我知道,严格来说,没有编译语言或解释语言这回事。 但是,一般来说,LISP 是用来编写 Python、bash 脚本、批处理脚本之类的脚本的吗? 还是像 C++、JAVA 和 C# 这样的通用编程语言
在此站点 http://jatha.sourceforge.net/快速函数的示例是通过递归。是不是递归通常比 Lisp 中的迭代更快并且性能更好? 编辑:Lisp 是否比其他语言更优化递归? 最佳答
另一个新手(常见)LISP 问题: 基本上在大多数编程语言中,函数都有一种方法接收对变量的引用而不仅仅是值,即通过引用传递而不是通过值传递。比方说,为了简单起见,我想编写一个 LISP 函数来接收一个
这个问题在这里已经有了答案: How do I find the index of an element in a list in Racket? (3 个答案) 关闭 9 年前。 如果我有这样的列
我在为这个程序生成正确的输出时遇到了一些问题。我的输出几乎是正确的,但缺少一些步骤。我的代码如下: (defun kt (x y m n) ;set the
我是一名优秀的程序员,十分优秀!