Found in Wikipedia: Design Strategist

“A design strategist has the ability to combine the innovative, perceptive and holistic insights of a designer with the pragmatic and systemic skills of a planner to guide strategic direction in context of business needs, brand intent, design quality and customer values.”

Please, don’t talk like this.

Ben Rich on Efficiency and Optimization

About the development of the air-inlet control system for the Lockheed SR-71 Blackbird:

Eighty percent efficiency would get the job done, so why strain resources and bust deadlines to achieve that extra 20 percent, which would cost as much as 50 percent more in overtime and delays and have little real impact on the overall performance of the aircraft itself?

− Ben Rich, Skunk Works: A Personal Memoir of My Years at Lockheed.

Process vs. People

I see this battle unfold daily.

Are you bringing process into projects hoping that it will generate great products?

What about bringing in great people?  Great people can get to great products faster and cheaper than process can.

The Daily Stand-up Meetings Remind Me That…

In no particular order:

  • There are plenty of reasons for a programmer to lose focus in a four-hour period.
  • Sometimes my boss goes directly to a developer and tries to re-prioritize her tasks.
  • Learning the business domain by osmosis is not enough for most programmers.
  • Overanalysis and featuritis must be fought daily.
  • Overanalyzer and great coder are not synonyms.
  • It’s hard for a programmer to explain what they are doing, even to another programmer.
  • Knowledge of, and love for the testing discipline, do not come spontaneously.
  • “Please create unit tests” does not do the trick.
  • “Please enter the bugs in the tracking system” does not work either.
  • If something can possibly be misunderstood, it will be misunderstood. If it can’t possibly be misunderstood, guess what?

Ease of Use Is Difficult To Achieve

A reminder of how fallible we software developers are came last night in the form of a call from my Dad. He was asking for help with his blog. He told me that he went in to “replace one word” in one of his posts and when he was done he noticed that all the images in the post had disappeared.  And he didn’t know how to bring them back.

Although I was not able to find out how he did it, it is evident that my Dad modified the html of the post in such a way that the image tags were accidentally removed from it.

My Dad is no html connoisseur. He does not need to be one. I am sure the very popular blogging software he prefers was designed with the expectancy that its users do not know html.

The users of my systems are like my Dad. Are the users of your software like him, too?

Most times, users just want to “replace one word”. I think we still have a long road ahead when it comes to making this easy for them.

Application Development 2.0: Agile Practices Redux?

Computerworld’s recent analysis Five Web 2.0 app dev lessons for enterprise IT shows how we can’t seem to stop the tendency to re-discover and re-name things that have been with us for quite some time. The analysis asserts that quick and incremental updates along with user involvement are the main characteristics of a new software development paradigm, a new process some call “application development 2.0”, championed by a new generation of Web 2.0 start-ups.

“Application development 2.0” is seen in contrast to what in the analysis is called the “traditional corporate waterfall process”, suggesting that the former could reduce development costs and improve quality, if corporate developers and managers are willing to make “hard changes” like these:

  • Bring developers and end users closer and involve users in quality assurance processes.
  • Keep applications simple. Stay away from unnecessary complexity.
  • Favor dynamic languages.
  • Release early and often.
  • Let the users determine new features.

Look familiar?

With the exception of the much debated subject of favoring dynamic languages, compare the changes above to the principles behind the Agile Manifesto:

  • Our highest priority is to satisfy the customer through early and continuous delivery of valuable software.
  • Welcome changing requirements, even late in development. Agile processes harness change for the customer’s competitive advantage.
  • Deliver working software frequently, from a couple of weeks to a couple of months, with a preference to the shorter timescale.
  • Business people and developers must work together daily throughout the project.
  • Build projects around motivated individuals. Give them the environment and support they need, and trust them to get the job done.
  • The most efficient and effective method of conveying information to and within a development team is face-to-face conversation.
  • Working software is the primary measure of progress.
  • Agile processes promote sustainable development. The sponsors, developers, and users should be able to maintain a constant pace indefinitely.
  • Continuous attention to technical excellence and good design enhances agility.
  • Simplicity – the art of maximizing the amount of work not done – is essential.
  • The best architectures, requirements, and designs emerge from self-organizing teams.
  • At regular intervals, the team reflects on how to become more effective, then tunes and adjusts its behavior accordingly.

I don’t know what percent of corporate developers are using agile development methods, but I know that Agile has been around for a while, and even though it might be a common occurrence among Web 2.0 developers, it’s also made progress within the corporate community. Computerworld has also known this for a while, by the way.

So, and without dismissing the importance of waterfall methods, what should we really be talking about? How corporate developers can benefit from a new development process “discovered” by Web 2.0 companies? Or how we can all benefit from agile software development and contribute to its adoption?

Agile practices are pretty much alive. They don’t need to be brought back, they’re here. And they don’t need a new name either.

ScrumMaster

I just attended the Certified ScrumMaster Workshop offered by Winnow Management. It was the best class I’ve taken in a long time.

We’ve been doing agile development for a while and I think there are many pieces of the Scrum framework we can benefit from. We will certainly continue adding elements of Scrum to our process.

I’m planning on coming back to this subject after we have some concrete results to comment on.