- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想用Dymos解决最优控制问题:
服从动力系统:
我有两个问题:
(1)如何设置V(X(T))的目标函数(object1
),其中最终时间点的状态变量值是函数V的输入。
我觉得设置
phase.add_objective('V(X)', loc='final', scale=1)
将最小化速率为 V(X) 的变量从 t=0 到 t=T 的积分,对吗?
(2) 我想我可以设置一个时间变化率 L(X, u) 的输出 objectval2
然后设置
phase.add_objective('objectval2', loc='final', scale=1)
那么我如何让优化器知道我想要最小化 objectval1 + objectval2 的总和,而不是 objectval1*objectval2 或 objectval1 和 objectval2 的任何其他函数。
我阅读了教程,但没有找到与我的案例相似的示例。
#################
评论:谢谢。我不能在答案的评论中添加以下澄清问题,它说这些太长了。所以我在这里添加了它们。
我认为这里的关键代码是:
p.model.add_subsystem('other_calcs', om.ExecComp("f=a+b"))
p.model.connect('traj.phase0.timeseries.states:v', 'other_calcs.a', src_indices=[-1])
p.model.connect('traj.pahse0.timeseries.states:v', 'other_calcs.b', src_indices=[0])
我在教程中看到这个,我有 3 个问题:
(1)对于关键字输入src_indices
,我认为src_indices=[-1]
传递了v
的最后一个值(v[-1]
) 到 a
和 src_indices=[0]
传递 v
( v[0]
) 到 b
。我认为v[-1]
的时间点取决于节点数,节点数由参数num_segments
和order
决定。那么转录函数是否总是将最后一个节点位置设置为最后一个时间点?例如,如果我解决了从 t=0
到 t=2000
的控制问题,无论我如何设置 num_segments
和 顺序
,例如num_segments=2
和 order=3
或 num_segments=20
和 order=5
, v[- 1]
将始终是 t=2000
时 v
的值,而 v[0]
将始终是 v
在 t=0
?
(2) 我可以在节点上添加一个或多个特定的时间点吗?例如,如果我解决一个从 t=0 到 t=2000 的控制问题,我想最小化 t=500
时 v
的值之和,t=1000
和t=2000
,我可以要求节点必须包含时间点t=500
,t=1000
和 t=2000
,无论我如何设置 num_segments
和 order
?
(3) 最后一个问题是我第一次问的目标函数设置。在示例中,您注释掉了 # phase.add_objective('time', loc='final')
。如果我设置代码,优化器会做什么:
phase.add_objective('x', loc='final')
p.model.add_objective('other_calcs.f')
优化器是否最小化从t=0
到t=T
和v(T)<的
?如果不是,我如何设置优化器以最小化从 x
积分之和t=0
到 t=T
和 v 的
?x
积分总和(T)
最佳答案
使用标准的 Brachistochrone 问题,我对目标函数进行了玩具修改,以向您展示如何实现您的要求。我定义的新目标函数不是一个非常有意义的目标函数,但它明白了这一点。
这里的关键思想是,除了 traj
组之外,您还可以向模型添加额外的组件。这些可以在 traj
组之前或之后出现,但在您的情况下,您希望它们在之后。然后你可以将东西连接到你的其他组件和 traj
组。
我在这里制作了一个非常简单的 ExecComp
,它将状态变量 V 的初始条件和最终条件相加,并将其设置为目标。为此,我连接了该阶段的 timeseries
输出。显然,您可以构建一个对最终时间状态值进行运算的不同方程式。此示例中的连接语句向您展示了如何执行此操作。
import numpy as np
import openmdao.api as om
import dymos as dm
import matplotlib.pyplot as plt
# First define a system which computes the equations of motion
class BrachistochroneEOM(om.ExplicitComponent):
def initialize(self):
self.options.declare('num_nodes', types=int)
def setup(self):
nn = self.options['num_nodes']
# Inputs
self.add_input('v', val=np.zeros(nn), units='m/s', desc='velocity')
self.add_input('theta', val=np.zeros(nn), units='rad', desc='angle of wire')
self.add_output('xdot', val=np.zeros(nn), units='m/s', desc='x rate of change')
self.add_output('ydot', val=np.zeros(nn), units='m/s', desc='y rate of change')
self.add_output('vdot', val=np.zeros(nn), units='m/s**2', desc='v rate of change')
# Ask OpenMDAO to compute the partial derivatives using complex-step
# with a partial coloring algorithm for improved performance
self.declare_partials(of='*', wrt='*', method='cs')
self.declare_coloring(wrt='*', method='cs', show_summary=True)
def compute(self, inputs, outputs):
v, theta = inputs.values()
outputs['vdot'] = 9.80665 * np.cos(theta)
outputs['xdot'] = v * np.sin(theta)
outputs['ydot'] = -v * np.cos(theta)
p = om.Problem()
# Define a Trajectory object
traj = p.model.add_subsystem('traj', dm.Trajectory())
# Define a Dymos Phase object with GaussLobatto Transcription
tx = dm.GaussLobatto(num_segments=10, order=3)
phase = dm.Phase(ode_class=BrachistochroneEOM, transcription=tx)
traj.add_phase(name='phase0', phase=phase)
# Set the time options
phase.set_time_options(fix_initial=True,
duration_bounds=(0.5, 10.0))
# Set the state options
phase.add_state('x', rate_source='xdot',
fix_initial=True, fix_final=True)
phase.add_state('y', rate_source='ydot',
fix_initial=True, fix_final=True)
phase.add_state('v', rate_source='vdot',
fix_initial=True, fix_final=False)
# Define theta as a control.
phase.add_control(name='theta', units='rad',
lower=0, upper=np.pi)
######################################################
# Post trajectory calculations for composite objective
######################################################
p.model.add_subsystem('other_calcs', om.ExecComp("f=v[0]+v[1]", v={"shape":(2,)}))
p.model.connect('traj.phase0.timeseries.states:v', 'other_calcs.v', src_indices=[0,-1])
###################################################################
# Standard Dymos API for objective function - minimize final time.
###################################################################
# phase.add_objective('time', loc='final')
###################################################################
# OpenMDAO API for objective functions that require post-dymos calculations
###################################################################
p.model.add_objective('other_calcs.f')
# Set the driver.
p.driver = om.ScipyOptimizeDriver()
# Allow OpenMDAO to automatically determine total
# derivative sparsity pattern.
# This works in conjunction with partial derivative
# coloring to give a large speedup
p.driver.declare_coloring()
# Setup the problem
p.setup()
# Now that the OpenMDAO problem is setup, we can guess the
# values of time, states, and controls.
p.set_val('traj.phase0.t_duration', 2.0)
# States and controls here use a linearly interpolated
# initial guess along the trajectory.
p.set_val('traj.phase0.states:x',
phase.interp('x', ys=[0, 10]),
units='m')
p.set_val('traj.phase0.states:y',
phase.interp('y', ys=[10, 5]),
units='m')
p.set_val('traj.phase0.states:v',
phase.interp('v', ys=[0, 5]),
units='m/s')
# constant initial guess for control
p.set_val('traj.phase0.controls:theta', 90, units='deg')
# Run the driver to solve the problem and generate default plots of
# state and control values vs time
dm.run_problem(p, make_plots=True, simulate=True)
关于openmdao - 动力 : How can I set object to minimize a function value of state variables at the end of simulation time,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/74497365/
我需要最小化一个函数,比如五个变量(x[0] 到 x[4]) 要最小化的标量函数由X'*H*X给出。目标函数看起来类似于: def objfun(x): H = 0.1*np.ones([5,
我在使用 scipy.minimize.optimize 时遇到问题。这是我的代码。 from time import process_time import numpy as np from sci
我正在创建一个 C# WinForms MDI 应用程序。我有一个主窗体,其中包含 4 个其他窗体。我希望能够将子窗体移出父窗体(它们的 FormBorderStyle 值设置为可调整大小的工具栏,以
在 views app/views/listings/show.haml 中,我有这段代码: - if @listing.price .row .col-12 .listing
我有一个用于构建 .net 解决方案的批处理文件,并试图将详细程度降至最低,它仅显示正在构建的项目以及任何警告和/或错误,但也希望在结尾处查看带有警告数量的摘要和错误加上构建时间。 我已经尝试了详细程
我正在尝试进行一些参数估计,并希望选择最小化预测方程中的平方误差的参数估计 超过大约 30 个变量 .如果方程是线性的,我只需计算 30 个偏导数,将它们全部设置为零,然后使用线性方程求解器。但不幸的
Pyomo 中多目标优化的任何示例吗? 我正在尝试最小化 4 个目标(非线性),并且我想使用 pyomo 和 ipopt。还可以访问古罗比。 我想看一个非常简单的例子,我们尝试优化一系列决策变量(不仅
我正在尝试在我的 java 项目中使用这个库 https://github.com/ralfstx/minimal-json 以下是如何使用它来创建对象和数组。 JsonObject jsonObje
我正在尝试执行以下函数的最小化: def mvqr(P, y, x, c): s = 0 for i in xrange(1, len(y)): summation =
在虚拟机上安装发现默认是命令行界面一路进行下去,最后发现是Minimal的安装,并且网卡也没有默认启动...晕死。网上搜了下才知道原来Centos 6的Minimal下,网卡默认onboot=&qu
我已经开发了VB6应用程序。现在,我想禁用调整窗体的大小。我知道有一个属性Border style,它更改为fixed single,可以完成我的工作。但是我想要最小化按钮到我的形式。最小化按钮仅在“
我的游戏应用程序有问题: 如果将其最小化,则会崩溃...例如如果您按下主屏幕按钮或点击广告。 这是日志: >threadid=19: thread exiting with uncaught exce
我有以下问题:我们正在构建一个相当大的应用程序(win32,Delphi 6 Enterprise)。在应用程序的几个部分中,使用了模态窗口,通常包含主窗口选择的详细信息。 我们对 WM_SYSCOM
我正在开发一个基于 Minim 的音频可视化项目。对于这个项目的一部分,我需要一个频率放大器阵列(我将使用这个阵列来确定监视器条的高度)。我以前从未使用过 Minim,所以我提前为我在这个主题上的有限
scipy.minimize 似乎不遵守约束。这是一个简单的示例,其中约束是为了防止对数中的负参数,但最小化函数不遵守: import math from scipy.optimize import
我是 scipy.optimize 模块的新手,需要帮助尝试在与矩阵一起使用的公式 V 上使用最小化函数,并且有 2 个约束,但我不确定我是否正确处理了函数的形成或其中之一限制条件。 M 是一个 Nx
是否有 Android 标准或编码约定/最佳实践规定当用户“退出”应用时应用是否应退出(不在后台运行)或最小化(在后台运行)? 例如,您在某个应用的主页上。处理背压的最佳做法是什么?显而易见的答案是让
有没有办法在不使用回调和重新执行成本函数的情况下使用 scipy.minimize 在每次迭代的基础上访问成本函数? options.disp 似乎打算这样做,但只会导致优化器打印终止消息。 最好将它
我想在我的主题的答案帖子中自定义问题的外观,该主题基于 Minimal theme .我尝试从我以前的模板中添加内容,该模板已按照我想要的方式设置格式,但没有成功。 这是我添加的: 在 {Questi
我想要一个方法在很多地方创建以下 json 字符串: {"daily_calendar":{"search":{"print_date":"2014-06-30"}}} 我有以下四行代码来制作散列:
我是一名优秀的程序员,十分优秀!