import numpy as np
import math

DER_num = 40
lines_num = 42
loads_num = 20
sampling_time = 0.05
state_dim = 9

pi = math.pi
# --------Parameter values--------------
Lc = .35e-3
rLc = .03
wc = 31.41

rN = 1e4
wref = 2 * pi * 60
Vnom = 480.0

mp1 = 9.4e-5
mp2 = mp1
mp6 = 12.5e-5
mp7 = mp6
mp3 = 9.4e-5
mp4 = mp3
mp8 = 12.5e-5
mp9 = mp8
mp5 = 9.4e-5
mp11 = mp5
mp10 = 12.5e-5
mp16 = mp10
mp12 = 9.4e-5
mp13 = mp12
mp17 = 12.5e-5
mp18 = mp17
mp14 = 9.4e-5
mp15 = mp14
mp19 = 12.5e-5
mp20 = mp19

mp21 = 9.4e-5
mp22 = mp21
mp26 = 12.5e-5
mp27 = mp26
mp23 = 9.4e-5
mp24 = mp23
mp28 = 12.5e-5
mp29 = mp28
mp25 = 9.4e-5
mp31 = mp25
mp30 = 12.5e-5
mp36 = mp30
mp32 = 9.4e-5
mp33 = mp32
mp37 = 12.5e-5
mp38 = mp37
mp34 = 9.4e-5
mp35 = mp34
mp39 = 12.5e-5
mp40 = mp39

nq1 = 1.3e-3
nq2 = nq1
nq6 = 1.5e-3
nq7 = nq6
nq3 = 1.3e-3
nq4 = nq3
nq8 = 1.5e-3
nq9 = nq8
nq5 = 1.3e-3
nq11 = nq5
nq10 = 1.5e-3
nq16 = nq10
nq12 = 1.3e-3
nq13 = nq12
nq17 = 1.5e-3
nq18 = nq17
nq14 = 1.3e-3
nq15 = nq14
nq19 = 1.5e-3
nq20 = nq19

nq21 = 1.3e-3
nq22 = nq21
nq26 = 1.5e-3
nq27 = nq26
nq23 = 1.3e-3
nq24 = nq23
nq28 = 1.5e-3
nq29 = nq28
nq25 = 1.3e-3
nq31 = nq25
nq30 = 1.5e-3
nq36 = nq30
nq32 = 1.3e-3
nq33 = nq32
nq37 = 1.5e-3
nq38 = nq37
nq34 = 1.3e-3
nq35 = nq34
nq39 = 1.5e-3
nq40 = nq39

# ---------------
kp = 4
ki = 60

# ----Network Data-------
rline1 = .23
Lline1 = .1 / (2 * pi * 60)
rline2 = .35
Lline2 = .58 / (2 * pi * 60)
rline3 = .23
Lline3 = .1 / (2 * pi * 60)
rline4 = .23
Lline4 = .1 / (2 * pi * 60)
rline5 = .35
Lline5 = .58 / (2 * pi * 60)
rline6 = .23
Lline6 = .1 / (2 * pi * 60)
rline7 = .23
Lline7 = .1 / (2 * pi * 60)
rline8 = .35
Lline8 = .58 / (2 * pi * 60)
rline9 = .23
Lline9 = .1 / (2 * pi * 60)
rline10 = .23
Lline10 = .1 / (2 * pi * 60)
rline11 = .35
Lline11 = .58 / (2 * pi * 60)
rline12 = .23
Lline12 = .1 / (2 * pi * 60)
rline13 = .23
Lline13 = .1 / (2 * pi * 60)
rline14 = .35
Lline14 = .58 / (2 * pi * 60)
rline15 = .23
Lline15 = .1 / (2 * pi * 60)
rline16 = .23
Lline16 = .1 / (2 * pi * 60)
rline17 = .35
Lline17 = .58 / (2 * pi * 60)
rline18 = .23
Lline18 = .1 / (2 * pi * 60)
rline19 = .23
Lline19 = .1 / (2 * pi * 60)
rline20 = .35
Lline20 = .58 / (2 * pi * 60)

# ----Network Data-------
rline21 = .23
Lline21 = .1 / (2 * pi * 60)
rline22 = .35
Lline22 = .58 / (2 * pi * 60)
rline23 = .23
Lline23 = .1 / (2 * pi * 60)
rline24 = .23
Lline24 = .1 / (2 * pi * 60)
rline25 = .35
Lline25 = .58 / (2 * pi * 60)
rline26 = .23
Lline26 = .1 / (2 * pi * 60)
rline27 = .23
Lline27 = .1 / (2 * pi * 60)
rline28 = .35
Lline28 = .58 / (2 * pi * 60)
rline29 = .23
Lline29 = .1 / (2 * pi * 60)
rline30 = .23
Lline30 = .1 / (2 * pi * 60)
rline31 = .35
Lline31 = .58 / (2 * pi * 60)
rline32 = .23
Lline32 = .1 / (2 * pi * 60)
rline33 = .23
Lline33 = .1 / (2 * pi * 60)
rline34 = .35
Lline34 = .58 / (2 * pi * 60)
rline35 = .23
Lline35 = .1 / (2 * pi * 60)
rline36 = .23
Lline36 = .1 / (2 * pi * 60)
rline37 = .35
Lline37 = .58 / (2 * pi * 60)
rline38 = .23
Lline38 = .1 / (2 * pi * 60)
rline39 = .23
Lline39 = .1 / (2 * pi * 60)
rline40 = .35
Lline40 = .58 / (2 * pi * 60)

# vb 18 --> 21
rline41 = .23
Lline41 = .1 / (2 * pi * 60)
# vb 20 --> 23
rline42 = .35
Lline42 = .58 / (2 * pi * 60)

QF = 0.5
Rload1 = 2
Lload1 = QF * 2 / (2 * pi * 60)
Rload2 = 2
Lload2 = QF * 1 / (2 * pi * 60)
Rload3 = 2
Lload3 = QF * 2 / (2 * pi * 60)
Rload4 = 2
Lload4 = QF * 1 / (2 * pi * 60)
Rload5 = 2
Lload5 = QF * 2 / (2 * pi * 60)
Rload6 = 2
Lload6 = QF * 1 / (2 * pi * 60)
Rload7 = 2
Lload7 = QF * 2 / (2 * pi * 60)
Rload8 = 2
Lload8 = QF * 1 / (2 * pi * 60)
Rload9 = 2
Lload9 = QF * 2 / (2 * pi * 60)
Rload10 = 2
Lload10 = QF * 1 / (2 * pi * 60)
Rload11 = 2
Lload11 = QF * 2 / (2 * pi * 60)
Rload12 = 2
Lload12 = QF * 1 / (2 * pi * 60)
Rload13 = 2
Lload13 = QF * 2 / (2 * pi * 60)
Rload14 = 2
Lload14 = QF * 1 / (2 * pi * 60)
Rload15 = 2
Lload15 = QF * 2 / (2 * pi * 60)
Rload16 = 2
Lload16 = QF * 1 / (2 * pi * 60)
Rload17 = 2
Lload17 = QF * 2 / (2 * pi * 60)
Rload18 = 2
Lload18 = QF * 1 / (2 * pi * 60)
Rload19 = 2
Lload19 = QF * 2 / (2 * pi * 60)
Rload20 = 2
Lload20 = QF * 1 / (2 * pi * 60)

# ------------Controller Parameters------------------------
a_ctrl = 400
# Physical Graph
AP = 60 * np.array([[.0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                     0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 1
                    [1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                     0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 2
                    [0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                     0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 3
                    [0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                     0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 4
                    [0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                     0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 5
                    [1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                     0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 6
                    [0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                     0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 7
                    [0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                     0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 8
                    [0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                     0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 9
                    [0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0,
                     0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 10
                    [0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0,
                     0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 11
                    [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0,
                     0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 12
                    [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0,
                     0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 13
                    [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0,
                     0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 14
                    [0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1,
                     0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 15
                    [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0,
                     1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 16
                    [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0,
                     0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 17
                    [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0,
                     1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 18
                    [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1,
                     0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 19
                    [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0,
                     0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 20
                    [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0,
                     0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 21
                    [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0,
                     1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 22
                    [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1,
                     0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 23
                    [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0,
                     0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 24
                    [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1,
                     0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 25
                    [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                     1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 26
                    [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                     0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 27
                    [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                     0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 28
                    [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                     0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 29
                    [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                     0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0],  # 30
                    [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                     0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0],  # 31
                    [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                     0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0],  # 32
                    [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                     0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0],  # 33
                    [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                     0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0],  # 34
                    [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                     0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1],  # 35
                    [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                     0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0],  # 36
                    [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                     0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0],  # 37
                    [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                     0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0],  # 38
                    [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                     0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1],  # 39
                    [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                     0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0]  # 40
                    ])

D = np.array([[sum(AP[0]), 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0],
              [0, sum(AP[1]), 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0],
              [0, 0, sum(AP[2]), 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0],
              [0, 0, 0, sum(AP[3]), 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0],
              [0, 0, 0, 0, sum(AP[4]), 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0],
              [0, 0, 0, 0, 0, sum(AP[5]), 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0],
              [0, 0, 0, 0, 0, 0, sum(AP[6]), 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0],
              [0, 0, 0, 0, 0, 0, 0, sum(AP[7]), 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, sum(AP[8]), 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, sum(AP[9]), 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, sum(AP[10]), 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, sum(AP[11]), 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, sum(AP[12]), 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, sum(AP[13]), 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, sum(AP[14]), 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, sum(AP[15]), 0, 0, 0, 0,
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, sum(AP[16]), 0, 0, 0,
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, sum(AP[17]), 0, 0,
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, sum(AP[18]), 0,
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, sum(AP[19]),
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0,
               sum(AP[20]), 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0,
               0, sum(AP[21]), 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0,
               0, 0, sum(AP[22]), 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0,
               0, 0, 0, sum(AP[23]), 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0,
               0, 0, 0, 0, sum(AP[24]), 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0,
               0, 0, 0, 0, 0, sum(AP[25]), 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0,
               0, 0, 0, 0, 0, 0, sum(AP[26]), 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0,
               0, 0, 0, 0, 0, 0, 0, sum(AP[27]), 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0,
               0, 0, 0, 0, 0, 0, 0, 0, sum(AP[28]), 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0,
               0, 0, 0, 0, 0, 0, 0, 0, 0, sum(AP[29]), 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0,
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0, sum(AP[30]), 0, 0, 0, 0, 0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0,
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, sum(AP[31]), 0, 0, 0, 0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0,
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, sum(AP[32]), 0, 0, 0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0,
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, sum(AP[33]), 0, 0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0,
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, sum(AP[34]), 0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0,
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, sum(AP[35]), 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0,
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, sum(AP[36]), 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0,
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, sum(AP[37]), 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0,
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, sum(AP[38]), 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0,
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, sum(AP[39])]
              ])

L = D - AP

# Pinning gain to the reference frequency
G = np.array([[1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0],
              [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0]
              ])

Physical_Graph = np.array([[0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                            0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 1
                           [0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                            0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 2
                           [0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                            0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 3
                           [0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                            0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 4
                           [0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                            0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 5
                           [1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                            0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 6
                           [0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                            0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 7
                           [0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                            0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 8
                           [0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                            0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 9
                           [0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0,
                            0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 10
                           [0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0,
                            0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 11
                           [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0,
                            0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 12
                           [0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0,
                            0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 13
                           [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0,
                            0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 14
                           [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1,
                            0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 15
                           [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0,
                            0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 16
                           [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0,
                            0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 17
                           [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0,
                            0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 18
                           [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0,
                            0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 19
                           [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0,
                            0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 20
                           [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0,
                            0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 21
                           [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                            0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 22
                           [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1,
                            0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 23
                           [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                            0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 24
                           [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                            0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 25
                           [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                            1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 26
                           [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                            0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 27
                           [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                            0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 28
                           [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                            0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],  # 29
                           [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                            0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0],  # 30
                           [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                            0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0],  # 31
                           [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                            0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0],  # 32
                           [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                            0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0],  # 33
                           [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                            0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0],  # 34
                           [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                            0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1],  # 35
                           [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                            0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0],  # 36
                           [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                            0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0],  # 37
                           [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                            0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0],  # 38
                           [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                            0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0],  # 39
                           [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
                            0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0]  # 40
                           ])

Distance_Mask = np.array([[0, 3, 4, 7, 8, 1, 2, 5, 6, 9, 6, 9, 10, 13, 14, 7, 8, 11, 12, 15,
                           12, 15, 16, 19, 20, 13, 14, 17, 18, 21, 18, 20, 20, 20, 20, 20, 20, 20, 20, 20],  # 1
                          [3, 0, 1, 4, 5, 2, 1, 2, 3, 6, 4, 7, 8, 11, 12, 5, 6, 9, 10, 13,
                           10, 13, 14, 17, 18, 11, 12, 15, 16, 19, 16, 18, 20, 20, 20, 20, 20, 20, 20, 20],  # 2
                          [4, 1, 0, 3, 4, 3, 2, 1, 2, 5, 2, 5, 6, 9, 10, 3, 4, 7, 8, 11,
                           9, 12, 13, 16, 17, 10, 11, 14, 15, 18, 15, 17, 19, 20, 20, 20, 20, 20, 20, 20],  # 3
                          [7, 4, 3, 0, 1, 6, 5, 2, 1, 2, 3, 6, 3, 6, 7, 4, 5, 4, 5, 8,
                           5, 8, 9, 12, 13, 6, 7, 10, 11, 14, 11, 14, 15, 18, 19, 12, 13, 16, 17, 20],  # 4
                          [8, 5, 4, 1, 0, 7, 6, 3, 2, 1, 4, 3, 2, 5, 6, 5, 4, 3, 4, 7,
                           4, 7, 8, 11, 12, 5, 6, 9, 10, 13, 10, 13, 14, 17, 18, 11, 12, 15, 16, 19],  # 5
                          [1, 2, 3, 6, 7, 0, 1, 4, 5, 8, 5, 8, 9, 12, 13, 6, 7, 10, 11, 14,
                           11, 14, 15, 18, 19, 12, 13, 16, 17, 20, 17, 19, 20, 20, 20, 20, 20, 20, 20, 20],  # 6
                          [2, 1, 2, 5, 6, 1, 0, 3, 4, 7, 4, 7, 8, 11, 12, 5, 6, 9, 10, 13,
                           10, 13, 14, 17, 18, 11, 12, 15, 16, 19, 16, 18, 19, 19, 20, 20, 20, 20, 20, 20],  # 7
                          [5, 2, 1, 2, 3, 4, 3, 0, 1, 4, 1, 4, 5, 8, 9, 2, 3, 5, 6, 9,
                           8, 11, 12, 15, 16, 9, 10, 13, 14, 17, 14, 16, 18, 19, 20, 20, 20, 20, 20, 20],  # 8
                          [6, 3, 2, 1, 2, 5, 4, 1, 0, 3, 2, 5, 4, 7, 8, 3, 4, 5, 6, 9,
                           9, 12, 13, 16, 17, 10, 11, 14, 15, 18, 15, 17, 19, 20, 20, 20, 20, 20, 20, 20],  # 9
                          [9, 6, 5, 2, 1, 8, 7, 4, 3, 0, 5, 2, 1, 4, 5, 4, 3, 2, 3, 6,
                           3, 6, 7, 10, 11, 4, 5, 8, 9, 12, 9, 12, 13, 16, 17, 10, 11, 14, 15, 18],  # 10
                          [6, 3, 2, 3, 4, 5, 4, 1, 2, 5, 0, 3, 4, 7, 8, 1, 2, 5, 6, 9,
                           6, 9, 10, 13, 14, 7, 8, 11, 12, 15, 12, 14, 16, 17, 18, 20, 20, 20, 20, 20],  # 11
                          [9, 6, 5, 4, 3, 8, 7, 4, 5, 2, 3, 0, 1, 4, 5, 2, 1, 2, 3, 6,
                           3, 6, 7, 10, 11, 4, 5, 8, 9, 12, 9, 12, 13, 16, 17, 13, 14, 17, 18, 21],  # 12
                          [10, 7, 6, 3, 2, 9, 8, 5, 4, 1, 4, 1, 0, 3, 4, 3, 2, 1, 2, 5,
                           2, 5, 6, 9, 10, 3, 4, 7, 8, 10, 8, 11, 12, 15, 16, 12, 13, 16, 17, 20],  # 13
                          [13, 10, 9, 6, 5, 12, 11, 8, 7, 4, 7, 4, 3, 0, 1, 6, 5, 2, 1, 2,
                           3, 4, 3, 6, 7, 4, 5, 4, 5, 8, 5, 9, 12, 13, 6, 7, 10, 11, 12, 15],  # 14
                          [14, 11, 10, 7, 6, 13, 12, 9, 8, 5, 8, 5, 4, 1, 0, 7, 6, 3, 2, 1,
                           4, 3, 2, 5, 6, 5, 4, 3, 4, 7, 4, 7, 6, 9, 10, 5, 6, 8, 9, 13],  # 15
                          [7, 4, 3, 4, 5, 6, 5, 2, 3, 6, 1, 2, 3, 6, 7, 0, 1, 4, 5, 8,
                           5, 8, 9, 12, 13, 6, 7, 10, 11, 14, 11, 14, 15, 18, 19, 12, 13, 16, 17, 20],  # 16
                          [8, 5, 4, 5, 4, 7, 6, 3, 4, 3, 2, 1, 2, 5, 6, 1, 0, 3, 4, 7,
                           4, 7, 8, 11, 12, 5, 6, 9, 10, 13, 10, 13, 14, 17, 18, 11, 12, 15, 16, 19],  # 17
                          [11, 8, 7, 4, 3, 10, 9, 6, 5, 2, 5, 2, 1, 2, 3, 4, 3, 0, 1, 4,
                           1, 4, 5, 8, 9, 2, 3, 6, 7, 10, 7, 10, 11, 14, 15, 8, 9, 12, 13, 16],  # 18
                          [12, 9, 8, 5, 4, 11, 10, 7, 6, 3, 6, 3, 2, 1, 2, 5, 4, 1, 0, 3,
                           2, 5, 4, 7, 8, 3, 4, 7, 8, 11, 8, 11, 12, 15, 16, 9, 10, 13, 14, 17],  # 19
                          [15, 12, 11, 8, 7, 14, 13, 10, 9, 6, 9, 6, 5, 2, 1, 8, 7, 4, 3, 0,
                           5, 2, 1, 4, 5, 4, 3, 2, 3, 6, 3, 6, 7, 10, 11, 4, 5, 8, 9, 12],  # 20
                          [12, 10, 9, 5, 4, 11, 10, 8, 9, 3, 6, 3, 2, 3, 4, 5, 4, 1, 2, 5,
                           0, 3, 4, 7, 8, 1, 2, 5, 6, 9, 6, 9, 10, 13, 14, 7, 8, 11, 12, 15],  # 21
                          [15, 13, 12, 8, 7, 14, 13, 11, 12, 6, 9, 6, 5, 4, 3, 8, 7, 4, 5, 2,
                           3, 0, 1, 4, 5, 2, 1, 2, 3, 6, 4, 7, 8, 11, 12, 5, 6, 9, 10, 13],  # 22
                          [16, 14, 13, 9, 8, 15, 14, 12, 13, 7, 10, 7, 6, 3, 2, 9, 8, 5, 4, 1,
                           4, 1, 0, 3, 4, 3, 2, 1, 2, 5, 2, 5, 6, 9, 10, 3, 4, 7, 8, 11],  # 23
                          [19, 17, 16, 12, 11, 18, 17, 15, 16, 10, 13, 10, 9, 6, 5, 12, 11, 8, 7, 4,
                           7, 4, 3, 0, 1, 6, 5, 2, 1, 2, 3, 6, 3, 6, 7, 4, 5, 4, 5, 8],  # 24
                          [20, 18, 17, 13, 12, 19, 18, 16, 17, 11, 14, 11, 10, 7, 6, 13, 12, 9, 8, 5,
                           8, 5, 4, 1, 0, 7, 6, 3, 2, 1, 4, 3, 2, 5, 6, 5, 4, 3, 4, 7],  # 25
                          [13, 11, 10, 6, 5, 12, 11, 9, 10, 4, 7, 4, 3, 4, 5, 6, 5, 2, 3, 4,
                           1, 2, 3, 6, 7, 0, 1, 4, 5, 8, 5, 8, 9, 12, 13, 6, 7, 10, 11, 14],  # 26
                          [14, 12, 11, 7, 6, 13, 12, 10, 11, 5, 8, 5, 4, 5, 4, 7, 6, 3, 4, 5,
                           2, 1, 2, 5, 6, 1, 0, 3, 4, 7, 4, 7, 8, 11, 12, 5, 6, 9, 10, 13],  # 27
                          [17, 15, 14, 10, 9, 16, 15, 13, 14, 8, 11, 8, 7, 4, 3, 10, 9, 6, 7, 2,
                           5, 2, 1, 2, 3, 4, 3, 0, 1, 4, 1, 4, 5, 8, 9, 2, 3, 5, 6, 9],  # 28
                          [18, 16, 15, 11, 10, 17, 16, 14, 15, 9, 12, 9, 8, 5, 4, 11, 10, 7, 8, 3,
                           6, 3, 2, 1, 2, 5, 4, 1, 0, 3, 2, 5, 4, 7, 8, 3, 4, 5, 6, 9],  # 29
                          [21, 19, 18, 14, 13, 20, 19, 17, 18, 12, 15, 12, 10, 8, 7, 14, 13, 10, 11, 6,
                           9, 6, 5, 2, 1, 8, 7, 4, 3, 0, 5, 2, 1, 4, 5, 4, 3, 2, 3, 6],  # 30
                          [18, 16, 15, 11, 10, 20, 16, 14, 15, 9, 12, 9, 8, 5, 4, 11, 10, 7, 8, 3,
                           6, 3, 2, 3, 4, 5, 4, 1, 2, 5, 0, 3, 4, 7, 8, 1, 2, 5, 6, 9],  # 31
                          [20, 18, 17, 14, 13, 20, 18, 16, 17, 12, 14, 12, 11, 8, 7, 14, 13, 10, 11, 6,
                           9, 6, 5, 4, 3, 8, 7, 4, 5, 2, 3, 0, 1, 4, 5, 2, 1, 2, 3, 6],  # 32
                          [20, 20, 19, 15, 14, 20, 19, 18, 19, 13, 16, 13, 12, 9, 6, 15, 14, 11, 12, 7,
                           10, 7, 6, 3, 2, 9, 8, 5, 4, 1, 4, 1, 0, 3, 4, 3, 2, 1, 2, 5],  # 33
                          [20, 20, 20, 18, 17, 20, 19, 19, 20, 16, 17, 16, 15, 12, 9, 18, 17, 14, 15, 10,
                           13, 10, 9, 6, 5, 12, 11, 8, 7, 4, 7, 4, 3, 0, 1, 6, 5, 2, 1, 2],  # 34
                          [20, 20, 20, 19, 18, 20, 20, 20, 20, 17, 18, 17, 16, 13, 10, 19, 18, 15, 16, 11,
                           14, 11, 10, 7, 6, 13, 12, 9, 8, 5, 8, 5, 4, 1, 0, 7, 6, 3, 2, 1],  # 35
                          [20, 20, 20, 12, 11, 20, 20, 20, 20, 10, 20, 13, 12, 6, 5, 12, 11, 8, 9, 4,
                           7, 4, 3, 4, 5, 6, 5, 2, 3, 6, 1, 2, 3, 6, 7, 0, 1, 4, 5, 8],  # 36
                          [20, 20, 20, 13, 12, 20, 20, 20, 20, 11, 20, 14, 13, 7, 6, 13, 12, 9, 10, 5,
                           8, 5, 4, 5, 4, 7, 6, 3, 4, 3, 2, 1, 2, 5, 6, 1, 0, 3, 4, 7],  # 37
                          [20, 20, 20, 16, 15, 20, 20, 20, 20, 14, 20, 17, 16, 10, 8, 16, 15, 12, 13, 8,
                           11, 8, 7, 4, 3, 10, 9, 6, 5, 2, 5, 2, 1, 2, 3, 4, 3, 0, 1, 4],  # 38
                          [20, 20, 20, 17, 16, 20, 20, 20, 20, 15, 20, 18, 17, 11, 9, 17, 16, 13, 14, 9,
                           12, 9, 8, 5, 4, 11, 10, 7, 6, 3, 6, 3, 2, 1, 2, 5, 4, 1, 0, 3],  # 39
                          [20, 20, 20, 20, 19, 20, 20, 20, 20, 18, 20, 21, 20, 12, 13, 20, 19, 16, 17, 12,
                           15, 12, 11, 8, 7, 14, 13, 10, 9, 6, 9, 6, 5, 2, 1, 8, 7, 4, 3, 0]  # 40
                          ])

# add 0, to meet the difference between MATLAB and python, shape=(201,)
x0 = np.array([0, 0, 0, 0, 0, 0,  # 1
               0, 0, 0, 0, 0,  # 2
               0, 0, 0, 0, 0,  # 3
               0, 0, 0, 0, 0,  # 4
               0, 0, 0, 0, 0,  # 5
               0, 0, 0, 0, 0,  # 6
               0, 0, 0, 0, 0,  # 7
               0, 0, 0, 0, 0,  # 8
               0, 0, 0, 0, 0,  # 9
               0, 0, 0, 0, 0,  # 10
               0, 0, 0, 0, 0,  # 11
               0, 0, 0, 0, 0,  # 12
               0, 0, 0, 0, 0,  # 13
               0, 0, 0, 0, 0,  # 14
               0, 0, 0, 0, 0,  # 15
               0, 0, 0, 0, 0,  # 16
               0, 0, 0, 0, 0,  # 17
               0, 0, 0, 0, 0,  # 18
               0, 0, 0, 0, 0,  # 19
               0, 0, 0, 0, 0,  # 20
               0, 0, 0, 0, 0,  # 21
               0, 0, 0, 0, 0,  # 22
               0, 0, 0, 0, 0,  # 23
               0, 0, 0, 0, 0,  # 24
               0, 0, 0, 0, 0,  # 25
               0, 0, 0, 0, 0,  # 26
               0, 0, 0, 0, 0,  # 27
               0, 0, 0, 0, 0,  # 28
               0, 0, 0, 0, 0,  # 29
               0, 0, 0, 0, 0,  # 30
               0, 0, 0, 0, 0,  # 31
               0, 0, 0, 0, 0,  # 32
               0, 0, 0, 0, 0,  # 33
               0, 0, 0, 0, 0,  # 34
               0, 0, 0, 0, 0,  # 35
               0, 0, 0, 0, 0,  # 36
               0, 0, 0, 0, 0,  # 37
               0, 0, 0, 0, 0,  # 38
               0, 0, 0, 0, 0,  # 39
               0, 0, 0, 0, 0,  # 40
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               2 * pi * 60, 2 * pi * 60, 2 * pi * 60, 2 * pi * 60, 2 * pi * 60, 2 * pi * 60, 2 * pi * 60, 2 * pi * 60,
               2 * pi * 60, 2 * pi * 60, 2 * pi * 60, 2 * pi * 60, 2 * pi * 60, 2 * pi * 60, 2 * pi * 60, 2 * pi * 60,
               2 * pi * 60, 2 * pi * 60, 2 * pi * 60, 2 * pi * 60, 2 * pi * 60, 2 * pi * 60, 2 * pi * 60, 2 * pi * 60,
               2 * pi * 60, 2 * pi * 60, 2 * pi * 60, 2 * pi * 60, 2 * pi * 60, 2 * pi * 60, 2 * pi * 60, 2 * pi * 60,
               2 * pi * 60, 2 * pi * 60, 2 * pi * 60, 2 * pi * 60, 2 * pi * 60, 2 * pi * 60, 2 * pi * 60, 2 * pi * 60,
               Vnom, Vnom, Vnom, Vnom, Vnom, Vnom, Vnom, Vnom, Vnom, Vnom,
               Vnom, Vnom, Vnom, Vnom, Vnom, Vnom, Vnom, Vnom, Vnom, Vnom,
               Vnom, Vnom, Vnom, Vnom, Vnom, Vnom, Vnom, Vnom, Vnom, Vnom,
               Vnom, Vnom, Vnom, Vnom, Vnom, Vnom, Vnom, Vnom, Vnom, Vnom,
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
               0, 0, 0, 0, 0, 0, 0, 0, 0, 0])

mp = np.array(
    [mp1, mp2, mp3, mp4, mp5, mp6, mp7, mp8, mp9, mp10, mp11, mp12, mp13, mp14, mp15, mp16, mp17, mp18, mp19, mp20,
     mp21, mp22, mp23, mp24, mp25, mp26, mp27, mp28, mp29, mp30, mp31, mp32, mp33, mp34, mp35, mp36, mp37, mp38, mp39,
     mp40])
nq = np.array(
    [nq1, nq2, nq3, nq4, nq5, nq6, nq7, nq8, nq9, nq10, nq11, nq12, nq13, nq14, nq15, nq16, nq17, nq18, nq19, nq20,
     nq21, nq22, nq23, nq24, nq25, nq26, nq27, nq28, nq29, nq30, nq31, nq32, nq33, nq34, nq35, nq36, nq37, nq38, nq39,
     nq40])
     

#import csv     
#obs_min = []
#with open('algorithms/envs/PowerGrid/configs/obs_min.csv', 'r') as f:
    #reader = csv.reader(f)
    #for row in reader:
        #obs_min.append(row)
#obs_min = np.array(obs_min,dtype=float)

#obs_max = []
#with open('algorithms/envs/PowerGrid/configs/obs_max.csv', 'r') as f:
    #reader = csv.reader(f)
    #for row in reader:
        #obs_max.append(row)
#obs_max = np.array(obs_max,dtype=float)
#obs_mean = (obs_max + obs_min)/2
#obs_std = (obs_max - obs_min)/2
obs_mean = 0

obs_std = 1