# MINLP written by GAMS Convert at 02/17/22 17:18:39
#
# Equation counts
#     Total        E        G        L        N        X        C        B
#         1        0        0        1        0        0        0        0
#
# Variable counts
#                  x        b        i      s1s      s2s       sc       si
#     Total     cont   binary  integer     sos1     sos2    scont     sint
#        30       15        0       15        0        0        0        0
# FX      0
#
# Nonzero counts
#     Total    const       NL
#        30        0       30
#
# 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.x16 = Var(within=Reals, bounds=(0,5), initialize=0)
m.x17 = Var(within=Reals, bounds=(0,5), initialize=0)
m.x18 = Var(within=Reals, bounds=(0,5), initialize=0)
m.x19 = Var(within=Reals, bounds=(0,5), initialize=0)
m.x20 = Var(within=Reals, 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.obj = Objective(sense=minimize, expr= -0.95 * m.i1 - 0.92 * m.i2 - 0.055 *
    m.i3 - 0.74 * m.i4 - 0.27 * m.i5 - 0.42 * m.i6 - 0.55 * m.i7 - 0.945 * m.i8
    - 0.42 * m.i9 - 0.985 * m.i10 - 0.3 * m.i11 - 0.7 * m.i12 - 0.665 * m.i13
    - 0.54 * m.i14 - 0.7 * m.i15 - 0.665 * m.x16 - 0.18 * m.x17 - 0.13 * m.x18
    - m.x19 - 0.17 * m.x20 - 0.035 * m.x21 - 0.56 * m.x22 - 0.88 * m.x23 -
    0.67 * m.x24 - 0.19 * m.x25 - 0.37 * m.x26 - 0.46 * m.x27 - 0.98 * m.x28 -
    0.155 * m.x29 - 0.855 * m.x30)

m.e1 = Constraint(expr= sqrt(m.i1**2 + m.i2**2 + m.i3**2 + m.i4**2 + m.i5**2 +
    m.i6**2 + m.i7**2 + m.i8**2 + m.i9**2 + m.i10**2 + m.i11**2 + m.i12**2 +
    m.i13**2 + m.i14**2 + m.i15**2 + m.x16**2 + m.x17**2 + m.x18**2 + m.x19**2
    + m.x20**2 + m.x21**2 + m.x22**2 + m.x23**2 + m.x24**2 + m.x25**2 + m.x26
    **2 + m.x27**2 + m.x28**2 + m.x29**2 + m.x30**2 + 0.0001) <= 10)
