Stepwise Refinement

Stepwise Refinement

“You consume elephants a single spoonful at a time.”
– Bryce’s Law

In a nutshell, the principle of “stepwise refinement” is to acquire an object and shift it from a common standpoint to a specific degree of detail. Architects have employed this kind of an approach for many years, as have engineers creating products and solutions. But to do so, they understood they are not able to only go from the common to the particular in a single felled swoop, but in its place, in increments (ways). The selection of ways needed to decompose an object into sufficient detail is eventually based on the inherent character of the object. To illustrate, for architects designing a creating, the normal ways incorporate:

  1. Produce artist rendering (to contemplate viability).
  2. Design and style foundation and superstructure.
  3. Design and style Flooring strategies.
  4. Design and style electrical and plumbing diagrams.

In other terms, ahead of the initial shovel of filth is dug on the challenge, the architect understands precisely what the creating will glance like and how it will work. All of the guess work has been removed.

Engineers creating products and solutions this kind of as vehicles observe identical yet distinctive ways:

  1. Produce artist rendering (to contemplate viability).
  2. Design and style important assemblies (e.g., chassis, overall body)
  3. Design and style subassemblies (e.g., engine, transmission, electrical, etc.)
  4. Design and style functions (e.g., the different elements of the engine).

Like the architects, the engineers know precisely how the auto will glance, the sections needed to develop it, and the sequencing of assembly. All of the guess work has been removed.

“Stepwise refinement” eventually represents a “divide and conquer” approach to style. In other terms, break a complicated object into more compact, extra workable parts that can be reviewed and inspected ahead of transferring to the future degree of detail.

There are these in the I.T. field that really feel this kind of an approach is impractical to put into action, and in its place of engineering your way to success, you need to acquire an preliminary stab at creating a plan, then carry on to modify it until finally you have produced something to pacify the user’s requirements. This of study course is a hacker’s approach to enhancement and might be fine for creating an innocuous very little plan but absolutely not suited for creating anything at all of substance.

Can the principle of “stepwise refinement” be used to a one plan? Certainly. As a make a difference of simple fact, it lies at the core of the structured programming movement of the 1970’s-80’s. But can it be used on a grander scale, this kind of as an enterprise-large Information and facts System. Again, the respond to is Yes. In simple fact, it is the reasonable way of attacking this kind of a important endeavor.

In advance of we can deal with an data method, it would make feeling that we initial understood the inherent attributes or framework of the object of our interest. It has always been our rivalry that an Information and facts System is a item that can be engineered and made like any other item. To this close, we see an Information and facts System as a 4 degree hierarchical framework consisting of the next elements:

Stage one – System – representing the general item to be created.

Stage two – SUB-Programs – representing the business enterprise processes connected with the method (a single or extra).

Stage 3 – Procedures – representing the work move of each individual sub-method. There are vital two types of methods Administrative – representing methods executed by individuals and Computer.

Stage 4 – Applications – representing the packages needed to execute each individual computer process.

As an aside, there is also a Stage 4 for Administrative Procedures (to write the recommendations/ways pertaining to the process), but for the applications of this paper, let’s put this aside for the second.

Under “stepwise refinement” the ranges are decomposed leading-down in the course of the style system, and executed base-up a widespread engineering/producing strategy.

To put into action this approach, a “blueprinting” strategy is employed which is truly not also dissimilar with that employed by architects and engineers in other fields. Right here, the blueprints are employed to specific the succeeding ranges in the method hierarchy. To illustrate, contemplate the next diagram, where the work from the preceding phase feeds the future degree in the method hierarchy:

What this usually means is that all of the guess work has been removed. So significantly so, that the creation of executable packages need to be a rather simple endeavor. Again, the specs for the packages have been produced naturally in more compact and extra workable increments, not all in after.


The principle of “stepwise refinement” is not particularly new and has been employed properly in the engineering/producing of products and solutions for quite a few many years as a usually means to deal with complexity. It has only been in the very last 30 many years that persons have been trying to put into action the strategy in the enhancement of devices and computer software.

In the absence of “stepwise refinement” on a complicated method, the “brute power” approach is ordinarily employed, whereby superficial work is accomplished in the before phases and considerably extra time is used in programming 2nd-guessing what is to be produced. This is a single purpose why providers today rarely deal with important devices enhancement assignments, and are content material with attacking it in piecemeal.

But if you can assimilate a method as a item, and feel it can be engineered and made like any other item, than “stepwise refinement” is a pragmatic answer you can absolutely use.

If you would like to talk about this with me in extra depth, make sure you do not wait to ship me an e-mail.

Comments are closed.