Most visual programming environments fail to get any usage. Why? They try to replace code syntax and business logic but developers never try to visualize that. Instead, developers visualize state transitions, memory layouts, or network requests.

In my opinion, those working on visual programming would be more likely to succeed if they started with aspects of software that developers already visualize.

Developers say they want “visual programming”, which makes you think “oh, let’s replace if and for”. But nobody ever made a flow chart to read for (i in 0..10) if even?(i) print(i). Developers familiar with code already like and understand textual representations to read and write business logic2.

Let’s observe what developers do, not what they say.

Developers do spend the time to visualize aspects of their code but rarely the logic itself. They visualize other aspects of their software that are important, implicit, and hard to understand.

Here are some visualizations that I encounter often in serious contexts of use:

  • Various ways to visualize the codebase overall.
  • Diagrams that show how computers are connected in a network
  • Diagrams that show how data is laid out in memory
  • Transition diagrams for state machines.
  • Swimlane diagrams for request / response protocols.

This is the visual programming developers are asking for. Developers need help with those problems and they resort to visuals to tackle them.

  • Zikeji
    link
    fedilink
    English
    arrow-up
    6
    ·
    4 months ago

    Ooh that’s a thought. As someone with aphantasia, the concept of visualizing programming is absolutely foreign to me. I should ask my colleagues what they visualize.

    • Kissaki
      link
      fedilink
      English
      arrow-up
      1
      ·
      edit-2
      4 months ago

      Aphantasia is the inability to visualize.

      Interesting.

      Wikipedia

      For some things I definitely spatially lay out elements to put them into relation. I also visualize UI when thinking about it.

      When I think of code hierarchies and relations, I wonder if it always ends up spatially or if sometimes I skip/omit that visualization, and if and what difference that makes. 🤔 I guess when it’s complex enough, I skip the obvious intuition and visualize to find understanding.