# MINLP written by GAMS Convert at 02/17/22 17:18:40
#
# Equation counts
#     Total        E        G        L        N        X        C        B
#        40        0        0       40        0        0        0        0
#
# Variable counts
#                  x        b        i      s1s      s2s       sc       si
#     Total     cont   binary  integer     sos1     sos2    scont     sint
#        79       59        0       20        0        0        0        0
# FX      0
#
# Nonzero counts
#     Total    const       NL
#       156       78       78
#
# Reformulation has removed 1 variable and 1 equation

from pyomo.environ import *

model = m = ConcreteModel()

m.i1 = Var(within=Integers, bounds=(0,5), initialize=0)
m.i2 = Var(within=Integers, bounds=(0,5), initialize=0)
m.i3 = Var(within=Integers, bounds=(0,5), initialize=0)
m.i4 = Var(within=Integers, bounds=(0,5), initialize=0)
m.i5 = Var(within=Integers, bounds=(0,5), initialize=0)
m.i6 = Var(within=Integers, bounds=(0,5), initialize=0)
m.i7 = Var(within=Integers, bounds=(0,5), initialize=0)
m.i8 = Var(within=Integers, bounds=(0,5), initialize=0)
m.i9 = Var(within=Integers, bounds=(0,5), initialize=0)
m.i10 = Var(within=Integers, bounds=(0,5), initialize=0)
m.i11 = Var(within=Integers, bounds=(0,5), initialize=0)
m.i12 = Var(within=Integers, bounds=(0,5), initialize=0)
m.i13 = Var(within=Integers, bounds=(0,5), initialize=0)
m.i14 = Var(within=Integers, bounds=(0,5), initialize=0)
m.i15 = Var(within=Integers, bounds=(0,5), initialize=0)
m.i16 = Var(within=Integers, bounds=(0,5), initialize=0)
m.i17 = Var(within=Integers, bounds=(0,5), initialize=0)
m.i18 = Var(within=Integers, bounds=(0,5), initialize=0)
m.i19 = Var(within=Integers, bounds=(0,5), initialize=0)
m.i20 = Var(within=Integers, bounds=(0,5), initialize=0)
m.x21 = Var(within=Reals, bounds=(0,5), initialize=0)
m.x22 = Var(within=Reals, bounds=(0,5), initialize=0)
m.x23 = Var(within=Reals, bounds=(0,5), initialize=0)
m.x24 = Var(within=Reals, bounds=(0,5), initialize=0)
m.x25 = Var(within=Reals, bounds=(0,5), initialize=0)
m.x26 = Var(within=Reals, bounds=(0,5), initialize=0)
m.x27 = Var(within=Reals, bounds=(0,5), initialize=0)
m.x28 = Var(within=Reals, bounds=(0,5), initialize=0)
m.x29 = Var(within=Reals, bounds=(0,5), initialize=0)
m.x30 = Var(within=Reals, bounds=(0,5), initialize=0)
m.x31 = Var(within=Reals, bounds=(0,5), initialize=0)
m.x32 = Var(within=Reals, bounds=(0,5), initialize=0)
m.x33 = Var(within=Reals, bounds=(0,5), initialize=0)
m.x34 = Var(within=Reals, bounds=(0,5), initialize=0)
m.x35 = Var(within=Reals, bounds=(0,5), initialize=0)
m.x36 = Var(within=Reals, bounds=(0,5), initialize=0)
m.x37 = Var(within=Reals, bounds=(0,5), initialize=0)
m.x38 = Var(within=Reals, bounds=(0,5), initialize=0)
m.x39 = Var(within=Reals, bounds=(0,5), initialize=0)
m.x40 = Var(within=Reals, bounds=(0,5), initialize=0)
m.x41 = Var(within=Reals, bounds=(None,None), initialize=0)
m.x42 = Var(within=Reals, bounds=(None,None), initialize=0)
m.x43 = Var(within=Reals, bounds=(None,None), initialize=0)
m.x44 = Var(within=Reals, bounds=(None,None), initialize=0)
m.x45 = Var(within=Reals, bounds=(None,None), initialize=0)
m.x46 = Var(within=Reals, bounds=(None,None), initialize=0)
m.x47 = Var(within=Reals, bounds=(None,None), initialize=0)
m.x48 = Var(within=Reals, bounds=(None,None), initialize=0)
m.x49 = Var(within=Reals, bounds=(None,None), initialize=0)
m.x50 = Var(within=Reals, bounds=(None,None), initialize=0)
m.x51 = Var(within=Reals, bounds=(None,None), initialize=0)
m.x52 = Var(within=Reals, bounds=(None,None), initialize=0)
m.x53 = Var(within=Reals, bounds=(None,None), initialize=0)
m.x54 = Var(within=Reals, bounds=(None,None), initialize=0)
m.x55 = Var(within=Reals, bounds=(None,None), initialize=0)
m.x56 = Var(within=Reals, bounds=(None,None), initialize=0)
m.x57 = Var(within=Reals, bounds=(None,None), initialize=0)
m.x58 = Var(within=Reals, bounds=(None,None), initialize=0)
m.x59 = Var(within=Reals, bounds=(None,None), initialize=0)
m.x60 = Var(within=Reals, bounds=(None,None), initialize=0)
m.x61 = Var(within=Reals, bounds=(None,None), initialize=0)
m.x62 = Var(within=Reals, bounds=(None,None), initialize=0)
m.x63 = Var(within=Reals, bounds=(None,None), initialize=0)
m.x64 = Var(within=Reals, bounds=(None,None), initialize=0)
m.x65 = Var(within=Reals, bounds=(None,None), initialize=0)
m.x66 = Var(within=Reals, bounds=(None,None), initialize=0)
m.x67 = Var(within=Reals, bounds=(None,None), initialize=0)
m.x68 = Var(within=Reals, bounds=(None,None), initialize=0)
m.x69 = Var(within=Reals, bounds=(None,None), initialize=0)
m.x70 = Var(within=Reals, bounds=(None,None), initialize=0)
m.x71 = Var(within=Reals, bounds=(None,None), initialize=0)
m.x72 = Var(within=Reals, bounds=(None,None), initialize=0)
m.x73 = Var(within=Reals, bounds=(None,None), initialize=0)
m.x74 = Var(within=Reals, bounds=(None,None), initialize=0)
m.x75 = Var(within=Reals, bounds=(None,None), initialize=0)
m.x76 = Var(within=Reals, bounds=(None,None), initialize=0)
m.x77 = Var(within=Reals, bounds=(None,None), initialize=0)
m.x78 = Var(within=Reals, bounds=(None,None), initialize=0)
m.x79 = Var(within=Reals, bounds=(None,None), initialize=0)

m.obj = Objective(sense=minimize, expr= -0.18 * m.i1 - 0.72 * m.i2 - 0.47 *
    m.i3 - 0.15 * m.i4 - 0.34 * m.i5 - 0.61 * m.i6 - 0.19 * m.i7 - 0.74 * m.i8
    - 0.24 * m.i9 - 0.92 * m.i10 - 0.27 * m.i11 - 0.77 * m.i12 - 0.19 * m.i13
    - 0.29 * m.i14 - 0.09 * m.i15 - 0.58 * m.i16 - 0.68 * m.i17 - 0.55 * m.i18
    - 0.43 * m.i19 - 0.64 * m.i20 - 0.65 * m.x21 - 0.68 * m.x22 - 0.64 * m.x23
    - 0.95 * m.x24 - 0.21 * m.x25 - 0.71 * m.x26 - 0.24 * m.x27 - 0.12 * m.x28
    - 0.61 * m.x29 - 0.45 * m.x30 - 0.46 * m.x31 - 0.66 * m.x32 - 0.77 * m.x33
    - 0.35 * m.x34 - 0.66 * m.x35 - 0.42 * m.x36 - 0.84 * m.x37 - 0.83 * m.x38
    - 0.26 * m.x39 - 0.61 * m.x40)

m.e1 = Constraint(expr= m.x41 + m.x42 + m.x43 + m.x44 + m.x45 + m.x46 + m.x47
    + m.x48 + m.x49 + m.x50 + m.x51 + m.x52 + m.x53 + m.x54 + m.x55 + m.x56 +
    m.x57 + m.x58 + m.x59 + m.x60 + m.x61 + m.x62 + m.x63 + m.x64 + m.x65 +
    m.x66 + m.x67 + m.x68 + m.x69 + m.x70 + m.x71 + m.x72 + m.x73 + m.x74 +
    m.x75 + m.x76 + m.x77 + m.x78 + m.x79 <= 480)
m.e2 = Constraint(expr= 2**(m.i1 + m.i2) - m.x41 <= 0)
m.e3 = Constraint(expr= 2**(m.i2 + m.i3) - m.x42 <= 0)
m.e4 = Constraint(expr= 2**(m.i3 + m.i4) - m.x43 <= 0)
m.e5 = Constraint(expr= 2**(m.i4 + m.i5) - m.x44 <= 0)
m.e6 = Constraint(expr= 2**(m.i5 + m.i6) - m.x45 <= 0)
m.e7 = Constraint(expr= 2**(m.i6 + m.i7) - m.x46 <= 0)
m.e8 = Constraint(expr= 2**(m.i7 + m.i8) - m.x47 <= 0)
m.e9 = Constraint(expr= 2**(m.i8 + m.i9) - m.x48 <= 0)
m.e10 = Constraint(expr= 2**(m.i9 + m.i10) - m.x49 <= 0)
m.e11 = Constraint(expr= 2**(m.i10 + m.i11) - m.x50 <= 0)
m.e12 = Constraint(expr= 2**(m.i11 + m.i12) - m.x51 <= 0)
m.e13 = Constraint(expr= 2**(m.i12 + m.i13) - m.x52 <= 0)
m.e14 = Constraint(expr= 2**(m.i13 + m.i14) - m.x53 <= 0)
m.e15 = Constraint(expr= 2**(m.i14 + m.i15) - m.x54 <= 0)
m.e16 = Constraint(expr= 2**(m.i15 + m.i16) - m.x55 <= 0)
m.e17 = Constraint(expr= 2**(m.i16 + m.i17) - m.x56 <= 0)
m.e18 = Constraint(expr= 2**(m.i17 + m.i18) - m.x57 <= 0)
m.e19 = Constraint(expr= 2**(m.i18 + m.i19) - m.x58 <= 0)
m.e20 = Constraint(expr= 2**(m.i19 + m.i20) - m.x59 <= 0)
m.e21 = Constraint(expr= 2**(m.i20 + m.x21) - m.x60 <= 0)
m.e22 = Constraint(expr= 2**(m.x21 + m.x22) - m.x61 <= 0)
m.e23 = Constraint(expr= 2**(m.x22 + m.x23) - m.x62 <= 0)
m.e24 = Constraint(expr= 2**(m.x23 + m.x24) - m.x63 <= 0)
m.e25 = Constraint(expr= 2**(m.x24 + m.x25) - m.x64 <= 0)
m.e26 = Constraint(expr= 2**(m.x25 + m.x26) - m.x65 <= 0)
m.e27 = Constraint(expr= 2**(m.x26 + m.x27) - m.x66 <= 0)
m.e28 = Constraint(expr= 2**(m.x27 + m.x28) - m.x67 <= 0)
m.e29 = Constraint(expr= 2**(m.x28 + m.x29) - m.x68 <= 0)
m.e30 = Constraint(expr= 2**(m.x29 + m.x30) - m.x69 <= 0)
m.e31 = Constraint(expr= 2**(m.x30 + m.x31) - m.x70 <= 0)
m.e32 = Constraint(expr= 2**(m.x31 + m.x32) - m.x71 <= 0)
m.e33 = Constraint(expr= 2**(m.x32 + m.x33) - m.x72 <= 0)
m.e34 = Constraint(expr= 2**(m.x33 + m.x34) - m.x73 <= 0)
m.e35 = Constraint(expr= 2**(m.x34 + m.x35) - m.x74 <= 0)
m.e36 = Constraint(expr= 2**(m.x35 + m.x36) - m.x75 <= 0)
m.e37 = Constraint(expr= 2**(m.x36 + m.x37) - m.x76 <= 0)
m.e38 = Constraint(expr= 2**(m.x37 + m.x38) - m.x77 <= 0)
m.e39 = Constraint(expr= 2**(m.x38 + m.x39) - m.x78 <= 0)
m.e40 = Constraint(expr= 2**(m.x39 + m.x40) - m.x79 <= 0)
