Get Lean, Eliminate Waste

If you want to tune your software engineering, take a look at Lean.  Lean is a great discipline with a rich history and proven practices to draw from.  James has a good post on applying Lean principles to software engineering.  I think he summarizes a key concept very well:

"You let quality drive your speed by building in quality up front and with increased speed and quality comes lower cost and easier maintenance of the product moving forward."

7 Key Principles in Lean
James writes about 7 key principles in Lean:

  1. Eliminate waste.
  2. Focus on learning.
  3. Build quality in.
  4. Defer commitment.
  5. Deliver fast.
  6. Respect people.
  7. Optimize the whole.

Example of Deferring Commitment
I think the trick with any principles is knowing when to use them and how to apply them in context.  James gives an example of how Toyota defers commitment until the last possible moment:

"Another key idea in Toyota's Product Development System is set-based design. If a new brake system is needed for a car, for example, three teams may design solutions to the same problem. Each team learns about the problem space and designs a potential solution. As a solution is deemed unreasonable, it is cut. At the end of a period, the surviving designs are compared and one is chosen, perhaps with some modifications based on learning from the others - a great example of deferring commitment until the last possible moment. Software decisions could also benefit from this practice to minimize the risk brought on by big up-front design."

Examples in Software Engineering
From a software perspective, what I've seen teams do is prototype multiple solutions to a problem and then pick the best fit.  The anti-pattern that I've seen is committing to one path too early without putting other options on the table.

A Lean Way of Life
How can you use Lean principles in your software development effort?  ... your organization?  ... your life?

More Information