changeset 407:bd6d03596ea8

add worm segment to demonstrate self-organizing touch maps.
author Robert McIntyre <rlm@mit.edu>
date Tue, 18 Mar 2014 19:53:42 -0400 (2014-03-18)
parents 40b67bb71430
children 3b4012b42611
files assets/Models/worm/worm-single-segment.blend org/worm_learn.clj thesis/org/roadmap.org
diffstat 3 files changed, 94 insertions(+), 19 deletions(-) [+]
line wrap: on
line diff
     1.1 Binary file assets/Models/worm/worm-single-segment.blend has changed
     2.1 --- a/org/worm_learn.clj	Tue Mar 18 18:34:10 2014 -0400
     2.2 +++ b/org/worm_learn.clj	Tue Mar 18 19:53:42 2014 -0400
     2.3 @@ -143,6 +143,17 @@
     2.4  (defn touch-average [[coords touch]]
     2.5    (/ (average (map first touch)) (average (map second touch))))
     2.6  
     2.7 +(def worm-segment-touch-bottom
     2.8 +  [[8 15] [8 16] [8 17] [8 18] [8 19] [8 20] [8 21] [8 22] [9 15]
     2.9 +   [9 16] [9 17] [9 18] [9 19] [9 20] [9 21] [9 22] [10 15] [10 16]
    2.10 +   [10 17] [10 18] [10 19] [10 20] [10 21] [10 22] [11 15] [11 16]
    2.11 +   [11 17] [11 18] [11 19] [11 20] [11 21] [11 22] [12 15] [12 16]
    2.12 +   [12 17] [12 18] [12 19] [12 20] [12 21] [12 22] [13 15] [13 16]
    2.13 +   [13 17] [13 18] [13 19] [13 20] [13 21] [13 22] [14 15] [14 16]
    2.14 +   [14 17] [14 18] [14 19] [14 20] [14 21] [14 22]])
    2.15 +
    2.16 +
    2.17 +
    2.18  (defn floor-contact [[coords contact :as touch]]
    2.19    (let [raw-average
    2.20          (average
    2.21 @@ -151,13 +162,7 @@
    2.22            (vals
    2.23             (select-keys
    2.24              (zipmap coords contact)
    2.25 -            [[8 15] [8 16] [8 17] [8 18] [8 19] [8 20] [8 21] [8 22] [9 15]
    2.26 -             [9 16] [9 17] [9 18] [9 19] [9 20] [9 21] [9 22] [10 15] [10 16]
    2.27 -             [10 17] [10 18] [10 19] [10 20] [10 21] [10 22] [11 15] [11 16]
    2.28 -             [11 17] [11 18] [11 19] [11 20] [11 21] [11 22] [12 15] [12 16]
    2.29 -             [12 17] [12 18] [12 19] [12 20] [12 21] [12 22] [13 15] [13 16]
    2.30 -             [13 17] [13 18] [13 19] [13 20] [13 21] [13 22] [14 15] [14 16]
    2.31 -             [14 17] [14 18] [14 19] [14 20] [14 21] [14 22]]))))]
    2.32 +            ))))]
    2.33      (Math/abs (- 1. (* 10 raw-average)))))
    2.34  
    2.35  
    2.36 @@ -186,7 +191,10 @@
    2.37       :motor-control (:motor-control direct-control)
    2.38       :keybindings (:keybindings direct-control)
    2.39       :record nil
    2.40 -     :experiences nil}))
    2.41 +     :experiences nil
    2.42 +     :worm-model worm-model
    2.43 +     :end-frame nil}))
    2.44 +
    2.45  
    2.46  (defn dir! [file]
    2.47    (if (not (.exists file))
    2.48 @@ -197,8 +205,10 @@
    2.49    (swap! experiences #(conj % data)))
    2.50  
    2.51  (defn worm-world
    2.52 -  [& {:keys [record motor-control keybindings view experiences] :as settings}]
    2.53 -  (let [{:keys [record motor-control keybindings view]}
    2.54 +  [& {:keys [record motor-control keybindings view experiences
    2.55 +             worm-model end-frame] :as settings}]
    2.56 +  (let [{:keys [record motor-control keybindings view experiences
    2.57 +                worm-model end-frame]}
    2.58          (merge (worm-world-defaults) settings)
    2.59          worm (doto (worm-model) (body!))
    2.60          touch   (touch! worm)
    2.61 @@ -210,16 +220,16 @@
    2.62          muscle-display (view-movement)
    2.63          
    2.64          floor (box 10 1 10 :position (Vector3f. 0 -10 0)
    2.65 -                   :color ColorRGBA/Gray :mass 0)]
    2.66 +                   :color ColorRGBA/Gray :mass 0)
    2.67 +        timer (IsoTimer. 60)]
    2.68  
    2.69      (world
    2.70         (nodify [worm floor])
    2.71         (merge standard-debug-controls keybindings)
    2.72         (fn [world]
    2.73           (position-camera world view)
    2.74 -         (let [timer (IsoTimer. 60)]
    2.75 -           (.setTimer world timer)
    2.76 -           (display-dilated-time world timer))
    2.77 +         (.setTimer world timer)
    2.78 +         (display-dilated-time world timer)
    2.79           (if record
    2.80             (Capture/captureVideo
    2.81              world
    2.82 @@ -227,6 +237,8 @@
    2.83           (speed-up world)
    2.84           (light-up-everything world))
    2.85         (fn [world tpf]
    2.86 +         (if (> (.getTime timer) end-frame)
    2.87 +           (.stop world))
    2.88           (let [muscle-data (motor-control muscles)
    2.89                 proprioception-data (prop)
    2.90                 touch-data (map #(% (.getRootNode world)) touch)]
    2.91 @@ -237,10 +249,10 @@
    2.92                             :muscle muscle-data})
    2.93               (if (curled? @experiences) (println "Curled"))
    2.94               ;;(if (straight? @experiences)    (println "Straight"))
    2.95 -             (println-repl
    2.96 -              (apply format "%.2f %.2f %.2f %.2f %.2f\n"
    2.97 -                     (map floor-contact touch-data)))
    2.98 -
    2.99 +             ;; (println-repl
   2.100 +             ;;  (apply format "%.2f %.2f %.2f %.2f %.2f\n"
   2.101 +             ;;         (map floor-contact touch-data)))
   2.102 +             
   2.103               )
   2.104             (muscle-display
   2.105              muscle-data
   2.106 @@ -251,3 +263,61 @@
   2.107             (touch-display 
   2.108              touch-data
   2.109              (if record (dir! (File. record "touch")))))))))
   2.110 +
   2.111 +
   2.112 +;; A demonstration of self organiging touch maps through experience. 
   2.113 +
   2.114 +(def single-worm-segment-view
   2.115 +  [(Vector3f. 2.0681207, -6.1406755, 1.6106138)
   2.116 +   (Quaternion. -0.15558705, 0.843615, -0.3428654, -0.38281822)])
   2.117 +
   2.118 +(def worm-single-segment-muscle-labels
   2.119 +  [:lift-1 :lift-2 :roll-1 :roll-2])
   2.120 +
   2.121 +(defn touch-kinesthetics []
   2.122 +  [[170 :lift-1 40]
   2.123 +   [190 :lift-1 20]
   2.124 +   [206 :lift-1  0]
   2.125 +
   2.126 +   [400 :lift-2 40]
   2.127 +   [410 :lift-2  0]
   2.128 +
   2.129 +   [570 :lift-2 40]
   2.130 +   [590 :lift-2 20]
   2.131 +   [606 :lift-2  0]
   2.132 +
   2.133 +   [800 :lift-1 40]
   2.134 +   [809 :lift-1 0]
   2.135 +
   2.136 +   [900 :roll-2 40]
   2.137 +   [905 :roll-2 20]
   2.138 +   [910 :roll-2  0]
   2.139 +
   2.140 +   [1000 :roll-2 40]
   2.141 +   [1005 :roll-2 20]
   2.142 +   [1010 :roll-2  0]
   2.143 +   
   2.144 +   [1100 :roll-2 40]
   2.145 +   [1105 :roll-2 20]
   2.146 +   [1110 :roll-2  0]
   2.147 +   ])
   2.148 +
   2.149 +(defn worm-segment-defaults []
   2.150 +  (let [direct-control (worm-direct-control worm-muscle-labels 40)]
   2.151 +    (merge (worm-world-defaults)
   2.152 +           {:worm-model single-worm-segment
   2.153 +            :view single-worm-segment-view
   2.154 +            :motor-control
   2.155 +            (motor-control-program
   2.156 +             worm-single-segment-muscle-labels
   2.157 +             (touch-kinesthetics))})))
   2.158 +
   2.159 +(defn single-worm-segment []
   2.160 +  (load-blender-model "Models/worm/worm-single-segment.blend"))
   2.161 +
   2.162 +
   2.163 +(defn pure-touch?
   2.164 +  "This is worm specific code to determine if a large region of touch
   2.165 +   sensors is either all on or all off."
   2.166 +  [[coords touch :as touch-data]]
   2.167 +  (= (set (map first touch)) #{(float 0.1)  (float 0.0)}))
   2.168 \ No newline at end of file
     3.1 --- a/thesis/org/roadmap.org	Tue Mar 18 18:34:10 2014 -0400
     3.2 +++ b/thesis/org/roadmap.org	Tue Mar 18 19:53:42 2014 -0400
     3.3 @@ -191,9 +191,14 @@
     3.4  *** DONE add phi-space output to debug control
     3.5      CLOSED: [2014-03-17 Mon 17:42] SCHEDULED: <2014-03-17 Mon>
     3.6      CLOCK: [2014-03-17 Mon 17:31]--[2014-03-17 Mon 17:42] =>  0:11
     3.7 +
     3.8 +*** TODO complete automatic touch partitioning
     3.9 +*** TODO complete cyclic predicate
    3.10  *** TODO complete three phi-stream action predicatates; test them with debug control
    3.11      SCHEDULED: <2014-03-17 Mon>
    3.12 -    CLOCK: [2014-03-17 Mon 19:19]
    3.13 +    CLOCK: [2014-03-18 Tue 18:36]
    3.14 +    CLOCK: [2014-03-18 Tue 18:34]--[2014-03-18 Tue 18:36] =>  0:02
    3.15 +    CLOCK: [2014-03-17 Mon 19:19]--[2014-03-17 Mon 21:19] =>  2:00
    3.16  *** TODO create test videos, also record positions of worm segments
    3.17      SCHEDULED: <2014-03-17 Mon>
    3.18  *** TODO complete proprioception based movement lookup in phi-space