首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >OpenMDAO奇异项

OpenMDAO奇异项
EN

Stack Overflow用户
提问于 2018-04-11 13:49:06
回答 1查看 118关注 0票数 1

我正在努力理解OpenMDAO错误消息

代码语言:javascript
复制
RuntimeError: Singular entry found in '' for column associated with state/residual 'x'.

代码语言:javascript
复制
RuntimeError: Singular entry found in '' for row associated with state/residual 'y'.

有人能解释一下吗?例如,在运行代码时

代码语言:javascript
复制
from openmdao.api import Problem, Group, IndepVarComp, ImplicitComponent, ScipyOptimizeDriver, NewtonSolver, DirectSolver, view_model, view_connections


class Test1Comp(ImplicitComponent):

    def setup(self):
        self.add_input('x', 0.5)
        self.add_input('design_x', 1.0)
        self.add_output('z', val=0.0)
        self.add_output('obj')

        self.declare_partials(of='*', wrt='*', method='fd', form='central', step=1.0e-4)

    def apply_nonlinear(self, inputs, outputs, resids):
        x = inputs['x']
        design_x = inputs['design_x']
        z = outputs['z']

        resids['z'] = x*z + z - 4
        resids['obj'] = (z/5.833333 - design_x)**2


if __name__ == "__main__":

    prob = Problem()
    model = prob.model = Group()

    model.add_subsystem('p1', IndepVarComp('x', 0.5))
    model.add_subsystem('d1', IndepVarComp('design_x', 1.0))
    model.add_subsystem('comp', Test1Comp())

    model.connect('p1.x', 'comp.x')
    model.connect('d1.design_x', 'comp.design_x')

    prob.driver = ScipyOptimizeDriver()
    prob.driver.options["optimizer"] = 'SLSQP'
    model.add_design_var("d1.design_x", lower=0.5, upper=1.5)
    model.add_objective('comp.obj')

    model.nonlinear_solver = NewtonSolver()
    model.nonlinear_solver.options['iprint'] = 2
    model.nonlinear_solver.options['maxiter'] = 20
    model.linear_solver = DirectSolver()

    prob.setup()
    prob.run_model()
    print(prob['comp.z'])

我得到了错误消息:

代码语言:javascript
复制
  File "C:\Scripts/mockup_component3.py", line 46, in <module>
    prob.run_model()
  File "C:\Python_32\lib\site-packages\openmdao\core\problem.py", line 315, in run_model
    return self.model.run_solve_nonlinear()
  File "C:\Python_32\lib\site-packages\openmdao\core\system.py", line 2960, in run_solve_nonlinear
    result = self._solve_nonlinear()
  File "C:\Python_32\lib\site-packages\openmdao\core\group.py", line 1420, in _solve_nonlinear
    result = self._nonlinear_solver.solve()
  File "C:\Python_32\lib\site-packages\openmdao\solvers\solver.py", line 602, in solve
    fail, abs_err, rel_err = self._run_iterator()
  File "C:\Python_32\lib\site-packages\openmdao\solvers\solver.py", line 349, in _run_iterator
    self._iter_execute()
  File "C:\Python_32\lib\site-packages\openmdao\solvers\nonlinear\newton.py", line 234, in _iter_execute
    system._linearize()
  File "C:\Python_32\lib\site-packages\openmdao\core\group.py", line 1562, in _linearize
    self._linear_solver._linearize()
  File "C:\Python_32\lib\site-packages\openmdao\solvers\linear\direct.py", line 199, in _linearize
    raise RuntimeError(format_singluar_error(err, system, mtx))
RuntimeError: Singular entry found in '' for column associated with state/residual 'comp.obj'.

通过将- outputs['obj']添加到resids['obj']的方程中,我能够解决这个错误。但对于这两条错误信息的含义,我仍然知之甚少。什么矩阵是奇异的?这意味着

( 1)列的单数条目?

( 2)一行的单数条目?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-04-11 14:19:46

我意识到,单数行的原因是,我没有定义组件的偏导数。我通过将命令declare_partials添加到顶层系统来解决这个问题。追溯给了我一个线索,那就是矩阵与线性化有关。

奇异列的情况似乎与我在apply_nonlinear中有两个方程有关,但只有一个未知(z)。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/49776879

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档