Allow gnuplot to take alists
author |
Steve Losh <steve@stevelosh.com> |
date |
Sun, 23 May 2021 16:51:40 -0400 (2021-05-23) |
parents |
25d07c157495
|
children |
acf6a1d4de2e
|
branches/tags |
(none) |
files |
src/gnuplot.lisp src/iterate.lisp |
Changes
--- a/src/gnuplot.lisp Sun May 23 16:43:03 2021 -0400
+++ b/src/gnuplot.lisp Sun May 23 16:51:40 2021 -0400
@@ -23,6 +23,13 @@
(terpri s))
sequence))
+(defun gnuplot-data-alist% (alist s)
+ (loop :for (k . v) :in alist :do
+ (princ k s)
+ (princ #\tab s)
+ (princ v s)
+ (terpri s)))
+
(defun gnuplot-data-matrix% (matrix s)
(destructuring-bind (rows cols) (array-dimensions matrix)
(dotimes (r rows)
@@ -36,7 +43,8 @@
`identifier` must be a string of the form `$foo`.
- `data` must be a sequence of sequences of data or a 2D array of data.
+ `data` must be one of the following: a sequence of sequences of data points,
+ an alist of data points, or a 2D array of data points.
Must be called from inside `with-gnuplot`.
@@ -47,6 +55,7 @@
(format s "~A << EOD~%" identifier)
(etypecase data
((array * (* *)) (gnuplot-data-matrix% data s))
+ ((cons (cons t (not cons))) (gnuplot-data-alist% data s))
(sequence (gnuplot-data-sequence% data s)))
(format s "EOD~%"))
@@ -72,9 +81,11 @@
(defun gnuplot (data commands)
"Graph `data` with gnuplot using `commands`.
- `data` must be an alist of `(identifier . data)` pairs. `identifier` must be
- a string of the form `$foo`. `data` must be a sequence of sequences of data
- or a 2D array of data.
+ `data` must be an alist of `(identifier . data)` pairs.
+
+ Each `identifier` must be a string of the form `$foo`. Each `data` must be
+ one of the following: a sequence of sequences of data points, an alist of data
+ points, or a 2D array of data points.
`commands` must be a string or a sequence of strings.
@@ -86,3 +97,4 @@
(string (gnuplot-command commands))
(sequence (map nil #'gnuplot-command commands)))))
+
--- a/src/iterate.lisp Sun May 23 16:43:03 2021 -0400
+++ b/src/iterate.lisp Sun May 23 16:51:40 2021 -0400
@@ -727,7 +727,6 @@
(finally (return (get-output-stream-string ,sos)))))))
-
(defmacro-clause (ORING expr &optional INTO var)
(let ((result (or var iterate::*result-var*)))
`(reducing ,expr :by #'or :into ,result :initial-value nil)))