Omni-test¶
The Omni-test problem is a multi-modal multi-objective optimization problem proposed by Deb in [50]. It has two objective functions. Suppose that the dimension of the decision space is \(D\), then it has \(3^D\) Pareto subsets in the decision space corresponding to the same Pareto front.
2-dimensional case¶
Pareto front¶
[1]:
from pymoo.problems.multi.omnitest import OmniTest
from pymoo.visualization.scatter import Scatter
problem = OmniTest(n_var=2)
pf = problem.pareto_front(1000)
Scatter(title="Pareto front").add(pf).show()
[1]:
<pymoo.visualization.scatter.Scatter at 0x11f727650>
data:image/s3,"s3://crabby-images/4ce9d/4ce9de4007a7d1275c4d34c703854e379304037e" alt="../../_images/problems_multi_omni_test_2_1.png"
Pareto set¶
[2]:
ps = problem.pareto_set(1000)
Scatter(title="Pareto set", labels=["$x_1$", "$x_2$"]).add(ps).show()
[2]:
<pymoo.visualization.scatter.Scatter at 0x11f9dd5b0>
data:image/s3,"s3://crabby-images/efd18/efd1876a2d6182bce715497fb5b8a5acd4f3248b" alt="../../_images/problems_multi_omni_test_4_1.png"
3-dimensional case¶
Pareto front¶
[3]:
problem = OmniTest(n_var=3)
pf = problem.pareto_front(3000)
Scatter(title="Pareto front").add(pf).show()
[3]:
<pymoo.visualization.scatter.Scatter at 0x11fd0d580>
data:image/s3,"s3://crabby-images/6f5d4/6f5d4051ff23b577c359b1b1872e0b8aa5c232d2" alt="../../_images/problems_multi_omni_test_6_1.png"
Pareto set¶
[4]:
import matplotlib.pyplot as plt
ps = problem.pareto_set(1000)
sc = Scatter(title="Pareto set", labels=["$x_1$", "$x_2$", "$x_3$"])
sc.add(ps)
sc.do()
sc.ax.view_init(elev=20, azim=5)
plt.show()
data:image/s3,"s3://crabby-images/63c78/63c787af90f6b6f8a28027d491dce0e17bdc2e2b" alt="../../_images/problems_multi_omni_test_8_0.png"