![]() |
The Paradox of Demanding Solutionsveryard projects > requirements > demanding solutions |
Richard Veryard, 1996 |
abstract | contents | more material ... |
The purpose of requirements engineering is
to determine exactly what the user wants or needs, so that a high-quality
solution can be designed and implemented. The quality of the solution is
defined as the totality of characteristics of the solution that bear on
its ability to meet the user's stated or implied needs.
But requirements engineering is doomed to fail; the user's needs will never be met; the customer will never be satisfied; there is always more work to do. This article was first published in the journal Requirements Engineering in 1996. |
Axiom 1: The
user demands the impossible
Axiom 2: Technology promises gratification of all desires Corollary 1: Technology always disappoints Corollary 2: The solution generates further demands Axiom 3: Everything changes Corollary 3: The user’s requirement changes Corollary 4: The user changes Axiom 4: The user never learns Theorem: Quality is impossible |
Technology and Magic |
The User's problem is the real world. The real world is troublesome. Competitors steal customers, politicians change the rules, staff make mistakes. The future is unpredictable and chaotic.
The goal of the User is to make the world less troublesome. If only we could insulate ourselves against the perverse demands of customers and politicians, if only our competitors could be tamed, if only our staff were perfect. To the extent that the User is successful today, he wants this success to be perpetuated; to the extent that the User is unsuccessful today, he wants this lack of success to be permanently reversed.
And it is technology that is supposed to achieve this miracle. Ultimately, at the bottom of every requirements engineering project, this kind of fantasy can be detected. This is not a complaint but an observation. We humans are irrational creatures, and we need these kinds of drives to spur us into action. Any technological project requires human energy and vision, as well as an element of play, and these qualities are inextricably linked to irrational fantasies.
Why do we expect so much from technology? Because it often delivers.
We believe in magic because magic sometimes works. Primitive man believed that if you want something to fly, you attach a symbol of flight. So they tied feathers to their arrows. As luck would have it, this improved the aerodynamic qualities of the arrows, thus confirming their superstitions. But primitive man's superstitions are as nothing compared to the superstitions of the modern technology user. (Think of the 'magical' powers attributed to Bill Gates.)
Technological progress offers an apparently unlimited trend of improvements in productivity, efficiency, quality, user-friendliness, safety, accessibility, eco-friendliness and, above all, speed. These improvements are visible and genuine - to some extent. This encourages us to believe that they will continue - and that the improvements themselves will become faster and more reliable.In an environment where technology is expected to succeed magically in resolving all the world's troubles, it is of course bound to fall short of these expectations. Mary Catherine Bateson calls this the Revenge of the Good Fairy - technology is like the three wishes in the fairy stories that have unforeseen and unwanted effects.
In the long run, technology also disappoints the supplier. It loses its ability to excite, it becomes taken for granted, the intellectual property gets eroded, competitors learn how to produce similar (or better) devices, a once-unique technology becomes a standard commodity - taken for granted unless it fails.
A prime example of this is the motor car and its associated production technologies. Produced in enormous quantities, the car has made most of us dependent upon it. We take for granted a level of comfort, convenience and safety that was unheard-of a few decades ago. The technological differences between one model and another are actually quite small, but they are made to seem highly significant by desperate suppliers and compliant motor-journalists.
Instead of feeling grateful to the motoring technologists, the driver fumes against the pollution and congestion caused by other drivers, and envies the features and styling of more expensive models.
And think of the inventions that seemed such good ideas at the time: DDT, leaded petrol, various pharmaceutical drugs whose side-effects only became known later. The people who developed these products were no different from us - they meant well, but they were just horribly unlucky.
Neither the engineer nor the user can fully anticipate these demands. How many readers, however technically sophisticated, can honestly claim to have completely configured a new personal computer in one go? Many of us have to go back to the shop (or the purchasing department) to get this extra piece of software, that connector or network card, before we can even get onto the Internet - and then the further demands really start.
A solution is an application of technology to a problem in the User's world. Not only is the user's world changing, but also the available technological opportunities are changing.
For the engineer, it's like trying to build a bridge between two banks of a river, but both banks of the river are moving.
Sometimes it is possible to find a spot where the two banks of the river are at least moving in the same direction, albeit at different speeds. That's the case with the technological trend towards open distributed computing technology, which happens to coincide with a business trend towards federated organization structures. Does that make it easier to build bridges?
What can the engineer do about such posthoc reinterpretations of the user's requirements? He cannot ignore them, since they affect the user's judgement (which is, after all, the only one that counts) of quality. Quality means satisfying the user's needs, which means today's needs. It's just no good matching yesterday's needs - you may be able to force the user to pay for something he no longer wants, on the grounds of a written contractual specification, but that's not quality.
Hence the standard advice to the engineer to manage the user's expectations. But although it's an arrogant conceit, it is also insufficient. What the engineer needs to do is manage the whole user. Both the user's interpretation of the stated needs, and the user's implied needs, shift as the user's worldview shifts.
These technologies change users' perception of the world, and their place in it. It changes users' behaviour. Thus it changes their identity - the psychological identity of an individual, the cultural identity of an organization. Such changes affect the priorities and needs, which lead back again into new requirements for new technologies.
Each of us, as simultaneous users and engineers of technology, have multiple conflicting perceptions, perverse agendas and even inconsistent value systems. These shift over time, so that we are never the same again. No wonder our requirements change.
Meanwhile the engineer is also changing, in ways that resemble how the user is changing.
The same patterns recur, over and over again. While pooh-poohing silver bullets, we fall for the next silver bullet; while preaching caution, we take preposterous risks.
How can we learn, if we have even forgotten who we are? How can we learn, if we cannot even maintain continuity of perception? How can we build on our experience, if our experience must be constantly and radically reinterpreted?
![]() |
veryard projects > requirements |
Technical update July 22nd, 2003
http://www.veryard.com/tcm/banre.htmCopyright © 1996 Veryard Projects Ltd |