changeset 400:6ba908c1a0a9

on the warpath to the final stretch.
author Robert McIntyre <rlm@mit.edu>
date Sun, 16 Mar 2014 23:30:32 -0400 (2014-03-17)
parents 85393ec986dc
children 7ee735a836da
files assets/Models/worm-segment/touch-profile.png assets/Models/worm-segment/touch-profile.xcf assets/Models/worm-segment/worm-segment.blend assets/Models/worm-segment/worm.blend assets/Models/worm/basic-muscle.png assets/Models/worm/touch-profile.png assets/Models/worm/touch-profile.xcf assets/Models/worm/worm-segment.blend assets/Models/worm/worm.blend org/util.org org/worm_learn.clj
diffstat 11 files changed, 74 insertions(+), 33 deletions(-) [+]
line wrap: on
line diff
     1.1 Binary file assets/Models/worm-segment/touch-profile.png has changed
     2.1 Binary file assets/Models/worm-segment/touch-profile.xcf has changed
     3.1 Binary file assets/Models/worm-segment/worm-segment.blend has changed
     4.1 Binary file assets/Models/worm-segment/worm.blend has changed
     5.1 Binary file assets/Models/worm/basic-muscle.png has changed
     6.1 Binary file assets/Models/worm/touch-profile.png has changed
     7.1 Binary file assets/Models/worm/touch-profile.xcf has changed
     8.1 Binary file assets/Models/worm/worm-segment.blend has changed
     9.1 Binary file assets/Models/worm/worm.blend has changed
    10.1 --- a/org/util.org	Tue Mar 04 23:04:43 2014 -0500
    10.2 +++ b/org/util.org	Sun Mar 16 23:30:32 2014 -0400
    10.3 @@ -128,10 +128,13 @@
    10.4  
    10.5  (defn position-camera
    10.6    "Change the position of the in-world camera."
    10.7 -  [world #^Vector3f position #^Quaternion rotation]
    10.8 +  ([world #^Vector3f position #^Quaternion rotation]
    10.9       (doto (.getCamera world)
   10.10         (.setLocation position)
   10.11         (.setRotation rotation)))
   10.12 +  ([world [position rotation]]
   10.13 +     (position-camera world position rotation)))
   10.14 +     
   10.15  
   10.16  (defn enable-debug 
   10.17    "Turn on debug wireframes for every object in this simulation."
   10.18 @@ -614,7 +617,7 @@
   10.19  #+end_src
   10.20  
   10.21  
   10.22 -* COMMENT code generation
   10.23 +* code generation
   10.24  #+begin_src clojure :tangle ../src/cortex/import.clj
   10.25  <<import>>
   10.26  #+end_src
    11.1 --- a/org/worm_learn.clj	Tue Mar 04 23:04:43 2014 -0500
    11.2 +++ b/org/worm_learn.clj	Sun Mar 16 23:30:32 2014 -0400
    11.3 @@ -14,13 +14,14 @@
    11.4  (dorun (cortex.import/mega-import-jme3))
    11.5  (rlm.rlm-commands/help)
    11.6  
    11.7 +(load-bullet)
    11.8  
    11.9  (def hand "Models/test-creature/hand.blend")
   11.10  
   11.11  (defn worm-model []
   11.12    (load-blender-model "Models/worm/worm.blend"))
   11.13  
   11.14 -(def output-base (File. "/home/r/proj/cortex/render/worm-learn/"))
   11.15 +(def output-base (File. "/home/r/proj/cortex/render/worm-learn/curl"))
   11.16  
   11.17  
   11.18  (defn motor-control-program
   11.19 @@ -40,19 +41,25 @@
   11.20                      effectors
   11.21                      (map #(@current-forces % 0) muscle-positions)))))))
   11.22  
   11.23 +
   11.24 +
   11.25 +
   11.26 +;; These are scripts that direct the worm to move in two radically
   11.27 +;; different patterns -- a sinusoidal wiggling motion, and a curling
   11.28 +;; motions that causes the worm to form a circle.
   11.29 +
   11.30 +(def curl-script
   11.31 +  [[370 :d-up 40]
   11.32 +   [600 :d-up 0]])
   11.33 +
   11.34 +(def period 18)
   11.35 +
   11.36  (def muscle-labels
   11.37    [:base-up :base-down
   11.38     :a-up :a-down
   11.39     :b-up :b-down
   11.40     :c-up :c-down
   11.41 -   :d-up :d-down
   11.42 -   ])
   11.43 -
   11.44 -(def curl-script
   11.45 -  [[370 :d-up 20]
   11.46 -   [390 :d-up 0]])
   11.47 -
   11.48 -(def period 18)
   11.49 +   :d-up :d-down])
   11.50  
   11.51  (defn gen-wiggle [[flexor extensor :as muscle-pair] time-base]
   11.52    (let [period period
   11.53 @@ -63,24 +70,68 @@
   11.54       [(+ time-base (+ (* 2 period) 2))  extensor 0]]))
   11.55    
   11.56  (def wiggle-script
   11.57 -  (mapcat gen-wiggle [[:d-up :d-down]
   11.58 -                      [:c-up :c-down]
   11.59 -                      [:b-up :b-down]
   11.60 -                      [:a-up :a-down]] (range 100 1000 12)))
   11.61 -
   11.62 -(def wiggle-script
   11.63    (mapcat gen-wiggle (repeat 40 [:a-down :a-up])
   11.64                       (range 100 10000 (+ 3 (* period 2)))))
   11.65  
   11.66  
   11.67 +;; Normally, we'd use unsupervised/supervised machine learning to pick
   11.68 +;; out the defining features of the different actions available to the
   11.69 +;; worm. For this project, I am going to explicitely define functions
   11.70 +;; that recognize curling and wiggling respectively. These functions
   11.71 +;; are defined using all the information available from an embodied
   11.72 +;; simulation of the action. Note how much easier they are to define
   11.73 +;; than if I only had vision to work with. Things like scale/position
   11.74 +;; invariance are complete non-issues here. This is the advantage of
   11.75 +;; body-centered action recognition and what I hope to show with this
   11.76 +;; thesis.
   11.77 +
   11.78 +(defn last-nth
   11.79 +  "Create function that will, when called each frame with the senses
   11.80 +   of a creature, will record those results and return the last n
   11.81 +   results."
   11.82 +  [n]
   11.83 +  (let [last-n  '()]
   11.84 +    (fn [frame-num {:keys [touch proprioception muscles hearing]}]
   11.85 +      (take n (cons [frame-num :stuff] last-n)))))
   11.86 +      
   11.87 +
   11.88 +(defn wiggling?
   11.89 +  "Generate a function which, when called each frame with the sensory
   11.90 +   inputs of a worm, will determine whether the worm is wiggling."
   11.91 +  [{:keys [touch proprioception muscles hearing]}]
   11.92 +  (map (fn [f] (f)) proprioception
   11.93 +   
   11.94 +
   11.95 +))
   11.96 +
   11.97 +(defn curling?
   11.98 +  "Is the worm curled up?"
   11.99 +  []
  11.100 +  )
  11.101 +
  11.102 +(defn resting?
  11.103 +  "Is the worm on the ground in a neutral position?"
  11.104 +  [])
  11.105 +
  11.106 +(def standard-world-view
  11.107 +  [(Vector3f. 4.207176, -3.7366982, 3.0816958)
  11.108 +   (Quaternion. 0.11118768, 0.87678415, 0.24434438, -0.3989771)])
  11.109 +
  11.110 +(def worm-side-view
  11.111 +  [(Vector3f. 4.207176, -3.7366982, 3.0816958)
  11.112 +   (Quaternion. -0.11555642, 0.88188726, -0.2854942, -0.3569518)])
  11.113 +
  11.114 +(def degenerate-worm-view
  11.115 +  [(Vector3f. -0.0708936, -8.570261, 2.6487997)
  11.116 +   (Quaternion. -2.318909E-4, 0.9985348, 0.053941682, 0.004291452)])
  11.117  
  11.118  (defn worm-world
  11.119    ""
  11.120    ([] (worm-world curl-script))
  11.121    ([motion-script]
  11.122 -     (let [record? false
  11.123 +     (let [record? false ;;true
  11.124             worm (doto (worm-model) (body!))
  11.125 -           touch   '();;(touch! worm)
  11.126 +           touch   (touch! worm)
  11.127             prop    (proprioception! worm)
  11.128             muscles (movement! worm)
  11.129             
  11.130 @@ -99,19 +150,7 @@
  11.131          
  11.132          (fn [world]
  11.133            ;; (set-gravity world Vector3f/ZERO)
  11.134 -          ;; (position-camera
  11.135 -          ;;  world (Vector3f. 4.207176, -3.7366982, 3.0816958)
  11.136 -          ;;  (Quaternion. 0.11118768, 0.87678415, 0.24434438, -0.3989771))
  11.137 -
  11.138 -
  11.139 -
  11.140 -          (position-camera
  11.141 -           world (Vector3f. 4.207176, -3.7366982, 3.0816958)
  11.142 -           (Quaternion. -0.11555642, 0.88188726, -0.2854942, -0.3569518))
  11.143 -
  11.144 -
  11.145 -
  11.146 -
  11.147 +          (position-camera world degenerate-worm-view)
  11.148            (let [timer (IsoTimer. 60)]
  11.149              (.setTimer world timer)
  11.150              (display-dilated-time world timer))
  11.151 @@ -121,7 +160,6 @@
  11.152               (File. output-base "main-view")))
  11.153            (speed-up world)
  11.154            (light-up-everything world))
  11.155 -        
  11.156          (fn [world tpf]
  11.157            (muscle-display
  11.158             (control-script muscles)