I've always enjoyed the mathematical tradition of “proofs without words”, so I wanted to see if something similar could be done with an algorithm. Of course, an algorithm is typically more complicated than a mathematical identity, so it's not surprising that an algorithm typically can't be captured in a single picture. Instead, I've found the idea of a commutative diagram to be a useful pictorial shorthand, where the short way around the diagram gives a high-level view of the operation, and the long way around gives more detail. Here is an attempt to describe my breadth-first numbering algorithm from ICFP 2000 using this idea.
Wanted
data:image/s3,"s3://crabby-images/5e2d7/5e2d762c96bab82af1b00bb7c6166593f34b2d82" alt=""
Rules
data:image/s3,"s3://crabby-images/425f1/425f16af653ef3e5ad284b130e4d8d5d4a8ba9a8" alt=""
Example
data:image/s3,"s3://crabby-images/d59b4/d59b4ea412d375f3097e7cc20526e15ec23bd64c" alt=""
Cool. I have tried to do similar things here: Visualizing algorithms and data structures
ReplyDeleteWay cool. For those interested, the paper is online (Postscript, other formats here).
ReplyDeleteThis reminds me of Aardappel, a programming language in which you write programs in the form of such before-and-after diagrams — sort of. It's free software, you should play with it.
ReplyDelete