This page is not created by, affiliated with, or supported by Slack Technologies, Inc.
2019-12-12
Channels
- # adventofcode (67)
- # announcements (8)
- # babashka (46)
- # beginners (154)
- # calva (5)
- # cider (9)
- # clara (5)
- # clj-kondo (34)
- # cljdoc (31)
- # cljsrn (4)
- # clojure (146)
- # clojure-europe (5)
- # clojure-italy (3)
- # clojure-losangeles (2)
- # clojure-nl (149)
- # clojure-spec (22)
- # clojure-uk (73)
- # clojured (6)
- # clojurescript (95)
- # clojureverse-ops (3)
- # cryogen (7)
- # cursive (12)
- # data-science (1)
- # datomic (9)
- # docker (1)
- # emacs (1)
- # figwheel-main (1)
- # hyperfiddle (1)
- # jobs (3)
- # malli (29)
- # nrepl (2)
- # off-topic (61)
- # pathom (6)
- # pedestal (1)
- # planck (1)
- # reitit (19)
- # shadow-cljs (52)
- # spacemacs (5)
- # tools-deps (24)
- # vim (30)
- # yada (6)
Lotta folks don't dig the cpu simulators; they've always been my favs, and it's much more interesting to me now that he's using it to drive other systems. The integration aspect is its own set of neat challenges that he wouldn't have been able to put in a single day previously. The downside I can see is that it makes catching up very linear; skipping days isn't as simple this year as it was in prior.
Yeah, I'd agree with you on the fun-aspect of integrating the sim with other systems. I only finally today got around to extracting the intcode "machine" into its own namespace and refactored my day 11 code to use the imported machine. Figure we've got at least 6 more days that'll use the machine, maybe more.
Day 11: https://github.com/transducer/adventofcode/blob/master/src/adventofcode/2019/day11.clj
nothing wrong with cpu simulator except too convoluted and verbose description of one, spread across 3 or 4 days, and like total of 15 pages of text. Even changes in requirements are not that bad comparing to this.
Definitely can't brute-force it. I ran out of memory on the second test data set (and I have 16Gb of physical memory). Gonna sleep on it and see if I can think of something in the morning.
my velocities keep blowing up for part 1
Guess the name of the task itself is known problem with existing solutions
slow though:
p1 input "Elapsed time: 35.301894 msecs"
p2 sample1 "Elapsed time: 2.732321 msecs"
p2 sample2 "Elapsed time: 293.312654 msecs"
p2 input "Elapsed time: 11600.599702 msecs"
total cycle can be predicted from cycles of each of the axes, which are much shorter. Think frequency of a wave which is a summary of sine waves with different frequencies
ah was almost there, needed to split by axis too
now some primw factor voodoo
am stuck example 1 works with my code exampen2 and my puzzle give way too high answers
you need to check when the whole x axis and vx isnrhe same for all moons
and you need some prime factor work indeed
bingo
main observation. The equations of motion in each axis are completely independent
not for me 🙂
interesting. Changing the moons from maps to records reduces the part 2 runtime from 40 to 30 seconds
Any other performance tips?
You don't actually have to find the prime factorizations of each axis, just their lowest common multiple
Thats indeed not thw borrlenexk
It was a fun exercise though
how do check if you reached the initial state?
I've only played around with Clojure notebooks for a while before, but the Parinfer plugin was essential for keeping some grasp on the parens: https://github.com/jelmerderonde/jupyter-lab-parinfer
my step is slow
i am doing this on my phone so indentation is not the best
count on a lazy seq is slow?
if I remove the xount
and add a doall, its much faster
did you use recur or iterate?
how do you know the number of steps?
iterate generates an infinite seq, I reduce over it and break using reduced
when it cycles back around
Here's some of the relevant bits
(def input
(parse "<x=14, y=9, z=14>
<x=9, y=11, z=6>
<x=-6, y=14, z=-4>
<x=4, y=-4, z=-3>"))
;; => ((14 9 14) (9 11 6) (-6 14 -4) (4 -4 -3))
(def test-input
(parse "<x=-1, y=0, z=2>
<x=2, y=-10, z=-7>
<x=4, y=-8, z=8>
<x=3, y=5, z=-1>"))
;; => ((-1 0 2) (2 -10 -7) (4 -8 8(3 5 -1))
;; * Part 2
(defn axis-step
[pvs]
(map (fn [[p v]]
(let [nv (+ v (reduce (fn [acc [p']]
(+ acc (compare p' p)))
0 pvs))]
[(+ p nv) nv]))
pvs))
(defn axis-period
[ps]
(let [vs (repeat 0)
pvs (map vector ps vs)]
(reduce (fn [cnt x]
(if (= pvs x)
(reduced cnt)
(inc cnt)))
1 (next (iterate axis-step pvs)))))
(for [ps (apply map vector test-input)]
(axis-period ps))
;; => (18 28 44)
(util/lcm 18 28 44)
;; => 2772
(apply util/lcm
(for [ps (apply map vector input)]
(axis-period ps)))
;; => 282399002133976
oww addp is just +
ah and reduce for the count
my phone is quite fast I am not much slower than the really fast solutions
oh yeah, I did not think to completely split the computation from for-all-axes-in-a-single-step into 1-axis-per-step
@UCPS050BV But why do you assume that the cycle will include the first configuration?
Also I strongly suspect the equations of motion are time-reversible, which would mean that for any configuration to repeat, all the previous steps leading up to it would also have to be repeated
Finally one that required some puzzling 😃. I drew a graph of one of the moon coordinates that hinted towards a solution. https://gitlab.com/dmarjenburgh/adventofcode/blob/master/src/adventofcode/year_2019.clj#L277-314
I got part 2 to run In about 3 seconds: https://github.com/Average-user/adventofcode-clj-2019/blob/master/src/adventofcode_clj_2019/day12.clj
adventofcode-clj-2019.day12> (time (part-2))
"Elapsed time: 2809.105945 msecs"
324618307124784
I am working on Day 11 part 2 and I keep getting a weird drawing. Looks like a rabbit. I already set the first panel to white as per the instructions but still no actual word.
Hmm. I'd ask if there's something wrong with your turning implementation, but Part 1 should have rooted that out.
This would be my turning function
(defn move-bot
[[face [x y]] outputs]
(let [[_ turn] outputs]
(if (empty? outputs)
(do (println "OUTPUTS EMPTY standing still")
[face [x y]])
(case face
:north (if (= turn 0)
[:west [(dec x) y]]
[:east [(inc x) y]])
:south (if (= turn 0)
[:east [(inc x) y]]
[:west [(dec x) y]])
:west (if (= turn 0)
[:south [x (dec y)]]
[:north [x (inc y)]])
:east (if (= turn 0)
[:north [x (inc y)]]
[:south [x (dec y)]])))))
you can leverage maps and vectors:
{:north [[:west [dec identity]] [:east [inc identity]]]
:south [[:east [inc identity]] [:west [dec identity]]]
:west [[:south [identity dec]] [:north [identity inc]]]
:east [[:north [identity inc]] [:south [identity dec]]]}