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/dcpf0.py ADDED
@@ -0,0 +1,196 @@
1
+ """
2
+ DC power flow routines using PYPOWER.
3
+ """
4
+ import logging
5
+
6
+ from andes.shared import deg2rad
7
+ from andes.utils.misc import elapsed
8
+
9
+ from ams.routines.routine import RoutineBase
10
+ from ams.opt import Var
11
+ from ams.pypower import runpf
12
+ from ams.pypower.core import ppoption
13
+
14
+ from ams.io.pypower import system2ppc
15
+ from ams.core.param import RParam
16
+
17
+ logger = logging.getLogger(__name__)
18
+
19
+
20
+ class DCPF0(RoutineBase):
21
+ """
22
+ DC power flow using PYPOWER.
23
+
24
+ This class is deprecated as of version 0.9.12 and will be removed in 1.1.0.
25
+
26
+ Notes
27
+ -----
28
+ 1. DCPF is solved with PYPOWER ``runpf`` function.
29
+ 2. DCPF formulation is not complete yet, but this does not affect the
30
+ results because the data are passed to PYPOWER for solving.
31
+ """
32
+
33
+ def __init__(self, system, config):
34
+ RoutineBase.__init__(self, system, config)
35
+ self.info = 'DC Power Flow'
36
+ self.type = 'PF'
37
+
38
+ self.ug = RParam(info='Gen connection status',
39
+ name='ug', tex_name=r'u_{g}',
40
+ model='StaticGen', src='u',
41
+ no_parse=True)
42
+
43
+ # --- routine data ---
44
+ self.x = RParam(info="line reactance",
45
+ name='x', tex_name='x',
46
+ unit='p.u.',
47
+ model='Line', src='x',)
48
+ self.tap = RParam(info="transformer branch tap ratio",
49
+ name='tap', tex_name=r't_{ap}',
50
+ model='Line', src='tap',
51
+ unit='float',)
52
+ self.phi = RParam(info="transformer branch phase shift in rad",
53
+ name='phi', tex_name=r'\phi',
54
+ model='Line', src='phi',
55
+ unit='radian',)
56
+
57
+ # --- load ---
58
+ self.pd = RParam(info='active deman',
59
+ name='pd', tex_name=r'p_{d}',
60
+ unit='p.u.',
61
+ model='StaticLoad', src='p0')
62
+ # --- gen ---
63
+ self.pg = Var(info='Gen active power',
64
+ unit='p.u.',
65
+ name='pg', tex_name=r'p_{g}',
66
+ model='StaticGen', src='p',)
67
+
68
+ # --- bus ---
69
+ self.aBus = Var(info='bus voltage angle',
70
+ unit='rad',
71
+ name='aBus', tex_name=r'a_{Bus}',
72
+ model='Bus', src='a',)
73
+
74
+ # --- line flow ---
75
+ self.plf = Var(info='Line flow',
76
+ unit='p.u.',
77
+ name='plf', tex_name=r'p_{lf}',
78
+ model='Line',)
79
+
80
+ def unpack(self, res):
81
+ """
82
+ Unpack results from PYPOWER.
83
+ """
84
+ system = self.system
85
+ mva = res['baseMVA']
86
+
87
+ # --- copy results from ppc into system algeb ---
88
+ # --- Bus ---
89
+ system.Bus.v.v = res['bus'][:, 7] # voltage magnitude
90
+ system.Bus.a.v = res['bus'][:, 8] * deg2rad # voltage angle
91
+
92
+ # --- PV ---
93
+ system.PV.p.v = res['gen'][system.Slack.n:, 1] / mva # active power
94
+ system.PV.q.v = res['gen'][system.Slack.n:, 2] / mva # reactive power
95
+
96
+ # --- Slack ---
97
+ system.Slack.p.v = res['gen'][:system.Slack.n, 1] / mva # active power
98
+ system.Slack.q.v = res['gen'][:system.Slack.n, 2] / mva # reactive power
99
+
100
+ # --- Line ---
101
+ self.plf.optz.value = res['branch'][:, 13] / mva # line flow
102
+
103
+ # --- copy results from system algeb into routine algeb ---
104
+ for vname, var in self.vars.items():
105
+ owner = getattr(system, var.model) # instance of owner, Model or Group
106
+ if var.src is None: # skip if no source variable is specified
107
+ continue
108
+ elif hasattr(owner, 'group'): # if owner is a Model instance
109
+ grp = getattr(system, owner.group)
110
+ idx = grp.get_all_idxes()
111
+ elif hasattr(owner, 'get_idx'): # if owner is a Group instance
112
+ idx = owner.get_all_idxes()
113
+ else:
114
+ msg = f"Failed to find valid source variable `{owner.class_name}.{var.src}` for "
115
+ msg += f"{self.class_name}.{vname}, skip unpacking."
116
+ logger.warning(msg)
117
+ continue
118
+ try:
119
+ logger.debug(f"Unpacking {vname} into {owner.class_name}.{var.src}.")
120
+ var.optz.value = owner.get(src=var.src, attr='v', idx=idx)
121
+ except AttributeError:
122
+ logger.debug(f"Failed to unpack {vname} into {owner.class_name}.{var.src}.")
123
+ continue
124
+ self.system.recent = self.system.routines[self.class_name]
125
+ return True
126
+
127
+ def solve(self, method=None):
128
+ """
129
+ Solve DC power flow using PYPOWER.
130
+ """
131
+ ppc = system2ppc(self.system)
132
+ ppopt = ppoption(PF_DC=True)
133
+
134
+ res, sstats = runpf(casedata=ppc, ppopt=ppopt)
135
+ return res, sstats
136
+
137
+ def run(self, **kwargs):
138
+ """
139
+ Run DC pwoer flow.
140
+ *args and **kwargs go to `self.solve()`, which are not used yet.
141
+
142
+ Examples
143
+ --------
144
+ >>> ss = ams.load(ams.get_case('matpower/case14.m'))
145
+ >>> ss.DCPF.run()
146
+
147
+ Parameters
148
+ ----------
149
+ method : str
150
+ Placeholder for future use.
151
+
152
+ Returns
153
+ -------
154
+ exit_code : int
155
+ Exit code of the routine.
156
+ """
157
+ if not self.initialized:
158
+ self.init()
159
+ t0, _ = elapsed()
160
+
161
+ res, sstats = self.solve(**kwargs)
162
+ self.converged = res['success']
163
+ self.exit_code = 0 if res['success'] else 1
164
+ _, s = elapsed(t0)
165
+ self.exec_time = float(s.split(' ')[0])
166
+ n_iter = int(sstats['num_iters'])
167
+ n_iter_str = f"{n_iter} iterations " if n_iter > 1 else f"{n_iter} iteration "
168
+ if self.exit_code == 0:
169
+ msg = f"<{self.class_name}> solved in {s}, converged in "
170
+ msg += n_iter_str + f"with {sstats['solver_name']}."
171
+ logger.info(msg)
172
+ try:
173
+ self.unpack(res)
174
+ except Exception as e:
175
+ logger.error(f"Failed to unpack results from {self.class_name}.\n{e}")
176
+ return False
177
+ self.system.report()
178
+ return True
179
+ else:
180
+ msg = f"{self.class_name} failed in "
181
+ msg += f"{int(sstats['num_iters'])} iterations with "
182
+ msg += f"{sstats['solver_name']}!"
183
+ logger.warning(msg)
184
+ return False
185
+
186
+ def summary(self, **kwargs):
187
+ """
188
+ # TODO: Print power flow summary.
189
+ """
190
+ raise NotImplementedError
191
+
192
+ def enable(self, name):
193
+ raise NotImplementedError
194
+
195
+ def disable(self, name):
196
+ raise NotImplementedError
ams/routines/dopf.py ADDED
@@ -0,0 +1,150 @@
1
+ """
2
+ Distributional optimal power flow (DOPF).
3
+ """
4
+ import numpy as np
5
+
6
+ from ams.core.param import RParam
7
+
8
+ from ams.routines.dcopf import DCOPF
9
+
10
+ from ams.opt import Var, Constraint, Objective
11
+
12
+
13
+ class DOPF(DCOPF):
14
+ """
15
+ Linearzied distribution OPF, where power loss are ignored.
16
+
17
+ UNDER DEVELOPMENT!
18
+
19
+ Reference:
20
+
21
+ [1] L. Bai, J. Wang, C. Wang, C. Chen, and F. Li, “Distribution Locational Marginal Pricing (DLMP)
22
+ for Congestion Management and Voltage Support,” IEEE Trans. Power Syst., vol. 33, no. 4,
23
+ pp. 4061–4073, Jul. 2018, doi: 10.1109/TPWRS.2017.2767632.
24
+ """
25
+
26
+ def __init__(self, system, config):
27
+ DCOPF.__init__(self, system, config)
28
+ self.info = 'Linearzied distribution OPF'
29
+ self.type = 'DED'
30
+
31
+ # -- Data Section --
32
+ # --- generator ---
33
+ self.qmax = RParam(info='generator maximum reactive power',
34
+ name='qmax', tex_name=r'q_{max}', unit='p.u.',
35
+ model='StaticGen', src='qmax',)
36
+ self.qmin = RParam(info='generator minimum reactive power',
37
+ name='qmin', tex_name=r'q_{min}', unit='p.u.',
38
+ model='StaticGen', src='qmin',)
39
+ # --- load ---
40
+ self.qd = RParam(info='reactive demand',
41
+ name='qd', tex_name=r'q_{d}', unit='p.u.',
42
+ model='StaticLoad', src='q0',)
43
+ # --- bus ---
44
+ self.vmax = RParam(info="Bus voltage upper limit",
45
+ name='vmax', tex_name=r'v_{max}',
46
+ unit='p.u.',
47
+ model='Bus', src='vmax', no_parse=True,
48
+ )
49
+ self.vmin = RParam(info="Bus voltage lower limit",
50
+ name='vmin', tex_name=r'v_{min}',
51
+ unit='p.u.',
52
+ model='Bus', src='vmin', no_parse=True,)
53
+ # --- line ---
54
+ self.r = RParam(info='line resistance',
55
+ name='r', tex_name='r', unit='p.u.',
56
+ model='Line', src='r',
57
+ no_parse=True,)
58
+ self.x = RParam(info='line reactance',
59
+ name='x', tex_name='x', unit='p.u.',
60
+ model='Line', src='x',
61
+ no_parse=True,)
62
+ # --- Model Section ---
63
+ # --- generator ---
64
+ self.qg = Var(info='Gen reactive power',
65
+ name='qg', tex_name=r'q_{g}', unit='p.u.',
66
+ model='StaticGen', src='q',)
67
+ self.qglb = Constraint(name='qglb', is_eq=False,
68
+ info='qg min',
69
+ e_str='-qg + mul(ug, qmin)',)
70
+ self.qgub = Constraint(name='qgub', is_eq=False,
71
+ info='qg max',
72
+ e_str='qg - mul(ug, qmax)',)
73
+ # --- bus ---
74
+ self.v = Var(info='Bus voltage',
75
+ name='v', tex_name=r'v',
76
+ unit='p.u.',
77
+ model='Bus', src='v')
78
+ self.vsq = Var(info='square of Bus voltage',
79
+ name='vsq', tex_name=r'v^{2}', unit='p.u.',
80
+ model='Bus',)
81
+ self.vu = Constraint(name='vu',
82
+ info='Voltage upper limit',
83
+ e_str='vsq - vmax**2',
84
+ is_eq=False,)
85
+ self.vl = Constraint(name='vl',
86
+ info='Voltage lower limit',
87
+ e_str='-vsq + vmin**2',
88
+ is_eq=False,)
89
+ # --- line ---
90
+ self.qlf = Var(info='line reactive power',
91
+ name='qlf', tex_name=r'q_{lf}',
92
+ unit='p.u.', model='Line',)
93
+ self.lvd = Constraint(info='line voltage drop',
94
+ name='lvd', is_eq=True,
95
+ e_str='CftT@vsq - (r * plf + x * qlf)',)
96
+ # --- power balance ---
97
+ # NOTE: following Eqn seems to be wrong, double check
98
+ # g_Q(\Theta, V, Q_g) = B_{bus}V\Theta + Q_{bus,shift} + Q_d + B_{sh} - C_gQ_g = 0
99
+ self.qb = Constraint(info='reactive power balance',
100
+ name='qb', is_eq=True,
101
+ e_str='sum(qd) - sum(qg)',)
102
+
103
+ # --- objective ---
104
+ # NOTE: no need to revise objective function
105
+
106
+ def _post_solve(self):
107
+ self.v.optz.value = np.sqrt(self.vsq.optz.value)
108
+ return super()._post_solve()
109
+
110
+
111
+ class DOPFVIS(DOPF):
112
+ """
113
+ Linearzied distribution OPF with variables for virtual inertia and damping from from REGCV1,
114
+ where power loss are ignored.
115
+
116
+ UNDER DEVELOPMENT!
117
+
118
+ Reference:
119
+
120
+ [1] L. Bai, J. Wang, C. Wang, C. Chen, and F. Li, “Distribution Locational Marginal Pricing (DLMP)
121
+ for Congestion Management and Voltage Support,” IEEE Trans. Power Syst., vol. 33, no. 4,
122
+ pp. 4061–4073, Jul. 2018, doi: 10.1109/TPWRS.2017.2767632.
123
+ """
124
+
125
+ def __init__(self, system, config):
126
+ DOPF.__init__(self, system, config)
127
+
128
+ # --- params ---
129
+ self.cm = RParam(info='Virtual inertia cost',
130
+ name='cm', src='cm',
131
+ tex_name=r'c_{m}', unit=r'$/s',
132
+ model='VSGCost',
133
+ indexer='reg', imodel='VSG')
134
+ self.cd = RParam(info='Virtual damping cost',
135
+ name='cd', src='cd',
136
+ tex_name=r'c_{d}', unit=r'$/(p.u.)',
137
+ model='VSGCost',
138
+ indexer='reg', imodel='VSG',)
139
+ # --- vars ---
140
+ self.M = Var(info='Emulated startup time constant (M=2H) from REGCV1',
141
+ name='M', tex_name=r'M', unit='s',
142
+ model='VSG',)
143
+ self.D = Var(info='Emulated damping coefficient from REGCV1',
144
+ name='D', tex_name=r'D', unit='p.u.',
145
+ model='VSG',)
146
+ obj = 'sum(c2 * pg**2 + c1 * pg + ug * c0 + cm * M + cd * D)'
147
+ self.obj = Objective(name='tc',
148
+ info='total cost', unit='$',
149
+ e_str=obj,
150
+ sense='min',)
ams/routines/ed.py ADDED
@@ -0,0 +1,312 @@
1
+ """
2
+ Economic dispatch routines.
3
+ """
4
+ import logging
5
+ import numpy as np
6
+
7
+ from ams.core.param import RParam
8
+ from ams.core.service import (NumOpDual, NumHstack,
9
+ RampSub, NumOp, LoadScale)
10
+
11
+ from ams.routines.rted import RTED, DGBase, ESD1Base
12
+
13
+ from ams.opt import Var, Constraint
14
+
15
+ logger = logging.getLogger(__name__)
16
+
17
+
18
+ class SRBase:
19
+ """
20
+ Base class for spinning reserve.
21
+ """
22
+
23
+ def __init__(self) -> None:
24
+ self.dsrp = RParam(info='spinning reserve requirement in percentage',
25
+ name='dsr', tex_name=r'd_{sr}',
26
+ model='SR', src='demand',
27
+ unit='%',)
28
+ self.csr = RParam(info='cost for spinning reserve',
29
+ name='csr', tex_name=r'c_{sr}',
30
+ model='SRCost', src='csr',
31
+ unit=r'$/(p.u.*h)',
32
+ indexer='gen', imodel='StaticGen',)
33
+
34
+ self.prs = Var(name='prs', tex_name=r'p_{r,s}',
35
+ info='spinning reserve', unit='p.u.',
36
+ model='StaticGen', nonneg=True,)
37
+
38
+ self.dsrpz = NumOpDual(u=self.pdz, u2=self.dsrp, fun=np.multiply,
39
+ name='dsrpz', tex_name=r'd_{s,r, p, z}',
40
+ info='zonal spinning reserve requirement in percentage',)
41
+ self.dsr = NumOpDual(u=self.dsrpz, u2=self.sd, fun=np.multiply,
42
+ rfun=np.transpose,
43
+ name='dsr', tex_name=r'd_{s,r,z}',
44
+ info='zonal spinning reserve requirement',)
45
+
46
+ # NOTE: define e_str in the scheduling model
47
+ self.prsb = Constraint(info='spinning reserve balance',
48
+ name='prsb', is_eq=True,)
49
+ self.rsr = Constraint(info='spinning reserve requirement',
50
+ name='rsr', is_eq=False,)
51
+
52
+
53
+ class MPBase:
54
+ """
55
+ Base class for multi-period scheduling.
56
+ """
57
+
58
+ def __init__(self) -> None:
59
+ # NOTE: Setting `ED.scale.owner` to `Horizon` will cause an error when calling `ED.scale.v`.
60
+ # This is because `Horizon` is a group that only contains the model `TimeSlot`.
61
+ # The `get` method of `Horizon` calls `andes.models.group.GroupBase.get` and results in an error.
62
+ self.sd = RParam(info='zonal load factor for ED',
63
+ name='sd', tex_name=r's_{d}',
64
+ src='sd', model='EDTSlot')
65
+
66
+ # NOTE: update timeslot.model in dispatch model if necessary
67
+ self.timeslot = RParam(info='Time slot for multi-period ED',
68
+ name='timeslot', tex_name=r't_{s,idx}',
69
+ src='idx', model='EDTSlot',
70
+ no_parse=True)
71
+
72
+ self.tlv = NumOp(u=self.timeslot, fun=np.ones_like,
73
+ args=dict(dtype=float),
74
+ expand_dims=0,
75
+ name='tlv', tex_name=r'1_{tl}',
76
+ info='time length vector',
77
+ no_parse=True)
78
+
79
+ self.pds = LoadScale(u=self.pd, sd=self.sd,
80
+ name='pds', tex_name=r'p_{d,s}',
81
+ info='Scaled load',)
82
+
83
+ self.R30 = RParam(info='30-min ramp rate',
84
+ name='R30', tex_name=r'R_{30}',
85
+ src='R30', unit='p.u./h',
86
+ model='StaticGen', no_parse=True,)
87
+ self.Mr = RampSub(u=self.pg, name='Mr', tex_name=r'M_{r}',
88
+ info='Subtraction matrix for ramping',
89
+ no_parse=True, sparse=True,)
90
+ self.RR30 = NumHstack(u=self.R30, ref=self.Mr,
91
+ name='RR30', tex_name=r'R_{30,R}',
92
+ info='Repeated ramp rate', no_parse=True,)
93
+
94
+ items_to_expand = ['ctrl', 'c0', 'pmax', 'pmin', 'pg0', 'rate_a',
95
+ 'Pfinj', 'Pbusinj', 'gsh', 'ul']
96
+ for item in items_to_expand:
97
+ self.__dict__[item].expand_dims = 1
98
+
99
+ # NOTE: extend pg to 2D matrix: row for gen and col for timeslot
100
+ self.pg.horizon = self.timeslot
101
+ self.pg.info = '2D Gen power'
102
+ self.aBus.horizon = self.timeslot
103
+ self.aBus.info = '2D Bus angle'
104
+ self.vBus.horizon = self.timeslot
105
+ self.vBus.info = '2D Bus voltage'
106
+ self.pi.horizon = self.timeslot
107
+
108
+
109
+ class ED(RTED, MPBase, SRBase):
110
+ """
111
+ DC-based multi-period economic dispatch (ED).
112
+ Dispath interval ``config.t`` (:math:`T_{cfg}`) is introduced,
113
+ 1 [Hour] by default.
114
+
115
+ ED extends DCOPF as follows:
116
+
117
+ - Vars ``pg``, ``pru``, ``prd`` are extended to 2D
118
+ - 2D Vars ``rgu`` and ``rgd`` are introduced
119
+ - Param ``ug`` is sourced from ``EDTSlot.ug`` as generator commitment
120
+
121
+ Notes
122
+ -----
123
+ 1. Formulations has been adjusted with interval ``config.t``
124
+
125
+ 2. The tie-line flow is not implemented in this model.
126
+
127
+ 3. `EDTSlot.ug` is used instead of `StaticGen.u` for generator commitment.
128
+ """
129
+
130
+ def __init__(self, system, config):
131
+ RTED.__init__(self, system, config)
132
+ MPBase.__init__(self)
133
+ SRBase.__init__(self)
134
+
135
+ self.config.t = 1 # scheduling interval in hour
136
+ self.config.add_extra("_help",
137
+ t="time interval in hours",
138
+ )
139
+
140
+ self.info = 'Economic dispatch'
141
+ self.type = 'DCED'
142
+
143
+ self.ug.info = 'unit commitment decisions'
144
+ self.ug.model = 'EDTSlot'
145
+ self.ug.src = 'ug'
146
+ # self.ug.tex_name = r'u_{g}',
147
+
148
+ self.dud.expand_dims = 1
149
+ self.ddd.expand_dims = 1
150
+ self.amin.expand_dims = 1
151
+ self.amax.expand_dims = 1
152
+
153
+ # --- Data Section ---
154
+ self.ugt = NumOp(u=self.ug, fun=np.transpose,
155
+ name='ugt', tex_name=r'u_{g}',
156
+ info='input ug transpose',
157
+ no_parse=True)
158
+
159
+ # --- Model Section ---
160
+ # --- gen ---
161
+ self.ctrle.u2 = self.ugt
162
+ self.nctrle.u2 = self.ugt
163
+ pmaxe = 'mul(mul(nctrle, pg0), tlv) + mul(mul(ctrle, tlv), pmax)'
164
+ self.pmaxe.e_str = pmaxe
165
+ self.pmaxe.horizon = self.timeslot
166
+ pmine = 'mul(mul(nctrle, pg0), tlv) + mul(mul(ctrle, tlv), pmin)'
167
+ self.pmine.e_str = pmine
168
+ self.pmine.horizon = self.timeslot
169
+ self.pglb.e_str = '-pg + pmine'
170
+ self.pgub.e_str = 'pg - pmaxe'
171
+
172
+ self.pru.horizon = self.timeslot
173
+ self.pru.info = '2D RegUp power'
174
+ self.prd.horizon = self.timeslot
175
+ self.prd.info = '2D RegDn power'
176
+
177
+ self.prs.horizon = self.timeslot
178
+ self.prsb.e_str = 'mul(ugt, pmax@tlv - pg) - prs'
179
+ self.rsr.e_str = '-gs@prs + dsr'
180
+
181
+ # --- line ---
182
+ self.plf.horizon = self.timeslot
183
+ self.plf.info = '2D Line flow'
184
+ self.plflb.e_str = '-Bf@aBus - Pfinj@tlv - mul(ul, rate_a)@tlv'
185
+ self.plfub.e_str = 'Bf@aBus + Pfinj@tlv - mul(ul, rate_a)@tlv'
186
+ self.alflb.e_str = '-CftT@aBus + amin@tlv'
187
+ self.alfub.e_str = 'CftT@aBus - amax@tlv'
188
+
189
+ self.plf.e_str = 'Bf@aBus + Pfinj@tlv'
190
+
191
+ # --- power balance ---
192
+ self.pb.e_str = 'Bbus@aBus + Pbusinj@tlv + Cl@pds + Csh@gsh@tlv - Cg@pg'
193
+
194
+ # --- ramping ---
195
+ self.rbu.e_str = 'gs@mul(ugt, pru) - mul(dud, tlv)'
196
+ self.rbd.e_str = 'gs@mul(ugt, prd) - mul(ddd, tlv)'
197
+
198
+ self.rru.e_str = 'pg + pru - mul(mul(ugt, pmax), tlv)'
199
+ self.rrd.e_str = '-pg + prd + mul(mul(ugt, pmin), tlv)'
200
+
201
+ self.rgu.e_str = 'pg @ Mr - t dot RR30'
202
+ self.rgd.e_str = '-pg @ Mr - t dot RR30'
203
+
204
+ self.rgu0 = Constraint(name='rgu0',
205
+ info='Initial gen ramping up',
206
+ e_str='mul(ugt[:, 0], pg[:, 0] - pg0[:, 0] - R30)',
207
+ is_eq=False,)
208
+ self.rgd0 = Constraint(name='rgd0',
209
+ info='Initial gen ramping down',
210
+ e_str='mul(ugt[:, 0], -pg[:, 0] + pg0[:, 0] - R30)',
211
+ is_eq=False,)
212
+
213
+ # --- objective ---
214
+ cost = 'sum(t**2 dot c2 @ pg**2)'
215
+ cost += '+ t dot sum(c1 @ pg + csr @ prs)'
216
+ cost += '+ sum(mul(ugt, mul(c0, tlv)))'
217
+ self.obj.e_str = cost
218
+
219
+ def dc2ac(self, **kwargs):
220
+ """
221
+ AC conversion ``dc2ac`` is not implemented yet for
222
+ multi-period scheduling.
223
+ """
224
+ return NotImplementedError
225
+
226
+ def unpack(self, **kwargs):
227
+ """
228
+ Multi-period scheduling will not unpack results from
229
+ solver into devices.
230
+
231
+ # TODO: unpack first period results, and allow input
232
+ # to specify which period to unpack.
233
+ """
234
+ return None
235
+
236
+
237
+ class EDDG(ED, DGBase):
238
+ """
239
+ ED with distributed generation :ref:`DG`.
240
+
241
+ Note that EDDG only inlcudes DG output power. If ESD1 is included,
242
+ EDES should be used instead, otherwise there is no SOC.
243
+ """
244
+
245
+ def __init__(self, system, config):
246
+ ED.__init__(self, system, config)
247
+ DGBase.__init__(self)
248
+
249
+ self.info = 'Economic dispatch with distributed generation'
250
+ self.type = 'DCED'
251
+
252
+ # NOTE: extend vars to 2D
253
+ self.pgdg.horizon = self.timeslot
254
+
255
+
256
+ class ESD1MPBase(ESD1Base):
257
+ """
258
+ Extended base class for energy storage in multi-period scheduling.
259
+ """
260
+
261
+ def __init__(self):
262
+ ESD1Base.__init__(self)
263
+
264
+ self.Mre = RampSub(u=self.SOC, name='Mre', tex_name=r'M_{r,ES}',
265
+ info='Subtraction matrix for SOC',
266
+ no_parse=True, sparse=True,)
267
+ self.EnR = NumHstack(u=self.En, ref=self.Mre,
268
+ name='EnR', tex_name=r'E_{n,R}',
269
+ info='Repeated En as 2D matrix, (ng, ng-1)')
270
+ self.EtaCR = NumHstack(u=self.EtaC, ref=self.Mre,
271
+ name='EtaCR', tex_name=r'\eta_{c,R}',
272
+ info='Repeated Etac as 2D matrix, (ng, ng-1)')
273
+ self.REtaDR = NumHstack(u=self.REtaD, ref=self.Mre,
274
+ name='REtaDR', tex_name=r'R_{\eta_d,R}',
275
+ info='Repeated REtaD as 2D matrix, (ng, ng-1)')
276
+ SOCb = 'mul(EnR, SOC @ Mre) - t dot mul(EtaCR, zce[:, 1:])'
277
+ SOCb += ' + t dot mul(REtaDR, zde[:, 1:])'
278
+ self.SOCb.e_str = SOCb
279
+
280
+ SOCb0 = 'mul(En, SOC[:, 0] - SOCinit) - t dot mul(EtaC, zce[:, 0])'
281
+ SOCb0 += ' + t dot mul(REtaD, zde[:, 0])'
282
+ self.SOCb0 = Constraint(name='SOCb0', is_eq=True,
283
+ info='ESD1 SOC initial balance',
284
+ e_str=SOCb0,)
285
+
286
+ self.SOCr = Constraint(name='SOCr', is_eq=True,
287
+ info='SOC requirement',
288
+ e_str='SOC[:, -1] - SOCinit',)
289
+
290
+
291
+ class EDES(ED, ESD1MPBase):
292
+ """
293
+ ED with energy storage :ref:`ESD1`.
294
+ The bilinear term in the formulation is linearized with big-M method.
295
+ """
296
+
297
+ def __init__(self, system, config):
298
+ ED.__init__(self, system, config)
299
+ ESD1MPBase.__init__(self)
300
+
301
+ self.info = 'Economic dispatch with energy storage'
302
+ self.type = 'DCED'
303
+
304
+ # NOTE: extend vars to 2D
305
+ self.pgdg.horizon = self.timeslot
306
+ self.SOC.horizon = self.timeslot
307
+ self.pce.horizon = self.timeslot
308
+ self.pde.horizon = self.timeslot
309
+ self.uce.horizon = self.timeslot
310
+ self.ude.horizon = self.timeslot
311
+ self.zce.horizon = self.timeslot
312
+ self.zde.horizon = self.timeslot