ltbams 1.0.12__py3-none-any.whl → 1.0.13__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (45) hide show
  1. ams/_version.py +3 -3
  2. ams/core/matprocessor.py +170 -104
  3. ams/io/matpower.py +4 -0
  4. ams/io/psse.py +2 -0
  5. ams/opt/exprcalc.py +11 -0
  6. ams/routines/grbopt.py +2 -0
  7. ams/routines/pypower.py +8 -0
  8. ams/routines/routine.py +118 -1
  9. ams/shared.py +30 -2
  10. ams/system.py +10 -0
  11. docs/source/index.rst +4 -3
  12. docs/source/release-notes.rst +8 -0
  13. {ltbams-1.0.12.dist-info → ltbams-1.0.13.dist-info}/METADATA +4 -2
  14. {ltbams-1.0.12.dist-info → ltbams-1.0.13.dist-info}/RECORD +17 -45
  15. {ltbams-1.0.12.dist-info → ltbams-1.0.13.dist-info}/top_level.txt +0 -1
  16. tests/__init__.py +0 -0
  17. tests/test_1st_system.py +0 -64
  18. tests/test_addressing.py +0 -40
  19. tests/test_case.py +0 -301
  20. tests/test_cli.py +0 -34
  21. tests/test_export_csv.py +0 -89
  22. tests/test_group.py +0 -83
  23. tests/test_interface.py +0 -238
  24. tests/test_io.py +0 -190
  25. tests/test_jumper.py +0 -27
  26. tests/test_known_good.py +0 -267
  27. tests/test_matp.py +0 -437
  28. tests/test_model.py +0 -54
  29. tests/test_omodel.py +0 -119
  30. tests/test_paths.py +0 -89
  31. tests/test_report.py +0 -251
  32. tests/test_repr.py +0 -21
  33. tests/test_routine.py +0 -178
  34. tests/test_rtn_acopf.py +0 -75
  35. tests/test_rtn_dcopf.py +0 -121
  36. tests/test_rtn_dcopf2.py +0 -103
  37. tests/test_rtn_ed.py +0 -279
  38. tests/test_rtn_opf.py +0 -142
  39. tests/test_rtn_pflow.py +0 -147
  40. tests/test_rtn_pypower.py +0 -315
  41. tests/test_rtn_rted.py +0 -273
  42. tests/test_rtn_uc.py +0 -248
  43. tests/test_service.py +0 -73
  44. {ltbams-1.0.12.dist-info → ltbams-1.0.13.dist-info}/WHEEL +0 -0
  45. {ltbams-1.0.12.dist-info → ltbams-1.0.13.dist-info}/entry_points.txt +0 -0
tests/test_rtn_pypower.py DELETED
@@ -1,315 +0,0 @@
1
- """
2
- Test wrapper routines of PYPOWER.
3
- """
4
- import unittest
5
-
6
- import ams
7
- from ams.shared import skip_unittest_without_PYPOWER
8
-
9
-
10
- class TestDCPF1(unittest.TestCase):
11
- """
12
- Test routine `DCPF1`.
13
- """
14
-
15
- def setUp(self) -> None:
16
- self.ss = ams.load(ams.get_case("5bus/pjm5bus_demo.json"),
17
- setup=True, default_config=True, no_output=True)
18
- # decrease load first
19
- self.ss.PQ.set(src='p0', attr='v', idx=['PQ_1', 'PQ_2'], value=[0.3, 0.3])
20
-
21
- def test_init(self):
22
- """
23
- Test initialization.
24
- """
25
- self.ss.DCPF1.init()
26
- self.assertTrue(self.ss.DCPF1.initialized, "DCPF1 initialization failed!")
27
-
28
- @skip_unittest_without_PYPOWER
29
- def test_trip_gen(self):
30
- """
31
- Test generator tripping.
32
- """
33
- stg = 'PV_1'
34
- self.ss.StaticGen.set(src='u', idx=stg, attr='v', value=0)
35
-
36
- self.ss.DCPF1.update()
37
- self.ss.DCPF1.run()
38
- self.assertTrue(self.ss.DCPF1.converged, "DCPF1 did not converge under generator trip!")
39
- self.assertAlmostEqual(self.ss.DCPF1.get(src='pg', attr='v', idx=stg),
40
- 0, places=6,
41
- msg="Generator trip does not take effect!")
42
-
43
- self.ss.StaticGen.set(src='u', idx=stg, attr='v', value=1) # reset
44
-
45
- @skip_unittest_without_PYPOWER
46
- def test_trip_line(self):
47
- """
48
- Test line tripping.
49
- """
50
- self.ss.Line.set(src='u', attr='v', idx='Line_3', value=0)
51
-
52
- self.ss.DCPF1.update()
53
- self.ss.DCPF1.run()
54
- self.assertTrue(self.ss.DCPF1.converged, "DCPF1 did not converge under line trip!")
55
- self.assertAlmostEqual(self.ss.DCPF1.get(src='plf', attr='v', idx='Line_3'),
56
- 0, places=6,
57
- msg="Line trip does not take effect!")
58
-
59
- self.ss.Line.alter(src='u', idx='Line_3', value=1) # reset
60
-
61
- @skip_unittest_without_PYPOWER
62
- def test_set_load(self):
63
- """
64
- Test setting and tripping load.
65
- """
66
- # --- run DCPF1 ---
67
- self.ss.DCPF1.run()
68
- pgs = self.ss.DCPF1.pg.v.sum()
69
-
70
- # --- set load ---
71
- self.ss.PQ.set(src='p0', attr='v', idx='PQ_1', value=0.1)
72
- self.ss.DCPF1.update()
73
-
74
- self.ss.DCPF1.run()
75
- pgs_pqt = self.ss.DCPF1.pg.v.sum()
76
- self.assertLess(pgs_pqt, pgs, "Load set does not take effect!")
77
-
78
- # --- trip load ---
79
- self.ss.PQ.set(src='u', attr='v', idx='PQ_2', value=0)
80
- self.ss.DCPF1.update()
81
-
82
- self.ss.DCPF1.run()
83
- pgs_pqt2 = self.ss.DCPF1.pg.v.sum()
84
- self.assertLess(pgs_pqt2, pgs_pqt, "Load trip does not take effect!")
85
-
86
-
87
- class TestPFlow1(unittest.TestCase):
88
- """
89
- Test routine `PFlow1`.
90
- """
91
-
92
- def setUp(self) -> None:
93
- self.ss = ams.load(ams.get_case("5bus/pjm5bus_demo.json"),
94
- setup=True, default_config=True, no_output=True)
95
- # decrease load first
96
- self.ss.PQ.set(src='p0', attr='v', idx=['PQ_1', 'PQ_2'], value=[0.3, 0.3])
97
-
98
- def test_init(self):
99
- """
100
- Test initialization.
101
- """
102
- self.ss.PFlow1.init()
103
- self.assertTrue(self.ss.PFlow1.initialized, "PFlow1 initialization failed!")
104
-
105
- @skip_unittest_without_PYPOWER
106
- def test_trip_gen(self):
107
- """
108
- Test generator tripping.
109
- """
110
- stg = 'PV_1'
111
- self.ss.StaticGen.set(src='u', idx=stg, attr='v', value=0)
112
-
113
- self.ss.PFlow1.update()
114
- self.ss.PFlow1.run()
115
- self.assertTrue(self.ss.PFlow1.converged, "PFlow1 did not converge under generator trip!")
116
- self.assertAlmostEqual(self.ss.PFlow1.get(src='pg', attr='v', idx=stg),
117
- 0, places=6,
118
- msg="Generator trip does not take effect!")
119
-
120
- self.ss.StaticGen.set(src='u', idx=stg, attr='v', value=1) # reset
121
-
122
- @skip_unittest_without_PYPOWER
123
- def test_trip_line(self):
124
- """
125
- Test line tripping.
126
- """
127
- self.ss.Line.set(src='u', attr='v', idx='Line_3', value=0)
128
-
129
- self.ss.PFlow1.update()
130
- self.ss.PFlow1.run()
131
- self.assertTrue(self.ss.PFlow1.converged, "PFlow1 did not converge under line trip!")
132
- self.assertAlmostEqual(self.ss.PFlow1.get(src='plf', attr='v', idx='Line_3'),
133
- 0, places=6,
134
- msg="Line trip does not take effect!")
135
-
136
- self.ss.Line.alter(src='u', idx='Line_3', value=1) # reset
137
-
138
- @skip_unittest_without_PYPOWER
139
- def test_set_load(self):
140
- """
141
- Test setting and tripping load.
142
- """
143
- # --- run PFlow1 ---
144
- self.ss.PFlow1.run()
145
- pgs = self.ss.PFlow1.pg.v.sum()
146
-
147
- # --- set load ---
148
- self.ss.PQ.set(src='p0', attr='v', idx='PQ_1', value=0.1)
149
- self.ss.PFlow1.update()
150
-
151
- self.ss.PFlow1.run()
152
- pgs_pqt = self.ss.PFlow1.pg.v.sum()
153
- self.assertLess(pgs_pqt, pgs, "Load set does not take effect!")
154
-
155
- # --- trip load ---
156
- self.ss.PQ.set(src='u', attr='v', idx='PQ_2', value=0)
157
- self.ss.PFlow1.update()
158
-
159
- self.ss.PFlow1.run()
160
- pgs_pqt2 = self.ss.PFlow1.pg.v.sum()
161
- self.assertLess(pgs_pqt2, pgs_pqt, "Load trip does not take effect!")
162
-
163
-
164
- class TestDCOPF1(unittest.TestCase):
165
- """
166
- Test routine `DCOPF1`.
167
- """
168
-
169
- def setUp(self) -> None:
170
- self.ss = ams.load(ams.get_case("5bus/pjm5bus_demo.json"),
171
- setup=True, default_config=True, no_output=True)
172
- # decrease load first
173
- self.ss.PQ.set(src='p0', attr='v', idx=['PQ_1', 'PQ_2'], value=[0.3, 0.3])
174
-
175
- def test_init(self):
176
- """
177
- Test initialization.
178
- """
179
- self.ss.DCOPF1.init()
180
- self.assertTrue(self.ss.DCOPF1.initialized, "DCOPF initialization failed!")
181
-
182
- @skip_unittest_without_PYPOWER
183
- def test_trip_gen(self):
184
- """
185
- Test generator tripping.
186
- """
187
- stg = 'PV_1'
188
- self.ss.StaticGen.set(src='u', idx=stg, attr='v', value=0)
189
-
190
- self.ss.DCOPF1.update()
191
- self.ss.DCOPF1.run()
192
- self.assertTrue(self.ss.DCOPF1.converged, "DCOPF did not converge under generator trip!")
193
- self.assertAlmostEqual(self.ss.DCOPF1.get(src='pg', attr='v', idx=stg),
194
- 0, places=6,
195
- msg="Generator trip does not take effect!")
196
-
197
- self.ss.StaticGen.set(src='u', idx=stg, attr='v', value=1) # reset
198
-
199
- @skip_unittest_without_PYPOWER
200
- def test_trip_line(self):
201
- """
202
- Test line tripping.
203
- """
204
- self.ss.Line.set(src='u', attr='v', idx='Line_3', value=0)
205
-
206
- self.ss.DCOPF1.update()
207
- self.ss.DCOPF1.run()
208
- self.assertTrue(self.ss.DCOPF1.converged, "DCOPF1 did not converge under line trip!")
209
- self.assertAlmostEqual(self.ss.DCOPF1.get(src='plf', attr='v', idx='Line_3'),
210
- 0, places=6,
211
- msg="Line trip does not take effect!")
212
-
213
- self.ss.Line.alter(src='u', idx='Line_3', value=1) # reset
214
-
215
- @skip_unittest_without_PYPOWER
216
- def test_set_load(self):
217
- """
218
- Test setting and tripping load.
219
- """
220
- # --- run DCOPF1 ---
221
- self.ss.DCOPF1.run()
222
- pgs = self.ss.DCOPF1.pg.v.sum()
223
-
224
- # --- set load ---
225
- self.ss.PQ.set(src='p0', attr='v', idx='PQ_1', value=0.1)
226
- self.ss.DCOPF1.update()
227
-
228
- self.ss.DCOPF1.run()
229
- pgs_pqt = self.ss.DCOPF1.pg.v.sum()
230
- self.assertLess(pgs_pqt, pgs, "Load set does not take effect!")
231
-
232
- # --- trip load ---
233
- self.ss.PQ.set(src='u', attr='v', idx='PQ_2', value=0)
234
- self.ss.DCOPF1.update()
235
-
236
- self.ss.DCOPF1.run()
237
- pgs_pqt2 = self.ss.DCOPF1.pg.v.sum()
238
- self.assertLess(pgs_pqt2, pgs_pqt, "Load trip does not take effect!")
239
-
240
-
241
- class TestACOPF1(unittest.TestCase):
242
- """
243
- Test routine `ACOPF1`.
244
- """
245
-
246
- def setUp(self) -> None:
247
- self.ss = ams.load(ams.get_case("5bus/pjm5bus_demo.json"),
248
- setup=True, default_config=True, no_output=True)
249
- # decrease load first
250
- self.ss.PQ.set(src='p0', attr='v', idx=['PQ_1', 'PQ_2'], value=[0.3, 0.3])
251
-
252
- def test_init(self):
253
- """
254
- Test initialization.
255
- """
256
- self.ss.ACOPF1.init()
257
- self.assertTrue(self.ss.ACOPF1.initialized, "ACOPF1 initialization failed!")
258
-
259
- @skip_unittest_without_PYPOWER
260
- def test_trip_gen(self):
261
- """
262
- Test generator tripping.
263
- """
264
- stg = 'PV_1'
265
- self.ss.StaticGen.set(src='u', idx=stg, attr='v', value=0)
266
-
267
- self.ss.ACOPF1.update()
268
- self.ss.ACOPF1.run()
269
- self.assertTrue(self.ss.ACOPF1.converged, "ACOPF1 did not converge under generator trip!")
270
- self.assertAlmostEqual(self.ss.ACOPF1.get(src='pg', attr='v', idx=stg),
271
- 0, places=6,
272
- msg="Generator trip does not take effect!")
273
-
274
- self.ss.StaticGen.set(src='u', idx=stg, attr='v', value=1) # reset
275
-
276
- @skip_unittest_without_PYPOWER
277
- def test_trip_line(self):
278
- """
279
- Test line tripping.
280
- """
281
- self.ss.Line.set(src='u', attr='v', idx='Line_3', value=0)
282
-
283
- self.ss.ACOPF1.update()
284
- self.ss.ACOPF1.run()
285
- self.assertTrue(self.ss.ACOPF1.converged, "ACOPF1 did not converge under line trip!")
286
- self.assertAlmostEqual(self.ss.ACOPF1.get(src='plf', attr='v', idx='Line_3'),
287
- 0, places=6,
288
- msg="Line trip does not take effect!")
289
-
290
- self.ss.Line.alter(src='u', idx='Line_3', value=1) # reset
291
-
292
- @skip_unittest_without_PYPOWER
293
- def test_set_load(self):
294
- """
295
- Test setting and tripping load.
296
- """
297
- # --- run ACOPF1 ---
298
- self.ss.ACOPF1.run()
299
- pgs = self.ss.ACOPF1.pg.v.sum()
300
-
301
- # --- set load ---
302
- self.ss.PQ.set(src='p0', attr='v', idx='PQ_1', value=0.1)
303
- self.ss.ACOPF1.update()
304
-
305
- self.ss.ACOPF1.run()
306
- pgs_pqt = self.ss.ACOPF1.pg.v.sum()
307
- self.assertLess(pgs_pqt, pgs, "Load set does not take effect!")
308
-
309
- # --- trip load ---
310
- self.ss.PQ.set(src='u', attr='v', idx='PQ_2', value=0)
311
- self.ss.ACOPF1.update()
312
-
313
- self.ss.ACOPF1.run()
314
- pgs_pqt2 = self.ss.ACOPF1.pg.v.sum()
315
- self.assertLess(pgs_pqt2, pgs_pqt, "Load trip does not take effect!")
tests/test_rtn_rted.py DELETED
@@ -1,273 +0,0 @@
1
- import unittest
2
- import numpy as np
3
-
4
- import ams
5
- from ams.shared import skip_unittest_without_MISOCP
6
-
7
-
8
- class TestRTED(unittest.TestCase):
9
- """
10
- Test methods of `RTED`.
11
- """
12
-
13
- def setUp(self) -> None:
14
- self.ss = ams.load(ams.get_case("5bus/pjm5bus_demo.json"),
15
- setup=True, default_config=True, no_output=True)
16
- # decrease load first
17
- self.ss.PQ.set(src='p0', attr='v', idx=['PQ_1', 'PQ_2'], value=[0.3, 0.3])
18
-
19
- def test_init(self):
20
- """
21
- Test `RTED.init()` method.
22
- """
23
- self.ss.RTED.init()
24
- self.assertTrue(self.ss.RTED.initialized, "RTED initialization failed!")
25
-
26
- def test_trip_gen(self):
27
- """
28
- Test generator tripping.
29
- """
30
- stg = 'PV_1'
31
- self.ss.StaticGen.set(src='u', idx=stg, attr='v', value=0)
32
-
33
- self.ss.RTED.update()
34
- self.ss.RTED.run(solver='CLARABEL')
35
- self.assertTrue(self.ss.RTED.converged, "RTED did not converge under generator trip!")
36
- self.assertAlmostEqual(self.ss.RTED.get(src='pg', attr='v', idx=stg),
37
- 0, places=6,
38
- msg="Generator trip does not take effect!")
39
-
40
- self.ss.StaticGen.set(src='u', idx=stg, attr='v', value=1) # reset
41
-
42
- def test_trip_line(self):
43
- """
44
- Test line tripping.
45
- """
46
- self.ss.Line.set(src='u', attr='v', idx='Line_3', value=0)
47
-
48
- self.ss.RTED.update()
49
- self.ss.RTED.run(solver='CLARABEL')
50
- self.assertTrue(self.ss.RTED.converged, "RTED did not converge under line trip!")
51
- self.assertAlmostEqual(self.ss.RTED.get(src='plf', attr='v', idx='Line_3'),
52
- 0, places=6,
53
- msg="Line trip does not take effect!")
54
-
55
- self.ss.Line.alter(src='u', idx='Line_3', value=1)
56
-
57
- def test_set_load(self):
58
- """
59
- Test setting and tripping load.
60
- """
61
- self.ss.RTED.run(solver='CLARABEL')
62
- pgs = self.ss.RTED.pg.v.sum()
63
-
64
- # --- set load ---
65
- self.ss.PQ.set(src='p0', attr='v', idx='PQ_1', value=0.1)
66
- self.ss.RTED.update()
67
-
68
- self.ss.RTED.run(solver='CLARABEL')
69
- pgs_pqt = self.ss.RTED.pg.v.sum()
70
- self.assertLess(pgs_pqt, pgs, "Load set does not take effect!")
71
-
72
- # --- trip load ---
73
- self.ss.PQ.set(src='u', attr='v', idx='PQ_2', value=0)
74
- self.ss.RTED.update()
75
-
76
- self.ss.RTED.run(solver='CLARABEL')
77
- pgs_pqt2 = self.ss.RTED.pg.v.sum()
78
- self.assertLess(pgs_pqt2, pgs_pqt, "Load trip does not take effect!")
79
-
80
- def test_dc2ac(self):
81
- """
82
- Test `RTED.dc2ac()` method.
83
- """
84
- self.ss.RTED.run(solver='CLARABEL')
85
- self.ss.RTED.dc2ac()
86
- self.assertTrue(self.ss.RTED.converted, "AC conversion failed!")
87
- self.assertTrue(self.ss.RTED.exec_time > 0, "Execution time is not greater than 0.")
88
-
89
- stg_idx = self.ss.StaticGen.get_all_idxes()
90
- pg_rted = self.ss.RTED.get(src='pg', attr='v', idx=stg_idx)
91
- pg_acopf = self.ss.ACOPF.get(src='pg', attr='v', idx=stg_idx)
92
- np.testing.assert_almost_equal(pg_rted, pg_acopf, decimal=3)
93
-
94
- bus_idx = self.ss.Bus.get_all_idxes()
95
- v_rted = self.ss.RTED.get(src='vBus', attr='v', idx=bus_idx)
96
- v_acopf = self.ss.ACOPF.get(src='vBus', attr='v', idx=bus_idx)
97
- np.testing.assert_almost_equal(v_rted, v_acopf, decimal=3)
98
-
99
- a_rted = self.ss.RTED.get(src='aBus', attr='v', idx=bus_idx)
100
- a_acopf = self.ss.ACOPF.get(src='aBus', attr='v', idx=bus_idx)
101
- np.testing.assert_almost_equal(a_rted, a_acopf, decimal=3)
102
-
103
-
104
- class TestRTEDDG(unittest.TestCase):
105
- """
106
- Test routine `RTEDDG`.
107
- """
108
-
109
- def setUp(self) -> None:
110
- self.ss = ams.load(ams.get_case("5bus/pjm5bus_demo.json"),
111
- setup=True, default_config=True, no_output=True)
112
- # decrease load first
113
- self.ss.PQ.set(src='p0', attr='v', idx=['PQ_1', 'PQ_2'], value=[0.3, 0.3])
114
-
115
- def test_init(self):
116
- """
117
- Test initialization.
118
- """
119
- self.ss.RTEDDG.init()
120
- self.assertTrue(self.ss.RTEDDG.initialized, "RTEDDG initialization failed!")
121
-
122
- def test_trip_gen(self):
123
- """
124
- Test generator tripping.
125
- """
126
- stg = 'PV_1'
127
- self.ss.StaticGen.set(src='u', idx=stg, attr='v', value=0)
128
-
129
- self.ss.RTEDDG.update()
130
- self.ss.RTEDDG.run(solver='CLARABEL')
131
- self.assertTrue(self.ss.RTEDDG.converged, "RTEDDG did not converge under generator trip!")
132
- self.assertAlmostEqual(self.ss.RTEDDG.get(src='pg', attr='v', idx=stg),
133
- 0, places=6,
134
- msg="Generator trip does not take effect!")
135
-
136
- self.ss.StaticGen.set(src='u', idx=stg, attr='v', value=1)
137
-
138
- def test_trip_line(self):
139
- """
140
- Test line tripping.
141
- """
142
- self.ss.Line.set(src='u', attr='v', idx='Line_3', value=0)
143
-
144
- self.ss.RTEDDG.update()
145
- self.ss.RTEDDG.run(solver='CLARABEL')
146
- self.assertTrue(self.ss.RTEDDG.converged, "RTEDDG did not converge under line trip!")
147
- self.assertAlmostEqual(self.ss.RTEDDG.get(src='plf', attr='v', idx='Line_3'),
148
- 0, places=6,
149
- msg="Line trip does not take effect!")
150
-
151
- self.ss.Line.alter(src='u', idx='Line_3', value=1)
152
-
153
- def test_set_load(self):
154
- """
155
- Test setting and tripping load.
156
- """
157
- self.ss.RTEDDG.run(solver='CLARABEL')
158
- pgs = self.ss.RTEDDG.pg.v.sum()
159
-
160
- # --- set load ---
161
- self.ss.PQ.set(src='p0', attr='v', idx='PQ_1', value=0.1)
162
- self.ss.RTEDDG.update()
163
-
164
- self.ss.RTEDDG.run(solver='CLARABEL')
165
- pgs_pqt = self.ss.RTEDDG.pg.v.sum()
166
- self.assertLess(pgs_pqt, pgs, "Load set does not take effect!")
167
-
168
- # --- trip load ---
169
- self.ss.PQ.set(src='u', attr='v', idx='PQ_2', value=0)
170
- self.ss.RTEDDG.update()
171
-
172
- self.ss.RTEDDG.run(solver='CLARABEL')
173
- pgs_pqt2 = self.ss.RTEDDG.pg.v.sum()
174
- self.assertLess(pgs_pqt2, pgs_pqt, "Load trip does not take effect!")
175
-
176
- def test_dc2ac(self):
177
- """
178
- Test `RTEDDG.dc2ac()` method.
179
- """
180
- self.ss.RTEDDG.run(solver='CLARABEL')
181
- self.ss.RTEDDG.dc2ac()
182
- self.assertTrue(self.ss.RTEDDG.converted, "AC conversion failed!")
183
- self.assertTrue(self.ss.RTEDDG.exec_time > 0, "Execution time is not greater than 0.")
184
-
185
- stg_idx = self.ss.StaticGen.get_all_idxes()
186
- pg_rted = self.ss.RTEDDG.get(src='pg', attr='v', idx=stg_idx)
187
- pg_acopf = self.ss.ACOPF.get(src='pg', attr='v', idx=stg_idx)
188
- np.testing.assert_almost_equal(pg_rted, pg_acopf, decimal=3)
189
-
190
- bus_idx = self.ss.Bus.get_all_idxes()
191
- v_rted = self.ss.RTEDDG.get(src='vBus', attr='v', idx=bus_idx)
192
- v_acopf = self.ss.ACOPF.get(src='vBus', attr='v', idx=bus_idx)
193
- np.testing.assert_almost_equal(v_rted, v_acopf, decimal=3)
194
-
195
- a_rted = self.ss.RTEDDG.get(src='aBus', attr='v', idx=bus_idx)
196
- a_acopf = self.ss.ACOPF.get(src='aBus', attr='v', idx=bus_idx)
197
- np.testing.assert_almost_equal(a_rted, a_acopf, decimal=3)
198
-
199
-
200
- class TestRTEDES(unittest.TestCase):
201
- """
202
- Test routine `RTEDES`.
203
- """
204
-
205
- def setUp(self) -> None:
206
- self.ss = ams.load(ams.get_case("5bus/pjm5bus_demo.json"),
207
- setup=True, default_config=True, no_output=True)
208
- # decrease load first
209
- self.ss.PQ.set(src='p0', attr='v', idx=['PQ_1', 'PQ_2'], value=[0.3, 0.3])
210
-
211
- def test_init(self):
212
- """
213
- Test initialization.
214
- """
215
- self.ss.RTEDES.init()
216
- self.assertTrue(self.ss.RTEDES.initialized, "RTEDES initialization failed!")
217
-
218
- @skip_unittest_without_MISOCP
219
- def test_trip_gen(self):
220
- """
221
- Test generator tripping.
222
- """
223
- stg = 'PV_1'
224
- self.ss.StaticGen.set(src='u', idx=stg, attr='v', value=0)
225
-
226
- self.ss.RTEDES.update()
227
- self.ss.RTEDES.run(solver='SCIP')
228
- self.assertTrue(self.ss.RTEDES.converged, "RTEDES did not converge under generator trip!")
229
- self.assertAlmostEqual(self.ss.RTEDES.get(src='pg', attr='v', idx=stg),
230
- 0, places=6,
231
- msg="Generator trip does not take effect!")
232
-
233
- self.ss.StaticGen.set(src='u', idx=stg, attr='v', value=1)
234
-
235
- @skip_unittest_without_MISOCP
236
- def test_trip_line(self):
237
- """
238
- Test line tripping.
239
- """
240
- self.ss.Line.set(src='u', attr='v', idx='Line_3', value=0)
241
-
242
- self.ss.RTEDES.update()
243
- self.ss.RTEDES.run(solver='SCIP')
244
- self.assertTrue(self.ss.RTEDES.converged, "RTEDES did not converge under line trip!")
245
- self.assertAlmostEqual(self.ss.RTEDES.get(src='plf', attr='v', idx='Line_3'),
246
- 0, places=6,
247
- msg="Line trip does not take effect!")
248
-
249
- self.ss.Line.alter(src='u', idx='Line_3', value=1)
250
-
251
- @skip_unittest_without_MISOCP
252
- def test_set_load(self):
253
- """
254
- Test setting and tripping load.
255
- """
256
- self.ss.RTEDES.run(solver='SCIP')
257
- pgs = self.ss.RTEDES.pg.v.sum()
258
-
259
- # --- set load ---
260
- self.ss.PQ.set(src='p0', attr='v', idx='PQ_1', value=0.05)
261
- self.ss.RTEDES.update()
262
-
263
- self.ss.RTEDES.run(solver='SCIP')
264
- pgs_pqt = self.ss.RTEDES.pg.v.sum()
265
- self.assertLess(pgs_pqt, pgs, "Load set does not take effect!")
266
-
267
- # --- trip load ---
268
- self.ss.PQ.set(src='u', attr='v', idx='PQ_2', value=0)
269
- self.ss.RTEDES.update()
270
-
271
- self.ss.RTEDES.run(solver='SCIP')
272
- pgs_pqt2 = self.ss.RTEDES.pg.v.sum()
273
- self.assertLess(pgs_pqt2, pgs_pqt, "Load trip does not take effect!")