changeset 318:9a4d3f801c89

fixing runs to use new util functions.
author Robert McIntyre <rlm@mit.edu>
date Mon, 02 Apr 2012 23:13:49 -0500 (2012-04-03)
parents 3c5bf2221ea0
children 92c47a9cdaea
files clojure/com/aurellem/gb/saves.clj clojure/com/aurellem/run/save_corruption.clj clojure/com/aurellem/run/title.clj clojure/com/aurellem/run/util.clj save-states/battle-rival.sav save-states/grass' edge.sav
diffstat 6 files changed, 63 insertions(+), 86 deletions(-) [+]
line wrap: on
line diff
     1.1 --- a/clojure/com/aurellem/gb/saves.clj	Mon Apr 02 21:25:24 2012 -0500
     1.2 +++ b/clojure/com/aurellem/gb/saves.clj	Mon Apr 02 23:13:49 2012 -0500
     1.3 @@ -18,4 +18,8 @@
     1.4    (read-state "normal-conversation"))
     1.5  
     1.6  (defn oak-battle []
     1.7 -  (read-state "oak-battle"))
     1.8 \ No newline at end of file
     1.9 +  (read-state "oak-battle"))
    1.10 +
    1.11 +(defn crit-fight []
    1.12 +  (read-state "battle-rival"))
    1.13 +  
    1.14 \ No newline at end of file
     2.1 --- a/clojure/com/aurellem/run/save_corruption.clj	Mon Apr 02 21:25:24 2012 -0500
     2.2 +++ b/clojure/com/aurellem/run/save_corruption.clj	Mon Apr 02 23:13:49 2012 -0500
     2.3 @@ -1,54 +1,33 @@
     2.4  (ns com.aurellem.run.save-corruption
     2.5    (:use (com.aurellem.gb gb-driver vbm))
     2.6 -  (:use (com.aurellem.run title)))
     2.7 +  (:use (com.aurellem.run util title)))
     2.8  
     2.9 -(defn-memo start-walking
    2.10 -  ([script] 
    2.11 -     (->> script
    2.12 -          (advance [:b] [:b :r])))
    2.13 -  ([] (start-walking (finish-title))))
    2.14 -  
    2.15  (defn-memo walk-to-stairs
    2.16 -  ([] (walk-to-stairs (start-walking)))
    2.17 +  ([] (walk-to-stairs (finish-title)))
    2.18    ([script]
    2.19       (->> script
    2.20 -          (move [:u])
    2.21 -          (move [:u])
    2.22 -          (move [:u])
    2.23 -          (move [:u])
    2.24 -          (move [:u])
    2.25 -          (move [:r])
    2.26 -          (move [:r])
    2.27 -          (move [:r]))))
    2.28 +          (walk [→ ↑ ↑ ↑ ↑ ↑ → → →]))))
    2.29  
    2.30  (defn-memo walk-to-door
    2.31    ([] (walk-to-door (walk-to-stairs)))
    2.32    ([script]
    2.33       (->> script
    2.34 -          (move [:d])
    2.35 -          (move [:d])
    2.36 -          (move [:d])
    2.37 -          (move [:d])
    2.38 -          (move [:d])
    2.39 -          (move [:d])
    2.40 -          (move [:l])
    2.41 -          (move [:l])
    2.42 -          (move [:l])
    2.43 -          (move [:l]))))
    2.44 +          (walk [↓ ↓ ↓ ↓ ↓ ← ← ← ←])))) 
    2.45  
    2.46  (defn-memo activate-menu
    2.47    ([] (activate-menu (walk-to-door)))
    2.48    ([script]
    2.49       (->> script
    2.50 -          (advance [:b] [:a :b :start]))))
    2.51 +          (first-difference [:b] [:a :b :start] AF))))
    2.52  
    2.53  (defn-memo save-game
    2.54    ([] (save-game (activate-menu)))
    2.55    ([script]
    2.56       (->> script
    2.57 -          (advance [] [:d])
    2.58 +          (first-difference [] [:d] AF)
    2.59            (play-moves [[] [] [] [:d] [] [] [] [:d] [] [] [:a]])
    2.60 -          scroll-text)))
    2.61 +          (do-nothing 200)
    2.62 +          (play-moves [[:a]]))))
    2.63  
    2.64  (defn-memo corrupt-save
    2.65    ([] (corrupt-save (save-game)))
    2.66 @@ -67,9 +46,9 @@
    2.67    ([script]
    2.68       (->> script
    2.69            (title)
    2.70 -          (advance [] [:start])
    2.71 -          (advance [] [:a])
    2.72 -          (advance [:a] [:a :start]))))
    2.73 +          (first-difference [] [:start] AF)
    2.74 +          (first-difference [] [:a] AF)
    2.75 +          (first-difference [:a] [:a :start] AF))))
    2.76  
    2.77  (defn-memo destroy-item-end-of-list-marker
    2.78    ([] (destroy-item-end-of-list-marker (start-game)))
     3.1 --- a/clojure/com/aurellem/run/title.clj	Mon Apr 02 21:25:24 2012 -0500
     3.2 +++ b/clojure/com/aurellem/run/title.clj	Mon Apr 02 23:13:49 2012 -0500
     3.3 @@ -1,6 +1,6 @@
     3.4  (ns com.aurellem.run.title
     3.5 -  (:use (com.aurellem.gb gb-driver vbm)))
     3.6 -
     3.7 +  (:use (com.aurellem.gb gb-driver vbm))
     3.8 +  (:use (com.aurellem.run util)))
     3.9  
    3.10  (defn start [] [[] (root)])
    3.11  
    3.12 @@ -8,10 +8,10 @@
    3.13    ([] (title (start)))
    3.14    ([script]
    3.15       (->> script
    3.16 -          (advance [] [:a])
    3.17 -          (advance [] [:start])
    3.18 -          (advance [] [:a])
    3.19 -          (advance [] [:start]))))
    3.20 +          (first-difference [] [:a] AF)
    3.21 +          (first-difference [] [:start] AF)
    3.22 +          (first-difference [] [:a] AF)
    3.23 +          (first-difference [] [:start] AF))))
    3.24  
    3.25  (defn-memo oak
    3.26    ([] (oak (title)))
    3.27 @@ -23,8 +23,8 @@
    3.28    ([] (name-entry-rlm (oak)))
    3.29    ([script]
    3.30       (->> script
    3.31 -          (advance [] [:a])
    3.32 -          (advance [] [:r] DE)
    3.33 +          (first-difference [] [:a] AF)
    3.34 +          (first-difference [] [:r] DE)
    3.35            (play-moves
    3.36             [[]
    3.37              [:r] [] [:r] [] [:r] [] [:r] []
    3.38 @@ -38,26 +38,26 @@
    3.39    ([] (name-entry-ash (oak)))
    3.40    ([script]
    3.41       (->> script
    3.42 -          (advance [] [:d])
    3.43 -          (advance [] [:d])
    3.44 -          (advance [] [:a]))))
    3.45 +          (first-difference [] [:d] AF)
    3.46 +          (first-difference [] [:d] AF)
    3.47 +          (first-difference [] [:a] AF))))
    3.48         
    3.49  (defn-memo rival-name-entry-gary
    3.50    ([] (rival-name-entry-gary (name-entry-ash)))
    3.51    ([script]
    3.52       (->> script
    3.53            (scroll-text 5)
    3.54 -          (advance [] [:d])
    3.55 -          (advance [] [:d])
    3.56 -          (advance [] [:a]))))
    3.57 +          (first-difference [] [:d] AF)
    3.58 +          (first-difference [] [:d] AF)
    3.59 +          (first-difference [] [:a] AF))))
    3.60    
    3.61  (defn-memo rival-name-entry-blue
    3.62    ([] (rival-name-entry-blue (name-entry-ash)))
    3.63    ([script]
    3.64       (->> script
    3.65            (scroll-text 5)
    3.66 -          (advance [] [:d])
    3.67 -          (advance [] [:a]))))
    3.68 +          (first-difference [] [:d] AF)
    3.69 +          (first-difference [] [:a] AF))))
    3.70  
    3.71  (defn-memo finish-title
    3.72    ([] (finish-title (rival-name-entry-blue)))
     4.1 --- a/clojure/com/aurellem/run/util.clj	Mon Apr 02 21:25:24 2012 -0500
     4.2 +++ b/clojure/com/aurellem/run/util.clj	Mon Apr 02 23:13:49 2012 -0500
     4.3 @@ -7,6 +7,8 @@
     4.4  (def ← [:l])
     4.5  (def → [:r])
     4.6  
     4.7 +[↑ ↓ ← →]
     4.8 +
     4.9  (defn first-difference
    4.10    [base alt difference-metric [moves root :as script]]
    4.11    (loop [branch-point root
    4.12 @@ -145,6 +147,25 @@
    4.13         (play-moves
    4.14          (repeat n []))))
    4.15  
    4.16 +(defn delayed-improbability-search
    4.17 +  "insert blank frames before calling script-fn until
    4.18 +   metric returns true."
    4.19 +  [delay metric script-fn script]
    4.20 +  (loop [blanks 0]
    4.21 +    (let [new-script
    4.22 +          (->> script
    4.23 +               (play-moves
    4.24 +                (concat (repeat blanks [])))
    4.25 +               script-fn)
    4.26 +          future-state
    4.27 +          (run-moves (second new-script)
    4.28 +                     (repeat delay []))
    4.29 +          result (metric future-state)]
    4.30 +      (if result
    4.31 +        (do
    4.32 +          (println "improbability factor:" blanks)
    4.33 +          new-script)
    4.34 +        (recur (inc blanks))))))
    4.35  
    4.36  (defn critical-hit
    4.37    "Put the cursor over the desired attack. This program will
    4.38 @@ -152,46 +173,19 @@
    4.39     insert before pressing [:a] to ensure that the attack is
    4.40     a critical hit."
    4.41    [script]
    4.42 -  (loop [blanks 6]
    4.43 -    (let [new-script
    4.44 -          (->> script
    4.45 -               (play-moves
    4.46 -                (concat (repeat blanks [])
    4.47 -                        [[:a][]])))]
    4.48 -      (if (let [future-state
    4.49 -                (run-moves (second new-script)
    4.50 -                           (repeat 400 []))
    4.51 -
    4.52 -                result (search-string (memory future-state)
    4.53 -                                      "Critical")]
    4.54 -            (if result
    4.55 -              (println "critical hit with" blanks "blank frames"))
    4.56 -            result) 
    4.57 -        new-script
    4.58 -        (recur (inc blanks))))))  
    4.59 +  (delayed-improbability-search
    4.60 +   400
    4.61 +   #(search-string  % "Critical")
    4.62 +   (partial play-moves [[:a][]])
    4.63 +   script))
    4.64  
    4.65  (defn move-thru-grass
    4.66    [direction script]
    4.67 -  (loop [blanks 0]
    4.68 -    (let [new-script
    4.69 -          (->> script
    4.70 -               (play-moves (repeat blanks []))
    4.71 -               (move direction))
    4.72 -
    4.73 -          future-state
    4.74 -          (run-moves (second new-script)
    4.75 -                     (repeat 600 []))
    4.76 -          
    4.77 -          result (search-string (memory future-state)
    4.78 -                                "Wild")]
    4.79 -      (if (nil? result)
    4.80 -        (do
    4.81 -          (if (< 0 blanks)
    4.82 -            (do
    4.83 -              (println "avoided pokemon with"
    4.84 -                       blanks "blank frames")))
    4.85 -             new-script)
    4.86 -        (recur (inc blanks))))))
    4.87 +  (delayed-improbability-search
    4.88 +   600
    4.89 +   #(nil? (search-string % "Wild"))
    4.90 +   (partial move direction)
    4.91 +   script))
    4.92  
    4.93  (defn walk-thru-grass
    4.94    [directions script]
     5.1 Binary file save-states/battle-rival.sav has changed
     6.1 Binary file save-states/grass' edge.sav has changed