graphgif/demo.scm

32 lines
793 B
Scheme
Raw Normal View History

(use-modules (graphgif)
(srfi srfi-1)
(srfi srfi-43)
2024-10-23 09:13:50 -05:00
(ice-9 copy-tree)
(d-))
2024-10-16 13:48:22 -05:00
(define red (create-color 1 0 0))
(define graph
(~> (generate-web 10 10)
2024-10-23 09:46:15 -05:00
(remove-rect 10 1 3 6 3)
(remove-rect 10 6 3 6 7)))
(define (color-graph graph visited heap)
(map (lambda (pair)
(cons (car pair)
(if (memq (car pair) visited)
(set-node-color (cdr pair) red)
(cdr pair))))
graph))
(define (make-graph-generator f)
2024-11-11 22:15:04 -06:00
(generator
(f graph 90 9 (lambda (visited heap)
2024-11-11 22:15:04 -06:00
(yield (color-graph graph visited heap))))
#f))
(define djikstra-generator (make-graph-generator djikstra))
(define a*-generator (make-graph-generator a*))
2024-11-11 21:07:19 -06:00
(write-graphs-to-file "djikstra.webp" djikstra-generator)
(write-graphs-to-file "astar.webp" a*-generator)