Functional flow block diagram

Last updated
Figure 1: Functional flow block diagram format. Functional Flow Block Diagram Format.jpg
Figure 1: Functional flow block diagram format.

A functional flow block diagram (FFBD) is a multi-tier, time-sequenced, step-by-step flow diagram of a system's functional flow. [2] The term "functional" in this context is different from its use in functional programming or in mathematics, where pairing "functional" with "flow" would be ambiguous. Here, "functional flow" pertains to the sequencing of operations, with "flow" arrows expressing dependence on the success of prior operations. FFBDs may also express input and output data dependencies between functional blocks, as shown in figures below, but FFBDs primarily focus on sequencing.

Contents

The FFBD notation was developed in the 1950s, and is widely used in classical systems engineering. FFBDs are one of the classic business process modeling methodologies, along with flow charts, data flow diagrams, control flow diagrams, Gantt charts, PERT diagrams, and IDEF. [3]

FFBDs are also referred to as functional flow diagrams, functional block diagrams, and functional flows. [4]

History

The first structured method for documenting process flow, the flow process chart, was introduced by Frank Gilbreth to members of American Society of Mechanical Engineers (ASME) in 1921 as the presentation “Process Charts—First Steps in Finding the One Best Way”. [5] Gilbreth's tools quickly found their way into industrial engineering curricula.

In the early 1930s, an industrial engineer, Allan H. Mogensen began training business people in the use of some of the tools of industrial engineering at his Work Simplification Conferences in Lake Placid, New York. A 1944 graduate of Mogensen's class, Art Spinanger, took the tools back to Procter and Gamble where he developed their Deliberate Methods Change Program. Another 1944 graduate, Ben S. Graham, Director of Formcraft Engineering at Standard Register Industrial, adapted the flow process chart to information processing with his development of the multi-flow process chart to display multiple documents and their relationships. In 1947, ASME adopted a symbol set as the ASME Standard for Operation and Flow Process Charts, derived from Gilbreth's original work. [5]

The modern Functional Flow Block Diagram was developed by TRW Incorporated, a defense-related business, in the 1950s. [6] In the 1960s it was exploited by NASA to visualize the time sequence of events in space systems and flight missions. [7] FFBDs became widely used in classical systems engineering to show the order of execution of system functions. [3]

Development of functional flow block diagrams

Figure 2: Development of functional flow block diagrams Development of Functional Flow Block Diagrams.jpg
Figure 2: Development of functional flow block diagrams

FFBDs can be developed in a series of levels. FFBDs show the same tasks identified through functional decomposition and display them in their logical, sequential relationship. For example, the entire flight mission of a spacecraft can be defined in a top level FFBD, as shown in Figure 2. Each block in the first level diagram can then be expanded to a series of functions, as shown in the second level diagram for "perform mission operations." Note that the diagram shows both input (transfer to operational orbit) and output (transfer to space transportation system orbit), thus initiating the interface identification and control process. Each block in the second level diagram can be progressively developed into a series of functions, as shown in the third level diagram on Figure 2. [8]

These diagrams are used both to develop requirements and to identify profitable trade studies. For example, does the spacecraft antenna acquire the tracking and data relay satellite (TDRS) only when the payload data are to be transmitted, or does it track TDRS continually to allow for the reception of emergency commands or transmission of emergency data? The FFBD also incorporates alternate and contingency operations, which improve the probability of mission success. The flow diagram provides an understanding of total operation of the system, serves as a basis for development of operational and contingency procedures, and pinpoints areas where changes in operational procedures could simplify the overall system operation. In certain cases, alternate FFBDs may be used to represent various means of satisfying a particular function until data are acquired, which permits selection among the alternatives. [8]

Building blocks

Key attributes

An overview of the key FFBD attributes: [1]

Graphical explanation of a "function block" used in these diagrams. Flow is from left to right. Function block.jpg
Graphical explanation of a "function block" used in these diagrams. Flow is from left to right.

Function symbolism

A function shall be represented by a rectangle containing the title of the function (an action verb followed by a noun phrase) and its unique decimal delimited number. A horizontal line shall separate this number and the title, as shown in see Figure 3 above. The figure also depicts how to represent a reference function, which provides context within a specific FFBD. See Figure 9 for an example regarding use of a reference function. [9]

Figure 3. Function symbol 3 Function Symbol.jpg
Figure 3. Function symbol
Figure 4. Directed lines 4 Directed Lines.jpg
Figure 4. Directed lines

Directed lines

A line with a single arrowhead shall depict functional flow from left to right, see Figure 4. [9]

Logic symbols

The following basic logic symbols shall be used. [9]

Figure 5. "AND" symbol 5 AND Symbol.jpg
Figure 5. "AND" symbol
Figure 6. "Exclusive OR" Symbol 6 Exclusive OR Symbol.jpg
Figure 6. "Exclusive OR" Symbol
Figure 7. "Inclusive OR" logic 7 Inclusive OR Logic.png
Figure 7. "Inclusive OR" logic

Contextual and administrative data

Each FFBD shall contain the following contextual and administrative data: [9]

Figure 8 and Figure 9 present the data in an FFBD. Figure 9 is a decomposition of the function F2 contained in Figure 8 and illustrates the context between functions at different levels of the model.

Figure 8. FFBD Function 0 illustration 8 FFBD Function 0 Illustration.jpg
Figure 8. FFBD Function 0 illustration
Figure 9. FFBD Function 2 illustration 9 FFBD Function 2 Illustration.jpg
Figure 9. FFBD Function 2 illustration

See also

Notes

  1. 1 2 Systems Engineering Fundamentals. Archived 2011-07-28 at the Wayback Machine Defense Acquisition University Press, 2001
  2. The first version of this article is completely based on the NAS SYSTEM ENGINEERING MANUAL SECTION 4.4 VERSION 3.1 06/06/06.
  3. 1 2 Thomas Dufresne & James Martin (2003). "Process Modeling for E-Business" Archived December 20, 2006, at the Wayback Machine . INFS 770 Methods for Information Systems Engineering: Knowledge Management and E-Business. Spring 2003
  4. 1 2 Task Analysis Tools Used Throughout Development. FAA 2008. Retrieved 25 Sept 2008.
  5. 1 2 Ben B. Graham (2004). "Detail Process Charting: Speaking the Language of Process". p.1
  6. Tim Weilkiens (2008). Systems Engineering with SysML/UML: Modeling, Analysis, Design. Page 257.
  7. Harold Chestnut (1967). Systems Engineering Methods. Page 254.
  8. 1 2 3 NASA (2007). NASA Systems Engineering Handbook December 2007. p.53.
  9. 1 2 3 4 FAA (2006). NAS SYSTEM ENGINEERING MANUAL SECTION 4.4 VERSION 3.1 06/06/06.

Further reading

Related Research Articles

<span class="mw-page-title-main">Logic gate</span> Device performing a Boolean function

A logic gate is a device that performs a Boolean function, a logical operation performed on one or more binary inputs that produces a single binary output. Depending on the context, the term may refer to an ideal logic gate, one that has, for instance, zero rise time and unlimited fan-out, or it may refer to a non-ideal physical device.

<span class="mw-page-title-main">Programmable logic controller</span> Programmable digital computer used to control machinery

A programmable logic controller (PLC) or programmable controller is an industrial computer that has been ruggedized and adapted for the control of manufacturing processes, such as assembly lines, machines, robotic devices, or any activity that requires high reliability, ease of programming, and process fault diagnosis.

<span class="mw-page-title-main">State diagram</span> Diagram of behavior of finite state systems

A state diagram is a type of diagram used in computer science and related fields to describe the behavior of systems. State diagrams require that the system described is composed of a finite number of states; sometimes, this is indeed the case, while at other times this is a reasonable abstraction. Many forms of state diagrams exist, which differ slightly and have different semantics.

<span class="mw-page-title-main">System context diagram</span> Engineering diagram displaying high level system-environment relationships

A system context diagram in engineering is a diagram that defines the boundary between the system, or part of a system, and its environment, showing the entities that interact with it. This diagram is a high level view of a system. It is similar to a block diagram.

<span class="mw-page-title-main">Flowchart</span> Diagram that represents a workflow or process

A flowchart is a type of diagram that represents a workflow or process. A flowchart can also be defined as a diagrammatic representation of an algorithm, a step-by-step approach to solving a task.

In computer programming, dataflow programming is a programming paradigm that models a program as a directed graph of the data flowing between operations, thus implementing dataflow principles and architecture. Dataflow programming languages share some features of functional languages, and were generally developed in order to bring some functional concepts to a language more suitable for numeric processing. Some authors use the term datastream instead of dataflow to avoid confusion with dataflow computing or dataflow architecture, based on an indeterministic machine paradigm. Dataflow programming was pioneered by Jack Dennis and his graduate students at MIT in the 1960s.

<span class="mw-page-title-main">Block diagram</span> Graphical system analysis method

A block diagram is a diagram of a system in which the principal parts or functions are represented by blocks connected by lines that show the relationships of the blocks. They are heavily used in engineering in hardware design, electronic design, software design, and process flow diagrams.

A data-flow diagram is a way of representing a flow of data through a process or a system. The DFD also provides information about the outputs and inputs of each entity and the process itself. A data-flow diagram has no control flowthere are no decision rules and no loops. Specific operations based on the data can be represented by a flowchart.

<span class="mw-page-title-main">Event-driven process chain</span>

An event-driven process chain (EPC) is a type of flow chart for business process modeling. EPC can be used to configure enterprise resource planning execution, and for business process improvement. It can be used to control an autonomous workflow instance in work sharing.

<span class="mw-page-title-main">Functional block diagram</span>

A functional block diagram, in systems engineering and software engineering, is a block diagram that describes the functions and interrelationships of a system.

<span class="mw-page-title-main">IDEF0</span>

IDEF0, a compound acronym, is a function modeling methodology for describing manufacturing functions, which offers a functional modeling language for the analysis, development, reengineering and integration of information systems, business processes or software engineering analysis.

Business process mapping refers to activities involved in defining what a business entity does, who is responsible, to what standard a business process should be completed, and how the success of a business process can be determined.

In computer programming, flow-based programming (FBP) is a programming paradigm that defines applications as networks of black box processes, which exchange data across predefined connections by message passing, where the connections are specified externally to the processes. These black box processes can be reconnected endlessly to form different applications without having to be changed internally. FBP is thus naturally component-oriented.

Logic optimization is a process of finding an equivalent representation of the specified logic circuit under one or more specified constraints. This process is a part of a logic synthesis applied in digital electronics and integrated circuit design.

<span class="mw-page-title-main">Structured analysis</span>

In software engineering, structured analysis (SA) and structured design (SD) are methods for analyzing business requirements and developing specifications for converting practices into computer programs, hardware configurations, and related manual procedures.

A signal-flow graph or signal-flowgraph (SFG), invented by Claude Shannon, but often called a Mason graph after Samuel Jefferson Mason who coined the term, is a specialized flow graph, a directed graph in which nodes represent system variables, and branches represent functional connections between pairs of nodes. Thus, signal-flow graph theory builds on that of directed graphs, which includes as well that of oriented graphs. This mathematical theory of digraphs exists, of course, quite apart from its applications.

<span class="mw-page-title-main">Function model</span>

In systems engineering, software engineering, and computer science, a function model or functional model is a structured representation of the functions within the modeled system or subject area.

<span class="mw-page-title-main">N2 chart</span>

The N2 chart or N2 diagram is a chart or diagram in the shape of a matrix, representing functional or physical interfaces between system elements. It is used to systematically identify, define, tabulate, design, and analyze functional and physical interfaces. It applies to system interfaces and hardware and/or software interfaces.

<span class="mw-page-title-main">Control-flow diagram</span> Business process modeling tool

A control-flow diagram (CFD) is a diagram to describe the control flow of a business process, process or review.

<span class="mw-page-title-main">Flow process chart</span> Industrial engineering graphical representation

The flow process chart is a graphical and symbolic representation of the activities performed on the work piece during the operation in industrial engineering.