The Ten Most Important Ideas in Software Engineering

Bookmark and Share

October 17th, 2006

Software Estimation: Demystifying the Black ArtI had the good fortune to be invited to participate in Construx’s Executive Summit conference in Seattle this week, and have just finished the first day of the conference. The highlight of the first day was the opening keynote presentation by Steve McConnell, founder of the firm, and author of a number of excellent books on software engineering (including a new book on estimating, Software Estimation: Demystifying the Black Art).

Steve’s talk was titled “The Ten Most Important Ideas in Software Engineering”; he emphasized that these are not new ideas, but ideas that are being “rediscovered” from other engineering disciplines, or simply ideas that have been discussed widely but not practiced widely. Here is Steve’s list:

  1. Psychology of Computer ProgrammingSoftware development is performed by human beings. This notion was first popularized by Gerald Weinberg in 1971, with a book entitled The Psychology of Computer Programming (the silver anniversary edition of the book was republished in 1998). McConnell noted that estimating models like COCOMO-II demonstrate the significant cost/effort multipliers associated with having talented, experienced personnel on a project. He also suggests that we can draw three conclusions from this point: (a) the success of companies like Google, Yahoo, and Microsoft is not accidental, and is partially due to their emphasis on hiring talented people; (b) recruiting talented staff members is easily cost-justified; and (c) spending money on employee retention programs is cost-justified.
  2. Incrementalism is essential. Steve distinguishes between “incremental” and “iterative” development; by “incrementalism,” he refers to the idea of developing a little bit at a time, in contrast to the big-bang software development approach.
  3. Iteration is essential. This is a familiar concept, but Steve warned us to avoid accepting the all-or-nothing extremes of iteration. You don’t have to accept the “keep iterating forever” extreme, nor do you have to accept the “no iterations are allowed” waterfall approach.
  4. The cost to increase a defect increases over time, throughout the development life cycle. This is a concept that has been widely accepted for the past 25 years, and McConnell says he has revalidated its truth with data as recent as 2004, including XP/agile projects. I was somewhat surprised by this, because a common argument from the XP/agile enthusiasts is that modern tools have made the old concept irrelevant — i.e., the XP/agile people argue that it doesn’t cost much to fix a requirements defect later in the development process, because modern IDE tools make it easy to redevelop software. McConnell obviously disagrees with this point, and I’ll have to look into it further before I make up my own mind.
  5. There is an important kernel of truth in the waterfall model of development. McConnell suggests that the primary activities of software development are discovery (of what the requirements really are), invention (of a solution), and construction (i.e., implementation of that invented solution). And he argues that while these activities can overlap and take place somewhat concurrently, there is an intrinsically sequential nature to the activities.
  6. The accuracy of estimates (about the schedule, effort, and cost) for a project increases over time throughout the development of a software system. There is a great deal of uncertainty in the initial estimates that we create at the beginning of a project. The “cone of uncertainty,” as McConnell calls it, does not narrow by itself, it must be actively managed. As a result, McConnell concludes that iteration must be iterative, project planning must be incremental, and that estimates aren’t meaningful unless they contain a description of their uncertainty.
  7. The most powerful form of reuse is reuse of everything — not just code. We’ve long known that we should be reusing designs, plans, checklists, role, etc; and McConnell reminds us that we should be reusing processes for developing systems. Indeed, that’s what SEI-CMM level 3 is all about.
  8. Risk management provides important insights into software development. McConnel notes that most projects spend more than 50% of their effort on unplanned work, and that the role of risk management is to reduce unplanned work.
  9. Different kinds of software calls for different kinds of software development approaches. The “one size fits all” approach to software development methodologies is just plain silly
  10. The Software Engineering Body of Knowledge (SWEBOK) is an important asset for software developers. SWEBOK has detailed information about 10 different areas of software development, including the familiar ones of analysis, design, construction, and testing. McConnell notes that it can be used for curriculum development, career development, certification, interviewing, and building a technical skills inventory.

Today’s presentation is from Joel Spolsky; if I get a chance this evening, I’ll post a blog entry summarizing his talk.

6 responses about “The Ten Most Important Ideas in Software Engineering”

  1. Muhammad Haroon said:

    I totally agree with the “Iteration is essential” point. All but the most trivial software projects can and should take advange of iterative development, which among other things plays a key role in identifying and mitigatings risks in a timely manner (risk management).

  2. mr7458 said:

    Hi,

    Very informative site. I am newbie in project management and am about to take on a project which seems to be well planned out since I did it myself :). I am an employee of the vendor, and the customer is a government orgranization. Since I will be one of the key personnel, can I be sued if the project doesn’t go as planned? Please let me know, cause I am loosing sleep over this.

  3. Peter Schorn said:

    “The cost to increase a defect increases over time, throughout the development life cycle” from above tripped me up. Maybe it should read “… fix a defect …”.

  4. Kenji HIRANABE said:

    Thank you for a very interesting information.
    I translated the 10, into Japanese.
    http://blogs.itmedia.co.jp/hiranabe/2007/09/post_8789.html

  5. yeefe 建站日志 » Blog Archive » The Ten Most Important Ideas in Software Engineering said:

    […] http://www.yourdonreport.com/index.php/2006/10/17/the-ten-most-important-ideas-in-software-engineeri… […]

  6. A said:

    d

Leave a Reply