Abstract
An improved particle swarm optimization (PSO) algorithm is proposed for solving bilevel multiobjective programming problem (BLMPP). For such problems, the proposed algorithm directly simulates the decision process of bilevel programming, which is different from most traditional algorithms designed for specific versions or based on specific assumptions. The BLMPP is transformed to solve multiobjective optimization problems in the upper level and the lower level interactively by an improved PSO. And a set of approximate Pareto optimal solutions for BLMPP is obtained using the elite strategy. This interactive procedure is repeated until the accurate Pareto optimal solutions of the original problem are found. Finally, some numerical examples are given to illustrate the feasibility of the proposed algorithm.
1. Introduction
Bilevel programming problem (BLPP) arises in a wide variety of scientific and engineering applications including optimal control, process optimization, game-playing strategy development, and transportation problem Thus, the BLPP has been developed and researched by many scholars. The reviews, monographs, and surveys on the BLPP can refer to [1–11]. Moreover, the evolutionary algorithms (EA) have been employed to address BLPP in papers [12–16].
However, the bilevel multiobjective programming problem (BLMPP) has seldom been studied. Shi and Xia [17, 18], Abo-Sinna and Baky [19], Nishizaki and Sakawa [20], and Zheng et al. [21] presented an interactive algorithm for BLMPP. Eichfelder [22] presented a method for solving nonlinear bilevel multiobjective optimization problems with coupled upper level constraints. Thereafter, Eichfelder [23] developed a numerical method for solving nonlinear nonconvex bilevel multiobjective optimization problems. In recent years, the metaheuristic has attracted considerable attention as an alternative method for BLMPP. For example, Deb and Sinha [24–26] as well as Sinha and Deb [27] discussed BLMPP based on evolutionary multiobjective optimization principles. Based on those studies, Deb and Sinha [28] proposed a viable and hybrid evolutionary-local-search-based algorithm and presented challenging test problems. Sinha [29] presented a progressively interactive evolutionary multiobjective optimization method for BLMPP.
Particle swarm optimization (PSO) is a relatively novel heuristic algorithm inspired by the choreography of a bird flock, which has been found to be quite successful in a wide variety of optimization tasks [30]. Due to its high speed of convergence and relative simplicity, the PSO algorithm has been employed by many researchers for solving BLPPs. For example, Li et al. [31] proposed a hierarchical PSO for solving BLPP. Kuo and Huang [32] applied the PSO algorithm for solving bilevel linear programming problem. Gao et al. [33] presented a method to solve bilevel pricing problems in supply chains using PSO. However, it is worth noting that the papers mentioned above are only for bilevel single objective problems.
In this paper, an improved PSO is presented for solving BLMPP. The algorithm can be outlined as follows. The BLMPP is transformed to solve multiobjective optimization problems in the upper level and the lower level interactively by an improved PSO. And a set of approximate Pareto optimal solutions for BLMPP is obtained using the elite strategy. The above interactive procedure is repeated for a predefined count, and then the accurate Pareto optimal solutions of the BLMPP will be achieved. Towards these ends, the rest of the paper is organized as follows. In Section 2, the problem formulation is provided. The proposed algorithm for solving bilevel multiobjective problem is presented in Section 3. In Section 4, some numerical examples are given to demonstrate the proposed algorithm, while the conclusion is reached in Section 5.
2. Problem Formulation
Let , , , , , and . The general model of the BLMPP can be written as follows: where and are the upper level and the lower level objective functions, respectively. and denote the upper level and the lower level constraints, respectively. Let , , , and for the fixed , let denote the weak efficiency set of solutions to the lower level problem, the feasible solution set of problem (2.1) is denoted as .
Definition 2.1. For a fixed , if is a Pareto optimal solution to the lower level problem, then is a feasible solution to the problem (2.1).
Definition 2.2. If is a feasible solution to the problem (2.1) and there are no , such that , then is a Pareto optimal solution to the problem (2.1), where “” denotes Pareto preference.
For problem (2.1), it is noted that a solution is feasible for the upper level problem if and only if is an optimal solution for the lower level problem with . In practice, we often make the approximate Pareto optimal solutions of the lower level problem as the optimal response feedback to the upper level problem, and this point of view is accepted usually. Based on this fact, the PSO algorithm may have a great potential for solving BLMPP. On the other hand, unlike the traditional point-by-point approach mentioned in Section 1, the PSO algorithm uses a group of points in its operation thus, the PSO can be developed as a new way for solving BLMPP. In the following, we present an improved PSO algorithm for solving problem (2.1).
3. The Algorithm
The process of the proposed algorithm is an interactive coevolutionary process for both the upper level and the lower level. We first initialize population and then solve multiobjective optimization problems in the upper level and the lower level interactively using an improved PSO. Afterwards, a set of approximate Pareto optimal solutions for problem 1 is obtained by the elite strategy which was adopted in Deb et al. [34]. This interactive procedure is repeated until the accurate Pareto optimal solutions of problem (2.1) are found. The details of the proposed algorithm are given as follows:
3.1. Algorithm
Step 1. Initialize.Substep 1.1. Initialize the population with particles which is composed by subswarms of size each. The particle’s position of the subswarm is presented as , and the corresponding velocity is presented as: , and are sampled randomly in the feasible space, respectively.Substep 1.2. Initialize the external loop counter .
Step 2. For the subswarm (), each particle is assigned a nondomination rank and a crowding value in space. Then, all resulting subswarms are combined into one population which is named as the . Afterwards, each particle is assigned a nondomination rank and a crowding value in space.
Step 3. The nondomination particles assigned both and from are saved in the elite set .
Step 4. For the subswarm (), update the lower level decision variables.Substep 4.1. Initialize the lower level loop counter .Substep 4.2. Update the ( particle’s position and velocity with the fixed and the fixed using Substep 4.3. Consider .Substep 4.4. If , go to Substep 4.5. Otherwise, go to Substep 4.2.Substep 4.5. Each particle of the subswarm is reassigned a nondomination rank and a crowding value in space. Then, all resulting subswarms are combined into one population which is renamed as the . Afterwards, each particle is reassigned a nondomination rank and a crowding value in space.
Step 5. Combine population and to form . The combined population is reassigned a nondomination rank , and the particles within an identical nondomination rank are assigned a crowding distance value in the space.
Step 6. Choose half particles from . The particles of rank are considered first. From the particles of rank , the particles with are noted one by one in the order of reducing crowding distance , for each such particle the corresponding subswarm from its source population (either or ) is copied in an intermediate population . If a subswarm is already copied in and a future particle from the same subswarm is found to have , the subswarm is not copied again. When all particles of are considered, a similar consideration is continued with and so on till exactly subswarms are copied in .
Step 7. Update the elite set . The nondomination particles assigned both and from are saved in the elite set .
Step 8. Update the upper level decision variables in .Substep 8.1. Initiate the upper level loop counter .Substep 8.2. Update the ) particle’s position and velocity with the fixed and the fixed using Substep 8.3. Consider .Substep 8.4. If , go to Substep 8.5. Otherwise, go to Substep 8.2.Substep 8.5. Every member is then assigned a nondomination rank and a crowding distance value in space.
Step 9. Consider .
Step 10. If , output the elite set . Otherwise, go to Step 2.
In Steps 4 and 8, the global best position is chosen at random from the elite set . The criterion of personal best position choice is that if the current position is dominated by the previous position, then the previous position is kept; otherwise, the current position replaces the previous one; if neither of them is dominated by the other, then we select one of them randomly. A relatively simple scheme is used to handle constraints. Whenever two individuals are compared, their constraints are checked. If both are feasible, nondomination sorting technology is directly applied to decide which one is selected. If one is feasible and the other is infeasible, the feasible dominates. If both are infeasible, then the one with the lowest amount of constraint violation dominates the other. Notations used in the proposed algorithm are detailed in Table 1.
4. Numerical Examples
In this section, three examples will be considered to illustrate the feasibility of the proposed algorithm for problem (2.1). In order to evaluate the closeness between the obtained Pareto optimal front and the theoretical Pareto optimal front, as well as the diversity of the obtained Pareto optimal solutions along the theoretical Pareto optimal front, we adopted the following evaluation metrics.
4.1. Generational Distance (GD)
This metric used by Deb [35] is employed in this paper as a way of evaluating the closeness between the obtained Pareto optimal front and the theoretical Pareto optimal front. The metric denotes the average distance between the obtained Pareto optimal front and the theoretical Pareto optimal front:
where is the number of the obtained Pareto optimal solutions by the proposed algorithm and is the Euclidean distance between each obtained Pareto optimal solution and the nearest member of the theoretical Pareto optimal set.
4.2. Spacing (SP)
This metric is used to evaluate the diversity of the obtained Pareto optimal solutions by comparing the uniform distribution and the deviation of solutions as described by Deb [35]:
where , is the mean of all , is the Euclidean distance between the extreme solutions in obtained Pareto optimal solution set and the theoretical Pareto optimal solution set on the objective, is the number of the upper level objective function, is the number of the obtained solutions by the proposed algorithm.
The PSO parameters are set as follows: , the inertia weight , and acceleration coefficients with . All results presented in this paper have been obtained on a personal computer (CPU: AMD Phenom II X6 1055T 2.80 GHz; RAM: 3.25 GB) using a C# implementation of the proposed algorithm, and the figures were obtained using the origin 8.0.
Example 4.1. Example 4.1 is taken from [22]. Here , . In this example, the population size and iteration times are set as follows: , , , , and : Figure 1 shows the obtained Pareto front of this example by the proposed algorithm. From Figure 1, it can be seen that the obtained Pareto front is very close to the theoretical Pareto optimal front, and the average distance between the obtained Pareto optimal front and the theoretical Pareto optimal front is 0.00026, that is, (see Table 2). Moreover, the lower value (, see Table 2) shows that the proposed algorithm is able to obtain a good distribution of solutions on the entire range of the theoretical Pareto optimal front. Figure 2 shows the obtained solutions of this example, which follow the relationship, that is, , and . It is also obvious that all obtained solutions are close to being on the upper level constraint boundary ().
Example 4.2. Example 4.2 is taken from [36]. Here , . In this example, the population size and iteration times are set as follows: , , , , and . Figure 3 shows the obtained Pareto optimal front of this example by the proposed algorithm. From Figure 3, it is obvious that the obtained Pareto optimal front is very close to the theoretical Pareto optimal front, the average distance between the obtained Pareto optimal front and the theoretical Pareto optimal front is 0.00004 (see Table 2). On the other hand, the obtained Pareto optimal solutions can be distributed uniformly on entire range of theoretical Pareto optimal front based on the fact that the value is lower (, see Table 2). Figure 4 shows the obtained Pareto optimal solutions; they follow the relationship, that is, , and .
Example 4.3. Example 4.3 is taken from [37], in which the theoretical Pareto optimal front is not given. Here , . In this example, the population size and iteration times are set as follows: , , , , and : Figure 5 shows the obtained Pareto optimal front of Example 4.3 by the proposed algorithm. Figure 6 shows all five constrains for all obtained Pareto optimal solutions and it can be seen that the , and are active constrains. Note that, Zhang et al. [37] only obtained a single optimal solution , and which lies on the maximum of the using weighted sum method. In contrast, a set of Pareto optimal solutions is obtained by the proposed algorithm. However, the fact that the single optimal solution in [37] is included in the obtained Pareto optimal solutions illustrates the feasibility of proposed algorithm.
5. Conclusion
In this paper, an improved PSO is presented for BLMPP. The BLMPP is transformed to solve the multiobjective optimization problems in the upper level and the lower level interactively using the proposed algorithm for a predefined count. And a set of accurate Pareto optimal solutions for BLMPP is obtained by the elite strategy. The experimental results illustrate that the obtained Pareto front by the proposed algorithm is very close to the theoretical Pareto optimal front, and the solutions are also distributed uniformly on entire range of the theoretical Pareto optimal front. Furthermore, the proposed algorithm is simple and easy to implement. It also provides another appealing method for further study on BLMPP.
Acknowledgment
This work is supported by the National Science Foundation of China (71171151, 50979073).