Paul Graham is spot on (as always)

Holding a Program in One’s Head

In fact, if you look at the way software gets written in most organizations, it’s almost as if they were deliberately trying to do things wrong. In a sense, they are. One of the defining qualities of organizations since there have been such a thing is to treat individuals as interchangeable parts. This works well for more parallelizable tasks, like fighting wars. For most of history a well-drilled army of professional soldiers could be counted on to beat an army of individual warriors, no matter how valorous. But having ideas is not very parallelizable. And that’s what programs are: ideas.

And some interesting thoughts from the comments:

One possible alternative organization pattern is the “band.” …

It would be interesting to see how a band-style organization would apply towards more practical software products. Software so produced would come in boxes with the band’s logo, but more importantly, a _list of credits_, anecdotes about the software’s creation, etc. That is, to make the delivery of the software more _human_.

Back in the day, when credits on software were more commonplace, it was possible to judge the quality of a product (to some extent) based on who was involved with it. Some people became reknowned coders, reknowned technical writers, etc. I think it gave two incentives: first, your name is going on the box of that package — this gave prestige in the community post-sale; second, it allowed the customers to predict the overall feel of the software prior to actually purchasing it, based on their experiences with software written by the same or similar authors.


The only part I don’t really agree with is the implicit condemnation of programming done by large companies. Yes, their methods result in mediocre software, but that’s often what you want. There’s a reason they try to treat programmers as interchangeable cogs, and resist having an entire program in one person’s head.

To use the tired “building a house” metaphor - you can get a renowned architect to design the next landmark in a city, or you can get mediocre, interchangeable architects to design a row of townhouses. Both approaches are valid and have their own place, but there’s no point asking the famous architect to build townhouses.

One Comment

  1. Posted 8/25/2007 at 10:55 pm | Permalink

    Amen to that!

Close
E-mail It