ltbams 0.9.9__py3-none-any.whl → 1.0.0__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 (728) hide show
  1. ams/__init__.py +4 -11
  2. ams/_version.py +4 -4
  3. ams/cases/5bus/pjm5bus_demo.xlsx +0 -0
  4. ams/cases/5bus/pjm5bus_jumper.xlsx +0 -0
  5. ams/cases/5bus/pjm5bus_uced.json +1062 -0
  6. ams/cases/5bus/pjm5bus_uced.xlsx +0 -0
  7. ams/cases/5bus/pjm5bus_uced_esd1.xlsx +0 -0
  8. ams/cases/5bus/pjm5bus_uced_ev.xlsx +0 -0
  9. ams/cases/ieee123/ieee123.xlsx +0 -0
  10. ams/cases/ieee123/ieee123_regcv1.xlsx +0 -0
  11. ams/cases/ieee14/ieee14.json +1166 -0
  12. ams/cases/ieee14/ieee14.raw +92 -0
  13. ams/cases/ieee14/ieee14_conn.xlsx +0 -0
  14. ams/cases/ieee14/ieee14_uced.xlsx +0 -0
  15. ams/cases/ieee39/ieee39.xlsx +0 -0
  16. ams/cases/ieee39/ieee39_uced.xlsx +0 -0
  17. ams/cases/ieee39/ieee39_uced_esd1.xlsx +0 -0
  18. ams/cases/ieee39/ieee39_uced_pvd1.xlsx +0 -0
  19. ams/cases/ieee39/ieee39_uced_vis.xlsx +0 -0
  20. ams/cases/matpower/benchmark.json +1594 -0
  21. ams/cases/matpower/case118.m +787 -0
  22. ams/cases/matpower/case14.m +129 -0
  23. ams/cases/matpower/case300.m +1315 -0
  24. ams/cases/matpower/case39.m +205 -0
  25. ams/cases/matpower/case5.m +62 -0
  26. ams/cases/matpower/case_ACTIVSg2000.m +9460 -0
  27. ams/cases/npcc/npcc.m +644 -0
  28. ams/cases/npcc/npcc_uced.xlsx +0 -0
  29. ams/cases/pglib/pglib_opf_case39_epri__api.m +243 -0
  30. ams/cases/wecc/wecc.m +714 -0
  31. ams/cases/wecc/wecc_uced.xlsx +0 -0
  32. ams/cli.py +6 -0
  33. ams/core/__init__.py +2 -0
  34. ams/core/documenter.py +652 -0
  35. ams/core/matprocessor.py +782 -0
  36. ams/core/model.py +330 -0
  37. ams/core/param.py +322 -0
  38. ams/core/service.py +918 -0
  39. ams/core/symprocessor.py +224 -0
  40. ams/core/var.py +59 -0
  41. ams/extension/__init__.py +5 -0
  42. ams/extension/eva.py +401 -0
  43. ams/interface.py +1085 -0
  44. ams/io/__init__.py +133 -0
  45. ams/io/json.py +82 -0
  46. ams/io/matpower.py +406 -0
  47. ams/io/psse.py +6 -0
  48. ams/io/pypower.py +103 -0
  49. ams/io/xlsx.py +80 -0
  50. ams/main.py +83 -4
  51. ams/models/__init__.py +24 -0
  52. ams/models/area.py +40 -0
  53. ams/models/bus.py +52 -0
  54. ams/models/cost.py +169 -0
  55. ams/models/distributed/__init__.py +3 -0
  56. ams/models/distributed/esd1.py +71 -0
  57. ams/models/distributed/ev.py +60 -0
  58. ams/models/distributed/pvd1.py +67 -0
  59. ams/models/group.py +231 -0
  60. ams/models/info.py +26 -0
  61. ams/models/line.py +238 -0
  62. ams/models/renewable/__init__.py +5 -0
  63. ams/models/renewable/regc.py +119 -0
  64. ams/models/reserve.py +94 -0
  65. ams/models/shunt.py +14 -0
  66. ams/models/static/__init__.py +2 -0
  67. ams/models/static/gen.py +165 -0
  68. ams/models/static/pq.py +61 -0
  69. ams/models/timeslot.py +69 -0
  70. ams/models/zone.py +49 -0
  71. ams/opt/__init__.py +12 -0
  72. ams/opt/constraint.py +175 -0
  73. ams/opt/exprcalc.py +127 -0
  74. ams/opt/expression.py +188 -0
  75. ams/opt/objective.py +174 -0
  76. ams/opt/omodel.py +432 -0
  77. ams/opt/optzbase.py +192 -0
  78. ams/opt/param.py +156 -0
  79. ams/opt/var.py +233 -0
  80. ams/pypower/__init__.py +8 -0
  81. ams/pypower/_compat.py +9 -0
  82. ams/pypower/core/__init__.py +8 -0
  83. ams/pypower/core/pips.py +894 -0
  84. ams/pypower/core/ppoption.py +244 -0
  85. ams/pypower/core/ppver.py +18 -0
  86. ams/pypower/core/solver.py +2451 -0
  87. ams/pypower/eps.py +6 -0
  88. ams/pypower/idx.py +174 -0
  89. ams/pypower/io.py +604 -0
  90. ams/pypower/make/__init__.py +11 -0
  91. ams/pypower/make/matrices.py +665 -0
  92. ams/pypower/make/pdv.py +506 -0
  93. ams/pypower/routines/__init__.py +7 -0
  94. ams/pypower/routines/cpf.py +513 -0
  95. ams/pypower/routines/cpf_callbacks.py +114 -0
  96. ams/pypower/routines/opf.py +1803 -0
  97. ams/pypower/routines/opffcns.py +1946 -0
  98. ams/pypower/routines/pflow.py +852 -0
  99. ams/pypower/toggle.py +1098 -0
  100. ams/pypower/utils.py +293 -0
  101. ams/report.py +212 -50
  102. ams/routines/__init__.py +23 -0
  103. ams/routines/acopf.py +117 -0
  104. ams/routines/cpf.py +65 -0
  105. ams/routines/dcopf.py +241 -0
  106. ams/routines/dcpf.py +209 -0
  107. ams/routines/dcpf0.py +196 -0
  108. ams/routines/dopf.py +150 -0
  109. ams/routines/ed.py +312 -0
  110. ams/routines/pflow.py +255 -0
  111. ams/routines/pflow0.py +113 -0
  112. ams/routines/pflow1.py +156 -0
  113. ams/routines/routine.py +1033 -0
  114. ams/routines/rted.py +519 -0
  115. ams/routines/type.py +160 -0
  116. ams/routines/uc.py +376 -0
  117. ams/shared.py +34 -9
  118. ams/system.py +61 -22
  119. ams/utils/__init__.py +3 -0
  120. ams/utils/misc.py +77 -0
  121. ams/utils/paths.py +257 -0
  122. docs/Makefile +21 -0
  123. docs/build/doctrees/nbsphinx/_examples_demo_demo_AGC_20_1.png +0 -0
  124. docs/build/doctrees/nbsphinx/_examples_demo_demo_AGC_37_1.png +0 -0
  125. docs/build/doctrees/nbsphinx/_examples_demo_demo_AGC_39_1.png +0 -0
  126. docs/build/html/_images/_examples_demo_demo_AGC_20_1.png +0 -0
  127. docs/build/html/_images/_examples_demo_demo_AGC_37_1.png +0 -0
  128. docs/build/html/_images/_examples_demo_demo_AGC_39_1.png +0 -0
  129. docs/build/html/_images/xlsx.png +0 -0
  130. docs/build/html/_static/file.png +0 -0
  131. docs/build/html/_static/minus.png +0 -0
  132. docs/build/html/_static/plus.png +0 -0
  133. docs/make.bat +35 -0
  134. docs/source/_generated/_generated/ams.core.model.Model.alter.rst +6 -0
  135. docs/source/_generated/_generated/ams.core.model.Model.class_name.rst +6 -0
  136. docs/source/_generated/_generated/ams.core.model.Model.doc.rst +6 -0
  137. docs/source/_generated/_generated/ams.core.model.Model.get.rst +6 -0
  138. docs/source/_generated/_generated/ams.core.model.Model.get_idx.rst +6 -0
  139. docs/source/_generated/_generated/ams.core.model.Model.idx2uid.rst +6 -0
  140. docs/source/_generated/_generated/ams.core.model.Model.list2array.rst +6 -0
  141. docs/source/_generated/_generated/ams.core.model.Model.set.rst +6 -0
  142. docs/source/_generated/_generated/ams.core.model.Model.set_backref.rst +6 -0
  143. docs/source/_generated/_generated/ams.core.param.RParam.class_name.rst +6 -0
  144. docs/source/_generated/_generated/ams.core.param.RParam.dtype.rst +6 -0
  145. docs/source/_generated/_generated/ams.core.param.RParam.evaluate.rst +6 -0
  146. docs/source/_generated/_generated/ams.core.param.RParam.get_idx.rst +6 -0
  147. docs/source/_generated/_generated/ams.core.param.RParam.n.rst +6 -0
  148. docs/source/_generated/_generated/ams.core.param.RParam.parse.rst +6 -0
  149. docs/source/_generated/_generated/ams.core.param.RParam.shape.rst +6 -0
  150. docs/source/_generated/_generated/ams.core.param.RParam.size.rst +6 -0
  151. docs/source/_generated/_generated/ams.core.param.RParam.update.rst +6 -0
  152. docs/source/_generated/_generated/ams.core.param.RParam.v.rst +6 -0
  153. docs/source/_generated/_generated/ams.core.service.LoadScale.assign_memory.rst +6 -0
  154. docs/source/_generated/_generated/ams.core.service.LoadScale.class_name.rst +6 -0
  155. docs/source/_generated/_generated/ams.core.service.LoadScale.evaluate.rst +6 -0
  156. docs/source/_generated/_generated/ams.core.service.LoadScale.get_names.rst +6 -0
  157. docs/source/_generated/_generated/ams.core.service.LoadScale.n.rst +6 -0
  158. docs/source/_generated/_generated/ams.core.service.LoadScale.parse.rst +6 -0
  159. docs/source/_generated/_generated/ams.core.service.LoadScale.shape.rst +6 -0
  160. docs/source/_generated/_generated/ams.core.service.LoadScale.size.rst +6 -0
  161. docs/source/_generated/_generated/ams.core.service.LoadScale.update.rst +6 -0
  162. docs/source/_generated/_generated/ams.core.service.LoadScale.v.rst +6 -0
  163. docs/source/_generated/_generated/ams.core.service.MinDur.assign_memory.rst +6 -0
  164. docs/source/_generated/_generated/ams.core.service.MinDur.class_name.rst +6 -0
  165. docs/source/_generated/_generated/ams.core.service.MinDur.evaluate.rst +6 -0
  166. docs/source/_generated/_generated/ams.core.service.MinDur.get_names.rst +6 -0
  167. docs/source/_generated/_generated/ams.core.service.MinDur.n.rst +6 -0
  168. docs/source/_generated/_generated/ams.core.service.MinDur.parse.rst +6 -0
  169. docs/source/_generated/_generated/ams.core.service.MinDur.shape.rst +6 -0
  170. docs/source/_generated/_generated/ams.core.service.MinDur.size.rst +6 -0
  171. docs/source/_generated/_generated/ams.core.service.MinDur.update.rst +6 -0
  172. docs/source/_generated/_generated/ams.core.service.MinDur.v.rst +6 -0
  173. docs/source/_generated/_generated/ams.core.service.MinDur.v0.rst +6 -0
  174. docs/source/_generated/_generated/ams.core.service.MinDur.v1.rst +6 -0
  175. docs/source/_generated/_generated/ams.core.service.NumExpandDim.assign_memory.rst +6 -0
  176. docs/source/_generated/_generated/ams.core.service.NumExpandDim.class_name.rst +6 -0
  177. docs/source/_generated/_generated/ams.core.service.NumExpandDim.evaluate.rst +6 -0
  178. docs/source/_generated/_generated/ams.core.service.NumExpandDim.get_names.rst +6 -0
  179. docs/source/_generated/_generated/ams.core.service.NumExpandDim.n.rst +6 -0
  180. docs/source/_generated/_generated/ams.core.service.NumExpandDim.parse.rst +6 -0
  181. docs/source/_generated/_generated/ams.core.service.NumExpandDim.shape.rst +6 -0
  182. docs/source/_generated/_generated/ams.core.service.NumExpandDim.size.rst +6 -0
  183. docs/source/_generated/_generated/ams.core.service.NumExpandDim.update.rst +6 -0
  184. docs/source/_generated/_generated/ams.core.service.NumExpandDim.v.rst +6 -0
  185. docs/source/_generated/_generated/ams.core.service.NumExpandDim.v0.rst +6 -0
  186. docs/source/_generated/_generated/ams.core.service.NumExpandDim.v1.rst +6 -0
  187. docs/source/_generated/_generated/ams.core.service.NumHstack.assign_memory.rst +6 -0
  188. docs/source/_generated/_generated/ams.core.service.NumHstack.class_name.rst +6 -0
  189. docs/source/_generated/_generated/ams.core.service.NumHstack.evaluate.rst +6 -0
  190. docs/source/_generated/_generated/ams.core.service.NumHstack.get_names.rst +6 -0
  191. docs/source/_generated/_generated/ams.core.service.NumHstack.n.rst +6 -0
  192. docs/source/_generated/_generated/ams.core.service.NumHstack.parse.rst +6 -0
  193. docs/source/_generated/_generated/ams.core.service.NumHstack.shape.rst +6 -0
  194. docs/source/_generated/_generated/ams.core.service.NumHstack.size.rst +6 -0
  195. docs/source/_generated/_generated/ams.core.service.NumHstack.update.rst +6 -0
  196. docs/source/_generated/_generated/ams.core.service.NumHstack.v.rst +6 -0
  197. docs/source/_generated/_generated/ams.core.service.NumHstack.v0.rst +6 -0
  198. docs/source/_generated/_generated/ams.core.service.NumHstack.v1.rst +6 -0
  199. docs/source/_generated/_generated/ams.core.service.NumOp.assign_memory.rst +6 -0
  200. docs/source/_generated/_generated/ams.core.service.NumOp.class_name.rst +6 -0
  201. docs/source/_generated/_generated/ams.core.service.NumOp.evaluate.rst +6 -0
  202. docs/source/_generated/_generated/ams.core.service.NumOp.get_names.rst +6 -0
  203. docs/source/_generated/_generated/ams.core.service.NumOp.n.rst +6 -0
  204. docs/source/_generated/_generated/ams.core.service.NumOp.parse.rst +6 -0
  205. docs/source/_generated/_generated/ams.core.service.NumOp.shape.rst +6 -0
  206. docs/source/_generated/_generated/ams.core.service.NumOp.size.rst +6 -0
  207. docs/source/_generated/_generated/ams.core.service.NumOp.update.rst +6 -0
  208. docs/source/_generated/_generated/ams.core.service.NumOp.v.rst +6 -0
  209. docs/source/_generated/_generated/ams.core.service.NumOp.v0.rst +6 -0
  210. docs/source/_generated/_generated/ams.core.service.NumOp.v1.rst +6 -0
  211. docs/source/_generated/_generated/ams.core.service.NumOpDual.assign_memory.rst +6 -0
  212. docs/source/_generated/_generated/ams.core.service.NumOpDual.class_name.rst +6 -0
  213. docs/source/_generated/_generated/ams.core.service.NumOpDual.evaluate.rst +6 -0
  214. docs/source/_generated/_generated/ams.core.service.NumOpDual.get_names.rst +6 -0
  215. docs/source/_generated/_generated/ams.core.service.NumOpDual.n.rst +6 -0
  216. docs/source/_generated/_generated/ams.core.service.NumOpDual.parse.rst +6 -0
  217. docs/source/_generated/_generated/ams.core.service.NumOpDual.shape.rst +6 -0
  218. docs/source/_generated/_generated/ams.core.service.NumOpDual.size.rst +6 -0
  219. docs/source/_generated/_generated/ams.core.service.NumOpDual.update.rst +6 -0
  220. docs/source/_generated/_generated/ams.core.service.NumOpDual.v.rst +6 -0
  221. docs/source/_generated/_generated/ams.core.service.NumOpDual.v0.rst +6 -0
  222. docs/source/_generated/_generated/ams.core.service.NumOpDual.v1.rst +6 -0
  223. docs/source/_generated/_generated/ams.core.service.RBaseService.assign_memory.rst +6 -0
  224. docs/source/_generated/_generated/ams.core.service.RBaseService.class_name.rst +6 -0
  225. docs/source/_generated/_generated/ams.core.service.RBaseService.evaluate.rst +6 -0
  226. docs/source/_generated/_generated/ams.core.service.RBaseService.get_names.rst +6 -0
  227. docs/source/_generated/_generated/ams.core.service.RBaseService.n.rst +6 -0
  228. docs/source/_generated/_generated/ams.core.service.RBaseService.parse.rst +6 -0
  229. docs/source/_generated/_generated/ams.core.service.RBaseService.shape.rst +6 -0
  230. docs/source/_generated/_generated/ams.core.service.RBaseService.size.rst +6 -0
  231. docs/source/_generated/_generated/ams.core.service.RBaseService.update.rst +6 -0
  232. docs/source/_generated/_generated/ams.core.service.RBaseService.v.rst +6 -0
  233. docs/source/_generated/_generated/ams.core.service.ROperationService.assign_memory.rst +6 -0
  234. docs/source/_generated/_generated/ams.core.service.ROperationService.class_name.rst +6 -0
  235. docs/source/_generated/_generated/ams.core.service.ROperationService.evaluate.rst +6 -0
  236. docs/source/_generated/_generated/ams.core.service.ROperationService.get_names.rst +6 -0
  237. docs/source/_generated/_generated/ams.core.service.ROperationService.n.rst +6 -0
  238. docs/source/_generated/_generated/ams.core.service.ROperationService.parse.rst +6 -0
  239. docs/source/_generated/_generated/ams.core.service.ROperationService.shape.rst +6 -0
  240. docs/source/_generated/_generated/ams.core.service.ROperationService.size.rst +6 -0
  241. docs/source/_generated/_generated/ams.core.service.ROperationService.update.rst +6 -0
  242. docs/source/_generated/_generated/ams.core.service.ROperationService.v.rst +6 -0
  243. docs/source/_generated/_generated/ams.core.service.RampSub.assign_memory.rst +6 -0
  244. docs/source/_generated/_generated/ams.core.service.RampSub.class_name.rst +6 -0
  245. docs/source/_generated/_generated/ams.core.service.RampSub.evaluate.rst +6 -0
  246. docs/source/_generated/_generated/ams.core.service.RampSub.get_names.rst +6 -0
  247. docs/source/_generated/_generated/ams.core.service.RampSub.n.rst +6 -0
  248. docs/source/_generated/_generated/ams.core.service.RampSub.parse.rst +6 -0
  249. docs/source/_generated/_generated/ams.core.service.RampSub.shape.rst +6 -0
  250. docs/source/_generated/_generated/ams.core.service.RampSub.size.rst +6 -0
  251. docs/source/_generated/_generated/ams.core.service.RampSub.update.rst +6 -0
  252. docs/source/_generated/_generated/ams.core.service.RampSub.v.rst +6 -0
  253. docs/source/_generated/_generated/ams.core.service.RampSub.v0.rst +6 -0
  254. docs/source/_generated/_generated/ams.core.service.RampSub.v1.rst +6 -0
  255. docs/source/_generated/_generated/ams.core.service.ValueService.assign_memory.rst +6 -0
  256. docs/source/_generated/_generated/ams.core.service.ValueService.class_name.rst +6 -0
  257. docs/source/_generated/_generated/ams.core.service.ValueService.evaluate.rst +6 -0
  258. docs/source/_generated/_generated/ams.core.service.ValueService.get_names.rst +6 -0
  259. docs/source/_generated/_generated/ams.core.service.ValueService.n.rst +6 -0
  260. docs/source/_generated/_generated/ams.core.service.ValueService.parse.rst +6 -0
  261. docs/source/_generated/_generated/ams.core.service.ValueService.shape.rst +6 -0
  262. docs/source/_generated/_generated/ams.core.service.ValueService.size.rst +6 -0
  263. docs/source/_generated/_generated/ams.core.service.ValueService.update.rst +6 -0
  264. docs/source/_generated/_generated/ams.core.service.ValueService.v.rst +6 -0
  265. docs/source/_generated/_generated/ams.core.service.VarReduction.assign_memory.rst +6 -0
  266. docs/source/_generated/_generated/ams.core.service.VarReduction.class_name.rst +6 -0
  267. docs/source/_generated/_generated/ams.core.service.VarReduction.evaluate.rst +6 -0
  268. docs/source/_generated/_generated/ams.core.service.VarReduction.get_names.rst +6 -0
  269. docs/source/_generated/_generated/ams.core.service.VarReduction.n.rst +6 -0
  270. docs/source/_generated/_generated/ams.core.service.VarReduction.parse.rst +6 -0
  271. docs/source/_generated/_generated/ams.core.service.VarReduction.shape.rst +6 -0
  272. docs/source/_generated/_generated/ams.core.service.VarReduction.size.rst +6 -0
  273. docs/source/_generated/_generated/ams.core.service.VarReduction.update.rst +6 -0
  274. docs/source/_generated/_generated/ams.core.service.VarReduction.v.rst +6 -0
  275. docs/source/_generated/_generated/ams.core.service.VarReduction.v0.rst +6 -0
  276. docs/source/_generated/_generated/ams.core.service.VarReduction.v1.rst +6 -0
  277. docs/source/_generated/_generated/ams.core.service.VarSelect.assign_memory.rst +6 -0
  278. docs/source/_generated/_generated/ams.core.service.VarSelect.class_name.rst +6 -0
  279. docs/source/_generated/_generated/ams.core.service.VarSelect.evaluate.rst +6 -0
  280. docs/source/_generated/_generated/ams.core.service.VarSelect.get_names.rst +6 -0
  281. docs/source/_generated/_generated/ams.core.service.VarSelect.n.rst +6 -0
  282. docs/source/_generated/_generated/ams.core.service.VarSelect.parse.rst +6 -0
  283. docs/source/_generated/_generated/ams.core.service.VarSelect.shape.rst +6 -0
  284. docs/source/_generated/_generated/ams.core.service.VarSelect.size.rst +6 -0
  285. docs/source/_generated/_generated/ams.core.service.VarSelect.update.rst +6 -0
  286. docs/source/_generated/_generated/ams.core.service.VarSelect.v.rst +6 -0
  287. docs/source/_generated/_generated/ams.core.service.VarSelect.v0.rst +6 -0
  288. docs/source/_generated/_generated/ams.core.service.VarSelect.v1.rst +6 -0
  289. docs/source/_generated/_generated/ams.core.service.ZonalSum.assign_memory.rst +6 -0
  290. docs/source/_generated/_generated/ams.core.service.ZonalSum.class_name.rst +6 -0
  291. docs/source/_generated/_generated/ams.core.service.ZonalSum.evaluate.rst +6 -0
  292. docs/source/_generated/_generated/ams.core.service.ZonalSum.get_names.rst +6 -0
  293. docs/source/_generated/_generated/ams.core.service.ZonalSum.n.rst +6 -0
  294. docs/source/_generated/_generated/ams.core.service.ZonalSum.parse.rst +6 -0
  295. docs/source/_generated/_generated/ams.core.service.ZonalSum.shape.rst +6 -0
  296. docs/source/_generated/_generated/ams.core.service.ZonalSum.size.rst +6 -0
  297. docs/source/_generated/_generated/ams.core.service.ZonalSum.update.rst +6 -0
  298. docs/source/_generated/_generated/ams.core.service.ZonalSum.v.rst +6 -0
  299. docs/source/_generated/_generated/ams.core.service.ZonalSum.v0.rst +6 -0
  300. docs/source/_generated/_generated/ams.core.service.ZonalSum.v1.rst +6 -0
  301. docs/source/_generated/_generated/ams.interface.Dynamic.is_tds.rst +6 -0
  302. docs/source/_generated/_generated/ams.interface.Dynamic.link_andes.rst +6 -0
  303. docs/source/_generated/_generated/ams.interface.Dynamic.receive.rst +6 -0
  304. docs/source/_generated/_generated/ams.interface.Dynamic.send.rst +6 -0
  305. docs/source/_generated/_generated/ams.opt.constraint.Constraint.class_name.rst +6 -0
  306. docs/source/_generated/_generated/ams.opt.constraint.Constraint.e.rst +6 -0
  307. docs/source/_generated/_generated/ams.opt.constraint.Constraint.evaluate.rst +6 -0
  308. docs/source/_generated/_generated/ams.opt.constraint.Constraint.n.rst +6 -0
  309. docs/source/_generated/_generated/ams.opt.constraint.Constraint.parse.rst +6 -0
  310. docs/source/_generated/_generated/ams.opt.constraint.Constraint.shape.rst +6 -0
  311. docs/source/_generated/_generated/ams.opt.constraint.Constraint.size.rst +6 -0
  312. docs/source/_generated/_generated/ams.opt.constraint.Constraint.v.rst +6 -0
  313. docs/source/_generated/_generated/ams.opt.exprcalc.ExpressionCalc.class_name.rst +6 -0
  314. docs/source/_generated/_generated/ams.opt.exprcalc.ExpressionCalc.e.rst +6 -0
  315. docs/source/_generated/_generated/ams.opt.exprcalc.ExpressionCalc.evaluate.rst +6 -0
  316. docs/source/_generated/_generated/ams.opt.exprcalc.ExpressionCalc.get_idx.rst +6 -0
  317. docs/source/_generated/_generated/ams.opt.exprcalc.ExpressionCalc.n.rst +6 -0
  318. docs/source/_generated/_generated/ams.opt.exprcalc.ExpressionCalc.parse.rst +6 -0
  319. docs/source/_generated/_generated/ams.opt.exprcalc.ExpressionCalc.shape.rst +6 -0
  320. docs/source/_generated/_generated/ams.opt.exprcalc.ExpressionCalc.size.rst +6 -0
  321. docs/source/_generated/_generated/ams.opt.exprcalc.ExpressionCalc.v.rst +6 -0
  322. docs/source/_generated/_generated/ams.opt.expression.Expression.class_name.rst +6 -0
  323. docs/source/_generated/_generated/ams.opt.expression.Expression.e.rst +6 -0
  324. docs/source/_generated/_generated/ams.opt.expression.Expression.evaluate.rst +6 -0
  325. docs/source/_generated/_generated/ams.opt.expression.Expression.get_idx.rst +6 -0
  326. docs/source/_generated/_generated/ams.opt.expression.Expression.n.rst +6 -0
  327. docs/source/_generated/_generated/ams.opt.expression.Expression.parse.rst +6 -0
  328. docs/source/_generated/_generated/ams.opt.expression.Expression.shape.rst +6 -0
  329. docs/source/_generated/_generated/ams.opt.expression.Expression.size.rst +6 -0
  330. docs/source/_generated/_generated/ams.opt.expression.Expression.v.rst +6 -0
  331. docs/source/_generated/_generated/ams.opt.objective.Objective.class_name.rst +6 -0
  332. docs/source/_generated/_generated/ams.opt.objective.Objective.e.rst +6 -0
  333. docs/source/_generated/_generated/ams.opt.objective.Objective.evaluate.rst +6 -0
  334. docs/source/_generated/_generated/ams.opt.objective.Objective.n.rst +6 -0
  335. docs/source/_generated/_generated/ams.opt.objective.Objective.parse.rst +6 -0
  336. docs/source/_generated/_generated/ams.opt.objective.Objective.shape.rst +6 -0
  337. docs/source/_generated/_generated/ams.opt.objective.Objective.size.rst +6 -0
  338. docs/source/_generated/_generated/ams.opt.objective.Objective.v.rst +6 -0
  339. docs/source/_generated/_generated/ams.opt.omodel.OModel.class_name.rst +6 -0
  340. docs/source/_generated/_generated/ams.opt.omodel.OModel.evaluate.rst +6 -0
  341. docs/source/_generated/_generated/ams.opt.omodel.OModel.finalize.rst +6 -0
  342. docs/source/_generated/_generated/ams.opt.omodel.OModel.init.rst +6 -0
  343. docs/source/_generated/_generated/ams.opt.omodel.OModel.initialized.rst +6 -0
  344. docs/source/_generated/_generated/ams.opt.omodel.OModel.parse.rst +6 -0
  345. docs/source/_generated/_generated/ams.opt.omodel.OModel.update.rst +6 -0
  346. docs/source/_generated/_generated/ams.opt.omodel.OModelBase.class_name.rst +6 -0
  347. docs/source/_generated/_generated/ams.opt.omodel.OModelBase.evaluate.rst +6 -0
  348. docs/source/_generated/_generated/ams.opt.omodel.OModelBase.finalize.rst +6 -0
  349. docs/source/_generated/_generated/ams.opt.omodel.OModelBase.init.rst +6 -0
  350. docs/source/_generated/_generated/ams.opt.omodel.OModelBase.initialized.rst +6 -0
  351. docs/source/_generated/_generated/ams.opt.omodel.OModelBase.parse.rst +6 -0
  352. docs/source/_generated/_generated/ams.opt.omodel.OModelBase.update.rst +6 -0
  353. docs/source/_generated/_generated/ams.opt.optbase.OptzBase.class_name.rst +6 -0
  354. docs/source/_generated/_generated/ams.opt.optbase.OptzBase.evaluate.rst +6 -0
  355. docs/source/_generated/_generated/ams.opt.optbase.OptzBase.n.rst +6 -0
  356. docs/source/_generated/_generated/ams.opt.optbase.OptzBase.parse.rst +6 -0
  357. docs/source/_generated/_generated/ams.opt.optbase.OptzBase.shape.rst +6 -0
  358. docs/source/_generated/_generated/ams.opt.optbase.OptzBase.size.rst +6 -0
  359. docs/source/_generated/_generated/ams.opt.param.Param.class_name.rst +6 -0
  360. docs/source/_generated/_generated/ams.opt.param.Param.evaluate.rst +6 -0
  361. docs/source/_generated/_generated/ams.opt.param.Param.n.rst +6 -0
  362. docs/source/_generated/_generated/ams.opt.param.Param.parse.rst +6 -0
  363. docs/source/_generated/_generated/ams.opt.param.Param.shape.rst +6 -0
  364. docs/source/_generated/_generated/ams.opt.param.Param.size.rst +6 -0
  365. docs/source/_generated/_generated/ams.opt.param.Param.update.rst +6 -0
  366. docs/source/_generated/_generated/ams.opt.var.Var.class_name.rst +6 -0
  367. docs/source/_generated/_generated/ams.opt.var.Var.evaluate.rst +6 -0
  368. docs/source/_generated/_generated/ams.opt.var.Var.get_idx.rst +6 -0
  369. docs/source/_generated/_generated/ams.opt.var.Var.n.rst +6 -0
  370. docs/source/_generated/_generated/ams.opt.var.Var.parse.rst +6 -0
  371. docs/source/_generated/_generated/ams.opt.var.Var.shape.rst +6 -0
  372. docs/source/_generated/_generated/ams.opt.var.Var.size.rst +6 -0
  373. docs/source/_generated/_generated/ams.opt.var.Var.v.rst +6 -0
  374. docs/source/_generated/_generated/ams.routines.dcopf.DCOPF.addConstrs.rst +6 -0
  375. docs/source/_generated/_generated/ams.routines.dcopf.DCOPF.addRParam.rst +6 -0
  376. docs/source/_generated/_generated/ams.routines.dcopf.DCOPF.addService.rst +6 -0
  377. docs/source/_generated/_generated/ams.routines.dcopf.DCOPF.addVars.rst +6 -0
  378. docs/source/_generated/_generated/ams.routines.dcopf.DCOPF.class_name.rst +6 -0
  379. docs/source/_generated/_generated/ams.routines.dcopf.DCOPF.dc2ac.rst +6 -0
  380. docs/source/_generated/_generated/ams.routines.dcopf.DCOPF.disable.rst +6 -0
  381. docs/source/_generated/_generated/ams.routines.dcopf.DCOPF.doc.rst +6 -0
  382. docs/source/_generated/_generated/ams.routines.dcopf.DCOPF.enable.rst +6 -0
  383. docs/source/_generated/_generated/ams.routines.dcopf.DCOPF.export_csv.rst +6 -0
  384. docs/source/_generated/_generated/ams.routines.dcopf.DCOPF.get.rst +6 -0
  385. docs/source/_generated/_generated/ams.routines.dcopf.DCOPF.init.rst +6 -0
  386. docs/source/_generated/_generated/ams.routines.dcopf.DCOPF.run.rst +6 -0
  387. docs/source/_generated/_generated/ams.routines.dcopf.DCOPF.set.rst +6 -0
  388. docs/source/_generated/_generated/ams.routines.dcopf.DCOPF.solve.rst +6 -0
  389. docs/source/_generated/_generated/ams.routines.dcopf.DCOPF.summary.rst +6 -0
  390. docs/source/_generated/_generated/ams.routines.dcopf.DCOPF.unpack.rst +6 -0
  391. docs/source/_generated/_generated/ams.routines.dcopf.DCOPF.update.rst +6 -0
  392. docs/source/_generated/_generated/ams.routines.pflow.PFlow.addConstrs.rst +6 -0
  393. docs/source/_generated/_generated/ams.routines.pflow.PFlow.addRParam.rst +6 -0
  394. docs/source/_generated/_generated/ams.routines.pflow.PFlow.addService.rst +6 -0
  395. docs/source/_generated/_generated/ams.routines.pflow.PFlow.addVars.rst +6 -0
  396. docs/source/_generated/_generated/ams.routines.pflow.PFlow.class_name.rst +6 -0
  397. docs/source/_generated/_generated/ams.routines.pflow.PFlow.dc2ac.rst +6 -0
  398. docs/source/_generated/_generated/ams.routines.pflow.PFlow.disable.rst +6 -0
  399. docs/source/_generated/_generated/ams.routines.pflow.PFlow.doc.rst +6 -0
  400. docs/source/_generated/_generated/ams.routines.pflow.PFlow.enable.rst +6 -0
  401. docs/source/_generated/_generated/ams.routines.pflow.PFlow.export_csv.rst +6 -0
  402. docs/source/_generated/_generated/ams.routines.pflow.PFlow.get.rst +6 -0
  403. docs/source/_generated/_generated/ams.routines.pflow.PFlow.init.rst +6 -0
  404. docs/source/_generated/_generated/ams.routines.pflow.PFlow.run.rst +6 -0
  405. docs/source/_generated/_generated/ams.routines.pflow.PFlow.set.rst +6 -0
  406. docs/source/_generated/_generated/ams.routines.pflow.PFlow.solve.rst +6 -0
  407. docs/source/_generated/_generated/ams.routines.pflow.PFlow.summary.rst +6 -0
  408. docs/source/_generated/_generated/ams.routines.pflow.PFlow.unpack.rst +6 -0
  409. docs/source/_generated/_generated/ams.routines.pflow.PFlow.update.rst +6 -0
  410. docs/source/_generated/_generated/ams.routines.routine.RoutineBase.addConstrs.rst +6 -0
  411. docs/source/_generated/_generated/ams.routines.routine.RoutineBase.addRParam.rst +6 -0
  412. docs/source/_generated/_generated/ams.routines.routine.RoutineBase.addService.rst +6 -0
  413. docs/source/_generated/_generated/ams.routines.routine.RoutineBase.addVars.rst +6 -0
  414. docs/source/_generated/_generated/ams.routines.routine.RoutineBase.class_name.rst +6 -0
  415. docs/source/_generated/_generated/ams.routines.routine.RoutineBase.dc2ac.rst +6 -0
  416. docs/source/_generated/_generated/ams.routines.routine.RoutineBase.disable.rst +6 -0
  417. docs/source/_generated/_generated/ams.routines.routine.RoutineBase.doc.rst +6 -0
  418. docs/source/_generated/_generated/ams.routines.routine.RoutineBase.enable.rst +6 -0
  419. docs/source/_generated/_generated/ams.routines.routine.RoutineBase.export_csv.rst +6 -0
  420. docs/source/_generated/_generated/ams.routines.routine.RoutineBase.get.rst +6 -0
  421. docs/source/_generated/_generated/ams.routines.routine.RoutineBase.init.rst +6 -0
  422. docs/source/_generated/_generated/ams.routines.routine.RoutineBase.run.rst +6 -0
  423. docs/source/_generated/_generated/ams.routines.routine.RoutineBase.set.rst +6 -0
  424. docs/source/_generated/_generated/ams.routines.routine.RoutineBase.solve.rst +6 -0
  425. docs/source/_generated/_generated/ams.routines.routine.RoutineBase.summary.rst +6 -0
  426. docs/source/_generated/_generated/ams.routines.routine.RoutineBase.unpack.rst +6 -0
  427. docs/source/_generated/_generated/ams.routines.routine.RoutineBase.update.rst +6 -0
  428. docs/source/_generated/_generated/ams.system.System.add.rst +6 -0
  429. docs/source/_generated/_generated/ams.system.System.as_dict.rst +6 -0
  430. docs/source/_generated/_generated/ams.system.System.calc_pu_coeff.rst +6 -0
  431. docs/source/_generated/_generated/ams.system.System.call_models.rst +6 -0
  432. docs/source/_generated/_generated/ams.system.System.collect_config.rst +6 -0
  433. docs/source/_generated/_generated/ams.system.System.collect_ref.rst +6 -0
  434. docs/source/_generated/_generated/ams.system.System.connectivity.rst +6 -0
  435. docs/source/_generated/_generated/ams.system.System.e_clear.rst +6 -0
  436. docs/source/_generated/_generated/ams.system.System.f_update.rst +6 -0
  437. docs/source/_generated/_generated/ams.system.System.fg_to_dae.rst +6 -0
  438. docs/source/_generated/_generated/ams.system.System.find_devices.rst +6 -0
  439. docs/source/_generated/_generated/ams.system.System.find_models.rst +6 -0
  440. docs/source/_generated/_generated/ams.system.System.from_ipysheet.rst +6 -0
  441. docs/source/_generated/_generated/ams.system.System.g_islands.rst +6 -0
  442. docs/source/_generated/_generated/ams.system.System.g_update.rst +6 -0
  443. docs/source/_generated/_generated/ams.system.System.get_z.rst +6 -0
  444. docs/source/_generated/_generated/ams.system.System.import_groups.rst +6 -0
  445. docs/source/_generated/_generated/ams.system.System.import_models.rst +6 -0
  446. docs/source/_generated/_generated/ams.system.System.import_routines.rst +6 -0
  447. docs/source/_generated/_generated/ams.system.System.import_types.rst +6 -0
  448. docs/source/_generated/_generated/ams.system.System.init.rst +6 -0
  449. docs/source/_generated/_generated/ams.system.System.j_islands.rst +6 -0
  450. docs/source/_generated/_generated/ams.system.System.j_update.rst +6 -0
  451. docs/source/_generated/_generated/ams.system.System.l_update_eq.rst +6 -0
  452. docs/source/_generated/_generated/ams.system.System.l_update_var.rst +6 -0
  453. docs/source/_generated/_generated/ams.system.System.link_ext_param.rst +6 -0
  454. docs/source/_generated/_generated/ams.system.System.precompile.rst +6 -0
  455. docs/source/_generated/_generated/ams.system.System.prepare.rst +6 -0
  456. docs/source/_generated/_generated/ams.system.System.reload.rst +6 -0
  457. docs/source/_generated/_generated/ams.system.System.remove_pycapsule.rst +6 -0
  458. docs/source/_generated/_generated/ams.system.System.report.rst +6 -0
  459. docs/source/_generated/_generated/ams.system.System.reset.rst +6 -0
  460. docs/source/_generated/_generated/ams.system.System.s_update_post.rst +6 -0
  461. docs/source/_generated/_generated/ams.system.System.s_update_var.rst +6 -0
  462. docs/source/_generated/_generated/ams.system.System.save_config.rst +6 -0
  463. docs/source/_generated/_generated/ams.system.System.set_address.rst +6 -0
  464. docs/source/_generated/_generated/ams.system.System.set_config.rst +6 -0
  465. docs/source/_generated/_generated/ams.system.System.set_dae_names.rst +6 -0
  466. docs/source/_generated/_generated/ams.system.System.set_output_subidx.rst +6 -0
  467. docs/source/_generated/_generated/ams.system.System.set_var_arrays.rst +6 -0
  468. docs/source/_generated/_generated/ams.system.System.setup.rst +6 -0
  469. docs/source/_generated/_generated/ams.system.System.store_adder_setter.rst +6 -0
  470. docs/source/_generated/_generated/ams.system.System.store_existing.rst +6 -0
  471. docs/source/_generated/_generated/ams.system.System.store_no_check_init.rst +6 -0
  472. docs/source/_generated/_generated/ams.system.System.store_sparse_pattern.rst +6 -0
  473. docs/source/_generated/_generated/ams.system.System.store_switch_times.rst +6 -0
  474. docs/source/_generated/_generated/ams.system.System.summary.rst +6 -0
  475. docs/source/_generated/_generated/ams.system.System.supported_models.rst +6 -0
  476. docs/source/_generated/_generated/ams.system.System.supported_routines.rst +6 -0
  477. docs/source/_generated/_generated/ams.system.System.switch_action.rst +6 -0
  478. docs/source/_generated/_generated/ams.system.System.to_andes.rst +6 -0
  479. docs/source/_generated/_generated/ams.system.System.to_ipysheet.rst +6 -0
  480. docs/source/_generated/_generated/ams.system.System.undill.rst +6 -0
  481. docs/source/_generated/_generated/ams.system.System.vars_to_dae.rst +6 -0
  482. docs/source/_generated/_generated/ams.system.System.vars_to_models.rst +6 -0
  483. docs/source/_generated/_generated/ams.utils.paths.DisplayablePath.display_filename_prefix_last.rst +6 -0
  484. docs/source/_generated/_generated/ams.utils.paths.DisplayablePath.display_filename_prefix_middle.rst +6 -0
  485. docs/source/_generated/_generated/ams.utils.paths.DisplayablePath.display_parent_prefix_last.rst +6 -0
  486. docs/source/_generated/_generated/ams.utils.paths.DisplayablePath.display_parent_prefix_middle.rst +6 -0
  487. docs/source/_generated/_generated/ams.utils.paths.DisplayablePath.displayable.rst +6 -0
  488. docs/source/_generated/_generated/ams.utils.paths.DisplayablePath.displayname.rst +6 -0
  489. docs/source/_generated/_generated/ams.utils.paths.DisplayablePath.make_tree.rst +6 -0
  490. docs/source/_generated/ams.cli.create_parser.rst +6 -0
  491. docs/source/_generated/ams.cli.main.rst +6 -0
  492. docs/source/_generated/ams.cli.preamble.rst +6 -0
  493. docs/source/_generated/ams.cli.rst +32 -0
  494. docs/source/_generated/ams.core.model.Model.rst +56 -0
  495. docs/source/_generated/ams.core.model.rst +30 -0
  496. docs/source/_generated/ams.core.param.RParam.rst +49 -0
  497. docs/source/_generated/ams.core.param.rst +30 -0
  498. docs/source/_generated/ams.core.service.LoadScale.rst +51 -0
  499. docs/source/_generated/ams.core.service.MinDur.rst +53 -0
  500. docs/source/_generated/ams.core.service.NumExpandDim.rst +53 -0
  501. docs/source/_generated/ams.core.service.NumHstack.rst +53 -0
  502. docs/source/_generated/ams.core.service.NumOp.rst +53 -0
  503. docs/source/_generated/ams.core.service.NumOpDual.rst +53 -0
  504. docs/source/_generated/ams.core.service.RBaseService.rst +51 -0
  505. docs/source/_generated/ams.core.service.ROperationService.rst +51 -0
  506. docs/source/_generated/ams.core.service.RampSub.rst +53 -0
  507. docs/source/_generated/ams.core.service.ValueService.rst +51 -0
  508. docs/source/_generated/ams.core.service.VarReduction.rst +53 -0
  509. docs/source/_generated/ams.core.service.VarSelect.rst +53 -0
  510. docs/source/_generated/ams.core.service.ZonalSum.rst +53 -0
  511. docs/source/_generated/ams.core.service.rst +42 -0
  512. docs/source/_generated/ams.interface.Dynamic.rst +41 -0
  513. docs/source/_generated/ams.interface.build_group_table.rst +6 -0
  514. docs/source/_generated/ams.interface.make_link_table.rst +6 -0
  515. docs/source/_generated/ams.interface.parse_addfile.rst +6 -0
  516. docs/source/_generated/ams.interface.replace_dev.rst +6 -0
  517. docs/source/_generated/ams.interface.rst +43 -0
  518. docs/source/_generated/ams.interface.sync_adsys.rst +6 -0
  519. docs/source/_generated/ams.interface.to_andes.rst +6 -0
  520. docs/source/_generated/ams.interface.verify_pf.rst +6 -0
  521. docs/source/_generated/ams.io.guess.rst +6 -0
  522. docs/source/_generated/ams.io.json.rst +30 -0
  523. docs/source/_generated/ams.io.json.write.rst +6 -0
  524. docs/source/_generated/ams.io.matpower.mpc2system.rst +6 -0
  525. docs/source/_generated/ams.io.matpower.read.rst +6 -0
  526. docs/source/_generated/ams.io.matpower.rst +33 -0
  527. docs/source/_generated/ams.io.matpower.system2mpc.rst +6 -0
  528. docs/source/_generated/ams.io.matpower.testlines.rst +6 -0
  529. docs/source/_generated/ams.io.parse.rst +6 -0
  530. docs/source/_generated/ams.io.psse.rst +23 -0
  531. docs/source/_generated/ams.io.pypower.ppc2system.rst +6 -0
  532. docs/source/_generated/ams.io.pypower.py2ppc.rst +6 -0
  533. docs/source/_generated/ams.io.pypower.read.rst +6 -0
  534. docs/source/_generated/ams.io.pypower.rst +34 -0
  535. docs/source/_generated/ams.io.pypower.system2ppc.rst +6 -0
  536. docs/source/_generated/ams.io.pypower.testlines.rst +6 -0
  537. docs/source/_generated/ams.io.rst +45 -0
  538. docs/source/_generated/ams.io.xlsx.rst +30 -0
  539. docs/source/_generated/ams.io.xlsx.write.rst +6 -0
  540. docs/source/_generated/ams.main.config_logger.rst +6 -0
  541. docs/source/_generated/ams.main.demo.rst +6 -0
  542. docs/source/_generated/ams.main.doc.rst +6 -0
  543. docs/source/_generated/ams.main.edit_conf.rst +6 -0
  544. docs/source/_generated/ams.main.find_log_path.rst +6 -0
  545. docs/source/_generated/ams.main.load.rst +6 -0
  546. docs/source/_generated/ams.main.misc.rst +6 -0
  547. docs/source/_generated/ams.main.print_license.rst +6 -0
  548. docs/source/_generated/ams.main.remove_output.rst +6 -0
  549. docs/source/_generated/ams.main.rst +44 -0
  550. docs/source/_generated/ams.main.run.rst +6 -0
  551. docs/source/_generated/ams.main.run_case.rst +6 -0
  552. docs/source/_generated/ams.main.save_conf.rst +6 -0
  553. docs/source/_generated/ams.main.selftest.rst +6 -0
  554. docs/source/_generated/ams.main.set_logger_level.rst +6 -0
  555. docs/source/_generated/ams.main.versioninfo.rst +6 -0
  556. docs/source/_generated/ams.opt.constraint.Constraint.rst +43 -0
  557. docs/source/_generated/ams.opt.constraint.rst +30 -0
  558. docs/source/_generated/ams.opt.exprcalc.ExpressionCalc.rst +46 -0
  559. docs/source/_generated/ams.opt.exprcalc.rst +30 -0
  560. docs/source/_generated/ams.opt.expression.Expression.rst +46 -0
  561. docs/source/_generated/ams.opt.expression.rst +30 -0
  562. docs/source/_generated/ams.opt.objective.Objective.rst +43 -0
  563. docs/source/_generated/ams.opt.objective.rst +30 -0
  564. docs/source/_generated/ams.opt.omodel.OModel.rst +48 -0
  565. docs/source/_generated/ams.opt.omodel.OModelBase.rst +48 -0
  566. docs/source/_generated/ams.opt.omodel.rst +31 -0
  567. docs/source/_generated/ams.opt.optbase.OptzBase.rst +41 -0
  568. docs/source/_generated/ams.opt.optbase.ensure_mats_and_parsed.rst +6 -0
  569. docs/source/_generated/ams.opt.optbase.ensure_symbols.rst +6 -0
  570. docs/source/_generated/ams.opt.optbase.rst +38 -0
  571. docs/source/_generated/ams.opt.param.Param.rst +44 -0
  572. docs/source/_generated/ams.opt.param.rst +30 -0
  573. docs/source/_generated/ams.opt.rst +40 -0
  574. docs/source/_generated/ams.opt.var.Var.rst +45 -0
  575. docs/source/_generated/ams.opt.var.rst +30 -0
  576. docs/source/_generated/ams.routines.dcopf.DCOPF.rst +83 -0
  577. docs/source/_generated/ams.routines.dcopf.rst +30 -0
  578. docs/source/_generated/ams.routines.pflow.PFlow.rst +83 -0
  579. docs/source/_generated/ams.routines.pflow.rst +30 -0
  580. docs/source/_generated/ams.routines.routine.RoutineBase.rst +83 -0
  581. docs/source/_generated/ams.routines.routine.collect_data.rst +6 -0
  582. docs/source/_generated/ams.routines.routine.initialize_data_dict.rst +6 -0
  583. docs/source/_generated/ams.routines.routine.rst +38 -0
  584. docs/source/_generated/ams.system.System.rst +189 -0
  585. docs/source/_generated/ams.system.disable_method.rst +6 -0
  586. docs/source/_generated/ams.system.disable_methods.rst +6 -0
  587. docs/source/_generated/ams.system.example.rst +6 -0
  588. docs/source/_generated/ams.system.rst +39 -0
  589. docs/source/_generated/ams.utils.paths.DisplayablePath.rst +42 -0
  590. docs/source/_generated/ams.utils.paths.ams_root.rst +6 -0
  591. docs/source/_generated/ams.utils.paths.cases_root.rst +6 -0
  592. docs/source/_generated/ams.utils.paths.confirm_overwrite.rst +6 -0
  593. docs/source/_generated/ams.utils.paths.get_case.rst +6 -0
  594. docs/source/_generated/ams.utils.paths.get_config_path.rst +6 -0
  595. docs/source/_generated/ams.utils.paths.get_dot_andes_path.rst +6 -0
  596. docs/source/_generated/ams.utils.paths.get_log_dir.rst +6 -0
  597. docs/source/_generated/ams.utils.paths.get_pkl_path.rst +6 -0
  598. docs/source/_generated/ams.utils.paths.get_pycode_path.rst +6 -0
  599. docs/source/_generated/ams.utils.paths.list_cases.rst +6 -0
  600. docs/source/_generated/ams.utils.paths.rst +47 -0
  601. docs/source/_generated/ams.utils.paths.tests_root.rst +6 -0
  602. docs/source/_templates/autosummary/base.rst +5 -0
  603. docs/source/_templates/autosummary/class.rst +35 -0
  604. docs/source/_templates/autosummary/module.rst +65 -0
  605. docs/source/_templates/autosummary/module_toctree.rst +66 -0
  606. docs/source/api.rst +102 -0
  607. docs/source/conf.py +203 -0
  608. docs/source/examples/index.rst +34 -0
  609. docs/source/genmodelref.py +61 -0
  610. docs/source/genroutineref.py +47 -0
  611. docs/source/getting_started/copyright.rst +20 -0
  612. docs/source/getting_started/formats/index.rst +20 -0
  613. docs/source/getting_started/formats/matpower.rst +183 -0
  614. docs/source/getting_started/formats/psse.rst +46 -0
  615. docs/source/getting_started/formats/pypower.rst +223 -0
  616. docs/source/getting_started/formats/xlsx.png +0 -0
  617. docs/source/getting_started/formats/xlsx.rst +23 -0
  618. docs/source/getting_started/index.rst +76 -0
  619. docs/source/getting_started/install.rst +234 -0
  620. docs/source/getting_started/overview.rst +26 -0
  621. docs/source/getting_started/testcase.rst +45 -0
  622. docs/source/getting_started/verification.rst +13 -0
  623. docs/source/groupdoc/ACLine.rst +92 -0
  624. docs/source/groupdoc/ACShort.rst +51 -0
  625. docs/source/groupdoc/ACTopology.rst +66 -0
  626. docs/source/groupdoc/Collection.rst +84 -0
  627. docs/source/groupdoc/Cost.rst +135 -0
  628. docs/source/groupdoc/DG.rst +204 -0
  629. docs/source/groupdoc/Horizon.rst +97 -0
  630. docs/source/groupdoc/Information.rst +36 -0
  631. docs/source/groupdoc/RenGen.rst +63 -0
  632. docs/source/groupdoc/Reserve.rst +135 -0
  633. docs/source/groupdoc/StaticGen.rst +229 -0
  634. docs/source/groupdoc/StaticLoad.rst +53 -0
  635. docs/source/groupdoc/StaticShunt.rst +45 -0
  636. docs/source/groupdoc/Undefined.rst +63 -0
  637. docs/source/groupdoc/VSG.rst +125 -0
  638. docs/source/images/dcopf_time.png +0 -0
  639. docs/source/images/sponsors/CURENT_Logo_NameOnTrans.png +0 -0
  640. docs/source/images/sponsors/CURENT_Logo_Transparent.png +0 -0
  641. docs/source/images/sponsors/CURENT_Logo_Transparent_Name.png +0 -0
  642. docs/source/images/sponsors/doe.png +0 -0
  643. docs/source/index.rst +108 -0
  644. docs/source/modeling/_generated/_generated/ams.opt.Constraint.class_name.rst +6 -0
  645. docs/source/modeling/_generated/_generated/ams.opt.Constraint.e.rst +6 -0
  646. docs/source/modeling/_generated/_generated/ams.opt.Constraint.evaluate.rst +6 -0
  647. docs/source/modeling/_generated/_generated/ams.opt.Constraint.n.rst +6 -0
  648. docs/source/modeling/_generated/_generated/ams.opt.Constraint.parse.rst +6 -0
  649. docs/source/modeling/_generated/_generated/ams.opt.Constraint.shape.rst +6 -0
  650. docs/source/modeling/_generated/_generated/ams.opt.Constraint.size.rst +6 -0
  651. docs/source/modeling/_generated/_generated/ams.opt.Constraint.v.rst +6 -0
  652. docs/source/modeling/_generated/_generated/ams.opt.OModel.class_name.rst +6 -0
  653. docs/source/modeling/_generated/_generated/ams.opt.OModel.evaluate.rst +6 -0
  654. docs/source/modeling/_generated/_generated/ams.opt.OModel.finalize.rst +6 -0
  655. docs/source/modeling/_generated/_generated/ams.opt.OModel.init.rst +6 -0
  656. docs/source/modeling/_generated/_generated/ams.opt.OModel.initialized.rst +6 -0
  657. docs/source/modeling/_generated/_generated/ams.opt.OModel.parse.rst +6 -0
  658. docs/source/modeling/_generated/_generated/ams.opt.OModel.update.rst +6 -0
  659. docs/source/modeling/_generated/_generated/ams.opt.Objective.class_name.rst +6 -0
  660. docs/source/modeling/_generated/_generated/ams.opt.Objective.e.rst +6 -0
  661. docs/source/modeling/_generated/_generated/ams.opt.Objective.evaluate.rst +6 -0
  662. docs/source/modeling/_generated/_generated/ams.opt.Objective.n.rst +6 -0
  663. docs/source/modeling/_generated/_generated/ams.opt.Objective.parse.rst +6 -0
  664. docs/source/modeling/_generated/_generated/ams.opt.Objective.shape.rst +6 -0
  665. docs/source/modeling/_generated/_generated/ams.opt.Objective.size.rst +6 -0
  666. docs/source/modeling/_generated/_generated/ams.opt.Objective.v.rst +6 -0
  667. docs/source/modeling/_generated/_generated/ams.opt.Var.class_name.rst +6 -0
  668. docs/source/modeling/_generated/_generated/ams.opt.Var.evaluate.rst +6 -0
  669. docs/source/modeling/_generated/_generated/ams.opt.Var.get_idx.rst +6 -0
  670. docs/source/modeling/_generated/_generated/ams.opt.Var.n.rst +6 -0
  671. docs/source/modeling/_generated/_generated/ams.opt.Var.parse.rst +6 -0
  672. docs/source/modeling/_generated/_generated/ams.opt.Var.shape.rst +6 -0
  673. docs/source/modeling/_generated/_generated/ams.opt.Var.size.rst +6 -0
  674. docs/source/modeling/_generated/_generated/ams.opt.Var.v.rst +6 -0
  675. docs/source/modeling/_generated/ams.opt.Constraint.rst +43 -0
  676. docs/source/modeling/_generated/ams.opt.OModel.rst +48 -0
  677. docs/source/modeling/_generated/ams.opt.Objective.rst +43 -0
  678. docs/source/modeling/_generated/ams.opt.Var.rst +45 -0
  679. docs/source/modeling/example.rst +159 -0
  680. docs/source/modeling/index.rst +17 -0
  681. docs/source/modeling/model.rst +210 -0
  682. docs/source/modeling/routine.rst +122 -0
  683. docs/source/modeling/system.rst +51 -0
  684. docs/source/modelref.rst +66 -0
  685. docs/source/release-notes.rst +385 -0
  686. docs/source/routineref.rst +38 -0
  687. docs/source/typedoc/ACED.rst +91 -0
  688. docs/source/typedoc/DCED.rst +1869 -0
  689. docs/source/typedoc/DCUC.rst +899 -0
  690. docs/source/typedoc/DED.rst +390 -0
  691. docs/source/typedoc/PF.rst +376 -0
  692. docs/source/typedoc/UndefinedType.rst +8 -0
  693. icebar/ips/ips.py +668 -0
  694. ltbams-1.0.0.dist-info/METADATA +231 -0
  695. ltbams-1.0.0.dist-info/RECORD +725 -0
  696. {ltbams-0.9.9.dist-info → ltbams-1.0.0.dist-info}/WHEEL +1 -1
  697. ltbams-1.0.0.dist-info/top_level.txt +5 -0
  698. tests/__init__.py +0 -0
  699. tests/test_1st_system.py +33 -0
  700. tests/test_addressing.py +40 -0
  701. tests/test_andes_mats.py +61 -0
  702. tests/test_case.py +266 -0
  703. tests/test_cli.py +34 -0
  704. tests/test_export_csv.py +89 -0
  705. tests/test_group.py +83 -0
  706. tests/test_interface.py +216 -0
  707. tests/test_io.py +32 -0
  708. tests/test_jumper.py +27 -0
  709. tests/test_known_good.py +267 -0
  710. tests/test_matp.py +437 -0
  711. tests/test_model.py +54 -0
  712. tests/test_omodel.py +119 -0
  713. tests/test_paths.py +22 -0
  714. tests/test_report.py +245 -0
  715. tests/test_repr.py +21 -0
  716. tests/test_routine.py +178 -0
  717. tests/test_rtn_dcopf.py +101 -0
  718. tests/test_rtn_dcpf.py +77 -0
  719. tests/test_rtn_ed.py +275 -0
  720. tests/test_rtn_pflow.py +219 -0
  721. tests/test_rtn_rted.py +273 -0
  722. tests/test_rtn_uc.py +248 -0
  723. tests/test_service.py +73 -0
  724. ltbams-0.9.9.dist-info/LICENSE +0 -692
  725. ltbams-0.9.9.dist-info/METADATA +0 -859
  726. ltbams-0.9.9.dist-info/RECORD +0 -14
  727. ltbams-0.9.9.dist-info/top_level.txt +0 -1
  728. {ltbams-0.9.9.dist-info → ltbams-1.0.0.dist-info}/entry_points.txt +0 -0
ams/routines/rted.py ADDED
@@ -0,0 +1,519 @@
1
+ """
2
+ Real-time economic dispatch.
3
+ """
4
+ import logging
5
+ from collections import OrderedDict
6
+ import numpy as np
7
+
8
+ from ams.core.param import RParam
9
+ from ams.core.service import ZonalSum, VarSelect, NumOp, NumOpDual
10
+ from ams.routines.dcopf import DCOPF
11
+
12
+ from ams.opt import Var, Constraint
13
+
14
+ logger = logging.getLogger(__name__)
15
+
16
+
17
+ class RTEDBase:
18
+ """
19
+ Base class for real-time economic dispatch (RTED).
20
+ """
21
+
22
+ def __init__(self):
23
+ # --- zone ---
24
+ self.zg = RParam(info='Gen zone',
25
+ name='zg', tex_name='z_{one,g}',
26
+ model='StaticGen', src='zone',
27
+ no_parse=True)
28
+ self.zd = RParam(info='Load zone',
29
+ name='zd', tex_name='z_{one,d}',
30
+ model='StaticLoad', src='zone',
31
+ no_parse=True)
32
+ self.gs = ZonalSum(u=self.zg, zone='Zone',
33
+ name='gs', tex_name=r'S_{g}',
34
+ info='Sum Gen vars vector in shape of zone',
35
+ no_parse=True, sparse=True)
36
+ self.ds = ZonalSum(u=self.zd, zone='Zone',
37
+ name='ds', tex_name=r'S_{d}',
38
+ info='Sum pd vector in shape of zone',
39
+ no_parse=True,)
40
+ self.pdz = NumOpDual(u=self.ds, u2=self.pd,
41
+ fun=np.multiply,
42
+ rfun=np.sum, rargs=dict(axis=1),
43
+ expand_dims=0,
44
+ name='pdz', tex_name=r'p_{d,z}',
45
+ unit='p.u.', info='zonal total load',
46
+ no_parse=True,)
47
+ # --- generator ---
48
+ self.R10 = RParam(info='10-min ramp rate',
49
+ name='R10', tex_name=r'R_{10}',
50
+ model='StaticGen', src='R10',
51
+ unit='p.u./h',)
52
+
53
+
54
+ class SFRBase:
55
+ """
56
+ Base class for SFR used in DCED.
57
+ """
58
+
59
+ def __init__(self):
60
+ # --- SFR cost ---
61
+ self.cru = RParam(info='RegUp reserve coefficient',
62
+ name='cru', tex_name=r'c_{r,u}',
63
+ model='SFRCost', src='cru',
64
+ indexer='gen', imodel='StaticGen',
65
+ unit=r'$/(p.u.)',)
66
+ self.crd = RParam(info='RegDown reserve coefficient',
67
+ name='crd', tex_name=r'c_{r,d}',
68
+ model='SFRCost', src='crd',
69
+ indexer='gen', imodel='StaticGen',
70
+ unit=r'$/(p.u.)',)
71
+ # --- reserve requirement ---
72
+ self.du = RParam(info='RegUp reserve requirement in percentage',
73
+ name='du', tex_name=r'd_{u}',
74
+ model='SFR', src='du',
75
+ unit='%', no_parse=True,)
76
+ self.dd = RParam(info='RegDown reserve requirement in percentage',
77
+ name='dd', tex_name=r'd_{d}',
78
+ model='SFR', src='dd',
79
+ unit='%', no_parse=True,)
80
+ self.dud = NumOpDual(u=self.pdz, u2=self.du, fun=np.multiply,
81
+ rfun=np.reshape, rargs=dict(newshape=(-1,)),
82
+ name='dud', tex_name=r'd_{u, d}',
83
+ info='zonal RegUp reserve requirement',)
84
+ self.ddd = NumOpDual(u=self.pdz, u2=self.dd, fun=np.multiply,
85
+ rfun=np.reshape, rargs=dict(newshape=(-1,)),
86
+ name='ddd', tex_name=r'd_{d, d}',
87
+ info='zonal RegDn reserve requirement',)
88
+ # --- SFR ---
89
+ self.pru = Var(info='RegUp reserve',
90
+ unit='p.u.', name='pru', tex_name=r'p_{r,u}',
91
+ model='StaticGen', nonneg=True,)
92
+ self.prd = Var(info='RegDn reserve',
93
+ unit='p.u.', name='prd', tex_name=r'p_{r,d}',
94
+ model='StaticGen', nonneg=True,)
95
+ # NOTE: define e_str in scheduling routine
96
+ self.rbu = Constraint(name='rbu', is_eq=True,
97
+ info='RegUp reserve balance',)
98
+ self.rbd = Constraint(name='rbd', is_eq=True,
99
+ info='RegDn reserve balance',)
100
+ self.rru = Constraint(name='rru', is_eq=False,
101
+ info='RegUp reserve source',)
102
+ self.rrd = Constraint(name='rrd', is_eq=False,
103
+ info='RegDn reserve source',)
104
+ self.rgu = Constraint(name='rgu', is_eq=False,
105
+ info='Gen ramping up',)
106
+ self.rgd = Constraint(name='rgd', is_eq=False,
107
+ info='Gen ramping down',)
108
+
109
+
110
+ class RTED(DCOPF, RTEDBase, SFRBase):
111
+ """
112
+ DC-based real-time economic dispatch (RTED).
113
+ RTED extends DCOPF with:
114
+
115
+ - Mapping dicts to interface with ANDES
116
+ - Function ``dc2ac`` to do the AC conversion
117
+ - Vars for SFR reserve: ``pru`` and ``prd``
118
+ - Param for linear SFR cost: ``cru`` and ``crd``
119
+ - Param for SFR requirement: ``du`` and ``dd``
120
+ - Param for ramping: start point ``pg0`` and ramping limit ``R10``
121
+ - Param ``pg0``, which can be retrieved from dynamic simulation results.
122
+
123
+ The function ``dc2ac`` sets the ``vBus`` value from solved ACOPF.
124
+ Without this conversion, dynamic simulation might fail due to the gap between
125
+ DC-based dispatch results and AC-based dynamic initialization.
126
+
127
+ Notes
128
+ -----
129
+ 1. Formulations has been adjusted with interval ``config.t``, 5/60 [Hour] by default.
130
+
131
+ 2. The tie-line flow has not been implemented in formulations.
132
+ """
133
+
134
+ def __init__(self, system, config):
135
+ DCOPF.__init__(self, system, config)
136
+ RTEDBase.__init__(self)
137
+ SFRBase.__init__(self)
138
+
139
+ self.config.add(OrderedDict((('t', 5/60),
140
+ )))
141
+ self.config.add_extra("_help",
142
+ t="time interval in hours",
143
+ )
144
+ self.config.add_extra("_tex",
145
+ t='T_{cfg}',
146
+ )
147
+
148
+ self.info = 'Real-time economic dispatch'
149
+ self.type = 'DCED'
150
+
151
+ # --- Mapping Section ---
152
+ # Add p -> pg0 in from map
153
+ self.map1.update({
154
+ 'pg0': ('StaticGen', 'p'),
155
+ })
156
+ # nothing to do with to map
157
+
158
+ # --- Model Section ---
159
+ # --- SFR ---
160
+ # RegUp/Dn reserve balance
161
+ self.rbu.e_str = 'gs @ mul(ug, pru) - dud'
162
+ self.rbd.e_str = 'gs @ mul(ug, prd) - ddd'
163
+ # RegUp/Dn reserve source
164
+ self.rru.e_str = 'mul(ug, (pg + pru)) - mul(ug, pmaxe)'
165
+ self.rrd.e_str = 'mul(ug, (-pg + prd)) + mul(ug, pmine)'
166
+ # Gen ramping up/down
167
+ self.rgu.e_str = 'mul(ug, (pg-pg0-R10))'
168
+ self.rgd.e_str = 'mul(ug, (-pg+pg0-R10))'
169
+
170
+ # --- objective ---
171
+ self.obj.info = 'total generation and reserve cost'
172
+ # NOTE: the product involved t should use ``dot``
173
+ cost = 't**2 dot sum(mul(c2, pg**2)) + sum(ug * c0)'
174
+ _to_sum = 'c1 @ pg + cru * pru + crd * prd'
175
+ cost += f'+ t dot sum({_to_sum})'
176
+ self.obj.e_str = cost
177
+
178
+ def dc2ac(self, kloss=1.0, **kwargs):
179
+ """
180
+ Convert the RTED results with ACOPF.
181
+
182
+ Parameters
183
+ ----------
184
+ kloss : float, optional
185
+ The loss factor for the conversion. Defaults to 1.2.
186
+ """
187
+ exec_time = self.exec_time
188
+ if self.exec_time == 0 or self.exit_code != 0:
189
+ logger.warning(f'{self.class_name} is not executed successfully, quit conversion.')
190
+ return False
191
+ # set pru and prd into pmin and pmax
192
+ pr_idx = self.pru.get_all_idxes()
193
+ pmin0 = self.system.StaticGen.get(src='pmin', attr='v', idx=pr_idx)
194
+ pmax0 = self.system.StaticGen.get(src='pmax', attr='v', idx=pr_idx)
195
+ p00 = self.system.StaticGen.get(src='p0', attr='v', idx=pr_idx)
196
+
197
+ # --- ACOPF ---
198
+ # scale up load
199
+ pq_idx = self.system.StaticLoad.get_all_idxes()
200
+ pd0 = self.system.StaticLoad.get(src='p0', attr='v', idx=pq_idx).copy()
201
+ qd0 = self.system.StaticLoad.get(src='q0', attr='v', idx=pq_idx).copy()
202
+ self.system.StaticLoad.set(src='p0', idx=pq_idx, attr='v', value=pd0 * kloss)
203
+ self.system.StaticLoad.set(src='q0', idx=pq_idx, attr='v', value=qd0 * kloss)
204
+ # preserve generator reserve
205
+ ACOPF = self.system.ACOPF
206
+ pmin = pmin0 + self.prd.v
207
+ pmax = pmax0 - self.pru.v
208
+ self.system.StaticGen.set(src='pmin', idx=pr_idx, attr='v', value=pmin)
209
+ self.system.StaticGen.set(src='pmax', idx=pr_idx, attr='v', value=pmax)
210
+ self.system.StaticGen.set(src='p0', idx=pr_idx, attr='v', value=self.pg.v)
211
+ # run ACOPF
212
+ ACOPF.run()
213
+ # scale load back
214
+ self.system.StaticLoad.set(src='p0', idx=pq_idx, attr='v', value=pd0)
215
+ self.system.StaticLoad.set(src='q0', idx=pq_idx, attr='v', value=qd0)
216
+ if not ACOPF.exit_code == 0:
217
+ logger.warning('<ACOPF> did not converge, conversion failed.')
218
+ self.vBus.optz.value = np.ones(self.system.Bus.n)
219
+ self.aBus.optz.value = np.zeros(self.system.Bus.n)
220
+ return False
221
+
222
+ self.pg.optz.value = ACOPF.pg.v
223
+ self.vBus.optz.value = ACOPF.vBus.v
224
+ self.aBus.optz.value = ACOPF.aBus.v
225
+ self.exec_time = exec_time
226
+
227
+ # reset pmin, pmax, p0
228
+ self.system.StaticGen.set(src='pmin', idx=pr_idx, attr='v', value=pmin0)
229
+ self.system.StaticGen.set(src='pmax', idx=pr_idx, attr='v', value=pmax0)
230
+ self.system.StaticGen.set(src='p0', idx=pr_idx, attr='v', value=p00)
231
+
232
+ # --- set status ---
233
+ self.system.recent = self
234
+ self.converted = True
235
+ logger.warning(f'<{self.class_name}> converted to AC.')
236
+ return True
237
+
238
+
239
+ class DGBase:
240
+ """
241
+ Base class for DG used in DCED.
242
+ """
243
+
244
+ def __init__(self):
245
+ # --- params ---
246
+ self.gendg = RParam(info='gen of DG',
247
+ name='gendg', tex_name=r'g_{DG}',
248
+ model='DG', src='gen',
249
+ no_parse=True,)
250
+ info = 'Ratio of DG.pge w.r.t to that of static generator'
251
+ self.gammapdg = RParam(name='gammapd', tex_name=r'\gamma_{p,DG}',
252
+ model='DG', src='gammap',
253
+ no_parse=True, info=info)
254
+
255
+ # --- vars ---
256
+ # TODO: maybe there will be constraints on pgd, maybe upper/lower bound?
257
+ # TODO: this might requre new device like DGSlot
258
+ self.pgdg = Var(info='DG output power',
259
+ unit='p.u.', name='pgdg',
260
+ tex_name=r'p_{g,DG}',
261
+ model='DG',)
262
+
263
+ # --- constraints ---
264
+ self.cdg = VarSelect(u=self.pg, indexer='gendg',
265
+ name='cd', tex_name=r'C_{DG}',
266
+ info='Select DG power from pg',
267
+ gamma='gammapdg',
268
+ no_parse=True, sparse=True,)
269
+ self.cdgb = Constraint(name='cdgb', is_eq=True,
270
+ info='Select DG power from pg',
271
+ e_str='cdg @ pg - pgdg',)
272
+
273
+
274
+ class RTEDDG(RTED, DGBase):
275
+ """
276
+ RTED with distributed generator :ref:`DG`.
277
+
278
+ Note that RTEDDG only inlcudes DG output power. If ESD1 is included,
279
+ RTEDES should be used instead, otherwise there is no SOC.
280
+ """
281
+
282
+ def __init__(self, system, config):
283
+ RTED.__init__(self, system, config)
284
+ DGBase.__init__(self)
285
+ self.info = 'Real-time economic dispatch with DG'
286
+ self.type = 'DCED'
287
+
288
+
289
+ class ESD1Base(DGBase):
290
+ """
291
+ Base class for ESD1 used in DCED.
292
+ """
293
+
294
+ def __init__(self):
295
+ DGBase.__init__(self)
296
+
297
+ # --- params ---
298
+ self.En = RParam(info='Rated energy capacity',
299
+ name='En', src='En',
300
+ tex_name='E_n', unit='MWh',
301
+ model='ESD1', no_parse=True,)
302
+ self.SOCmax = RParam(info='Maximum allowed value for SOC in limiter',
303
+ name='SOCmax', src='SOCmax',
304
+ tex_name=r'SOC_{max}', unit='%',
305
+ model='ESD1',)
306
+ self.SOCmin = RParam(info='Minimum required value for SOC in limiter',
307
+ name='SOCmin', src='SOCmin',
308
+ tex_name=r'SOC_{min}', unit='%',
309
+ model='ESD1',)
310
+ self.SOCinit = RParam(info='Initial SOC',
311
+ name='SOCinit', src='SOCinit',
312
+ tex_name=r'SOC_{init}', unit='%',
313
+ model='ESD1',)
314
+ self.EtaC = RParam(info='Efficiency during charging',
315
+ name='EtaC', src='EtaC',
316
+ tex_name=r'\eta_c', unit='%',
317
+ model='ESD1', no_parse=True,)
318
+ self.EtaD = RParam(info='Efficiency during discharging',
319
+ name='EtaD', src='EtaD',
320
+ tex_name=r'\eta_d', unit='%',
321
+ model='ESD1', no_parse=True,)
322
+
323
+ # --- service ---
324
+ self.REtaD = NumOp(name='REtaD', tex_name=r'\frac{1}{\eta_d}',
325
+ u=self.EtaD, fun=np.reciprocal,)
326
+ self.Mb = NumOp(info='10 times of max of pmax as big M',
327
+ name='Mb', tex_name=r'M_{big}',
328
+ u=self.pmax, fun=np.max,
329
+ rfun=np.dot, rargs=dict(b=10),
330
+ array_out=False,)
331
+
332
+ # --- vars ---
333
+ self.SOC = Var(info='ESD1 State of Charge', unit='%',
334
+ name='SOC', tex_name=r'SOC',
335
+ model='ESD1', pos=True,
336
+ v0=self.SOCinit,)
337
+ self.SOClb = Constraint(name='SOClb', is_eq=False,
338
+ info='SOC lower bound',
339
+ e_str='-SOC + SOCmin',)
340
+ self.SOCub = Constraint(name='SOCub', is_eq=False,
341
+ info='SOC upper bound',
342
+ e_str='SOC - SOCmax',)
343
+ self.pce = Var(info='ESD1 charging power',
344
+ unit='p.u.', name='pce',
345
+ tex_name=r'p_{c,ESD}',
346
+ model='ESD1', nonneg=True,)
347
+ self.pde = Var(info='ESD1 discharging power',
348
+ unit='p.u.', name='pde',
349
+ tex_name=r'p_{d,ESD}',
350
+ model='ESD1', nonneg=True,)
351
+ self.uce = Var(info='ESD1 charging decision',
352
+ name='uce', tex_name=r'u_{c,ESD}',
353
+ model='ESD1', boolean=True,)
354
+ self.ude = Var(info='ESD1 discharging decision',
355
+ name='ude', tex_name=r'u_{d,ESD}',
356
+ model='ESD1', boolean=True,)
357
+ self.zce = Var(name='zce', tex_name=r'z_{c,ESD}',
358
+ model='ESD1', nonneg=True,)
359
+ self.zce.info = 'Aux var for charging, '
360
+ self.zce.info += ':math:`z_{c,ESD}=u_{c,ESD}*p_{c,ESD}`'
361
+ self.zde = Var(name='zde', tex_name=r'z_{d,ESD}',
362
+ model='ESD1', nonneg=True,)
363
+ self.zde.info = 'Aux var for discharging, '
364
+ self.zde.info += ':math:`z_{d,ESD}=u_{d,ESD}*p_{d,ESD}`'
365
+
366
+ # NOTE: to ensure consistency with DG based routiens,
367
+ # here we select ESD1 power from DG rather than StaticGen
368
+ self.genesd = RParam(info='gen of ESD1',
369
+ name='genesd', tex_name=r'g_{ESD}',
370
+ model='ESD1', src='idx',
371
+ no_parse=True,)
372
+ self.ces = VarSelect(u=self.pgdg, indexer='genesd',
373
+ name='ces', tex_name=r'C_{ESD}',
374
+ info='Select ESD power from DG',
375
+ no_parse=True)
376
+ self.cescb = Constraint(name='cescb', is_eq=True,
377
+ info='Select pce from DG',
378
+ e_str='ces @ pgdg - pce',)
379
+ self.cesdb = Constraint(name='cesdb', is_eq=True,
380
+ info='Select pde from DG',
381
+ e_str='ces @ pgdg - pde',)
382
+
383
+ # --- constraints ---
384
+ self.cdb = Constraint(name='cdb', is_eq=True,
385
+ info='Charging decision bound',
386
+ e_str='uce + ude - 1',)
387
+
388
+ self.zce1 = Constraint(name='zce1', is_eq=False, info='zce bound 1',
389
+ e_str='-zce + pce',)
390
+ self.zce2 = Constraint(name='zce2', is_eq=False, info='zce bound 2',
391
+ e_str='zce - pce - Mb dot (1-uce)',)
392
+ self.zce3 = Constraint(name='zce3', is_eq=False, info='zce bound 3',
393
+ e_str='zce - Mb dot uce',)
394
+
395
+ self.zde1 = Constraint(name='zde1', is_eq=False, info='zde bound 1',
396
+ e_str='-zde + pde',)
397
+ self.zde2 = Constraint(name='zde2', is_eq=False, info='zde bound 2',
398
+ e_str='zde - pde - Mb dot (1-ude)',)
399
+ self.zde3 = Constraint(name='zde3', is_eq=False, info='zde bound 3',
400
+ e_str='zde - Mb dot ude',)
401
+
402
+ SOCb = 'mul(En, (SOC - SOCinit)) - t dot mul(EtaC, zce)'
403
+ SOCb += '+ t dot mul(REtaD, zde)'
404
+ self.SOCb = Constraint(name='SOCb', is_eq=True,
405
+ info='ESD1 SOC balance',
406
+ e_str=SOCb,)
407
+
408
+
409
+ class RTEDES(RTED, ESD1Base):
410
+ """
411
+ RTED with energy storage :ref:`ESD1`.
412
+ The bilinear term in the formulation is linearized with big-M method.
413
+ """
414
+
415
+ def __init__(self, system, config):
416
+ RTED.__init__(self, system, config)
417
+ ESD1Base.__init__(self)
418
+ self.info = 'Real-time economic dispatch with energy storage'
419
+ self.type = 'DCED'
420
+
421
+
422
+ class VISBase:
423
+ """
424
+ Base class for virtual inertia scheduling.
425
+ """
426
+
427
+ def __init__(self) -> None:
428
+ # --- Data Section ---
429
+ self.cm = RParam(info='Virtual inertia cost',
430
+ name='cm', src='cm',
431
+ tex_name=r'c_{m}', unit=r'$/s',
432
+ model='VSGCost',
433
+ indexer='reg', imodel='VSG')
434
+ self.cd = RParam(info='Virtual damping cost',
435
+ name='cd', src='cd',
436
+ tex_name=r'c_{d}', unit=r'$/(p.u.)',
437
+ model='VSGCost',
438
+ indexer='reg', imodel='VSG',)
439
+ self.zvsg = RParam(info='VSG zone',
440
+ name='zvsg', tex_name='z_{one,vsg}',
441
+ model='VSG', src='zone',
442
+ no_parse=True)
443
+ self.Mmax = RParam(info='Maximum inertia emulation',
444
+ name='Mmax', tex_name='M_{max}',
445
+ model='VSG', src='Mmax',
446
+ unit='s',)
447
+ self.Dmax = RParam(info='Maximum damping emulation',
448
+ name='Dmax', tex_name='D_{max}',
449
+ model='VSG', src='Dmax',
450
+ unit='p.u.',)
451
+ self.dvm = RParam(info='Emulated inertia requirement',
452
+ name='dvm', tex_name=r'd_{v,m}',
453
+ unit='s',
454
+ model='VSGR', src='dvm',)
455
+ self.dvd = RParam(info='Emulated damping requirement',
456
+ name='dvd', tex_name=r'd_{v,d}',
457
+ unit='p.u.',
458
+ model='VSGR', src='dvd',)
459
+
460
+ # --- Model Section ---
461
+ self.M = Var(info='Emulated startup time constant (M=2H)',
462
+ name='M', tex_name=r'M', unit='s',
463
+ model='VSG', src='M',
464
+ nonneg=True,)
465
+ self.D = Var(info='Emulated damping coefficient',
466
+ name='D', tex_name=r'D', unit='p.u.',
467
+ model='VSG', src='D',
468
+ nonneg=True,)
469
+
470
+ self.gvsg = ZonalSum(u=self.zvsg, zone='Zone',
471
+ name='gvsg', tex_name=r'S_{g}',
472
+ info='Sum VSG vars vector in shape of zone',
473
+ no_parse=True)
474
+ self.Mub = Constraint(name='Mub', is_eq=False,
475
+ info='M upper bound',
476
+ e_str='M - Mmax',)
477
+ self.Dub = Constraint(name='Dub', is_eq=False,
478
+ info='D upper bound',
479
+ e_str='D - Dmax',)
480
+ self.Mreq = Constraint(name='Mreq', is_eq=True,
481
+ info='Emulated inertia requirement',
482
+ e_str='-gvsg@M + dvm',)
483
+ self.Dreq = Constraint(name='Dreq', is_eq=True,
484
+ info='Emulated damping requirement',
485
+ e_str='-gvsg@D + dvd',)
486
+
487
+ # NOTE: revise the objective function to include virtual inertia cost
488
+
489
+
490
+ class RTEDVIS(RTED, VISBase):
491
+ """
492
+ RTED with virtual inertia scheduling.
493
+
494
+ This class implements real-time economic dispatch with virtual inertia scheduling.
495
+ Please ensure that the parameters `dvm` and `dvd` are set according to the system base.
496
+
497
+ Reference:
498
+
499
+ [1] B. She, F. Li, H. Cui, J. Wang, Q. Zhang and R. Bo, "Virtual
500
+ Inertia Scheduling (VIS) for Real-time Economic Dispatch of
501
+ IBRs-penetrated Power Systems," in IEEE Transactions on
502
+ Sustainable Energy, doi: 10.1109/TSTE.2023.3319307.
503
+ """
504
+
505
+ def __init__(self, system, config):
506
+ RTED.__init__(self, system, config)
507
+ VISBase.__init__(self)
508
+ self.info = 'Real-time economic dispatch with virtual inertia scheduling'
509
+ self.type = 'DCED'
510
+
511
+ # --- objective ---
512
+ self.obj.info = 'total generation and reserve cost'
513
+ vsgcost = '+ t dot sum(cm * M + cd * D)'
514
+ self.obj.e_str += vsgcost
515
+
516
+ self.map2.update({
517
+ 'M': ('RenGen', 'M'),
518
+ 'D': ('RenGen', 'D'),
519
+ })
ams/routines/type.py ADDED
@@ -0,0 +1,160 @@
1
+ import logging
2
+ import inspect
3
+ from collections import OrderedDict
4
+
5
+ logger = logging.getLogger(__name__)
6
+
7
+
8
+ class TypeBase:
9
+ """
10
+ Base class for types.
11
+ """
12
+
13
+ def __init__(self):
14
+
15
+ self.common_rparams = []
16
+ self.common_vars = []
17
+ self.common_constrs = []
18
+
19
+ self.routines = OrderedDict()
20
+
21
+ @property
22
+ def class_name(self):
23
+ return self.__class__.__name__
24
+
25
+ @property
26
+ def n(self):
27
+ """
28
+ Total number of routines.
29
+ """
30
+ return len(self.routines)
31
+
32
+ def __repr__(self):
33
+ dev_text = 'routine' if self.n == 1 else 'routines'
34
+ return f'{self.class_name} ({self.n} {dev_text}) at {hex(id(self))}'
35
+
36
+ def doc(self, export='plain'):
37
+ """
38
+ Return the documentation of the type in a string.
39
+ """
40
+ out = ''
41
+ if export == 'rest':
42
+ out += f'.. _{self.class_name}:\n\n'
43
+ group_header = '=' * 80 + '\n'
44
+ else:
45
+ group_header = ''
46
+
47
+ if export == 'rest':
48
+ out += group_header + f'{self.class_name}\n' + group_header
49
+ else:
50
+ out += group_header + f'Type <{self.class_name}>\n' + group_header
51
+
52
+ if self.__doc__ is not None:
53
+ out += inspect.cleandoc(self.__doc__) + '\n\n'
54
+
55
+ if len(self.common_rparams):
56
+ out += 'Common Parameters: ' + ', '.join(self.common_rparams)
57
+ out += '\n\n'
58
+ if len(self.common_vars):
59
+ out += 'Common Vars: ' + ', '.join(self.common_vars)
60
+ out += '\n\n'
61
+ if len(self.common_constrs):
62
+ out += 'Common Constraints: ' + ', '.join(self.common_constrs)
63
+ out += '\n\n'
64
+ if len(self.routines):
65
+ out += 'Available routines:\n'
66
+ rtn_name_list = list(self.routines.keys())
67
+
68
+ if export == 'rest':
69
+ def add_reference(name_list):
70
+ return [f'{item}_' for item in name_list]
71
+
72
+ rtn_name_list = add_reference(rtn_name_list)
73
+
74
+ out += ',\n'.join(rtn_name_list) + '\n'
75
+
76
+ return out
77
+
78
+ def doc_all(self, export='plain'):
79
+ """
80
+ Return documentation of the type and its routines.
81
+
82
+ Parameters
83
+ ----------
84
+ export : 'plain' or 'rest'
85
+ Export format, plain-text or RestructuredText
86
+
87
+ Returns
88
+ -------
89
+ str
90
+
91
+ """
92
+ out = self.doc(export=export)
93
+ out += '\n'
94
+ for instance in self.routines.values():
95
+ out += instance.doc(export=export)
96
+ out += '\n'
97
+ return out
98
+
99
+
100
+ class UndefinedType(TypeBase):
101
+ """
102
+ The undefined type.
103
+ """
104
+
105
+ def __init__(self):
106
+ TypeBase.__init__(self)
107
+
108
+
109
+ class PF(TypeBase):
110
+ """
111
+ Type for power flow routines.
112
+ """
113
+
114
+ def __init__(self):
115
+ TypeBase.__init__(self)
116
+ self.common_rparams.extend(('pd',))
117
+ self.common_vars.extend(('pg',))
118
+
119
+
120
+ class DCED(TypeBase):
121
+ """
122
+ Type for DC-based economic dispatch.
123
+ """
124
+
125
+ def __init__(self):
126
+ TypeBase.__init__(self)
127
+ self.common_rparams.extend(('c2', 'c1', 'c0', 'pmax', 'pmin', 'pd', 'ptdf', 'rate_a',))
128
+ self.common_vars.extend(('pg',))
129
+ self.common_constrs.extend(('pb', 'lub', 'llb'))
130
+
131
+
132
+ class DCUC(TypeBase):
133
+ """
134
+ Type for DC-based unit commitment.
135
+ """
136
+
137
+ def __init__(self):
138
+ TypeBase.__init__(self)
139
+ # TODO: add common parameters and variables
140
+
141
+
142
+ class DED(TypeBase):
143
+ """
144
+ Type for Distributional economic dispatch.
145
+ """
146
+
147
+ def __init__(self):
148
+ TypeBase.__init__(self)
149
+ # TODO: add common parameters and variables
150
+
151
+
152
+ class ACED(DCED):
153
+ """
154
+ Type for AC-based economic dispatch.
155
+ """
156
+
157
+ def __init__(self):
158
+ DCED.__init__(self)
159
+ self.common_rparams.extend(('qd',))
160
+ self.common_vars.extend(('aBus', 'vBus', 'qg',))