Coupling and cohesion

Sutha31 8,829 views 27 slides Sep 04, 2019
Slide 1
Slide 1 of 27
Slide 1
1
Slide 2
2
Slide 3
3
Slide 4
4
Slide 5
5
Slide 6
6
Slide 7
7
Slide 8
8
Slide 9
9
Slide 10
10
Slide 11
11
Slide 12
12
Slide 13
13
Slide 14
14
Slide 15
15
Slide 16
16
Slide 17
17
Slide 18
18
Slide 19
19
Slide 20
20
Slide 21
21
Slide 22
22
Slide 23
23
Slide 24
24
Slide 25
25
Slide 26
26
Slide 27
27

About This Presentation

When a software program is modularized, there are measures by which the quality of a design of modules and their interaction among them can be measured. These measures are called coupling and cohesion.


Slide Content

V.Sutha Jebakumari
AP/CSE
Kamaraj College of Engineering and Technology
September 4, 2019

Softwaredesignisaprocesstotransformuser
requirementsintosomesuitableform,whichhelps
theprogrammer insoftwarecodingand
implementation.
Theactivitythatleadsfromrequirementsto
implementation.

Softwaredesignyieldsthreelevelsofresults:
ArchitecturalDesign-Thearchitecturaldesignisthe
highestabstractversionofthesystem.Itidentifies
thesoftwareasasystemwithmanycomponents
interactingwitheachother.Atthislevel,the
designersgettheideaofproposedsolutiondomain.
High-levelDesign-High-leveldesignfocuseson
howthesystemalongwithallofitscomponentscan
beimplementedinformsofmodules.Itrecognizes
modularstructureofeachsub-systemandtheir
relationandinteractionamongeachother.
DetailedDesign-Detaileddesigndealswiththe
implementationpartofwhatisseenasasystemand
itssub-systemsintheprevioustwodesigns.Itis
moredetailedtowardsmodules andtheir
implementations.

Modularizationisatechniquetodividea
softwaresystemintomultiplediscreteand
independentmodules,whichareexpectedto
becapableofcarryingouttask(s)
independently.Designerstendtodesign
modulessuchthattheycanbeexecuted
and/or compiled separately and
independently.

Smallercomponentsareeasierto
maintain
Programcanbedividedbasedon
functionalaspects
Desiredlevelofabstractioncanbe
broughtintheprogram
Componentswithhighcohesioncan
bere-usedagain
Concurrentexecutioncanbemade
possible

Whenasoftwareprogramismodularized,
itstasksaredividedintoseveralmodules
basedonsomecharacteristics.Thereare
measuresbywhichthequalityofadesign
ofmodulesandtheirinteractionamong
themcanbemeasured.Thesemeasures
arecalledcouplingandcohesion.

Coupling –concerns relationships between
modules
Cohesion –concerns relationships within a
module
• Goal: To have loosely coupled modules with
high internal cohesion

Couplingisdefinedastheextenttowhicha
system,subsystem,methodormodule
connectswith(dependson)others.Inother
words,itmeasuresinterdependency.The
lowerthecoupling,thebettertheprogram.
Couplingincreasesasthenumberofcalls
betweenmodulesincreaseortheamountof
shareddataislarge

There is no direct coupling between M1 and
M2. Modules are subordinates to different
modules. Therefore, no direct coupling.

Whendataofonemoduleispassedto
anothermodule,thisiscalleddatacoupling.
Example-customerbillingsystem.

Twomodulesarestampcoupledifthey
communicateusingcompositedataitems
suchasstructure,objects,etc.Whenthe
modulepassesnon-globaldatastructureor
entirestructuretoanothermodule,theyare
saidtobestampcoupled.Forexample,
passingstructurevariableinCorobjectin
C++languagetoamodule.

Control Coupling exists
amongtwomodulesifdata
fromonemoduleisusedto
directthestructureof
instructionexecution in
another.

ExternalCouplingariseswhentwo
modulesshareanexternallyimposed
data format, communication
protocols,ordeviceinterface.Thisis
relatedtocommunicationtoexternal
toolsanddevices.
Ex-protocol,externalfile,device
format,etc.

Two modules are common coupled if they
share information through some global data
items.

Content Coupling exists among two modules
if they share code, e.g., a branch from one
module into another module.

Cohesiondefinestothedegreeto
whichtheelementsofamodule
belongtogether.Thus,cohesion
measuresthestrengthofrelationships
betweenpiecesoffunctionalitywithin
agivenmodule.Forexample,in
highlycohesivesystems,functionality
isstronglyrelated.Agoodsoftware
designwillhavehighcohesion.

Functional Cohesion is said to exist if the
different elements of a module, cooperate to
achieve a single function.

A module is said to possess sequential
cohesion if the element of a module form the
components of the sequence, where the
output from one component of the sequence
is input to the next.

A module is said to have communicational
cohesion, if all tasks of the module refer to or
update the same data structure, e.g., the set
of functions defined on an array or a stack.

A module is said to be procedural cohesion if
the set of purpose of the module are all parts
of a procedure in which particular sequence
of steps has to be carried out for achieving a
goal, e.g., the algorithm for decoding a
message.

When a module includes functions that are
associated by the fact that all the methods
must be executed in the same time, the
module is said to exhibit temporal cohesion.

A module is said to be logically cohesive if all
the elements of the module perform a similar
operation. For example Error handling, data
input and data output, etc.

A module is said to have coincidental
cohesion if it performs a set of tasks that are
associated with each other very loosely, if at
all.

S.No Coupling Cohesion
1
Cohesion is the concept of intra module.Coupling is the concept of inter module.
2
Cohesion represents the relationship within
module.
Coupling represents the relationships
between modules.
3
Increasing in cohesion is good for
software.
Increasing in coupling is avoided for
software.
4
Cohesion represents the functional
strength of modules.
Coupling represents the independence
among modules.
5
High cohesion gives the best software.Loose coupling gives the best software.
6
In cohesion, module focuses on the single
thing.
In coupling, modules are connected to
the other modules.