Sign in
Inside Architecture
Notes on Enterprise Architecture, Business Alignment, Interesting Trends, and anything else that interests me this week...
Options
Blog Home
About
Email Blog Author
Share this
RSS for posts
Atom
RSS for comments
Search Blogs
Tags
Agile development
Analysis
Application Portfolio Management
Architecture
BPM
Business Architecture
C# programming advice
Coding Tips and Tricks
Collaboration
Community
Enterprise Architecture
Frameworks
Governance
information architecture
Integration
Leadership
Metamodel
Operating Models
Personal and Humor
Project Management
Segment Architecture
SOA
Software as a Service
Standards
workflow
Archive
Archives
April 2013
(6)
February 2013
(1)
January 2013
(4)
December 2012
(2)
November 2012
(1)
October 2012
(1)
September 2012
(1)
August 2012
(5)
July 2012
(2)
June 2012
(2)
May 2012
(4)
April 2012
(4)
March 2012
(2)
February 2012
(1)
January 2012
(4)
December 2011
(2)
November 2011
(3)
September 2011
(2)
August 2011
(1)
July 2011
(7)
June 2011
(3)
May 2011
(2)
April 2011
(1)
March 2011
(5)
February 2011
(3)
January 2011
(2)
December 2010
(7)
November 2010
(6)
October 2010
(4)
September 2010
(6)
August 2010
(6)
July 2010
(5)
June 2010
(6)
May 2010
(3)
April 2010
(3)
March 2010
(4)
February 2010
(5)
January 2010
(4)
December 2009
(2)
November 2009
(2)
October 2009
(3)
September 2009
(4)
August 2009
(1)
July 2009
(4)
June 2009
(4)
May 2009
(8)
April 2009
(6)
March 2009
(5)
February 2009
(4)
January 2009
(3)
December 2008
(3)
November 2008
(4)
October 2008
(6)
September 2008
(9)
August 2008
(4)
July 2008
(11)
June 2008
(6)
May 2008
(6)
April 2008
(4)
March 2008
(6)
February 2008
(8)
January 2008
(5)
December 2007
(8)
November 2007
(6)
October 2007
(8)
September 2007
(13)
August 2007
(27)
July 2007
(20)
June 2007
(15)
May 2007
(15)
April 2007
(16)
March 2007
(11)
February 2007
(10)
January 2007
(11)
December 2006
(13)
November 2006
(10)
October 2006
(11)
September 2006
(13)
August 2006
(17)
July 2006
(18)
June 2006
(7)
May 2006
(9)
April 2006
(13)
March 2006
(10)
February 2006
(8)
January 2006
(10)
December 2005
(1)
November 2005
(1)
October 2005
(8)
September 2005
(8)
August 2005
(8)
July 2005
(4)
June 2005
(6)
May 2005
(1)
April 2005
(4)
March 2005
(2)
December 2004
(6)
November 2004
(3)
October 2004
(6)
September 2004
(5)
Feature Driven Development vs. Traditional Project Planning, part deux
MSDN Blogs
>
Inside Architecture
>
Feature Driven Development vs. Traditional Project Planning, part deux
Feature Driven Development vs. Traditional Project Planning, part deux
Nick Malik
30 Apr 2005 12:00 PM
Comments
2
A couple of weeks ago, I blogged about an experience I had that allowed me to directly compare Feature Driven Development's planning process with processes that used traditional workflow breakdown structure and the waterfall approach.
I pointed out how much pain was felt by the teams that used the traditional approach and compared that to the relative ease with which the FDD team reached consensus and proceeded with our work.
In sharing that article, I got quite a bit of feedback. Some of it is supportive, much of it is skeptical. The last article is presented as a case study. This one is analysis. The topic is essentially the same:
if we focus only on the planning process
, how does FDD compare to Traditional Waterfall.
The goal of planning
Let me start with a definition: The intent of planning is to take the requirements, develop cost estimates, and get them back to the customers. The purpose of this cycle is to
give control
to the customers in deciding what to build. "Now that I know how much it costs, what do I really want to build?"
The key takeaway from the FDD article that I blogged is this:
T-WBS processes provide lots of information, but do not effectively roll up the information in a way that allows the customer to answer the question above. FDD articles provide the same information in a different order that fosters better decision making.
Avoiding Sticker Shock
How many times have you presented a schedule to a customer, and they came back and said "that's too expensive?" In my experience, this is common but not really typical. Why? Because T-WBS Waterfall processes solve this problem in a different way.
In T-WBS systems, we plan things in layers so that we avoid the problem of "sticker shock." We cooperate to set high level goals, make high level estimates, and set expectations... then do it again, refining the estimates, clarifying requirements, and negotiating costs. Then we create "phases" and do it again within the coming phase. Everything moves, everything shifts. This negotiation takes time. It also assumes that the list of requirements is pretty static.
This also puts a huge focus on the Product Manager and the Program Manager making decisions for other people. The product manager makes decisions for the customer. The Program Manager makes decisions for the dev team.
Neither the customer nor the dev team is in the room.
Is this the right way to avoid Sticker Shock?
This traditional negotiation process starts to shred if the requirements are still being discovered, or if folks don't really know what they want. This is common knowledge in PM circles. If the requirements aren't known up front, you will have problems with this process. The problem is that this statement is ALWAYS TRUE. Requirements are nearly never well known up front, and even when they are, they always change as needs are uncovered or business moves.
What we lose is the ability for the
customer
and the
team
to cooperate in an agile manner throughout the life of the project. We lose the ability for the customer to expand scope in one area, restrict scope in another, and introduce entire sets of requirements part way through the process. We lose the ability of the team to offer ideas born of experience. We lose the ability for the customer to explain and expand on their understanding.
The multi-layered negotiation stage of T-WBS, and the notion that we can "manage to schedule" is very inflexible in this regard.
This traditional process assumes that we are guessing correctly about things that we don't know. It assumes that information we learn along the way is inconvenient or less valuable than the stuff we knew at the beginning.
This is an absurd notion, and no matter how well you refine and improve the Waterfall planning process, the act of building a framework on top of such an absurd notion cannot produce a stable process.
The fact that I am making this point, when T-WBS has been repeatedly refined for 25 years, is proof positive that the traditional work-breakdown structure concept is not stable.
Is FDD better than Traditional WBS when planning a project?
If the goal is to allow the customer the right to decide what to develop, and what not to develop, then yes, because T-WBS offers no easy way for the customer to push back on one feature, or to select one feature over another.
If you judge the process by it's output, then T-WBS is fundamentally broken.
Does FDD planning fit with Waterfall delivery?
Sure. You can use FDD to plan a waterfall project. In fact, we've done just that for some very short projects (what agilists would refer to as a single iteration or sprint). The point is not that Waterfall processes will go away any time soon. The point is that the traditional planning process, taught in project management class, is missing a basic tenent: that the tasks need to be collected into features and delivered as features, and that doing so allows the customer to provide better feedback, and to better prioritize the work.
This is an education process. It isn't easy. But I'm a pretty persistent fellow.
2 Comments
Agile development
Comments
Rob Caron's Blog
9 May 2005 5:14 AM
Visual Studio Team System
If you’re installing Beta 2 using Virtual PC, you should learn to appreciate...
ANdrew
15 May 2005 8:27 AM
You might find the following discussion about the 'original' waterfall useful.
http://c2.com/cgi/wiki?WaterFall
Page 1 of 1 (2 items)