src/robots/bit-loom.lisp @ 15523880959e

Add loom 3
author Steve Losh <steve@stevelosh.com>
date Tue, 06 Feb 2018 20:52:03 -0500
parents ceb49b25a451
children 2bf00f41a8b9
(in-package :magitek.robots.bit-loom)

(defun resize (filename size)
  (sb-ext:run-program "mogrify"
                      (list "-resize" (format nil "~Dx~D" size size) filename)
                      :error :output
                      :search t))

(defun loom-1 (seed)
  (let ((depth (random-range-inclusive 16 19)))
    (flax.looms.001-triangles:loom seed depth "out.png" 3000 3000)
    (format nil "depth ~D" depth)))

(defun loom-2 (seed)
  (let ((ticks (* 1000 (random-range-inclusive 3 8))))
    (flax.looms.002-wobbly-lines:loom seed ticks "out.png" 2000 400)
    (format nil "~R ticks" ticks)))

(defun loom-3 (seed)
  (flax.looms.003-basic-l-systems::loom-anabaena-catenula seed "out.png" 2000 2000)
  (format nil "variety: anabaena catenula"))

(defparameter *looms* '(loom-1 loom-2 loom-3))

(defun generate-image (seed &key force-loom)
  (let* ((loom-index (random (length *looms*)))
         (loom-index (if force-loom
                       (1- force-loom)
                       loom-index))
         (loom (elt *looms* loom-index)))
    (format t "Running ~A~%" loom)
    (force-output)
    (let ((extra (funcall loom seed)))
      (resize "out.png" 1200)
      (values (1+ loom-index) extra))))

(defun random-tweet (&key force-loom)
  (let ((seed (random (expt 2 32))))
    (multiple-value-bind (loom-number extra-information)
        (generate-image seed :force-loom force-loom)
      (values (string-upcase
                (format nil "loom ~R, seed ~D~A"
                        loom-number seed
                        (if extra-information
                          (concatenate 'string ", " extra-information)
                          "")))
              "out.png"))))