【发布时间】:2018-03-20 20:52:10
【问题描述】:
我得到了一个如下所示的数据框:
>data
x y
Name
A NaN 0
B 65,2 NaN
C NaN 100
我创建了一个 pyomo Set-Object m.index,用于索引可变的 pyomo Parameter-Object m.parameter_y。
m.index:
# code
m.index = pyomo.Set(
initialize=data.index.get_level_values(0).unique(),
doc='Index Set')
# output
(Pdb) m.index.pprint()
index : Index Set
Dim=0, Dimen=1, Size=3, Domain=None, Ordered=False, Mutable=True, Bounds=None
['A', 'B', 'C']
m.parameter_y:
# code
m.parameter_y = pyomo.Param(
m.index,
default=data['y'].values,
mutable=True
doc='Par y')
# output
(Pdb) m.parameter_y.pprint()
parameter_y : Par y
Size=3, Index=index, Domain=Any, Default=None, Mutable=True
Key : Value
A : [ 0 nan 100. ]
B : [ 0 nan 100. ]
C : [ 0 nan 100. ]
使用default=df['y'].values 可以看到,获取y 列的所有值作为参数的值。
如果我希望得到以下输出,我该如何设置可变索引 pyomo 参数对象的值?
(Pdb) m.parameter_y.pprint()
parameter_y : Par y
Size=3, Index=index, Domain=Any, Default=None, Mutable=True
Key : Value
A : [ 0 ]
B : [ nan ]
C : [ 100 ]
PS:请记住,这不是实际的数据框、索引集或参数。所以像手动添加值这样的答案在我的情况下不起作用。什么会起作用,从数据帧中获取某种更好的值获取函数,这样,我可以将该参数上的这些值设置为默认值。
【问题讨论】:
标签: dataframe parameters pyomo indexed