From 48f8401c59c483f7a2128975397f701099c0441b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Linas=20Vep=C5=A1tas?= Date: Wed, 8 Jun 2016 13:25:06 +0800 Subject: [PATCH 1/8] Move the old top-level tree out of the way. --- src/behavior.scm | 78 --------------------------------------- src/old-tree.scm | 96 ++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 96 insertions(+), 78 deletions(-) create mode 100644 src/old-tree.scm diff --git a/src/behavior.scm b/src/behavior.scm index 1f3cecda..767d7080 100644 --- a/src/behavior.scm +++ b/src/behavior.scm @@ -740,83 +740,5 @@ )) (TrueLink) )) -;; ------------------------------------------------------------------ -;; Main loop. Uses tail recursion optimization to form the loop. -(DefineLink - (DefinedPredicate "main loop") - (SatisfactionLink - (SequentialAnd - (SequentialOr - (DefinedPredicate "Skip Interaction?") - - (SequentialAnd - (DefinedPredicate "Someone requests interaction?") - (DefinedPredicate "Interaction requested action")) - - (SequentialAnd - (DefinedPredicate "Did someone arrive?") - (DefinedPredicate "New arrival sequence")) - - (SequentialAnd - (DefinedPredicate "Did someone leave?") - (DefinedPredicate "Someone left action")) - - ; True, if there is anyone visible. - (SequentialAnd - (DefinedPredicate "Someone visible?") - (DefinedPredicate "Interact with people")) - - (DefinedPredicate "Nothing is happening") - (True)) - - ;; XXX FIXME chatbot is disengaged from everything else. - ;; The room can be empty, the head is bored or even asleep, - ;; but the chatbot is still smiling and yabbering. - ;; If interaction is turned-off need keep alive gestures - (SequentialOr - ; If the TTS vocalization started (chatbot started talking) ... - (SequentialAnd - (DefinedPredicate "chatbot started talking?") - (DefinedPredicate "Speech started")) - - ; If the chatbot currently talking ... - (SequentialAnd - (DefinedPredicate "chatbot is talking?") - (DefinedPredicate "Speech ongoing")) - - ; If the chatbot stopped talking ... - (SequentialAnd - (DefinedPredicate "chatbot stopped talking?") - (DefinedPredicate "Speech ended")) - - (SequentialAnd - (DefinedPredicate "chatbot started listening?") - (DefinedPredicate "Listening started")) - - ; If the chatbot stopped talking ... - (SequentialAnd - (DefinedPredicate "chatbot is listening?") - (DefinedPredicate "Listening ongoing")) - - ; If the chatbot stopped talking ... - (SequentialAnd - (DefinedPredicate "chatbot stopped listening?") - (DefinedPredicate "Listening ended")) - - (SequentialAnd - (DefinedPredicate "Skip Interaction?") - (DefinedPredicate "Keep alive")) - - (True) - ) - - ; If ROS is dead, or the continue flag not set, then stop - ; running the behavior loop. - (DefinedPredicate "Continue running loop?") - (DefinedPredicate "ROS is running?") - - ;; Call self -- tail-recurse. - (DefinedPredicate "main loop") - ))) ; ---------------------------------------------------------------------- diff --git a/src/old-tree.scm b/src/old-tree.scm new file mode 100644 index 00000000..78a4d0a5 --- /dev/null +++ b/src/old-tree.scm @@ -0,0 +1,96 @@ +; +; old-tree.scm +; +; Old (deprecated) top-level behavior tree main loop. +; +; This has been supplanted by the newer, OpenPsi-based behavior +; rules, and is temporarily maintained here for backwards +; compaitbility. +; +; HOWTO: +; ------ +; Run the main loop: +; (behavior-tree-run) +; Pause the main loop: +; (behavior-tree-halt) +; +;; ------------------------------------------------------------------ +;; Main loop. Uses tail recursion optimization to form the loop. +(DefineLink + (DefinedPredicate "main loop") + (SatisfactionLink + (SequentialAnd + (SequentialOr + (DefinedPredicate "Skip Interaction?") + + (SequentialAnd + (DefinedPredicate "Someone requests interaction?") + (DefinedPredicate "Interaction requested action")) + + (SequentialAnd + (DefinedPredicate "Did someone arrive?") + (DefinedPredicate "New arrival sequence")) + + (SequentialAnd + (DefinedPredicate "Did someone leave?") + (DefinedPredicate "Someone left action")) + + ; True, if there is anyone visible. + (SequentialAnd + (DefinedPredicate "Someone visible?") + (DefinedPredicate "Interact with people")) + + (DefinedPredicate "Nothing is happening") + (True)) + + ;; XXX FIXME chatbot is disengaged from everything else. + ;; The room can be empty, the head is bored or even asleep, + ;; but the chatbot is still smiling and yabbering. + ;; If interaction is turned-off need keep alive gestures + (SequentialOr + ; If the TTS vocalization started (chatbot started talking) ... + (SequentialAnd + (DefinedPredicate "chatbot started talking?") + (DefinedPredicate "Speech started")) + + ; If the chatbot currently talking ... + (SequentialAnd + (DefinedPredicate "chatbot is talking?") + (DefinedPredicate "Speech ongoing")) + + ; If the chatbot stopped talking ... + (SequentialAnd + (DefinedPredicate "chatbot stopped talking?") + (DefinedPredicate "Speech ended")) + + (SequentialAnd + (DefinedPredicate "chatbot started listening?") + (DefinedPredicate "Listening started")) + + ; If the chatbot stopped talking ... + (SequentialAnd + (DefinedPredicate "chatbot is listening?") + (DefinedPredicate "Listening ongoing")) + + ; If the chatbot stopped talking ... + (SequentialAnd + (DefinedPredicate "chatbot stopped listening?") + (DefinedPredicate "Listening ended")) + + (SequentialAnd + (DefinedPredicate "Skip Interaction?") + (DefinedPredicate "Keep alive")) + + (True) + ) + + ; If ROS is dead, or the continue flag not set, then stop + ; running the behavior loop. + (DefinedPredicate "Continue running loop?") + (DefinedPredicate "ROS is running?") + + ;; Call self -- tail-recurse. + (DefinedPredicate "main loop") + ))) + +; ---------------------------------------------------------------------- From cc1bf25bfb0ade6a29d50dea5b1b0e59237b7dfe Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Linas=20Vep=C5=A1tas?= Date: Wed, 8 Jun 2016 13:31:42 +0800 Subject: [PATCH 2/8] More movement of the old code --- src/btree-eva-mute.scm | 1 + src/btree.scm | 1 + src/old-tree.scm | 65 ++++++++++++++++++++++++++++++++++++++++++ src/primitives.scm | 65 ------------------------------------------ 4 files changed, 67 insertions(+), 65 deletions(-) diff --git a/src/btree-eva-mute.scm b/src/btree-eva-mute.scm index 37c1b648..5de6e0c5 100644 --- a/src/btree-eva-mute.scm +++ b/src/btree-eva-mute.scm @@ -40,6 +40,7 @@ ; (display %load-path) (add-to-load-path "../src") (load-from-path "cfg-eva.scm") ;;; <<<=== See, its Eva here! +(load-from-path "old-tree.scm") ;; Call (run) to run the main loop, (halt) to pause the loop. ;; The main loop runs in its own thread. diff --git a/src/btree.scm b/src/btree.scm index 17350568..4858aea5 100644 --- a/src/btree.scm +++ b/src/btree.scm @@ -61,6 +61,7 @@ ;; Call (run) to run the main loop, (halt) to pause the loop. ;; The main loop runs in its own thread. +(load-from-path "old-btree.scm") ;;; <<<=== See, its Sophia here! (define (run) (behavior-tree-run)) (define (halt) (behavior-tree-halt)) diff --git a/src/old-tree.scm b/src/old-tree.scm index 78a4d0a5..53206787 100644 --- a/src/old-tree.scm +++ b/src/old-tree.scm @@ -94,3 +94,68 @@ ))) ; ---------------------------------------------------------------------- +;; Main loop control +(define do-run-loop #t) + +(define-public (behavior-tree-run) +" + behavior-tree-run + + Run the Eva behavior tree main loop (in a new thread), + Call (behavior-tree-halt) to exit the loop. +" + (set! do-run-loop #t) + (call-with-new-thread + (lambda () (cog-evaluate! (DefinedPredicateNode "main loop"))))) + +(define-public (behavior-tree-halt) +" + behavior-tree-halt + + Tell the Eva behavior tree main loop thread to exit. +" + (set! do-run-loop #f)) + + +(define-public (behavior-tree-running?) +" + behavior-tree-running? + + Return #t if the behavior tree is running, else return false. +" + do-run-loop) + +(define-public (behavior-tree-loop-count) +" + behavior-tree-loop-count + + Return the loop-count of the behavior tree. +" + loop-count) + + +(define loop-count 0) +(define-public (continue-running-loop) ; public only because its in a GPN + (set! loop-count (+ loop-count 1)) + + ; Print loop count to the screen. + ; (if (eq? 0 (modulo loop-count 30)) + ; (format #t "Main loop: ~a\n" loop-count)) + + ; Pause for one-tenth of a second... 101 millisecs + (usleep 101000) + (if do-run-loop (stv 1 1) (stv 0 1))) + +; Return true if the behavior loop should keep running. +(DefineLink + (DefinedPredicate "Continue running loop?") + (Evaluation + (GroundedPredicate "scm:continue-running-loop") (ListLink))) + +; Return true if ROS is still running. +(DefineLink + (DefinedPredicate "ROS is running?") + (Evaluation + (GroundedPredicate "py:ros_is_running") (ListLink))) + +; ---------------------------------------------------------------------- diff --git a/src/primitives.scm b/src/primitives.scm index 20a96aba..d01937d6 100644 --- a/src/primitives.scm +++ b/src/primitives.scm @@ -177,71 +177,6 @@ except: (change-template "Time to change gaze" "attn-search" "time_search_attn_min" "time_search_attn_max") -;; ------------------------------------------------------------------ -;; Main loop control -(define do-run-loop #t) - -(define-public (behavior-tree-run) -" - behavior-tree-run - - Run the Eva behavior tree main loop (in a new thread), - Call (behavior-tree-halt) to exit the loop. -" - (set! do-run-loop #t) - (call-with-new-thread - (lambda () (cog-evaluate! (DefinedPredicateNode "main loop"))))) - -(define-public (behavior-tree-halt) -" - behavior-tree-halt - - Tell the Eva behavior tree main loop thread to exit. -" - (set! do-run-loop #f)) - - -(define-public (behavior-tree-running?) -" - behavior-tree-running? - - Return #t if the behavior tree is running, else return false. -" - do-run-loop) - -(define-public (behavior-tree-loop-count) -" - behavior-tree-loop-count - - Return the loop-count of the behavior tree. -" - loop-count) - - -(define loop-count 0) -(define-public (continue-running-loop) ; public only because its in a GPN - (set! loop-count (+ loop-count 1)) - - ; Print loop count to the screen. - ; (if (eq? 0 (modulo loop-count 30)) - ; (format #t "Main loop: ~a\n" loop-count)) - - ; Pause for one-tenth of a second... 101 millisecs - (usleep 101000) - (if do-run-loop (stv 1 1) (stv 0 1))) - -; Return true if the behavior loop should keep running. -(DefineLink - (DefinedPredicate "Continue running loop?") - (Evaluation - (GroundedPredicate "scm:continue-running-loop") (ListLink))) - -; Return true if ROS is still running. -(DefineLink - (DefinedPredicate "ROS is running?") - (Evaluation - (GroundedPredicate "py:ros_is_running") (ListLink))) - ; ---------------------------------------------------------------------- ; Sigh. Perform manual garbage collection. This really should be ; automated. XXX TODO. (Can we get ECAN to do this for us?) From c610811fbd2b9af2fe728689a3a63cba609d8f01 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Linas=20Vep=C5=A1tas?= Date: Wed, 8 Jun 2016 13:48:23 +0800 Subject: [PATCH 3/8] Ooops, mioved too much --- src/btree.scm | 2 +- src/old-tree.scm | 6 ------ src/primitives.scm | 7 +++++++ 3 files changed, 8 insertions(+), 7 deletions(-) diff --git a/src/btree.scm b/src/btree.scm index 4858aea5..a0303354 100644 --- a/src/btree.scm +++ b/src/btree.scm @@ -61,7 +61,7 @@ ;; Call (run) to run the main loop, (halt) to pause the loop. ;; The main loop runs in its own thread. -(load-from-path "old-btree.scm") ;;; <<<=== See, its Sophia here! +(load-from-path "old-tree.scm") (define (run) (behavior-tree-run)) (define (halt) (behavior-tree-halt)) diff --git a/src/old-tree.scm b/src/old-tree.scm index 53206787..2bddf381 100644 --- a/src/old-tree.scm +++ b/src/old-tree.scm @@ -152,10 +152,4 @@ (Evaluation (GroundedPredicate "scm:continue-running-loop") (ListLink))) -; Return true if ROS is still running. -(DefineLink - (DefinedPredicate "ROS is running?") - (Evaluation - (GroundedPredicate "py:ros_is_running") (ListLink))) - ; ---------------------------------------------------------------------- diff --git a/src/primitives.scm b/src/primitives.scm index d01937d6..802c9415 100644 --- a/src/primitives.scm +++ b/src/primitives.scm @@ -177,6 +177,13 @@ except: (change-template "Time to change gaze" "attn-search" "time_search_attn_min" "time_search_attn_max") +; ---------------------------------------------------------------------- +; Return true if ROS is still running. +(DefineLink + (DefinedPredicate "ROS is running?") + (Evaluation + (GroundedPredicate "py:ros_is_running") (ListLink))) + ; ---------------------------------------------------------------------- ; Sigh. Perform manual garbage collection. This really should be ; automated. XXX TODO. (Can we get ECAN to do this for us?) From 7b9043189d9461502b2f594a55a3ec3a316587d6 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Linas=20Vep=C5=A1tas?= Date: Wed, 8 Jun 2016 13:52:53 +0800 Subject: [PATCH 4/8] Move the main loop around too --- src/btree-psi.scm | 17 ----------------- src/psi-behavior.scm | 19 +++++++++++++++++++ 2 files changed, 19 insertions(+), 17 deletions(-) diff --git a/src/btree-psi.scm b/src/btree-psi.scm index 4bc0e490..6edd085a 100644 --- a/src/btree-psi.scm +++ b/src/btree-psi.scm @@ -48,23 +48,6 @@ ;; Load the actual psi rules. (load-from-path "psi-behavior.scm") -; There MUST be a DefinedPredicateNode with exactly the name -; below in order for psi-run to work. Or we could just blow -; that off, and use our own loop... -(define loop-name (string-append psi-prefix-str "loop")) -(DefineLink - (DefinedPredicate loop-name) - (SatisfactionLink - (SequentialAnd - (Evaluation (GroundedPredicate "scm: psi-step") - (ListLink)) - (Evaluation (GroundedPredicate "scm: psi-run-continue?") - (ListLink)) - ; If ROS is dead, or the continue flag not set, - ; then stop running the behavior loop. - (DefinedPredicate "ROS is running?") - (DefinedPredicate loop-name)))) - ;; Call (run) to run the main loop, (halt) to pause the loop. ;; The main loop runs in its own thread. (define (run) (psi-run)) diff --git a/src/psi-behavior.scm b/src/psi-behavior.scm index 74613eb5..28cd5d75 100644 --- a/src/psi-behavior.scm +++ b/src/psi-behavior.scm @@ -115,3 +115,22 @@ speech-demand-satisfied (stv 1 1) speech-demand) ; ---------------------------------------------------------------------- + +; There MUST be a DefinedPredicateNode with exactly the name +; below in order for psi-run to work. Or we could just blow +; that off, and use our own loop... +(define loop-name (string-append psi-prefix-str "loop")) +(DefineLink + (DefinedPredicate loop-name) + (SatisfactionLink + (SequentialAnd + (Evaluation (GroundedPredicate "scm: psi-step") + (ListLink)) + (Evaluation (GroundedPredicate "scm: psi-run-continue?") + (ListLink)) + ; If ROS is dead, or the continue flag not set, + ; then stop running the behavior loop. + (DefinedPredicate "ROS is running?") + (DefinedPredicate loop-name)))) + +; ---------------------------------------------------------------------- From 5b5b12b1951d2dcf669a79ed318d7ed3194e4655 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Linas=20Vep=C5=A1tas?= Date: Wed, 8 Jun 2016 14:00:41 +0800 Subject: [PATCH 5/8] convert eva model to openpsi --- src/btree-eva.scm | 8 +++++--- src/btree-psi.scm | 6 +++--- 2 files changed, 8 insertions(+), 6 deletions(-) diff --git a/src/btree-eva.scm b/src/btree-eva.scm index 99562318..8bdb7c70 100644 --- a/src/btree-eva.scm +++ b/src/btree-eva.scm @@ -1,7 +1,7 @@ ; ; btree-eva.scm ; -; Eva behavior tree (for the Eva blender model animations). +; Eva OpenPsi behaviors (for the Eva blender model animations). ; ; Runs a set of defined behaviors that express Eva's personality. ; This version integrates the OpenCog chatbot. @@ -36,16 +36,18 @@ (use-modules (opencog exec)) ; needed for cog-evaluate! in put_atoms.py (use-modules (opencog eva-model)) ; needed for defines in put_atoms.py (use-modules (opencog eva-behavior)) +(use-modules (opencog openpsi)) ; Load the Eva personality configuration. ; (display %load-path) (add-to-load-path "../src") (load-from-path "cfg-eva.scm") ;;; <<<=== See, its Eva here! +(load-from-path "psi-behavior.scm") ;; Call (run) to run the main loop, (halt) to pause the loop. ;; The main loop runs in its own thread. -(define (run) (behavior-tree-run)) -(define (halt) (behavior-tree-halt)) +(define (run) (psi-run)) +(define (halt) (psi-halt)) ; --------------------------------------------------------- ; Load the chat modules. diff --git a/src/btree-psi.scm b/src/btree-psi.scm index 6edd085a..3e6cb454 100644 --- a/src/btree-psi.scm +++ b/src/btree-psi.scm @@ -1,10 +1,10 @@ ; ; btree-psi.scm ; -; OpenPsi-based Eva behavior action selection (for the Eva blender +; Sophia OpenPsi behavior action selection (for the Sophia blender ; model animations). ; -; Runs a set of defined behaviors that express Eva's personality. +; Runs a set of defined behaviors that express Sophia's personality. ; This version integrates the OpenCog chatbot. ; ; The currently-defined behaviors include acknowledging new people who @@ -82,7 +82,7 @@ ; --------------------------------------------------------- ; Run the hacky garbage collection loop. -; (run-behavior-tree-gc) +(run-behavior-tree-gc) ; Silence the output. *unspecified* From 92fc4abcd50fb3347fef3f2dc69106e091be18ff Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Linas=20Vep=C5=A1tas?= Date: Wed, 8 Jun 2016 14:05:37 +0800 Subject: [PATCH 6/8] Rename face deman --- src/psi-behavior.scm | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/src/psi-behavior.scm b/src/psi-behavior.scm index 28cd5d75..0a97fe15 100644 --- a/src/psi-behavior.scm +++ b/src/psi-behavior.scm @@ -39,7 +39,7 @@ ;(DefineLink (DefinedPredicateNode "do-noop") (True)) ;(pred-2-schema "do-noop") -(define demand-satisfied (True)) +(define face-demand-satisfied (True)) (define speech-demand-satisfied (True)) (define face-demand (psi-demand "face interaction" 1)) (define speech-demand (psi-demand "speech interaction" 1)) @@ -58,27 +58,27 @@ (psi-rule (list (NotLink (DefinedPredicate "Skip Interaction?")) (DefinedPredicate "Someone requests interaction?")) (DefinedSchemaNode "Interaction requested action") - demand-satisfied (stv 1 1) face-demand) + face-demand-satisfied (stv 1 1) face-demand) (psi-rule (list (NotLink (DefinedPredicate "Skip Interaction?")) (DefinedPredicate "Did someone arrive?")) (DefinedSchemaNode "New arrival sequence") - demand-satisfied (stv 1 1) face-demand) + face-demand-satisfied (stv 1 1) face-demand) (psi-rule (list (NotLink (DefinedPredicate "Skip Interaction?")) (DefinedPredicate "Did someone leave?")) (DefinedSchemaNode "Someone left action") - demand-satisfied (stv 1 1) face-demand) + face-demand-satisfied (stv 1 1) face-demand) (psi-rule (list (NotLink (DefinedPredicate "Skip Interaction?")) (DefinedPredicate "Someone visible?")) (DefinedSchemaNode "Interact with people") - demand-satisfied (stv 1 1) face-demand) + face-demand-satisfied (stv 1 1) face-demand) (psi-rule (list (NotLink (DefinedPredicate "Skip Interaction?")) (DefinedPredicate "Nothing happening?")) (DefinedSchemaNode "Nothing is happening") - demand-satisfied (stv 1 1) face-demand) + face-demand-satisfied (stv 1 1) face-demand) (psi-rule (list (NotLink (DefinedPredicate "Skip Interaction?")) (DefinedPredicate "chatbot started talking?")) From 6fabc45b9d6ebec3f7edace6437b2b5116293e10 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Linas=20Vep=C5=A1tas?= Date: Wed, 8 Jun 2016 17:58:31 +0800 Subject: [PATCH 7/8] update notes --- src/behavior.scm | 31 +++++++++++++++++++------------ src/psi-behavior.scm | 2 ++ 2 files changed, 21 insertions(+), 12 deletions(-) diff --git a/src/behavior.scm b/src/behavior.scm index 767d7080..9112b710 100644 --- a/src/behavior.scm +++ b/src/behavior.scm @@ -12,22 +12,28 @@ ; HOWTO: ; ------ ; Run the main loop: -; (behavior-tree-run) +; (run) ; Pause the main loop: -; (behavior-tree-halt) +; (halt) ; ; TODO: ; ----- -; XXX This needs a major redesign, to NOT use behavior trees at the top -; level, but instead to provide a library of suitable actions that can -; be searched over, and then performed when a given situation applies. -; That is, given a certain state vector (typically, a subset of the -; current state), the library is searched to see if there is a behavior -; sequence that can be applied to this situation. If there is no such -; explicit match, then the fuzzy matcher should be employed to find -; something that is at least close. If nothing close is found, then -; either the concept blending code, or a hack of the MOSES knob-turning -; and genetic cross-over code should be used to create new quasi-random +; The current OpenPsi framework allows much more general and flexible +; rules than what are presented below; this geneality should be made +; use of. +; +; A general OpenPsi rule has the form of if(context) then take(action); +; these can contain variables, adn can also be classed into different +; groups based on the demands that they are fulfilling. +; +; The content below consits entirely of actions to nbe taken; the +; contexts are in the `primitives.scm` file. +; +; The OpenPsi engine could be (should be?) updated to perform fuzzy +; matching on the contexts, to find close or similar contexts, if no +; one exact match can be made. If nothing close is found, then either +; the concept blending code, or a hack of the MOSES knob-turning and +; genetic cross-over code should be used to create new quasi-random ; performance sequences from a bag of likely matches. ; ; Unit testing: @@ -719,6 +725,7 @@ )) (TrueLink) )) + (DefineLink (DefinedPredicate "Keep alive") (SequentialAnd diff --git a/src/psi-behavior.scm b/src/psi-behavior.scm index 0a97fe15..73a7bc7e 100644 --- a/src/psi-behavior.scm +++ b/src/psi-behavior.scm @@ -10,6 +10,8 @@ ; ;; ------------------------------------------------------------------ +; XXX FIXME -- terrible errible hack -- mostly because OpenPsi +; is expecting actions to be schema, and not predicates. (define (foobar x) ; (display "duuuuuuuude foobar pred-schema wrapper\n") ; (display x) (newline) From 7671c4582527e2e3e9310f20814602ea4d6d8889 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Linas=20Vep=C5=A1tas?= Date: Wed, 8 Jun 2016 18:05:18 +0800 Subject: [PATCH 8/8] more note updates --- src/behavior.scm | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/behavior.scm b/src/behavior.scm index 9112b710..39f90895 100644 --- a/src/behavior.scm +++ b/src/behavior.scm @@ -27,7 +27,9 @@ ; groups based on the demands that they are fulfilling. ; ; The content below consits entirely of actions to nbe taken; the -; contexts are in the `primitives.scm` file. +; contexts are in the `self-model.scm` file. The structure of the +; conexts is fairly rigid; these could probably be loosened to a +; large degree. ; ; The OpenPsi engine could be (should be?) updated to perform fuzzy ; matching on the contexts, to find close or similar contexts, if no