The scheme of the algorithm expressing EEM is drawn in
Figure 1. The structure of the algorithm is iterative, so the same sequence of steps will perpetuate until one of the quitting conditions are fulfilled. The conditions that allow quitting the cycle are to be checked after the fourth step of the iteration. However, the cycle is doomed to be finished, and this point is considered in
Section 4.5, where the convergence of the algorithm is addressed.
2.1. Data Description
The set of variables used in the algorithm are denoted as follows:
is the iteration index, where Q is the total number of the iterations, which is written as an upper index in variables.
is the initial set of alternatives, or decision options.
I denotes the total number of alternatives to be compared.
is the set of alternatives at the qth iteration. During the run of the algorithm, the number of alternatives in subsequent iterations is getting reduced, and the alternatives are renumbered.
marks the number of alternatives at the qth iteration.
designates the number of attributes at the qth iteration. In subsequent iterations, the number of attributes cannot increase and tends to go down.
l denotes the indices of the attributes against which the decision options are compared, .
is the preference matrix at the qth iteration whose elements are estimates of the ith alternative by the lth attribute. Since the number of alternatives and attributes tend to reduce as the iterations go on, the size of this matrix will also go down.
stands for the elements of comparison matrices for alternative pairs in the qth iteration. Each pair of alternatives being compared corresponds to a unique row of the matrix.
designates the sum of matrix elements over all the attributes, i.e., the sum of the elements in the row indexed by .
The usage of triple indexing for elements requires additional clarification. Thus, the first two indices form a combined row index, while the the third l is the column one. The pairs of alternatives indexing do not repeat, and any of the pairs cannot contain two identical alternatives. Each of the attributes corresponds to a column of the matrix. Thus, each alternative pair, i.e., the row of the matrix, can be marked by compound index . Since neither of the alternative pairs repeats and none of them contains two identical alternatives, the second index k will run from to for each alternative marked with index i. Therefore, the total number of rows in the matrix turns out to be equal to the sum of arithmetic progression: .
2.2. Basic Concepts
There are two concepts which are important since they are intensively used in the algorithm.
The first concept is dominance which allows for establishing a sort of partial order between the compared alternatives. Basically, the alternative denoted by
i is called to be
weakly dominating over the alternative denoted by
k, i.e.,
, if
is completely not worse than
. Formally, it means that for all attributes
l the estimates
related to the
ith alternative are not worse than the estimates
related to the
kth alternative:
where the usage of the “greater or equal” sign should be avoided since the bigger value taken on by the attribute does not always imply that it is more preferable. Typically, expenses or ranks may set a good example here: the smaller their values are, the better the related alternative is.
The alternative denoted by i is deemed to be strictly dominating over the alternative denoted by k: , if
, i.e., is weakly dominating over the alternative denoted by ,
AND
there is at least one attribute such that the ith alternative is better than the kth alternative measured with it.
Conversely, in the relations where and , the kth alternative can be called dominated, respectfully weakly dominated or strictly dominated.
The special cases take place in the pair under comparison where the ith alternative turns out to be weakly dominating over the kth but not strictly dominating. In formal words, holds when does not. This literally happens if the estimates of both alternatives by all attributes are equal. Then, it is up to the DM to decide which of the alternatives has to be called dominating, and which will be considered as dominated.
The second concept is the insignificance of attributes. The attribute indexed by l is called insignificant if estimates have the same numerical value over all the alternatives being compared by this attribute. Upon transition to the comparison matrix for alternative pairs, the lth attribute is marked as insignificant if the lth column of matrix is fully populated with 1 as it is shown in the algorithm description below.
2.3. The Iteration of the EEM Algorithm
The input data available at the qth iteration are the following:
The set of alternatives at the qth iteration: ;
The set of attributes at the qth iteration ;
The preference matrix at the qth iteration: is made of the value of preference scalars against the lth attribute for alternative .
Each iteration of the algorithm consists of nine steps. The operations performed in each step is thoroughly described below accompanied with a numerical example for a better clarification.
2.3.1. Step 1: Computing the Comparison Matrix
At the first step, the comparison matrix is built for alternative pairs compared by each of the attributes in accordance with the rule:
As an example, assume that
,
,
. Then, for some preference matrix
, the corresponding comparison matrix can be evaluated:
Each row of matrix corresponds to a pair of alternatives being compared , which are given to the right for reference. The examples at all other steps of the algorithm will be given for these initial data.
2.3.2. Step 2: Search for Insignificant Attributes
As long as the
lth attribute can be recognized as insignificant, the estimates
for all the alternatives have the same numerical value. Upon the transition to the comparison matrix made for alternative pairs, the
lth attribute is deemed to be insignificant if the
lth column of the matrix contains all unity scalar elements. The conditions can be rewritten in a formal manner:
In the example started above, the attribute with turns out insignificant, since the 4th column of matrix consists of ones only.
2.3.3. Step 3: Search for Dominated Alternatives
The search for dominated alternatives should be carried out among all pairs
available at the
qth iteration. For each of the pairs, the sum of the elements in the corresponding row of the comparison matrix should be computed:
This sum basically means the number of attributes, by which the estimates of both alternatives in the current pair are equal. Hereafter, there are three possible cases:
Case A happens if , i.e., the sum of elements in the row of matrix corresponding to the pair of alternatives in the qth iteration is equal to the number of attributes in the same iteration. This is the case where the weak dominance takes place but not the strict dominance. The DM should make a decision about which of the alternatives is to be kept, and which is declared dominated. The DM may make such a decision straightforwardly or with taking into consideration additional factors, which have not been introduced into the task yet.
Case B happens if , i.e., the sum of elements in the row of matrix corresponding to the pair of alternatives in the qth iteration is less than the number of attributes by 1. Consequently, the estimate of alternatives is equal among all attributes except only one attribute denoted with . In formal words, . The DM must make a decision, which of the estimates by attribute is preferable: or . If estimate is considered preferable, i.e., , then alternative should be declared as strictly dominating over alternative , . Otherwise, alternative would be declared as strictly dominating over alternative .
Case C is the situation where neither Case A nor Case B take place. Then, there are no dominated alternatives which have been identified in the step.
It is worth noting that Case C does not imply that there is no dominated alternatives in the set of the alternatives. However, the searching procedure relying on the difference in a single attribute cannot identify it immediately. The more details about this point are discussed in
Section 4.6.
In the illustrating example started above, the values of
can be found for each pair of alternatives as a sum of all elements of the corresponding rows of matrix
, as it is shown in
Table 1.
In the given example, where , since there are five attributes in qth iteration, the indices of the sought alternative pair are as . In accordance with the conditions, case B takes place, since , i.e., alternatives and are equal among all the attributes but . The estimate of alternative by this attribute is , while the estimate of alternative by the same attribute is . The DM must make a decision, which one of the estimates by attribute is preferable for him or her: 7 or 9. As an example, let us assume that this attribute describes the amount of expenses. Then, estimate would be preferable. Therefore, alternative would be declared as a dominating one while alternative is to be called dominated.
2.3.4. Step 4: Shrinkage of the Preference Matrix
At this step, all insignificant attributes and dominated alternatives discovered in the previous step (if any) are excluded from consideration:
The dominated alternatives, which are related to both cases A and B in the previous step, have to be excluded from vector . The list of remaining alternatives are renumbered to restore the consequent indexing of the alternatives;
The rows corresponding to the dominated alternatives and the columns corresponding to insignificant attributes are deleted from matrix ;
The rows in the matrix corresponding to the pairs of alternatives where at least one of the alternatives is being dominated have to be excluded from matrix . The columns corresponding to insignificant attributes are also excluded;
Variables and take on the new values equal to the number of, respectively, alternatives and attributes remaining for further consideration.
Then, the branching in the run of the algorithm has to be carried out.
If , then the execution proceeds with step 5;
If , then it proceeds with step 6;
Otherwise, i.e., , it goes to step 7.
Regarding the example started above, attribute
was identified as insignificant in step 2, while, in step 3, alternative
was identified as dominated in step 3. Therefore, alternative
is being excluded from vector
. The remaining alternatives are renumbered so that the vector takes the following form:
. The transformation made to matrices
and
can be illustrated as follows:
Row 4 has been excluded from matrix
, since it corresponds to an alternative
, and column 4 has also been excluded, since it corresponds to some attribute
. The changes in matrix
are more complicated, since each row corresponds to a pair of alternatives. Thus, all the rows corresponding to the pairs of alternatives, where at least one of the alternatives is a dominated one, are excluded. Since alternative
is dominated, the rows indexed by the following pairs have to be excluded:
,
,
. In addition, column 4 is excluded because it describes the attribute found as insignificant. The reduced matrices take on the following values:
Variables and take on values equal to the new number of alternatives and attributes, respectively: and .
2.3.5. Step 5: The Single Alternative Found
If , there is only one alternative left in Step 4. Consequently, is the effective alternative.
The algorithm terminates here.
2.3.6. Step 6: The Single Attribute Remains
If , there only one attribute left in Step 4. Therefore, the DM must choose the alternative with the preferable estimate by the remaining attribute, i.e., to select such alternative that the estimate related to the ith alternative would be preferable among all. If more than one alternative has the same preferable estimates, then the algorithm output could produce the set made of these alternatives as its output.
The algorithm terminates afterwards.
2.3.7. Step 7: Search for the Alternative Suitable for Equivalent Exchange
The goal of this step is the selection of the pair of alternatives indexed as
and one attribute
, for which an equivalent exchange is the most suitable to be conducted. In order to perform this, the elements
of
taking on zero value are considered: Then, the pair of alternatives for which the value:
reaches the minimum that has to be chosen. Among all elements of matrix
that correspond to such pair of alternatives
, it is required to find such zero element
that will satisfy the following condition:
Due to the fact that the first term of the sum is constant, this condition may be replaced with the following:
It is worth noting that, while simply indicates the number of zero elements in the row indexed by , the left-hand side of the expression (9) implicitly expresses the number of zero elements in the column indexed as .
In those cases where more than one element of the matrix that meet this condition has been found, then the DM will have their own right to choose a pair among all identified.
In the continuing example, the elements of the comparison matrix meeting this requirement are underlined:
It is important to notice that each of the underlined elements has two zeros in its column. However, each of the other (not underlined) zero elements has 3 zeros in its column. The DM must choose any of the underlined elements. If they choose element , for instance, it will be the closest element to the upper left corner of the matrix since it is in its row 1 and column 2.
2.3.8. Step 8: Choice of an Exchangeable Attribute
In this step, the DM is set to select such attribute , which the DM considers to be an appropriate candidate for further comparison made in the pair of alternatives chosen in the previous step. Basically, attribute should be chosen to meet two criteria:
Attribute cannot be the same as attribute , selected in Step 7;
The element of the comparison matrix that corresponds to this attribute and the pair selected in step 7 must be zero: .
Provided the previous step are executed correctly, this attribute always exists because otherwise one of the alternatives would be dominated, which means that it should have been deleted in Step 4.
In the previous step of the continuing example, element was selected. Therefore, cannot be chosen equal to : , so the element in the first row and column of matrix must be zero. Therefore, both attributes with indices 1 and 4 are suitable. However, this becomes the DM’s personal decision: which of them will be chosen as the attribute ready for exchange . This choice should be made assuming that the DM will be obliged to compare simultaneous changes made in both of the estimates defined by attributes and in the next step of the algorithm. In the example under consideration, let be assumed.
2.3.9. Step 9: Performing the Equivalent Exchange
In this step, preference matrix
is formed for the next
th iteration of the algorithm. Initially, the preference matrix of the current iteration is copied into the matrix intended for the next iteration
; then, the modification is carried out. Primarily, the DM assigns the new values for the element in
, such that the change in the estimate by attribute
from
to
would be considered as equivalent to the change in the estimate by attribute
from
to
. Since the first exchange can deliberately be assumed as
, the new value of element
should be assigned by the DM. Performing these actions, the decrease in the value of
should be ensured in the next step, since the minimum is taken for all suitable pairs of alternatives. It follows from the fact that the number of attributes, by which the alternatives index by
differ, will inevitably be reduced by 1 after the iteration has complete.
Then, here comes the transition to the next iteration, marked as , where the whole procedure is to be repeated starting in Step 1.
Regarding the continuing example, the final step of the current iteration engages the preference matrix (7) obtained in Step 4, triplet chosen in Step 7 and attribute selected in Step 8.
In order to make the exchange more convenient and simpler for understanding, let us assume that attribute means “implementation period in weeks”, and attribute means “cost in thousand euros”. The DM considers it to be reasonable to make the following decision:
“Let us suppose that the cost of implementation changes from 220 to 200 thousand euros. By how many days should the implementation period be increased from the initial 20 weeks, so that both changes would be equivalent from the DM’s own perspective?”
For example, the DM may reason as follows:
“To reduce the cost of implementation by 20 thousand euros, we can give 3 extra weeks for system implementation”.
Accordingly, the DM will assign the value
. After the equivalent exchange has been completed, the preference matrix is formed for the next iteration:
where the just changed elements are underlined.
This matrix (13) will be used in the next iteration of the algorithm. However, even at the current step, it is rather easy to deduce that attribute 2 is bound to be claimed insignificant since the estimates of all the alternatives by this attribute have become equal to the similar value, namely 200.
2.4. The EDSS Description
A formal description of EEM algorithm was developed, which further allowed rewriting it in the terms ready to be implemented as an extending module of the Expert Decision Support System (EDSS) [
29]. This information system primarily focuses on automation of the procedures performing analysis of the problem situation where the selection of the effective decision among available ones is required. The specific features of the system are briefly highlighted below.
The EDSS was basically designed for the facilitation of the overall process of making decision. Firstly, the system helps its user, i.e., the DM, to choose a suitable method for particular problem among all available, depending on the amount of the problem related data the DM holds or even personal preferences. Secondly, the system provides the DM with the interactive graphical user interface. Finally, the system conducts all the computations required for running the chosen method.
The knowledge base of the EDSS contains different methods implemented in the form of executable modules. The range of the methods varies from those which are completely based on formal foundation, e.g., optimal solution techniques, to those which rely mostly on the decisions the experts bring in during their sessions. The current version of the system virtually implements nearly 50 particular instances of such mathematical methods and models, which makes it stand out from most of the other DSS, which usually realize a single decision-making method or a family of similar methods. Among the methods implemented in the system so far, there are also groups of decision-making methods performing under uncertainty and risk, which can be introduced to the simulation while solving a decision-making problem.
As the essential part of the EDSS, its knowledge base additionally contains a set of rules for selection among appropriate models and decision-making methods. The list of suitable methods become available as soon as all elements constituting the task being solved are collected together and properly brought in to the system. The knowledge base assists in the main session, performing the search for the most suitable decision-making methods which are driven by the sequence made of its user’s selection of the answer, taken out of the set of locally available answers, to the questions asked by the system about the general elements of the decision-making task. As a result, not only does the system provide a user with a better opportunity to select the decision-making method for a specific problem, but also it guides the user through the solution steps being carried out according to the method.
The EDSS is equipped with a sufficient set of functions to deal with a database server generally supporting SQL via a standard database provider interface. This supports the structured storage of all the information required for internal calculation, the description of task elements, and intermediate results obtained by decision-marking methods. It also stores the predefined templates utilized during the preparation of reports as well as for support of the multi-language user interface. In addition, relying on the database servers, the system can carry out a multidimensional analysis of the data before and during the main procedure of solving the task at hand, export the results back to the database tables, and prepare analytic reports with the use of an OLAP-server. However, the automation based on stored templates will slightly vary the procedure of report generation with respect to the functional specification provided by the server of the chosen relational database.
The system architecture includes a multiple user access which provides the set of tools for collective decision-making process that allows an expert panel to substantiate decisions in a cooperative manner so that the optimal solution can be reached as a consolidated opinion of the expert panel.
The EDSS is not a system oriented exclusively to solving problems in a dedicated field. In spite of the fact that it was primarily designed for solving tasks in managerial [
35,
36] or business [
37,
38] sciences, it can now be fruitfully used for coping with tasks emerging in many other applied sciences. As a system improving the process of choosing optimal system design at the earlier development stages, it has served a practical tool for solving a series of engineering tasks, e.g., searching for more effective estimators in radar systems [
39,
40], selecting more accurate estimators for electric signal parameters [
41,
42,
43], planning the design of experiments conducting in position location [
44], telecommunication [
45] and fast image recognition [
46], identification of hidden periodicity in data acquired at various measurement sites, and including power electronics [
47,
48] and antennas [
49]. Such approach can also be applied for designing the sites for measurement of the vibration signals exploited for fault detection in rotary machines [
50].
Since the system had been designed as a client–server architecture, it provides end users with a remote access to the web server running the main application. The end-user implementation in the form of a thin client offers the simultaneous sessions to multiple users connected via the Internet browser.
The inclusion of the newly developed method into the EDSS has been successfully carried out. The modular architecture of the server part of the system allows for adding new decision-making techniques without changing the source code of the main system modules. However, the user graphical interface of the EDSS has been slightly updated in order to support the interactive function of the included method. Practically, the proposed method has been implemented as a program module written in C# language with a support of the program interface providing the data structure interchange at a level that is enough for the full inclusion into the system. The knowledge base exploited by the EDSS has also been updated, since the new method had to be implemented in accordance with those decision-making conditions, under which the method is expected to be run.