-
Notifications
You must be signed in to change notification settings - Fork 72
cmd_explain
Allows you to explore how rules were learned.
======= Explainer Commands and Settings =======
explain ? Print this help listing
---------------- What to Record ---------------
all [ on | OFF ] Record all rules learned
justifications [ on | OFF ] Record justifications
record <chunk-name> Record specific rule
list List all rules learned
----------- Starting an Explanation -----------
chunk [<chunk name> | <chunk id> ] Start discussing chunk
formation Describe formation
----------- Browsing an Explanation -----------
instantiation <inst id> Explain instantiation
explanation-trace Switch explanation trace
wm-trace Switch to WM trace
-------------- Supporting Analysis ----------------
constraints Explain constraints
identity Explain identity sets
stats Display statistics
To change a setting: explain <setting> [<value>]
For a detailed explanation of these settings: help explain
Using the explain
command without any arguments will display a summary of which rule firings the explainer is watching for learning. It also shows which chunk or justification the user has specified is the current focus of its output, i.e. the chunk being discussed.
Tip: This is a good way to get a chunk id so that you don't have to type or paste in a chunk name.
=======================================================
Explainer Summary
=======================================================
Watch all chunk formations Yes
Explain justifications No
Number of specific rules watched 0
Chunks available for discussion: chunkx2*apply2 (c 14)
chunk*apply*o (c 13)
chunkx2*apply2 (c 12)
chunk*apply*d (c 11)
chunkx2*apply2 (c 6)
chunk*apply* (c 15)
chunkx2*apply (c 8)
chunk*apply*c (c 5)
chunkx2*apply (c 10)
chunk*apply (c 1)
* Note: Printed the first 10 chunks. 'explain --list' to see other 6 chunks.
Current chunk being discussed: chunk*apply*down-gripper(c 3)
Use 'explain chunk [ <chunk-name> | id ]' to discuss the formation of that chunk.
Use 'explain ?' to learn more about explain's sub-command and settings.
This starts the process.
Tip: Use c
, which is an alias to explain chunk
, to quickly start discussing a chunk, for example:
soar % c 3
Now explaining chunk*apply*move-gripper-above*pass*top-state*OpNoChange*t6-1.
- Note that future explain commands are now relative
to the problem-solving that led to that chunk.
Explanation Trace Using variable identity IDs Shortest Path to Result Instantiation
sp {chunk*apply*move-gripper-above*pass*top-state*OpNoChange*t6-1
1: (<s1> ^top-state <s2>) ([140] ^top-state [162])
-{
2: (<s1> ^operator <o*1>) ([140] ^operator [141])
3: (<o*1> ^name evaluate-operator) ([141] ^name evaluate-operator)
}
4: (<s2> ^gripper <g1>) ([162] ^gripper [156]) i 30 -> i 31
5: (<g1> ^position up) ([156] ^position up) i 30 -> i 31
6: (<g1> ^holding nothing) ([156] ^holding nothing) i 30 -> i 31
7: (<g1> ^above <t1>) ([156] ^above [157]) i 30 -> i 31
8: (<s2> ^io <i2>) ([162] ^io [163]) i 31
9: (<i2> ^output-link <i1>) ([163] ^output-link [164]) i 31
10: (<i1> ^gripper <g2>) ([164] ^gripper [165]) i 31
11: (<s2> ^clear { <> <t1> <b1> }) ([162] ^clear { <>[161] [161] }) i 30 -> i 31
12: (<s1> ^operator <o1>) ([140] ^operator [149])
13: (<o1> ^moving-block <b1>) ([149] ^moving-block [161])
14: (<o1> ^name pick-up) ([149] ^name pick-up)
-->
1: (<g2> ^command move-gripper-above +) ([165] ^command move-gripper-above +)
2: (<g2> ^destination <c1> +) ([165] ^destination [161] +)
}
explain formation
provides an explanation of the initial rule that fired which created a result. This
is what is called the 'base instantiation' and is what led to the chunk being learned. Other rules may also be base instantiations if they previously created children of the base instantiation's results. They also will be listed in the intial formation output.
soar % explain formation
------------------------------------------------------------------------------------
The formation of chunk 'chunk*apply*move-gripper-above*pass*top-state*OpNoChange*t6-1' (c 1)
------------------------------------------------------------------------------------
Initial base instantiation (i 31) that fired when apply*move-gripper-above*pass*top-state matched at level 3 at time 6:
Explanation trace of instantiation # 31 (match of rule apply*move-gripper-above*pass*top-state at level 3)
(produced chunk result)
Identities instead of variables Operational Creator
1: (<s> ^operator <op>) ([159] ^operator [160]) No i 30 (pick-up*propose*move-gripper-above)
2: (<op> ^name move-gripper-above) ([160] ^name move-gripper-above) No i 30 (pick-up*propose*move-gripper-above)
3: (<op> ^destination <des>) ([160] ^destination [161]) No i 30 (pick-up*propose*move-gripper-above)
4: (<s> ^top-state <t*1>) ([159] ^top-state [162]) No i 27 (elaborate*state*top-state)
5: (<t*1> ^io <i*1>) ([162] ^io [163]) Yes Higher-level Problem Space
6: (<i*1> ^output-link <o*1>) ([163] ^output-link [164]) Yes Higher-level Problem Space
7: (<o*1> ^gripper <gripper>) ([164] ^gripper [165]) Yes Higher-level Problem Space
-->
1: (<gripper> ^command move-gripper-above +) ([165] ^command move-gripper-above +)
2: (<gripper> ^destination <des> +) ([165] ^destination [161] +)
------
This chunk summarizes the problem-solving involved in the following 5 rule firings:
i 27 (elaborate*state*top-state)
i 28 (elaborate*state*operator*name)
i 29 (pick-up*elaborate*desired)
i 30 (pick-up*propose*move-gripper-above)
i 31 (apply*move-gripper-above*pass*top-state)
This is probably one of the most common things you will do while using the explainer. You are essentially browsing the instantiation graph one rule at a time.
Tip: Use i
, which is an alias to explain instantiation
, to quickly view an instantiation, for example:
soar % i 30
Explanation trace of instantiation # 30 (match of rule pick-up*propose*move-gripper-above at level 3)
- Shortest path to a result: i 30 -> i 31
Identities instead of variables Operational Creator
1: (<s> ^name pick-up) ([152] ^name pick-up) No i 28 (elaborate*state*operator*name)
2: (<s> ^desired <d*1>) ([152] ^desired [153]) No i 29 (pick-up*elaborate*desired)
3: (<d*1> ^moving-block <mblock>) ([153] ^moving-block [154]) No i 29 (pick-up*elaborate*desired)
4: (<s> ^top-state <ts>) ([152] ^top-state [155]) No i 27 (elaborate*state*top-state)
5: (<ts> ^clear <mblock>) ([155] ^clear [154]) Yes Higher-level Problem Space
6: (<ts> ^gripper <g>) ([155] ^gripper [156]) Yes Higher-level Problem Space
7: (<g> ^position up) ([156] ^position up) Yes Higher-level Problem Space
8: (<g> ^holding nothing) ([156] ^holding nothing) Yes Higher-level Problem Space
9: (<g> ^above { <> <mblock> <a*1> }) ([156] ^above { <>[154] [157] }) Yes Higher-level Problem Space
-->
1: (<s> ^operator <op1> +) ([152] ^operator [158] +)
2: (<op1> ^name move-gripper-above +) ([158] ^name move-gripper-above +)
3: (<op1> ^destination <mblock> +) ([158] ^destination [154] +)
In most cases, users spend most of their time browsing the explanation trace. This is where chunking learns most of the subtle relationships that you are likely to be debugging. But users will also need to examine the working memory trace to see the specific values matched.
To switch between traces, you can use the explain e
and the explain w
commands.
Tip: Use et
and 'wt', which are aliases to the above two commands, to quickly switch between traces.
soar % explain w
Working memory trace of instantiation # 30 (match of rule pick-up*propose*move-gripper-above at level 3)
1: (S9 ^name pick-up) No i 28 (elaborate*state*operator*name)
2: (S9 ^desired D6) No i 29 (pick-up*elaborate*desired)
3: (D6 ^moving-block B3) No i 29 (pick-up*elaborate*desired)
4: (S9 ^top-state S1) No i 27 (elaborate*state*top-state)
5: (S1 ^clear B3) Yes Higher-level Problem Space
6: (S1 ^gripper G2) Yes Higher-level Problem Space
7: (G2 ^position up) Yes Higher-level Problem Space
8: (G2 ^holding nothing) Yes Higher-level Problem Space
9: (G2 ^above { <> B3 T1 }) Yes Higher-level Problem Space
-->
1: (S9 ^operator O9) +
2: (O9 ^name move-gripper-above) +
3: (O9 ^destination B3) +
This feature explains any constraints on the value of variables in the chunk that were required by the problem-solving that occurred in the substate. If these constraints were not met, the problem-solving would not have occurred.
Explanation-based chunking tracks constraints as they apply to identity sets rather than how they apply to specific variables or identifiers. This means that sometimes constraints that appear in a chunk may have been a result of conditions that tested sub-state working memory element. Such conditions don't result in actual conditions in the chunk, but they can provide constraints. explain constraints
allows users to see where such constraints came from.
This feature is not yet implemented. You can use explain stats
to see if any transitive constraints were added to a particular chunk.
explain identity
will show the mappings from variable identities to identity sets. If available, the variable in a chunk that an identity set maps to will also be displayed. (Requires a debug build because of efficiency cost.)
Variable identities are the ID values that are displayed when explaining an individual chunk or instantiation. An identity set is a set of variable identities that were unified to a particular variable mapping. The null identity set indicates identities that should not be generalized, i.e. they retain their matched literal value even if the explanation trace indicates that the original rule had a variable in that element.
soar % explain identity
How the element identities in problem solving map to identity sets:
Identity Identity Set Chunk Variable
145 -> 10 <o1>
155 -> 2 <s2>
144 -> 1 <s1>
151 -> 16 #
148 -> 1 <s1>
158 -> 15 #
147 -> 14 #
152 -> 13 #
143 -> 12 #
154 -> 9 <b1>
150 -> 9 <b1>
149 -> 10 <o1>
162 -> 2 <s2>
139 -> 11 #
161 -> 9 <b1>
142 -> 2 <s2>
165 -> 8 <g2>
141 -> 3 <o*1>
164 -> 7 <i1>
156 -> 4 <g1>
140 -> 1 <s1>
163 -> 6 <i2>
157 -> 5 <t1>
The following element identities in problem solving map to the null
identity set. Elements in conditions that test those identities will
not be generalized:
146
explain stats
prints statistics about the chunk being discussed.
===========================================================
Statistics for 'chunk*apply*move-gripper-above*pass*top-state*OpNoChange*t6-1' (c 1):
===========================================================
Number of conditions 14
Number of actions 2
Base instantiation i 31 (apply*move-gripper-above*pass*top-state)
===========================================================
Generality and Correctness
===========================================================
Tested negation in local substate No
LHS required repair No
RHS required repair No
Was unrepairable chunk No
===========================================================
Work Performed
===========================================================
Instantiations backtraced through 5
Instantiations skipped 6
Constraints collected 1
Constraints attached 0
Duplicates chunks later created 0
Conditions merged 2
c explain chunk
i explain instantiation
et explain explanation-trace
wt explain wm-trace
Soar's visualize
command allows you to create an image that shows the entire instantiation graph at once, with arrows showing the dependencies between actions in one rule and conditions in others. This image is one of the most effective ways to understand how a chunk was formed, especially for particularly complex chunks. To use this feature, first choose a chunk for discussion. You can then issue the visualize
command with the appropriate settings.