diff org/worm_learn.clj @ 420:7f3581dc58ff

completed phi-space tests; beginning main thesis pdf.
author Robert McIntyre <rlm@mit.edu>
date Thu, 20 Mar 2014 22:57:06 -0400
parents dd40244255d4
children 5205535237fb
line wrap: on
line diff
     1.1 --- a/org/worm_learn.clj	Thu Mar 20 20:54:37 2014 -0400
     1.2 +++ b/org/worm_learn.clj	Thu Mar 20 22:57:06 2014 -0400
     1.3 @@ -215,7 +215,7 @@
     1.4  (defn grand-circle?
     1.5    "Does the worm form a majestic circle (one end touching the other)?"
     1.6    [experiences]
     1.7 -  (and true;; (curled? experiences)
     1.8 +  (and (curled? experiences)
     1.9         (let [worm-touch (:touch (peek experiences))
    1.10               tail-touch (worm-touch 0)
    1.11               head-touch (worm-touch 4)]
    1.12 @@ -380,7 +380,7 @@
    1.13    (loop [result '()
    1.14           [thread-bases & remaining :as phi-index-sets] phi-index-sets]
    1.15      (if (empty? phi-index-sets)
    1.16 -      result
    1.17 +      (vec result)
    1.18        (let [threads
    1.19              (for [thread-base thread-bases]
    1.20                (loop [thread (list thread-base)
    1.21 @@ -407,15 +407,58 @@
    1.22    )
    1.23  
    1.24  
    1.25 -(def ppp (atom ()))
    1.26  
    1.27 -(defn debug-experience-phi [experiences]
    1.28 -  (let [phi-indices (phi-scan (:proprioception (peek experiences)))]
    1.29 -    (swap! ppp (partial cons phi-indices))
    1.30 -    (println-repl phi-indices))
    1.31 -  (cond
    1.32 -   (grand-circle? experiences) (println "Grand Circle")
    1.33 -   (curled? experiences)       (println "Curled")
    1.34 -   (wiggling? experiences)     (println "Wiggling")
    1.35 -   (resting? experiences)      (println "Resting"))
    1.36 -  )
    1.37 +
    1.38 +
    1.39 +(defn infer-nils
    1.40 +  "Replace nils with the next available non-nil element in the
    1.41 +   sequence, or barring that, 0."
    1.42 +  [s]
    1.43 +  (loop [i (dec (count s)) v (transient s)]
    1.44 +    (if (= i 0) (persistent! v)
    1.45 +        (let [cur (v i)]
    1.46 +          (if cur
    1.47 +            (if (get v (dec i) 0)
    1.48 +              (recur (dec i) v)
    1.49 +              (recur (dec i) (assoc! v (dec i) cur)))
    1.50 +            (recur i (assoc! v i 0)))))))
    1.51 +
    1.52 +;; tests
    1.53 +
    1.54 +;;(infer-nils [1 nil 1 1]) [1 1 1 1]
    1.55 +;;(infer-nils [1 1 1 nil]) [1 1 1 0]
    1.56 +;;(infer-nils [nil 2 1 1]) [2 2 1 1]       
    1.57 +  
    1.58 +
    1.59 +(defn debug-experience-phi []
    1.60 +  (let [proprio (atom ())]
    1.61 +    (fn
    1.62 +      [experiences]
    1.63 +      (let [phi-indices (phi-scan (:proprioception (peek experiences)))]
    1.64 +        (swap! proprio (partial cons phi-indices))
    1.65 +        (let [exp-thread (longest-thread (take 300 @proprio))
    1.66 +              phi-loop (mapv phi-space (infer-nils exp-thread))]
    1.67 +          (println-repl (vector:last-n exp-thread 22))
    1.68 +          (cond
    1.69 +           (grand-circle? phi-loop) (println "Grand Circle")
    1.70 +           (curled? phi-loop)       (println "Curled")
    1.71 +           (wiggling? phi-loop)     (println "Wiggling")
    1.72 +           (resting? phi-loop)      (println "Resting")
    1.73 +           :else                    (println "Unknown")))))))
    1.74 +
    1.75 +
    1.76 +(defn init-interactive []
    1.77 +  (def phi-space
    1.78 +    (let [experiences (atom [])]
    1.79 +      (run-world
    1.80 +       (apply-map 
    1.81 +        worm-world
    1.82 +        (merge
    1.83 +         (worm-world-defaults)
    1.84 +         {:experiences experiences})))
    1.85 +      @experiences))
    1.86 +  (def phi-scan (gen-phi-scan phi-space)))
    1.87 +    
    1.88 +
    1.89 +(defn run-experiment-1 []
    1.90 +  (.start (worm-world :experience-watch (debug-experience-phi))))
    1.91 \ No newline at end of file