- Blog Post: Why Visual Programming Doesn't Suck
- HN Discussion
- Talks about Statebox, who have some interesting Medium posts
- Talk: Inventing on Principle
- The talk that launched a thousand research careers.
- Talk: Drawing Dynamic Visualizations
- Shares an idea for a direct-manipulation programming environment.
- Additional notes
- Talk: Stop Drawing Dead Fish
- A talk in which he demonstrates a prototype iPad app for interactively building animations, with an experience more akin to puppet theatre than traditional keyframe-and-curves computer animation.
- The app allows building algebraic relationships using geometric equivalents, a la Tristan Needham's book Visual Complex Analysis or the GeoGebra project. This is at odds with most computer animation tools, where dynamic relationships between visual elements are expressed using algebraic equations of the elements' numeric attributes.
- Article: Learnable Programming
- Not only is this a fantastic critique of augmented text-based programming tools, it's also sneaks in some fantastic critiques of visual programming languages too.
-
Traditional visual environments visualize the code. They visualize static structure. But that's not what we need to understand. We need to understand what the code is doing. Visualize data, not code. Dynamic behavior, not static structure.
I could continue linking to dozens of things on Bret's site. The next time I read through them, I might link to some more and add my reflections. In the mean time, it should suffice to say that pretty much everything on his website is revelatory, inspirational, worthy of mass movements being forming around, and essential. His work largely defined the current cultural moment in programming tools, HCI, visual languages, and other computing frontiers of interest to readers of this codex.
- Talk: Whoa, pictures! A visual history of visual programming languages!
- Quickly surveys some of history's more interesting VPLs, with fun commentary and a nod the handful of studied benefits and downsides.
- Slides and references
Fred's websites seem to have perished at the end of 2019, but Archive.org is a good friend:
- Illiterate Programming
- A blog post about literate programming that turns into a demo of the Ampleforth live-coding environment for Newspeak. Hint: the browser back button can be used to navigate "back" when interacting with the embedded Ampleforth editors.
- "The ability to change the code of the system you are using while using it is a key property that is lacking in most systems."
- Not directly about VPLs, but relevant due to the importance of live coding to most VPLs, and the mutual influence of Smalltalk.
- "It's a self-eating-dog-eat-self-eating dog world"
- Don't confuse the HopscotchIDE used by Ampleforth with the Scratch-like VPL named Hopscotch.
- Blog post: Rethinking Visual Programming with Go
- Blog post: Programming with Comics
- Talk: Evolving the Visual Programming Environment with React
- Features an (unreleased) browser-based nodes-and-lines VPL prototype named Collide. At 15:03, there's a nice UI feature where static typing is used to annotate node inputs/outputs, and they're numbered based on distance, so you can type the number and make a fast connection. Later there's some nice discussion of how the VPL is implemented in terms of pure functions, how side effects are handled, specs for nodes, and other thoughtful inner workings.
- Blog post: Working Notes on Chalktalk
- Paper: Aesthetic Programming
- A fantastic paper about the synthesis of artistic aesthetics, modelling, and systems.
- "By marrying traditional methods for computer programming with an artistic temperament, we give birth to a new phenomenon: the aesthetic program. Our work builds on visual approaches in programming as well as modeling for software, where I envision a gradual evolution from program to model. The need for the aesthetic model is strengthened with the importance of personalized, individually-tailored, models. I, and my students, have formulated the rube Project methodology around the use of 3D web-based virtual world construction of models. Initial results suggest that these models are artistic, while containing sufficient symbolism and concise metaphoric mapping as to be executable on a computer."
- Talk: A Live Programming Experience — From Strange Loop 2015, the talk demos a live programming environment where most of the coding work is done with the mouse. Partly inspired by Bret Victor, seemingly every part of the code can be "scrubbed", allowing interactive exploration of functions and values.
- Talk: The Future of Programming will be Live
- Discussion: Beyond FRP: physics-inspired programming abstractions?
- Sean has a number of videos of ThoughtTalk and other prototypes on his YouTube channel.
- Paper: Coding at the Speed of Touch — Describes a touchscreen visual programming interface inspired by Kodu.
- Paper: A visual perception account of programming languages : finding the natural science in the art — "[A] true visual language would then be a graphical language that actually leverages the perceptual system" — Proposes using Jacques Bertin's Semiologie Graphique as the lens through which to see programming language representation.
- Paper: Unifying Textual and Visual: A Theoretical Account of the Visual Perception of Programming Languages
- Essay: A Visual History of Eve: 2014-2018
- Blog post: Types are shapes — a graphical programming exploration
Created the Cornell Program Synthesizer in 1978, an IDE-like system that showed the power of editing tools deeply knowledgable about the structure and semantics of a language. This project was captured in the paper A Syntax-directed Programming Environment, co-authored with Thomas Reps.
Programs are not text; they are hierarchical compositions of computational structures and should be edited, executed, and debugged in an environment that consistently acknowledges and reinforces this viewpoint. The Cornell Program Synthesizer demands a structural perspective at all stages of program development. Its separate features are unified by a common foundation: a grammar for the programming language. Its full-screen derivation-tree editor and syntax-directed diagnostic interpreter combine to make the Synthesizer a powerful and responsive interactive programming tool.
- Talk: Alternative Programming Interfaces for Alternative Programmers
- Led to the Recursive Drawing project.