Code Companion
In my graduation thesis, I characterized the step of abstractions and translation when designers want to translate their idea into code. I created a toolkit to facilitate the design and prototyping process. This toolkit is called the Code Companion and contains two tools: the Blueprint, and the Pattern Dictionary.
data:image/s3,"s3://crabby-images/d7e85/d7e850c903006ca280d2466c92d17d11be9dde1e" alt="A photo of a person doing a paper programming exercise. The paper is full of notes and sketches."
data:image/s3,"s3://crabby-images/32437/32437a808df2a2a9ad9397d855fe8b64b6e754c9" alt="Picture of the pattern dictionary on an app, with a physical copy in the background"
The Code Companion: a tool to help interaction designs with programming their ideas
To investigate the gap between idea and code, I organized multiple workshops where 40+ design students had to program and prototype a similar design (an interactive dice). All their code was printed and analyzed for patterns; which indicated that none of the students had any overarching knowledge of programming concepts.
data:image/s3,"s3://crabby-images/7e97d/7e97dd00fb0310b8f264f475127401ed0097165e" alt="Research results of design students that programmed for the first time, hanged on a wall"
Code analysis of designers that were programming for the first time
Next, I organized a paper programming workshop, in which design students had to perform a paper programming exercise for two very limited design briefs. Together with the code analysis; I identified two strategies designers employ when breaking down ideas: pathfinding & trial-and-error.
data:image/s3,"s3://crabby-images/5be3f/5be3fc8922016c7f98fa87c004f3b79c81ccae89" alt="Research results of paper programming, hanged on a wall"
Besides observations, experiments, and exercises with designers, I also researched the history of programming. Understanding which programming paradigm influenced which language proved to be vital in determining possible solutions and design directions.
data:image/s3,"s3://crabby-images/79d76/79d76cdf511a1c5d84e7911343c1ad1167d1f727" alt="Blueprint in use: A paper drawing of a software program"
The Blueprint allows designers to breakdown their ideas into logic
To support the Blueprint and help designers find the right (programming) pattern, I designed the Pattern Dictionary. The dictionary includes common programming patterns and behaviors for Arduino, explains the flow and explains different concepts.
Additionally, a prototyping tool was made that had an array of pre-programmed inputs and outputs designers could use to test their concept. This eliminated learning hardware and electronics from the process, letting them focus on programming concepts.
data:image/s3,"s3://crabby-images/71558/715588b586c7730ac8a8b46b446d7a592170e8f5" alt="Arduino hardware prototyping board, to make programming easier"
In short, the Code Companion is an initial exploration in demystifying how programming works, and helps interaction designers breakdown their ideas into more manageable, programmable parts.
data:image/s3,"s3://crabby-images/32437/32437a808df2a2a9ad9397d855fe8b64b6e754c9" alt="Picture of the pattern dictionary on an app, with a physical copy in the background"
The Code Companion