"Design has become a synonym for a backdrop, a beautiful appearance for the stylish, and I fear we could lose our orientation at a point in time when orientation is needed as never before."
-Dieter Rams
Development processes are influenced by the accelerating growth of digital technologies, which is disrupting businesses. This is creating exciting prospects for some and undermining the business models used by others. For designers, it can result in working in substandard environments with growing inefficiencies that can compromise the quality of strategies, solutions, and products.
In order to mitigate the variables that create a substandard environment, one must know the logic behind its function. When standards are compromised incrementally in order to reach a deadline, such as a launch, a phenomenon called debt develops. In Agile Software development practiced by Engineers, this is called Technical Debt.
The disruption of businesses has created a need for developers to work in multi-disciplinary teams. Simultaneously the disruption created desired output found iterative development processes within disciplines that don’t require code, and thus, the phenomenon of debt has began appearing outside of code.
Agile has been around for a minute, and because of that, different practices have been created to mitigate the debt that it accrues. With Technical Debt, I’ve observed is that most companies will work in a SCRUM manner and adopt Agile principles. Conducting sprints to refactor the debt that has been accrued.
Another common way Technical Debt is mitigated is by adding QA to the iterative cycle. This is commonly known as DevOps. No coincidence that have adapted the strategy, now you see terms like DesignOps, ResearchOps, ProductOps, MarketingOps and so on.
Unfortunately, like Technical Debt, the phenomenon of debt outside of software struggles to be communicated outside of its discipline. Debt accrued can render products and operations useless and create other growing inefficiencies. For my thesis at Hyper island, I focused on the Debt that accrues in Design. To understand that Debt, one must understand the design and development landscape.
Design Landscape
“Design is concerned with how things work, how they are controlled, and the nature of interaction between people and technology.”
- Don Norman
There is a common misunderstanding of what design is, or at-least, the Data-Driven Design practiced by Product, Service, and User Experience Designers. Design making sense of things. It is abstract and yet concrete. It is the architecture to any strategy. Design is guided by philosophies, one such philosophy is Human-Centered Design. Roger Martin has a pretty elegant perspective where he sees right blend of intuition and analytical thinking.
Understanding Problems
Human-Centered Design focuses on human needs through empathy, ideation, and experimentation. It’s understood as focusing on Human needs instead of Customer needs. This means that you study the way in which the problem occurs rather then focusing on existing solutions.
Here is an example:
Something fantastic happened to you. You had your first kid, you met your hero, or maybe you just came back from a lovely trip. Someone has captured lovely photo of your expierience and you want to hang it up. The picture is stored on your phone. Thinking logically about it, you break it down into 3 overarching tasks:
1.
Print the picture so you have it physically to put on your wall.
2.
Purchase a frame to protect the picture.
3.
Put the picture on your wall.
Now for assume you have done steps 1 & 2 effortlessly, and now you have to put the picture on your wall. You currently have no tools or supplies to do this. You go to a hardware store. You think want to buy a hammer and some nails. You go up to associate and you ask what for a hammer and good nails. The associate will try to sell you the best hammer and the best nails. This is where human-centered comes in to disrupt businesses. Although you requested it, You didn’t want a hammer and some nails. You wanted to hang a picture on your wall. Approaching the problem from this standpoint broadens opportunities for teams to innovate and create effective solutions.
Wicked Problems
Understanding the goals of your consumers and developing from that scope creates more opportunities for innovations and is at the root of design. It allows orginizations to enter or strengthen their position and enter new markets. So how do companies or individuals innovate?
How do they disrupt? Solving problems is at the root of Design. In Academia, a popular term to describe problems that have many variables is Wicked Problems.
“The search for scientific bases for confronting problems of social policy is bound to fail, because of the nature of these problems. They are 'wicked' problems, whereas science has developed to deal with 'tame' problems.”
- Horst Rittel
This was first observed by Horst Rittel, who was dealing with social problems, he created an approach where you split a process, in his case the scientific method into two iterations. One where you define the problem and the second to solve the problem. Rittel, at the time, created the method to solve social problems. His work and approach can be seen all around us.
Wicked Problem
How do you reduce car accidents?
Solutions
1. Communication to Vehicles.
2. Communication to Pedestrians.
3. A beeping sound telling you when you can/can’t walk for deaf/hearing impaired, and for those texting/not looking up.
4. Reflective paint, All caps/high contrast for readibility.
5. Studs that add depth to the road, braille for the blind/visually impaired.
6. A ramp for wheelchairs & strollers
This approach was used to break up and incrementally solve a wicked problem. Over time, this method evolved and which is commonly understood by it's predessesor, the double diamond. Above is a variation of the Double Diamond that I created from primary and secondary data. One thing to understand when using the Double Diamond is that apart from having 2 phases. Phase one (Problem Definition) where you figure what the real problem you are trying to solve is and the phase 2 (Problem Solution) is the best solution we can create in this time and place.
Software Landscape
I’m going to quickly cover some the most common Software Development processes and how Technical Debt can be addressed by Developers and Organisations:
Waterfall
Waterfall is the traditional form of development. Waterfall is linear style of development with a fixed deadline with no opportunity for feedback. Types of Debt accrues due from the lack of early feedback, as insights and pain-points cannot be addressed when discovered. The inability to address, respond, or adapt to these problems compromises the success of that which is being developed. As it’s not iterative. All debt can be defined and addressed after that which has been developed has been implemented.
SCRUM
Like Waterfall, Scrum has fixed deadline, but adds feedback to the development cycle. Debt cannot be mitigated unless persuasions are made before development. The Debt accrued from development can be tackled through refactoring sprints.
Agile
Agile was breakthrough for Software Development as it removes fixed deadlines to ensure vital changes changes as quickly as possible regardless of at what stage something is in development and adds early launch the development process. Its greatest strength is its greatest weakness. In practice it is chaotic and often a nightmare to manage. Agile is all about creating product that is minimal and viable, releasing early, and developing and feedback is fed into the development stream. Since it has no fixed deadline, that which is being developed takes long as takes to get it done.
DevOps & DesOps
Debt accrues when it is not defined or communicated and therefore cannot be prioritised. So unless there is a stakeholder whose prerogative is to mitigate and address debt is deemed essential to the goal of the team, it won’t get done.
Both DevOps and DesOps mitigate Debt by adding a quality assurance (QA) stream to an Agile framework. DevOps priortises on coding metrrics where as DesOp uses design.
The Maelstrom
The Maelstrom is a framework I designed to convey how Debt can accrue during iterative processes. As pressures increase in maintaining iterative development processes, the Debt accumulates. Accumulated Debt can be split into 3 categories:
Code Debt
Unnecessary code duplication and complexity, bad style that reduces the readability of code, and poorly organised logic that makes it easy for a software solution to break when updated at a future point in time.
Design Debt
All the good design concepts or solutions that was skipped in order to reach short-term goals. It is made up of an overabundance of non-reusable and inconsistent styles and conventions.
Knowledge & Documentation Debt
This type of debt is created when knowledge is not documented properly. This can be created when developers and designers who originally created the product are no longer around to explain the reasoning behind its production.
Closing Thoughts
The Maelstrom helps understand Debt and its influence on the design development processes. This creates opportunities to identify and address causes of Debt accumulation. For all type of Debt, suboptimal communication and team collaboration are common underlying factors. These factors can be addressed through system changes and/or tools for improving communication and collaboration. The first step for companies is to be aware of Debt phenomenon, but to know it in theory and to address it in your organisation, are two entirely different things.