I am not skilled in drawing, but after trying PlantUML, I found that I can create visual representations directly using code. This has greatly aided my spatial imagination.
Take, for example, the usecases diagram:
@startuml
:user: -right-> (Right)
:user: -up-> (Up)
@enduml
With the use of directional terms like "up" and "right," you can intuitively draw the diagram as shown. it lowers barrier for non-artists - no drawing ability needed and focuses thought process on structural elements and relationships.
When immersed in text, our spatial imagination can often become less active. For example, when trying to imagine the hierarchical structure of an article such as org-mode, our mental representation tends to be more like a bullet structure in an editor, rather than a graphical tree structure.
PlantUML addresses the challenge of limited spatial imagination by providing an intuitive text-graph syntax. One notable feature is the Work Breakdown Structure (WBS) functionality.
Consider the following example:
@startwbs
!theme mono
Emamcs
** Texting Editing
** Note taking
** File Manager
** Literature Programming
@endwbs
The WBS feature in PlantUML facilitates the effortless transformation of a vertical structure into a horizontal representation. This allows me to mentally interpret and visualize the PlantUML code, automatically converting the vertical structure into a spatially-oriented horizontal structure in mind. Consequently, it effectively resolves the issue of my limited visual imagination and improving it continually.
You can also try mermaid (http://mermaid.js.org/syntax/sequenceDiagram.html). There is a babel extension for that
https://github.com/arnm/ob-mermaid
For me the syntax is lighter and the aesthetics are nice and modern.
PlantUML's Gantt charts is well-suited for a more natural language and textual representation, for instance:
[reading] starts 2023-10-18 and lasts 10 days.
I think the Mermaid Gantt charts look incredible and they are extremely feature-rich. I'm a huge fan of that project.