1  Taxonomies, Paradigms, and the Untangling of Terminology

Joyce Farrell, our textbook author, raises a number of interrelated issues on p. 92. I have tried to analyze her terminology in comparison to a dozen or so other print and web authors. I have tried to summarize or quote a number of these other authors below in outline form. I would propose to distinguish between the following aspects of computer programming:

1.  Program Logic Levels, Styles, and Classes

  1. Low-level program logic
  2. Intermediate-level program logic
  3. High-level program logic

1)  Class 0

2)  Class 1

3)  Class 2

  1. System-level logic

2.  Processing Mode

  1. Batch
  2. Interactive

3.  (User) Interface Design

4.  Implementing High-Level Program Logic Alternatives

  1. Operating System Features
  2. Event-Driven Programming

5.  Programming Language Paradigms

  1. Procedure-Oriented/Procedural Programming Languages

1)  Low-Level Programming Languages

a)  Machine Languages (First Generation Programming Languages)

b)  Assembly/Assembler Languages (Second Generation Programming Languages)

2)  High-Level Programming Languages (Third Generation Programming Languages)

  1. Nonprocedural Programming Languages

1)  Functional (“broad sense”)/Applicative Languages

a)  Definitional

b)  Single Assignment

2)  Declarative Languages

a)  Logic Programming Languages

b)  Expert System Languages

c)  Knowledge-based Systems (Knowledge Representation)

d)  Theorem Proving Systems

e)  Grammars for formal and natural languages (Meta-languages)

3)  Constraint Languages

a)  Query and Update Languages

4)  Multi-paradigm

a)  Constraint Logic

b)  Functional Logic

5)  Non-procedural Systems (Fourth Generation, Very High Level)

a)  Report Program Generators

b)  Sort Generators

c)  Spreadsheets

6.  Programming Methodologies

  1. Modular Programming
  2. Structured Programming
  3. Object-Oriented (& related) Programming

1)  Refactoring

2)  Patterns & Anti-Patterns

3)  Prototype Based

4)  Aspect-Oriented

a)  Reflective (related to Functional Programming Language Paradigm)

  1. Literate Programming
  2. Modeling Languages
  3. Unified Process
  4. Genetic

7.  Problem Analysis and Program Design Methodologies

  1. Structured Program Design (Top-Down)
  2. Object-Oriented Program Design (Bottom-Up)

8.  Programming Language Domains of Application

  1. Machine-oriented (i.e., Machine and Assembly/Assembler Languages)
  2. Problem-oriented/Application-oriented

1)  General Purpose

2)  Application areas sufficiently wide and important to justify particular consideration:

a)  numerical and non-numerical (i.e. formal algebraic) scientific applications

b)  business data processing

c)  special data structures

i)  string processing

ii)  (linked) list processing

3)  Special-Application-Oriented

4)  Special-purpose

1.1  Taxonomies and Paradigms

The term “taxonomy” generally means “an orderly classification”. Until recently, it was used mostly by biologists to indicate an orderly classification of plants and animals according to their presumed natural relationships. Computer technology authors have adopted the term to indicate their various efforts to bring order to a complex and constantly evolving discipline. Unfortunately, “taxonomy” is beginning to achieve “buzzword” status.

“Paradigm” is another term which is definitely in buzzword status. Nevertheless, it can still be useful if treated carefully. Its basic meaning is “a model, example, or pattern, especially an outstandingly clear or typical pattern or archetype”. More recently, it has come to mean some pattern or method used to interpret, understand, express, or (over?) simplify something more complex, such as “reality”—a kind of “world view” sort of thing. Computer technology authors seem to have adopted the term to classify various major types of programming languages.

1.2  Untangling Terminology, Part 1—the Use of Alternatives and Criteria in Program Logic

What I haven’t found so far is a good characterization of the underlying design decisions that software designers and programmers need to make in order to realize their analysis and design. Toward this end, it may be helpful to consider the role of logical alternatives and their related criteria in a program. As near as I can tell, all programming languages, properly so called, provide some means of specifying alternative evaluations or courses of action, and some means of specifying the criteria to select between those alternatives. In our course discussions so far, that would encompass the “decision” step and its use in selection and repetition structures.

It is possible for alternatives criteria to be based entirely on processing which is completely internal to the program, for example alternatives criteria based on a pseudo-random number generator. However, such programs would be self-deterministic, not very flexible, and probably of limited usefulness. It is much more common to base alternatives criteria on input to the program, or, indirectly, on calculations based on input. This allows the programmer to provide the program with various degrees of responsiveness to that input. Most programs, then, are programmer-specified combinations of basic evaluations or courses of action, and criteria-determined alternatives.

1.2.1  Levels of Program Logic

These alternatives and their criteria can be applied at any or all of several different levels in the overall program logic.

1.2.1.1  Low-Level Program Logic

At a relatively “low” level, alternatives and their criteria can be applied to particular data values. Chapter 5 of Farrell deals primarily with this level of programming. Major sections of chapters 6, 8, 9, and 10 also pertain.

1.2.1.2  Intermediate-Level Program Logic

At an “intermediate” level, alternatives and their criteria can be used to direct the processing of blocks of data. Examples include selecting, sorting, and organizing data, merging of multiple files, and the use of “transaction action codes” (“add”, “change”, or “delete”)—on a record by record basis. Chapters 7 and 11 illustrate these examples, along with major sections of chapters 6, 8, and 9.

1.2.1.3  High- (or Top-) Level Program Logic

The application of alternatives and criteria at a “high” level of program logic, i.e., in the mainline logic or “main loop” of a program, has the greatest effect on a program’s “personality”, that is, how the program is perceived by its users. For example, the popular distinction between “batch” and “interactive” processing, as well as the various approaches to batch and interactive processing, is most commonly manifested at this level of program design. Chapter 10 includes a discussion of batch processing and interactive processing. Likewise, while user interface issues pertain at all program logic levels, they are particularly relevant at the high level for interactive programs.

At this point, I would like to employ some terminology to describe the various types of high level program logic, independent of considerations of processing mode or user interface. If such a terminology is out there discipline wide, so far I haven’t been able to find it. It appears that Farrell is also struggling with this issue. Unfortunately, she has chosen some terminology that is easily confused with other common usages. So, for the purposes of this discussion at least, I would propose the following classes of high level program logic.

1.2.1.3.1  Class 0 High-Level Program Logic

This is the simplest possible form of high-level program logic. There are no alternatives and criteria, hence no looping or selection. It just executes straight through, step by step, from start to end. It has very limited application.

1.2.1.3.2  Class 1 High-Level Program Logic

This class is the simplest that results in truly useful programs. It includes a “main loop” with but a single criterion to determine whether the end of the input data has been encountered, along with alternatives to loop back and continue processing additional input data if the end has not yet been encountered or to conclude processing if the end has been encountered. Chapters 4 though 9, 11, and parts of 10 and 12 illustrate this approach.

1.2.1.3.3  Class 2 High-Level Program Logic

For now, this is a catchall class that encompasses all high-level program logic more complex than Class 0 or Class 1. It will typically include a main loop with program termination as just one of several or even many alternatives and criteria.

1.2.1.4  Logic Levels beyond the Program (“System”-level logic)

For the sake of completeness, I would note that most modern operating systems provide various facilities such as a (job) control language, “batch command files”, scripting, macros, or “record/playback”. At their most basic, these facilities provide a way to sequence a series of requests to the operating system to perform various system functions or to initiate specified utility or application programs. Once the sequence is initiated, it can be carried out automatically. User or system operator interaction may be provided for, but is not necessary. Many of these facilities also allow for selection and repetition logic through the use of some form of alternative sequences and related criteria. The most advanced forms of scripting even allow alternatives to be applied to standard program input using criteria based on standard program output.

1.2.2  Processing Mode and Program Logic Design

1.2.2.1  Batch Processing Mode

Most everyone seems to agree that batch-oriented programs are those that take relatively large collections of data, such as data files, and process these large collections forthwith. The only user intervention consists of gathering the data into the collection, initiating the execution of the program or submitting the program for later execution, and receiving, distributing, and acting on the output produced by the program. The mainline logic of batch-oriented programs is typically “Class 1”. There are examples of “Class 2” batch-oriented programs, such as “command-driven” batch-oriented programs.

1.2.2.2  Interactive Processing Mode

There is less agreement about the precise meaning of “interactive”. The most general definition of “interactive processing” is roughly this: a mode of processing where the program receives input, processes the input, and returns output that is “immediately” available to help determine further input. The program then awaits further input.

This definition has several significant implications. For one thing, because the computer will be awaiting further input, there must be some “correspondent” (other than a data file) that can provide the further input, based on the previous output. A human user is the most familiar correspondent; but other types of correspondents are possible, including (computer numeric or process control of) machinery, and (interaction with) external physical phenomena or other computer systems.

Note that batch processing may also involve interaction, but that this must take place between the time when the program terminates and the time when its execution is next initiated. With the interactive processing mode, interaction takes place between the time when the program is initiated and the time when it terminates, in other words, while the program is still “running”.

A second implication is “response time”. The timing requirements of the program’s external correspondent must be taken into consideration. Both hardware and software design features may need to be brought to bear to meet these response time requirements. Systems which are able to meet the response time requirements of external correspondents are commonly called “real time” systems. For the human user, response time requirements may be largely psychological but nonetheless real.

A third implication is what to do with a computer system that is awaiting further interactive input. For a mechanical or phenomenal correspondent, the wait time may be from relatively short to practically non-existent. The wait for input from a human user will, on the other hand, be fairly significant from the computer system’s point of view. For a relatively inexpensive single user system, an idle computer system may be acceptable, and no special handling may be needed. For a multi-user or multi-tasking system, there are a number of strategies available to redeem the wait time for use by other users or tasks.

A fourth implication is “on-line” connection. “On-line” refers to the state of (equipment) being directly controlled by or in direct communication with a computer. (Active networking is included.) On the other hand, “off-line” refers to (equipment) not being directly controlled by or connected to a computer. (Applications designed for batch processing mode can theoretically tolerate the delays involved with input-output via off-line equipment. Typically, off-line equipment records data into files or outputs data from files independently of the computer that processes the data. Of course, software designed for batch processing mode can just as well use on-line input-output equipment.) The relatively short response time required by interactive processing generally requires on-line input-output equipment, however.

Programmers can design very limited interactive programs using only “Class 1” high-level program logic. “Class 2” is usually more difficult to program, but gives the programmer many more options to satisfy human factor requirements in the user interface.

1.2.2.3  Interchangeability between Batch and Interactive Processing Modes

I would hasten to add that, from the programmer’s perspective, the distinction between “batch” and “interactive” is not absolute. For one thing, most modern operating systems allow the file input and output of batch-oriented programs to be redirected to the user’s console or terminal (keyboard, display, etc.). This provides for an admittedly crude form of interaction with the user.

In addition, most modern operating systems provide various facilities such as “batch command files”, scripting, macros, or “record/playback”, and the ability to redirect keyboard input from and console output to data files. With some effort, the programmer can embed interactive-oriented programs in a “batch” environment.

Also, there are forms of high-level program logic that can function in either a batch or an interactive mode, although with perhaps varying degrees of effectiveness. One example would be “command-driven” program logic.

1.2.3  Interface and Program Logic Design

In the broadest sense, (user) interface design encompasses both batch and interactive processing modes; and human factors should be taken into consideration for all types of programming. Most discussions, however, focus on the more contemporary issues of designing a viable user interface for an interactive processing mode. If interaction with a mechanical or phenomenal correspondent is part of the program design, technical knowledge of the interface protocols will be required. If interaction with a human user is part of the program design, human factors must be given central consideration in designing and implementing the user interface. Chapters 10 and 13 include discussions of various user interfaces and their features.

1.2.3.1  User Interface Design at Low- and Intermediate-Levels of Program Logic
1.2.3.1.1  Prompting
1.2.3.1.2  Form Fill-in (Screen/Window-based)
1.2.3.2  Interface Design at the High-Level of Program Logic
1.2.3.2.1  Command-Driven

Chapter 13 includes a discussion of command-driven program logic.

1.2.3.2.2  Function-key Driven
1.2.3.2.3  Menu-Driven

Chapter 10 includes a discussion of menu-driven program logic.