pythonpyomolinear-optimization

No objectives defined for input model. Cannot write legal LP file


I just write my pyomo model and i want to solve them but i got this Error:

ERROR: No objectives defined for input model. Cannot write legal LP file.

here is my code

import pyomo.environ as pyo
import sys

model = pyo.ConcreteModel()
model.i = pyo.Set(initialize=[1,2,3])
model.j = pyo.Set(initialize=[1,2])

data_d = {1:50 , 2:50 , 3:100}
model.d = pyo.Param(model.i , initialize=data_d)
data_d_p = {1:200 , 2:250 , 3:150}
model.d_p = pyo.Param(model.i , initialize=data_d_p)

model.X = pyo.Var(model.i , model.j ,domain = pyo.NonNegativeIntegers, initialize = 0) 
model.Y = pyo.Var(model.i , model.j ,domain = pyo.NonNegativeIntegers, initialize = 0)

model.obj = model.Objective(expr = (model.X[1,1] + model.Y[1,1]) + 2 * (model.X[1,2] + model.Y[1,2]) + 
               2 * (model.X[2,1] + model.Y[2,1]) + (model.X[2,2] + model.Y[2,2]) + 
               (model.X[3,1] + model.Y[3,1]) + (model.X[3,2] + model.Y[3,2]) , sense = pyo.minimize)

def xi_constraint_rule(m, i):
       return sum(m.X[i,j] for j in m.j)
    
def yi_constraint_rule(m, i):
       return sum(m.Y[i,j] for j in m.j)

def xj_constraint_rule(m, j):
       return sum(m.X[i,j] for i in m.i)
    
def yj_constraint_rule(m, j):
       return sum(m.Y[i,j] for i in m.i)

model.first_const = pyo.ConstraintList()
for i in model.i:
    model.first_const.add(xi_constraint_rule(model, i) == pyo.value(model.d[i]))

    
model.second_const = pyo.ConstraintList()
for i in model.i:
    model.second_const.add(yi_constraint_rule(model, i) == pyo.value(model.d_p[i]))

    
model.third_const = pyo.ConstraintList()
for j in model.j:
    model.third_const.add(xj_constraint_rule(model, j) >= 0.25 * (xj_constraint_rule(model, j) + yj_constraint_rule(model, j)))

                    
model.fourth_const = pyo.ConstraintList()
for j in model.j:
    model.fourth_const.add(xj_constraint_rule(model, j) + yj_constraint_rule(model, j) >= 300)
    

model.fifth_const = pyo.ConstraintList()
for j in model.j:
    model.fifth_const.add(xj_constraint_rule(model, j) + yj_constraint_rule(model, j) <= 500)

how i can solve this Error? Thank for your help!

I want to solve LP problem in pyomo


Solution

  • You have an unfortunate typo in your objective function statement. Instead of referencing the Objective construction function in pyo, you made a nonsensical model component.

    Change this:

    model.obj = model.Objective(expr = (model.X[1,1] + model.Y[1,1])...
    

    To this:

    model.obj = pyo.Objective(expr = (model.X[1,1] + model.Y[1,1])...