當前位置: 首頁>>代碼示例>>Python>>正文


Python ConcreteModel.X方法代碼示例

本文整理匯總了Python中pyomo.core.ConcreteModel.X方法的典型用法代碼示例。如果您正苦於以下問題:Python ConcreteModel.X方法的具體用法?Python ConcreteModel.X怎麽用?Python ConcreteModel.X使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在pyomo.core.ConcreteModel的用法示例。


在下文中一共展示了ConcreteModel.X方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: build_model

# 需要導入模塊: from pyomo.core import ConcreteModel [as 別名]
# 或者: from pyomo.core.ConcreteModel import X [as 別名]
def build_model(use_mccormick=False):
    """Build the GDP model."""
    m = ConcreteModel()
    m.F = Var(bounds=(0, 8), doc="Flow into reactor")
    m.X = Var(bounds=(0, 1), doc="Reactor conversion")
    m.d = Param(initialize=2, doc="Max product demand")
    m.c = Param([1, 2, 'I', 'II'], doc="Costs", initialize={
        1: 2,  # Value of product
        2: 0.2,  # Cost of raw material
        'I': 2.5,  # Cost of reactor I
        'II': 1.5  # Cost of reactor II
    })
    m.alpha = Param(['I', 'II'], doc="Reactor coefficient",
                    initialize={'I': -8, 'II': -10})
    m.beta = Param(['I', 'II'], doc="Reactor coefficient",
                   initialize={'I': 9, 'II': 15})
    m.X_LB = Param(['I', 'II'], doc="Reactor conversion lower bound",
                   initialize={'I': 0.2, 'II': 0.7})
    m.X_UB = Param(['I', 'II'], doc="Reactor conversion upper bound",
                   initialize={'I': 0.95, 'II': 0.99})
    m.C_rxn = Var(bounds=(1.5, 2.5), doc="Cost of reactor")
    m.reactor_choice = Disjunction(expr=[
        # Disjunct 1: Choose reactor I
        [m.F == m.alpha['I'] * m.X + m.beta['I'],
         m.X_LB['I'] <= m.X,
         m.X <= m.X_UB['I'],
         m.C_rxn == m.c['I']],
        # Disjunct 2: Choose reactor II
        [m.F == m.alpha['II'] * m.X + m.beta['II'],
         m.X_LB['II'] <= m.X,
         m.X <= m.X_UB['II'],
         m.C_rxn == m.c['II']]
    ], xor=True)
    if use_mccormick:
        m.P = Var(bounds=(0, 8), doc="McCormick approximation of F*X")
        m.mccormick_1 = Constraint(
            expr=m.P <= m.F.lb * m.X + m.F * m.X.ub - m.F.lb * m.X.ub,
            doc="McCormick overestimator")
        m.mccormick_2 = Constraint(
            expr=m.P <= m.F.ub * m.X + m.F * m.X.lb - m.F.ub * m.X.lb,
            doc="McCormick underestimator")
        m.max_demand = Constraint(expr=m.P <= m.d, doc="product demand")
        m.profit = Objective(
            expr=m.c[1] * m.P - m.c[2] * m.F - m.C_rxn, sense=maximize)
    else:
        m.max_demand = Constraint(expr=m.F * m.X <= m.d, doc="product demand")
        m.profit = Objective(
            expr=m.c[1] * m.F * m.X - m.c[2] * m.F - m.C_rxn, sense=maximize)

    return m
開發者ID:Pyomo,項目名稱:pyomo,代碼行數:52,代碼來源:two_rxn_model.py


注:本文中的pyomo.core.ConcreteModel.X方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。