Parametric scalable MDO problem - MDF#

We define a ScalableProblem with a shared design variable of size 1 and 2 strongly coupled disciplines. The first one has a local design variable of size 1 and a coupling variable of size 2 while the second one has a local design variable of size 3 and a coupling variable of size 4.

We would like to solve this MDO problem by means of an MDF formulation.

from __future__ import annotations

from gemseo import configure_logger
from gemseo import execute_algo
from gemseo import execute_post
from gemseo import generate_n2_plot
from gemseo.problems.mdo.scalable.parametric.core.scalable_discipline_settings import (
    ScalableDisciplineSettings,
)
from gemseo.problems.mdo.scalable.parametric.scalable_problem import ScalableProblem

configure_logger()
<RootLogger root (INFO)>

Instantiation of the scalable problem#

problem = ScalableProblem(
    [ScalableDisciplineSettings(1, 2), ScalableDisciplineSettings(3, 4)], 1
)

Display the coupling structure#

generate_n2_plot(problem.disciplines, save=False, show=True)
plot scalable param mdf

Solve the MDO using an MDF formulation#

scenario = problem.create_scenario()
scenario.execute(algo_name="NLOPT_SLSQP", max_iter=100)
   INFO - 08:36:21:
   INFO - 08:36:21: *** Start MDOScenario execution ***
   INFO - 08:36:21: MDOScenario
   INFO - 08:36:21:    Disciplines: MainDiscipline ScalableDiscipline[1] ScalableDiscipline[2]
   INFO - 08:36:21:    MDO formulation: MDF
   INFO - 08:36:21: Optimization problem:
   INFO - 08:36:21:    minimize f(x_0, x_1, x_2)
   INFO - 08:36:21:    with respect to x_0, x_1, x_2
   INFO - 08:36:21:    subject to constraints:
   INFO - 08:36:21:       c_1(x_0, x_1, x_2) <= 0
   INFO - 08:36:21:       c_2(x_0, x_1, x_2) <= 0
   INFO - 08:36:21:    over the design space:
   INFO - 08:36:21:       +--------+-------------+-------+-------------+-------+
   INFO - 08:36:21:       | Name   | Lower bound | Value | Upper bound | Type  |
   INFO - 08:36:21:       +--------+-------------+-------+-------------+-------+
   INFO - 08:36:21:       | x_0    |      0      |  0.5  |      1      | float |
   INFO - 08:36:21:       | x_1    |      0      |  0.5  |      1      | float |
   INFO - 08:36:21:       | x_2[0] |      0      |  0.5  |      1      | float |
   INFO - 08:36:21:       | x_2[1] |      0      |  0.5  |      1      | float |
   INFO - 08:36:21:       | x_2[2] |      0      |  0.5  |      1      | float |
   INFO - 08:36:21:       +--------+-------------+-------+-------------+-------+
   INFO - 08:36:21: Solving optimization problem with algorithm NLOPT_SLSQP:
   INFO - 08:36:21:      1%|          | 1/100 [00:00<00:02, 35.91 it/sec, obj=3.07]
WARNING - 08:36:21: MDAJacobi has reached its maximum number of iterations but the normed residual 2.7151398445206794e-06 is still above the tolerance 1e-06.
   INFO - 08:36:21:      2%|▏         | 2/100 [00:00<00:05, 19.03 it/sec, obj=1.21]
   INFO - 08:36:21:      3%|▎         | 3/100 [00:00<00:04, 21.48 it/sec, obj=0.991]
   INFO - 08:36:21:      4%|▍         | 4/100 [00:00<00:04, 23.22 it/sec, obj=0.986]
   INFO - 08:36:21:      5%|▌         | 5/100 [00:00<00:03, 24.40 it/sec, obj=0.982]
   INFO - 08:36:21:      6%|▌         | 6/100 [00:00<00:03, 25.27 it/sec, obj=0.971]
WARNING - 08:36:21: MDAJacobi has reached its maximum number of iterations but the normed residual 1.1427901203368072e-06 is still above the tolerance 1e-06.
   INFO - 08:36:21:      7%|▋         | 7/100 [00:00<00:03, 25.80 it/sec, obj=0.97]
WARNING - 08:36:21: MDAJacobi has reached its maximum number of iterations but the normed residual 1.1427840078240745e-06 is still above the tolerance 1e-06.
   INFO - 08:36:21:      8%|▊         | 8/100 [00:00<00:03, 26.23 it/sec, obj=0.969]
WARNING - 08:36:21: MDAJacobi has reached its maximum number of iterations but the normed residual 1.1427840073629847e-06 is still above the tolerance 1e-06.
   INFO - 08:36:21:      9%|▉         | 9/100 [00:00<00:03, 26.56 it/sec, obj=0.969]
WARNING - 08:36:21: MDAJacobi has reached its maximum number of iterations but the normed residual 1.1427840071115847e-06 is still above the tolerance 1e-06.
   INFO - 08:36:21:     10%|█         | 10/100 [00:00<00:03, 26.83 it/sec, obj=0.969]
   INFO - 08:36:21:     11%|█         | 11/100 [00:00<00:03, 29.44 it/sec, obj=Not evaluated]
   INFO - 08:36:21: Optimization result:
   INFO - 08:36:21:    Optimizer info:
   INFO - 08:36:21:       Status: None
   INFO - 08:36:21:       Message: Successive iterates of the design variables are closer than xtol_rel or xtol_abs. GEMSEO stopped the driver.
   INFO - 08:36:21:       Number of calls to the objective function by the optimizer: 11
   INFO - 08:36:21:    Solution:
   INFO - 08:36:21:       The solution is feasible.
   INFO - 08:36:21:       Objective: 0.9692147822181947
   INFO - 08:36:21:       Standardized constraints:
   INFO - 08:36:21:          c_1 = [-0.68663938 -0.21340355]
   INFO - 08:36:21:          c_2 = [-7.31227901e-01 -1.68967318e-01 -2.32696422e-01  7.82707232e-15]
   INFO - 08:36:21:       Design space:
   INFO - 08:36:21:          +--------+-------------+--------------------+-------------+-------+
   INFO - 08:36:21:          | Name   | Lower bound |       Value        | Upper bound | Type  |
   INFO - 08:36:21:          +--------+-------------+--------------------+-------------+-------+
   INFO - 08:36:21:          | x_0    |      0      | 0.7071335797308679 |      1      | float |
   INFO - 08:36:21:          | x_1    |      0      |         1          |      1      | float |
   INFO - 08:36:21:          | x_2[0] |      0      |         0          |      1      | float |
   INFO - 08:36:21:          | x_2[1] |      0      | 0.5233182522437052 |      1      | float |
   INFO - 08:36:21:          | x_2[2] |      0      |         0          |      1      | float |
   INFO - 08:36:21:          +--------+-------------+--------------------+-------------+-------+
   INFO - 08:36:21: *** End MDOScenario execution (time: 0:00:00.379932) ***

Post-process the results#

scenario.post_process(post_name="OptHistoryView", save=False, show=True)
  • Evolution of the optimization variables
  • Evolution of the objective value
  • Evolution of the distance to the optimum
  • Evolution of the inequality constraints
<gemseo.post.opt_history_view.OptHistoryView object at 0x7f6dc1f47310>

Solve the associated quadratic programming problem#

problem = problem.create_quadratic_programming_problem()
execute_algo(problem, algo_name="NLOPT_SLSQP", max_iter=100)
    INFO - 08:36:22: Optimization problem:
    INFO - 08:36:22:    minimize f = 0.5x'Qx + c'x + d
    INFO - 08:36:22:    with respect to x
    INFO - 08:36:22:    subject to constraints:
    INFO - 08:36:22:       g: Ax-b <= 0 <= 0.0
    INFO - 08:36:22:    over the design space:
    INFO - 08:36:22:       +------+-------------+-------+-------------+-------+
    INFO - 08:36:22:       | Name | Lower bound | Value | Upper bound | Type  |
    INFO - 08:36:22:       +------+-------------+-------+-------------+-------+
    INFO - 08:36:22:       | x[0] |      0      |  0.5  |      1      | float |
    INFO - 08:36:22:       | x[1] |      0      |  0.5  |      1      | float |
    INFO - 08:36:22:       | x[2] |      0      |  0.5  |      1      | float |
    INFO - 08:36:22:       | x[3] |      0      |  0.5  |      1      | float |
    INFO - 08:36:22:       | x[4] |      0      |  0.5  |      1      | float |
    INFO - 08:36:22:       +------+-------------+-------+-------------+-------+
    INFO - 08:36:22: Solving optimization problem with algorithm NLOPT_SLSQP:
    INFO - 08:36:22:      1%|          | 1/100 [00:00<00:00, 2841.67 it/sec, obj=3.07]
    INFO - 08:36:22:      2%|▏         | 2/100 [00:00<00:00, 702.27 it/sec, obj=1.21]
    INFO - 08:36:22:      3%|▎         | 3/100 [00:00<00:00, 705.40 it/sec, obj=0.991]
    INFO - 08:36:22:      4%|▍         | 4/100 [00:00<00:00, 708.26 it/sec, obj=0.986]
    INFO - 08:36:22:      5%|▌         | 5/100 [00:00<00:00, 686.24 it/sec, obj=0.982]
    INFO - 08:36:22:      6%|▌         | 6/100 [00:00<00:00, 693.81 it/sec, obj=0.971]
    INFO - 08:36:22:      7%|▋         | 7/100 [00:00<00:00, 697.46 it/sec, obj=0.97]
   ERROR - 08:36:22: NLopt run failed: NLopt roundoff-limited, RoundoffLimited
Traceback (most recent call last):
  File "/home/docs/checkouts/readthedocs.org/user_builds/gemseo/envs/6.0.0/lib/python3.9/site-packages/gemseo/algos/opt/nlopt/nlopt.py", line 384, in _run
    nlopt_problem.optimize(x_0.real)
  File "/home/docs/checkouts/readthedocs.org/user_builds/gemseo/envs/6.0.0/lib/python3.9/site-packages/nlopt/nlopt.py", line 335, in optimize
    return _nlopt.opt_optimize(self, *args)
nlopt.RoundoffLimited: NLopt roundoff-limited
    INFO - 08:36:22:      8%|▊         | 8/100 [00:00<00:00, 671.33 it/sec, obj=0.969]
    INFO - 08:36:22: Optimization result:
    INFO - 08:36:22:    Optimizer info:
    INFO - 08:36:22:       Status: None
    INFO - 08:36:22:       Message: GEMSEO stopped the driver.
    INFO - 08:36:22:       Number of calls to the objective function by the optimizer: 9
    INFO - 08:36:22:    Solution:
    INFO - 08:36:22:       The solution is feasible.
    INFO - 08:36:22:       Objective: 0.9692176254005034
    INFO - 08:36:22:       Standardized constraints:
    INFO - 08:36:22:          g = [-6.86640980e-01 -2.13404451e-01 -7.31227677e-01 -1.68967471e-01
    INFO - 08:36:22:  -2.32695870e-01 -2.22044605e-15]
    INFO - 08:36:22:       Design space:
    INFO - 08:36:22:          +------+-------------+--------------------+-------------+-------+
    INFO - 08:36:22:          | Name | Lower bound |       Value        | Upper bound | Type  |
    INFO - 08:36:22:          +------+-------------+--------------------+-------------+-------+
    INFO - 08:36:22:          | x[0] |      0      | 0.7071348743877915 |      1      | float |
    INFO - 08:36:22:          | x[1] |      0      |         1          |      1      | float |
    INFO - 08:36:22:          | x[2] |      0      |         0          |      1      | float |
    INFO - 08:36:22:          | x[3] |      0      | 0.5233180438726639 |      1      | float |
    INFO - 08:36:22:          | x[4] |      0      |         0          |      1      | float |
    INFO - 08:36:22:          +------+-------------+--------------------+-------------+-------+
Optimization result:
  • Design variables: [0.70713487 1. 0. 0.52331804 0. ]
  • Objective function: 0.9692176254005034
  • Feasible solution: True


Post-process the results#

execute_post(problem, post_name="OptHistoryView", save=False, show=True)
  • Evolution of the optimization variables
  • Evolution of the objective value
  • Evolution of the distance to the optimum
  • Evolution of the inequality constraints
<gemseo.post.opt_history_view.OptHistoryView object at 0x7f6dc9003cd0>

Total running time of the script: (0 minutes 2.941 seconds)

Gallery generated by Sphinx-Gallery