next up previous
Next: Data Abstraction Coupling ( Up: Coupling Previous: Efferent Coupling ( )


Coupling Factor ($ CF$ )

Works with all instances of a common meta-model, regardless if they where produced with the Java or the UML front-end. The respective call, create, field access, and type reference relations (Java) or association, message and type reference relations (UML) express the coupling (exclusive inheritance) between two classes. They are mapped to relations of type Invokes, Accesses, and ``Is Of Type", respectively, in the common meta model and further to type coupling in the view. By defining a view containing only classes and packages as elements, the metric definition can ignore methods and fields as part of its description, since the relations originating from them are lifted to the class element.
Description
Coupling Factor (CF) measures the coupling between classes excluding coupling due to inheritance. It is the ratio between the number of actually coupled pairs of classes in a scope (e.g., package) and the possible number of coupled pairs of classes. CF is primarily applicable to object-oriented systems.
Scope
Package
View
$ {V}^{CF} = ({G}^{CF}, {R}^{CF})$
  • Grammar $ {G}^{CF} = (\{\textrm{package}^{CF}, \textrm{class}^{CF}\}, {P}^{CF},\textrm{package}^{CF})$
  • Productions $ {P}^{CF}= \{\textrm{package}^{CF} ::= \textrm{class}^{CF\ *} \}$
  • Relations $ {R}^{CF}: \{\textrm{coupling}^{CF}\}$3.1
  • Mapping $ \alpha^{CF}$:
    $\displaystyle \alpha^{{CF}}(\textrm{Class})$ $\displaystyle \mapsto$ $\displaystyle \textrm{class}^{{CF}}$  
    $\displaystyle \alpha^{{CF}}(\textrm{Package})$ $\displaystyle \mapsto$ $\displaystyle \textrm{package}^{{CF}}$  
    $\displaystyle \alpha^{{CF}}(\textrm{Invokes})$ $\displaystyle \mapsto$ $\displaystyle \textrm{coupling}^{{CF}}$  
    $\displaystyle \alpha^{{CF}}(\textrm{Accesses})$ $\displaystyle \mapsto$ $\displaystyle \textrm{coupling}^{{CF}}$  
    $\displaystyle \alpha^{{CF}}(\textrm{IsOfType})$ $\displaystyle \mapsto$ $\displaystyle \textrm{coupling}^{{CF}}$  

Definition
The $ CF$value of a package $ p \in \textrm{package}^{CF}$is defined:
$\displaystyle Classes(p)$ $\displaystyle =$ $\displaystyle succ^*(p,\textrm{contains}^{CF}) \cap \textrm{class}^{\mathtt{CF}}$  
    $\displaystyle \textit{-\hspace{1pt}- set of classes contained in p}$  
$\displaystyle Coupled(p,c)$ $\displaystyle =$ $\displaystyle succ(c,\textrm{coupling}^{CF}) \cap Classes(p)$  
    $\displaystyle \textit{-\hspace{1pt}- set of classes contained in p,}$  
    $\displaystyle \textit{-\hspace{1pt}- which c is coupled to}$  
$\displaystyle CF(p)$ $\displaystyle =$ $\displaystyle \frac{\sum_{c \in Classes(p)} \vert~Coupled(p,c)~\vert} {0.5 * \vert~Classes(p)~\vert~^2-\vert~Classes(p)~\vert}$  

Scale
Absolute.
Domain
Integers in $ 0..\infty$.
Highly Related Software Quality Properties
 
Re-Usability 2.4
is negatively influenced by coupling.
Understandability for Reuse 2.4.1:
A art of a system that has a high (outgoing) efferent coupling may be highly inversely related to understandability, since it uses other parts of the system which need to be understood as well.

Understandability decreases with increasing CF.

Attractiveness 2.4.4:
Parts that have a high (outgoing) efferent coupling may be highly inversely related to attractiveness, since they are using other parts of the system which need to be understood as well, and represent dependencies.

Attractiveness decreases with increasing CF.

Maintainability 2.6
decreases with increasing CF.
Analyzability 2.6.1:
Parts that have a high (outgoing) efferent coupling may be highly inversely related to analyzability, since they are using other parts of the system which need to be analyzed as well.

Analyzability decreases with increasing CF.

Changeability 2.6.2:
Parts that have a high (outgoing) efferent coupling may be inversely related to changeability, since they are using other parts of the system which might need to be changed as well.

Changeability decreases with increasing CF.

Stability 2.6.3:
Parts showing a high (outgoing) efferent coupling may be inversely related to stability, since they are using other parts of the system, which are can affect them.

Stability decreases with increasing CF.

Testability 2.6.4:
Parts that have a high (outgoing) efferent coupling may be highly inversely related to testability, since they are using other parts of the system which increase the number of possible test paths.

Testability decreases with increasing CF.

Portability 2.7
decreases with increasing CF.
Adaptability 2.7.1:
Parts that have a high (outgoing) efferent coupling may be inversely related to adaptability, since they are using other parts of the system which might need to be adapted as well.

Adaptability decreases with increasing CF.

Related Software Quality Properties
 
Functionality 2.1
is both negatively and positively influenced by coupling.
Interoperability 2.1.3:
Parts that have a high (outgoing) efferent coupling may be directly related to interoperability, since they are using/interacting with other parts of the system.

Interoperability might increase with increasing CF.

Security 2.1.4:
Parts that have a high (outgoing) efferent coupling may be inversely related to security, since they can be affected by security problems in other parts of the system.

Security might decrease with increasing CF.

Reliability 2.2
might decrease with increasing CF.
Fault-tolerance 2.2.2:
Parts that have a high (outgoing) efferent coupling may be inversely related to fault-tolerance, since they can be affected by faults in other parts of the system.

Fault-Tolerance might decrease with increasing CF.

Recoverability 2.2.3:
Parts that have a high (outgoing) efferent coupling may be inversely related to recoverability, since their data is distributed in other parts of the system making their recovery difficult.

Recoverability might decrease with increasing CF.

Re-Usability 2.4
might decrease with increasing CF.
Learnability for Reuse 2.4.2:
Parts that have a high (outgoing) efferent coupling may be inversely related to learnability, since they are using other parts of the system which need to be understood as well.

Learnability might decrease with increasing CF.

Operability for Reuse - Programmability 2.4.3:
Parts that have a high (outgoing) efferent coupling may be inversely related to learnability, since they are using other parts of the system, which represent dependencies.

Programmability might decrease with increasing CF.

Efficiency 2.5
might decrease with increasing CF.
Time Behavior 2.5.1:
Parts that have a high (outgoing) efferent coupling may be inversely related to time behavior, since they are using other parts of the system, thus execution during test or operation does not stay local, but might involve huge parts of the system.

Time behavior might get worse with increasing CF.

Resource Utilization 2.5.2:
Parts that have a high (outgoing) efferent coupling may be inversely related to resource utilization, since they are using other parts of the system, thus execution during test or operation does not stay local, but might involve huge parts of the system.

Resource utilization might get worse with increasing CF.

References
 
  • CF is discussed in [8,2,17,9],
  • it is implemented in the VizzAnalyzer Metrics Suite.
Since
Compendium 1.0

next up previous
Next: Data Abstraction Coupling ( Up: Coupling Previous: Efferent Coupling ( )
Copyright © 2008-2009, ARiSA AB. Phone: +46-(0)470 70 8495 Email: info@arisa.se Valid CSS! Valid XHTML 1.0 Transitional