Friday, September 12, 2008

The inherent value of simplicity

"Make everything as simple as possible, but not simpler." -- Albert Einstein

Simplicity: the lowest energy state of being; seen as beautiful or hurled as invective. Is it good or is it bad? In software engineering, the pursuit that engages all Knowledge Warriors in some fashion, simplicity is good, an attribute worthy of careful craft. Why? Because simplicity is efficient. Because simplicity is understandable. Because simplicity is challenging. Because simplicity is differentiated in the face of our complexity addicted culture. Consider that designing a piece of software with a single unnecessary feature requires 1 unit of design, 1 unit of build, 1 unit of testing, 1 unit of documentation, and 1 unit of maintenance. 5 units of effort are expended where 5 units could have been saved for expanding the boundaries.

"Perfection (in design) is achieved not when there is nothing more to add, but rather when there is nothing more to take away." -- Antoine de Saint-Exupéry

Why strive for a simpler solution? To enumerate a few of the most obvious reasons:

  • Ease of explanation
  • Openness for future expansion/maintenance
  • Performance
  • Reliability – fewer bugs
  • Upgradability – fewer rules means less opportunity for failure in upgrade
  • Testing needs reduced
  • Usability improved
  • Training time reduced
  • Development time reduced

A simple design requires that we pare away unnecessary features. There are three types of unnecessary features constantly on my radar. Recognizing them is the first step in elimination.

  1. Bells and Whistles: Great for sales and terrible for maintenance, this class of unnecessary feature is usually an addendum to a feature considered critical to a particular business function. They blur the line between needful and wasteful. Bells and whistles seem attractive in the abstract, but in-practice are rarely used and frequently broken. A Bell and Whistle here and there can add spice to the application for an end-user, but each will carry costs in performance and maintainability. Use them to please, but please sparingly—the delivery of solid, dependable business tools should be our primary focus.
  2. Belt and Suspenders: A belt will hold up your pants 99.99% of the time, only spend money on suspenders when 0.01% will result in loss of life or limb. Belt and Suspenders are unnecessary features that address unfounded fears of failure in an application—paranoia expressed in design. Graceful handling of foreseeable errors and exceptions is important, but keep in mind that features added to handle imaginary errors are likely to become the source of errors themselves. A single, general purpose, pragmatic approach to dealing with system failure is best. More specific errors will emerge through testing and early production use—these will emerge from the quirks of each enterprises environment. Save time and money to fix these specific, actual errors in quick-response fixes post-rollout rather than waste ten-fold the time imaging and addressing all manner of potential problems whose multitude are unlikely to occur at all.
  3. Better mousetrap: The third class of unnecessary feature is often the brainchild of a business expert. These are paths of processing that add competitive approaches to well-established processes that will also be incorporated into the application—multiple paths that reach the same business outcome. The challenge in recognizing and redacting these better mousetrap features is to determine which of two processing paths represents the most acceptable to the mainstream business. End-users are often confused by multiple options whose outcomes are equivalent. When two such paths exist an individual will often pick a path based on their own internal criteria and then favor that path forever after. A single, straight-forward path to fulfilling a crucial business need will instead be leveraged consistently within the user community. Multiple paths are more likely to complicate training, introduce the possibility of inconsistent processes, and result in the inevitable introduction of maintenance headaches.

    "Remember that there is no code faster than no code." -- Taligent's Guide to Designing Programs

Labels:

Monday, September 1, 2008

Labor in Our Business

Given that today is Labor Day in the US, I thought I might comment on the role of labor in our consulting practice. First, let's start with a strict definition courtesy of Dictionary.com.

Defn: productive activity, esp. for the sake of economic gain.

Secondly, let's consider this definition more deeply in the context of our business. Does KR use labor as defined above? Yes, we unmistakably employ labor heavily in pursuit of economic gain. Every Knowledge Warrior is a source of this motive force. From the standpoint of management, the Knowledge Warrior is intended to conduct activities that are productive for KR.

Finally, let's consider the role labor plays in our services. Does KR sell labor? I think the answer is no. There is a distinction between the employer/employee relationship (Knowledge Warrior to KR) and the client/service provider relationship (Knowledge Warrior to client). An employee acts productively. A service provider provides services. We must recognize that productivity to our clients, while often important, is inferior to the provision of services whose value is perceived positively by the client. Said another way, an activity whose value is perceived most highly (a service) is not necessarily the same as the activity that is most productive (in absolute terms). When this is the case, as service providers, as consultants, we should prefer the former and shake-off the normal instinct to relentlessly pursue the latter.

This was a hard-won lesson for me in joining this service business. Sometimes, we need to back-off from our cultural impatience for action—to NOT rush to get the job done. Sometimes, the activity of most perceived value may be inaction. Since, intuitively, productivity is weighed against a volume of tangible deliverables, this flies in the face of our definition for labor. Recognizing that intangible deliverables are often more valuable to our clients than those resulting from 'productive activity'. Knowledge Warriors must seek to understand productivity in the provision of services more holistically. We can hold fast on our core belief in getting 'it' done quickly and effectively. We must embrace the notion that the client's 'it' always includes an element of desired, intangible action. This holistic notion reflects positively on the client's perception of value and therefore fulfills your commitment to act productively in pursuit of economic gains on KR's behalf.

Happy Labor Day.