top-down strategy
the top-down strategy uses the modular approach to develop the design of a system. it is called so because it starts from the top or the highest-level module and moves towards the lowest level modules.
in this technique, the highest-level module or main module for developing the software is identified. the main module is divided into several smaller and simpler submodules or segments based on the task performed by each module. then, each submodule is further subdivided into several submodules of next lower level. this process of dividing each module into several submodules continues until the lowest level modules, which cannot be further subdivided, are not identified.

bottom-up strategy
bottom-up strategy follows the modular approach to develop the design of the system. it is called so because it starts from the bottom or the most basic level modules and moves towards the highest level modules.
in this technique,
the modules at the most basic or the lowest level are identified.
these modules are then grouped together based on the function performed by each module to form the next higher-level modules.
then, these modules are further combined to form the next higher-level modules.
this process of grouping several simpler modules to form higher level modules continues until the main module of system development process is achieved.

structured design
structured design is a data-flow based methodology that helps in identifying the input and output of the developing system. the main objective of structured design is to minimize the complexity and increase the modularity of a program. structured design also helps in describing the functional aspects of the system.
in structured designing, the system specifications act as a basis for graphically representing the flow of data and sequence of processes involved in a software development with the help of dfds. after developing the dfds for the software system, the next step is to develop the structure chart.

modularization
structured design partitions the program into small and independent modules. these are organized in top down manner with the details shown in bottom.
thus, structured design uses an approach called modularization or decomposition to minimize the complexity and to manage the problem by subdividing it into smaller segments.
advantages
- critical interfaces are tested first.
- it provide abstraction.
- it allows multiple programmers to work simultaneously.
- it allows code reuse.
- it provides control and improves morale.
- it makes identifying structure easier.
structured charts
structured charts are a recommended tool for designing a modular, top down systems which define the various modules of system development and the relationship between each module. it shows the system module and their relationship between them.
it consists of diagram consisting of rectangular boxes that represent the modules, connecting arrows, or lines.
control module − it is a higher-level module that directs lower-level modules, called subordinate modules.
library module − it is a reusable module and can be invoked from more than one point in the chart.

we have two different approaches to design a structured chart −
transform-centered structured charts − they are used when all the transactions follow same path.
transaction–centered structured charts − they are used when all the transactions do not follow the same path.
objectives of using structure flowcharts
to encourage a top-down design.
to support the concept of modules and identify the appropriate modules.
to show the size and complexity of the system.
to identify the number of readily identifiable functions and modules within each function.
to depict whether each identifiable function is a manageable entity or should be broken down into smaller components.
factors affecting system complexity
to develop good quality of system software, it is necessary to develop a good design. therefore, the main focus on while developing the design of the system is the quality of the software design. a good quality software design is the one, which minimizes the complexity and cost expenditure in software development.
the two important concepts related to the system development that help in determining the complexity of a system are coupling and cohesion.
coupling
coupling is the measure of the independence of components. it defines the degree of dependency of each module of system development on the other. in practice, this means the stronger the coupling between the modules in a system, the more difficult it is to implement and maintain the system.
each module should have simple, clean interface with other modules, and that the minimum number of data elements should be shared between modules.
high coupling
these type of systems have interconnections with program units dependent on each other. changes to one subsystem leads to high impact on the other subsystem.

low coupling
these type of systems are made up of components which are independent or almost independent. a change in one subsystem does not affect any other subsystem.

coupling measures
content coupling − when one component actually modifies another,then the modified component is completely dependent on modifying one.
common coupling − when amount of coupling is reduced somewhat by organizing system design so that data are accessible from a common data store.
control coupling − when one component passes parameters to control the activity of another component.
stamp coupling − when data structures is used to pass information from one component to another.
data coupling − when only data is passed then components are connected by this coupling.
cohesion
cohesion is the measure of closeness of the relationship between its components. it defines the amount of dependency of the components of a module on one another. in practice, this means the systems designer must ensure that −
they do not split essential processes into fragmented modules.
they do not gather together unrelated processes represented as processes on the dfd into meaningless modules.
the best modules are those that are functionally cohesive. the worst modules are those that are coincidentally cohesive.
the worst degree of cohesion
coincidental cohesion is found in a component whose parts are unrelated to another.
logical cohesion − it is where several logically related functions or data elements are placed in same component.
temporal cohesion − it is when a component that is used to initialize a system or set variables performs several functions in sequence, but the functions are related by timing involved.
procedurally cohesion − it is when functions are grouped together in a component just to ensure this order.
sequential cohesion − it is when the output from one part of a component is the input to the next part of it.