What kills great design?

Wednesday, November 10, 2010 gc 3 Comments

The killer is complexity. Complexity kills design, projects, products, and companies. Many teams struggle to produce version 1.0 of a product. Other teams can produce version 1.0, but within a few versions, the product is stuck in a quagmire of complexity—unable to move the product in a strategic direction.

Managers and stakeholders see it in the form of rising issues and inability to do anything new. Meanwhile, more distance is created between what you are and what you want to be.

Complexity is the true enemy for companies, teams, and developers.

How can you fight it?

1. Don't hire complexifiers: On the surface, they seem smart because they point out every possible thing that could go wrong or that you might have to worry about someday; with it comes a load of conceptual weight; complexifiers are people that create over-abstracted designs and make everything too complicated. Like a tick, once they have dug-in, they are difficult to get rid of because they have produced a pile of code that is not understood or modified easily. One way to identify complexifiers is that they tend to write a lot of defensive and complex code with no test cases.

2. Use simple design and embrace change: Always strive for simply design and use automated test cases to embrace change. Do not overdesign. You can't predict the future so be ready to change when the future changes—seems inevitable. The idea is easy: to change a simple design should be simple and you will be able to have trust in the system because you have a suite of automated tests to validate change. Reduce conceptual weight.

Be agile not just in development but also operationally. Windows Azure provides the best operational agility that I have seen so far.

3. Be a champion for simplicity: Do not add stupid features and do not let others kill your product. Don’t listen to your lizard brain.

The best weapon against our common enemy, complexity, is simplicity. It is a powerful form of Kung Fu.

One last thing: complexity even kills people: http://www.amazon.com/Fatal-Defect-Chasing-Killer-Computer/

You Might Also Like

3 comments:

gc said...

For more thought about...
1. Complexifiers
http://www.scottberkun.com/blog/2006/there-are-two-kinds-of-people-complexifiers-and-simplifers/
http://en.wikipedia.org/wiki/You_ain%27t_gonna_need_it

2. Agility and simple design
http://en.wikipedia.org/wiki/Extreme_Programming
http://xprogramming.com/xpmag/whatisxp
http://www.microsoft.com/windowsazure

3. Simplicity and product design
http://techcrunch.com/2010/11/06/why-products-suck-and-how-to-make-them-suck-less/
http://lawsofsimplicity.com/

Anonymous said...

Greatness Greg...I agree 110%

gc said...

Thanks.