Skip to content

A sample workflow with the REPL

mrcslws edited this page Nov 7, 2014 · 18 revisions

Let's use the REPL to run the directional-steps-1d demo (blog post, comportexviz).

As described in README.md, start a REPL:

lein repl

Now, in the REPL, let's load the demo code, referring its public vars into the current namespace:

user> (use 'org.nfrac.comportex.demos.directional-steps-1d)

We're now equipped to create a model:

user> (def model (n-region-model 2))

You can explore the model. You probably shouldn't print the whole thing at once. Instead, explore it with keys.

user> (keys model)
(:ff-deps-map :fb-deps-map :strata :inputs-map :regions-map :uuid->id)
user> (keys (:regions-map model))
(:r0 :r1)
user> (keys (:r0 (:regions-map model)))
(:column-field :layer-3 :uuid :step-counter)
user> (keys (:column-field (:r0 (:regions-map model))))
(:spec :ff-sg :topology :input-topology :overlaps :sig-overlaps :prox-exc :inh-radius :boosts :active-duty-cycles :overlap-duty-cycles)
user> (keys (:layer-3 (:r0 (:regions-map model))))
(:spec :topology :distal-sg :active-cols :burst-cols :active-cells :learn-cells :signal-cells :tp-cells :prior-active-cells :prior-learn-cells :pred-cells :prior-pred-cells :distal-exc :tp-exc)

Use column-state-freqs for a summary.

user> (use 'org.nfrac.comportex.core)
user> (column-state-freqs (:r0 (:regions-map model)))
{:size 1000, :timestep 0, :active-predicted 0, :active 0, :predicted 0}

Before we move on and run the model, let's examine the input.

user> initial-input
[:up 0]
user> (input-transform initial-input)
[:up 1]
user> (input-transform (input-transform initial-input))
[:up 0]

Note that input-transform is nondeterministic. Let's look at sequences of transforms. To get pprint to work, you may need to (use 'clojure.pprint).

user> (defn showtransforms [input n]
	    (reduce (fn [sofar _] (conj sofar (input-transform (last sofar))))
		        [input]
		        (range n)))
user> (def the-inputs (showtransforms initial-input 10))
user> 
user> (pprint the-inputs)
[[:up 0]
 [:down 1]
 [:down 0]
 [:up 0]
 [:down 1]
 [:up 0]
 [:up 1]
 [:up 2]
 [:down 3]
 [:up 2]
 [:down 3]]
nil

Now let's see these inputs' encodings.

user> (use 'org.nfrac.comportex.protocols)
user> (def the-encodings (map #(apply sorted-set (encode encoder 0 %)) the-inputs))
user> (pprint (zipmap the-inputs the-encodings))
{[:down 3]
 #{0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25
   26 27 28 29 150 151 152 153 154 155 156 157 158 159 160 161 162 163
   164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179},
 [:up 2]
 #{30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52
   53 54 55 56 57 58 59 120 121 122 123 124 125 126 127 128 129 130 131
   132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148
   149},
 [:up 1]
 #{30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52
   53 54 55 56 57 58 59 90 91 92 93 94 95 96 97 98 99 100 101 102 103
   104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119},
 [:down 0]
 #{0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25
   26 27 28 29 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78
   79 80 81 82 83 84 85 86 87 88 89},
 [:down 1]
 #{0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25
   26 27 28 29 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105
   106 107 108 109 110 111 112 113 114 115 116 117 118 119},
 [:up 0]
 #{30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52
   53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75
   76 77 78 79 80 81 82 83 84 85 86 87 88 89}}
nil

Let's run the model.

user> (use 'org.nfrac.comportex.protocols) ; if you haven't done this already
user> (def model-t1 (htm-step model))

You can probe into model-t1, similar to above.

Let's use a similar helper function to run lots of steps at once.

user> (defn steps [model n]
	    (reduce (fn [sofar _] (htm-step sofar))
		        model
		        (range n)))
user> (def model-t2000 (steps model-t1 1999))

Wait a few seconds for it to compute. And then explore.

user> (pprint (:prior-pred-cells (:layer-3 (:r0 (:regions-map model-t2000)))))
#{[347 1] [188 3] [133 3] [40 3] [107 3] [311 0] [299 3] [48 1] [284 2]
  [117 2] [284 3] [237 0] [94 2] [271 1] [227 0] [163 1] [123 2]
  [332 0] [332 3] [227 2] [203 0] [94 1] [81 1] [127 3] [357 3] [150 1]
  [131 1] [299 0] [10 1] [27 2] [136 1] [50 0] [103 0] [67 0] [271 3]
  [255 1] [66 1] [311 1] [87 3] [0 2] [26 3] [147 0] [107 0] [2 1]
  [136 0] [131 3] [237 1] [34 2] [66 3] [36 2] [67 1] [221 2] [133 1]
  [10 3] [221 3] [373 2] [247 3]}
nil
user> (pprint (:active-cells (:layer-3 (:r0 (:regions-map model-t2000)))))
#{[347 1] [188 3] [40 3] [284 3] [271 1] [332 3] [227 2] [203 0] [94 1]
  [131 1] [299 0] [136 1] [50 0] [103 0] [255 1] [311 1] [87 3] [0 2]
  [26 3] [34 2] [67 1] [221 2] [10 3] [373 2] [247 3]}
nil
user> (pprint (:burst-cols (:layer-3 (:r0 (:regions-map model-t2000)))))
#{}
nil
user> (column-state-freqs (:r0 (:regions-map model-t2000)))
{:size 500, :timestep 2000, :active-predicted 25, :active 0, :predicted 16}

Every active cell was predicted in the previous timestep (among others), so no columns were bursted.

Hopefully this page has helped you:

  1. Get an idea of where to start with this API
  2. See how useful it is to have visualizations like comportexviz, and not just a REPL :)
Clone this wiki locally