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.
- ams/__init__.py +4 -11
- ams/_version.py +4 -4
- ams/cases/5bus/pjm5bus_demo.xlsx +0 -0
- ams/cases/5bus/pjm5bus_jumper.xlsx +0 -0
- ams/cases/5bus/pjm5bus_uced.json +1062 -0
- ams/cases/5bus/pjm5bus_uced.xlsx +0 -0
- ams/cases/5bus/pjm5bus_uced_esd1.xlsx +0 -0
- ams/cases/5bus/pjm5bus_uced_ev.xlsx +0 -0
- ams/cases/ieee123/ieee123.xlsx +0 -0
- ams/cases/ieee123/ieee123_regcv1.xlsx +0 -0
- ams/cases/ieee14/ieee14.json +1166 -0
- ams/cases/ieee14/ieee14.raw +92 -0
- ams/cases/ieee14/ieee14_conn.xlsx +0 -0
- ams/cases/ieee14/ieee14_uced.xlsx +0 -0
- ams/cases/ieee39/ieee39.xlsx +0 -0
- ams/cases/ieee39/ieee39_uced.xlsx +0 -0
- ams/cases/ieee39/ieee39_uced_esd1.xlsx +0 -0
- ams/cases/ieee39/ieee39_uced_pvd1.xlsx +0 -0
- ams/cases/ieee39/ieee39_uced_vis.xlsx +0 -0
- ams/cases/matpower/benchmark.json +1594 -0
- ams/cases/matpower/case118.m +787 -0
- ams/cases/matpower/case14.m +129 -0
- ams/cases/matpower/case300.m +1315 -0
- ams/cases/matpower/case39.m +205 -0
- ams/cases/matpower/case5.m +62 -0
- ams/cases/matpower/case_ACTIVSg2000.m +9460 -0
- ams/cases/npcc/npcc.m +644 -0
- ams/cases/npcc/npcc_uced.xlsx +0 -0
- ams/cases/pglib/pglib_opf_case39_epri__api.m +243 -0
- ams/cases/wecc/wecc.m +714 -0
- ams/cases/wecc/wecc_uced.xlsx +0 -0
- ams/cli.py +6 -0
- ams/core/__init__.py +2 -0
- ams/core/documenter.py +652 -0
- ams/core/matprocessor.py +782 -0
- ams/core/model.py +330 -0
- ams/core/param.py +322 -0
- ams/core/service.py +918 -0
- ams/core/symprocessor.py +224 -0
- ams/core/var.py +59 -0
- ams/extension/__init__.py +5 -0
- ams/extension/eva.py +401 -0
- ams/interface.py +1085 -0
- ams/io/__init__.py +133 -0
- ams/io/json.py +82 -0
- ams/io/matpower.py +406 -0
- ams/io/psse.py +6 -0
- ams/io/pypower.py +103 -0
- ams/io/xlsx.py +80 -0
- ams/main.py +83 -4
- ams/models/__init__.py +24 -0
- ams/models/area.py +40 -0
- ams/models/bus.py +52 -0
- ams/models/cost.py +169 -0
- ams/models/distributed/__init__.py +3 -0
- ams/models/distributed/esd1.py +71 -0
- ams/models/distributed/ev.py +60 -0
- ams/models/distributed/pvd1.py +67 -0
- ams/models/group.py +231 -0
- ams/models/info.py +26 -0
- ams/models/line.py +238 -0
- ams/models/renewable/__init__.py +5 -0
- ams/models/renewable/regc.py +119 -0
- ams/models/reserve.py +94 -0
- ams/models/shunt.py +14 -0
- ams/models/static/__init__.py +2 -0
- ams/models/static/gen.py +165 -0
- ams/models/static/pq.py +61 -0
- ams/models/timeslot.py +69 -0
- ams/models/zone.py +49 -0
- ams/opt/__init__.py +12 -0
- ams/opt/constraint.py +175 -0
- ams/opt/exprcalc.py +127 -0
- ams/opt/expression.py +188 -0
- ams/opt/objective.py +174 -0
- ams/opt/omodel.py +432 -0
- ams/opt/optzbase.py +192 -0
- ams/opt/param.py +156 -0
- ams/opt/var.py +233 -0
- ams/pypower/__init__.py +8 -0
- ams/pypower/_compat.py +9 -0
- ams/pypower/core/__init__.py +8 -0
- ams/pypower/core/pips.py +894 -0
- ams/pypower/core/ppoption.py +244 -0
- ams/pypower/core/ppver.py +18 -0
- ams/pypower/core/solver.py +2451 -0
- ams/pypower/eps.py +6 -0
- ams/pypower/idx.py +174 -0
- ams/pypower/io.py +604 -0
- ams/pypower/make/__init__.py +11 -0
- ams/pypower/make/matrices.py +665 -0
- ams/pypower/make/pdv.py +506 -0
- ams/pypower/routines/__init__.py +7 -0
- ams/pypower/routines/cpf.py +513 -0
- ams/pypower/routines/cpf_callbacks.py +114 -0
- ams/pypower/routines/opf.py +1803 -0
- ams/pypower/routines/opffcns.py +1946 -0
- ams/pypower/routines/pflow.py +852 -0
- ams/pypower/toggle.py +1098 -0
- ams/pypower/utils.py +293 -0
- ams/report.py +212 -50
- ams/routines/__init__.py +23 -0
- ams/routines/acopf.py +117 -0
- ams/routines/cpf.py +65 -0
- ams/routines/dcopf.py +241 -0
- ams/routines/dcpf.py +209 -0
- ams/routines/dcpf0.py +196 -0
- ams/routines/dopf.py +150 -0
- ams/routines/ed.py +312 -0
- ams/routines/pflow.py +255 -0
- ams/routines/pflow0.py +113 -0
- ams/routines/pflow1.py +156 -0
- ams/routines/routine.py +1033 -0
- ams/routines/rted.py +519 -0
- ams/routines/type.py +160 -0
- ams/routines/uc.py +376 -0
- ams/shared.py +34 -9
- ams/system.py +61 -22
- ams/utils/__init__.py +3 -0
- ams/utils/misc.py +77 -0
- ams/utils/paths.py +257 -0
- docs/Makefile +21 -0
- docs/build/doctrees/nbsphinx/_examples_demo_demo_AGC_20_1.png +0 -0
- docs/build/doctrees/nbsphinx/_examples_demo_demo_AGC_37_1.png +0 -0
- docs/build/doctrees/nbsphinx/_examples_demo_demo_AGC_39_1.png +0 -0
- docs/build/html/_images/_examples_demo_demo_AGC_20_1.png +0 -0
- docs/build/html/_images/_examples_demo_demo_AGC_37_1.png +0 -0
- docs/build/html/_images/_examples_demo_demo_AGC_39_1.png +0 -0
- docs/build/html/_images/xlsx.png +0 -0
- docs/build/html/_static/file.png +0 -0
- docs/build/html/_static/minus.png +0 -0
- docs/build/html/_static/plus.png +0 -0
- docs/make.bat +35 -0
- docs/source/_generated/_generated/ams.core.model.Model.alter.rst +6 -0
- docs/source/_generated/_generated/ams.core.model.Model.class_name.rst +6 -0
- docs/source/_generated/_generated/ams.core.model.Model.doc.rst +6 -0
- docs/source/_generated/_generated/ams.core.model.Model.get.rst +6 -0
- docs/source/_generated/_generated/ams.core.model.Model.get_idx.rst +6 -0
- docs/source/_generated/_generated/ams.core.model.Model.idx2uid.rst +6 -0
- docs/source/_generated/_generated/ams.core.model.Model.list2array.rst +6 -0
- docs/source/_generated/_generated/ams.core.model.Model.set.rst +6 -0
- docs/source/_generated/_generated/ams.core.model.Model.set_backref.rst +6 -0
- docs/source/_generated/_generated/ams.core.param.RParam.class_name.rst +6 -0
- docs/source/_generated/_generated/ams.core.param.RParam.dtype.rst +6 -0
- docs/source/_generated/_generated/ams.core.param.RParam.evaluate.rst +6 -0
- docs/source/_generated/_generated/ams.core.param.RParam.get_idx.rst +6 -0
- docs/source/_generated/_generated/ams.core.param.RParam.n.rst +6 -0
- docs/source/_generated/_generated/ams.core.param.RParam.parse.rst +6 -0
- docs/source/_generated/_generated/ams.core.param.RParam.shape.rst +6 -0
- docs/source/_generated/_generated/ams.core.param.RParam.size.rst +6 -0
- docs/source/_generated/_generated/ams.core.param.RParam.update.rst +6 -0
- docs/source/_generated/_generated/ams.core.param.RParam.v.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.LoadScale.assign_memory.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.LoadScale.class_name.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.LoadScale.evaluate.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.LoadScale.get_names.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.LoadScale.n.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.LoadScale.parse.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.LoadScale.shape.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.LoadScale.size.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.LoadScale.update.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.LoadScale.v.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.MinDur.assign_memory.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.MinDur.class_name.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.MinDur.evaluate.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.MinDur.get_names.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.MinDur.n.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.MinDur.parse.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.MinDur.shape.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.MinDur.size.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.MinDur.update.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.MinDur.v.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.MinDur.v0.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.MinDur.v1.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumExpandDim.assign_memory.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumExpandDim.class_name.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumExpandDim.evaluate.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumExpandDim.get_names.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumExpandDim.n.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumExpandDim.parse.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumExpandDim.shape.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumExpandDim.size.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumExpandDim.update.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumExpandDim.v.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumExpandDim.v0.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumExpandDim.v1.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumHstack.assign_memory.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumHstack.class_name.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumHstack.evaluate.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumHstack.get_names.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumHstack.n.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumHstack.parse.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumHstack.shape.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumHstack.size.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumHstack.update.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumHstack.v.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumHstack.v0.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumHstack.v1.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumOp.assign_memory.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumOp.class_name.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumOp.evaluate.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumOp.get_names.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumOp.n.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumOp.parse.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumOp.shape.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumOp.size.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumOp.update.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumOp.v.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumOp.v0.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumOp.v1.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumOpDual.assign_memory.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumOpDual.class_name.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumOpDual.evaluate.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumOpDual.get_names.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumOpDual.n.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumOpDual.parse.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumOpDual.shape.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumOpDual.size.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumOpDual.update.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumOpDual.v.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumOpDual.v0.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.NumOpDual.v1.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.RBaseService.assign_memory.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.RBaseService.class_name.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.RBaseService.evaluate.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.RBaseService.get_names.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.RBaseService.n.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.RBaseService.parse.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.RBaseService.shape.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.RBaseService.size.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.RBaseService.update.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.RBaseService.v.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.ROperationService.assign_memory.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.ROperationService.class_name.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.ROperationService.evaluate.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.ROperationService.get_names.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.ROperationService.n.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.ROperationService.parse.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.ROperationService.shape.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.ROperationService.size.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.ROperationService.update.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.ROperationService.v.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.RampSub.assign_memory.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.RampSub.class_name.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.RampSub.evaluate.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.RampSub.get_names.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.RampSub.n.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.RampSub.parse.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.RampSub.shape.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.RampSub.size.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.RampSub.update.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.RampSub.v.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.RampSub.v0.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.RampSub.v1.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.ValueService.assign_memory.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.ValueService.class_name.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.ValueService.evaluate.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.ValueService.get_names.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.ValueService.n.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.ValueService.parse.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.ValueService.shape.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.ValueService.size.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.ValueService.update.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.ValueService.v.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.VarReduction.assign_memory.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.VarReduction.class_name.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.VarReduction.evaluate.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.VarReduction.get_names.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.VarReduction.n.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.VarReduction.parse.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.VarReduction.shape.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.VarReduction.size.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.VarReduction.update.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.VarReduction.v.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.VarReduction.v0.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.VarReduction.v1.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.VarSelect.assign_memory.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.VarSelect.class_name.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.VarSelect.evaluate.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.VarSelect.get_names.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.VarSelect.n.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.VarSelect.parse.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.VarSelect.shape.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.VarSelect.size.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.VarSelect.update.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.VarSelect.v.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.VarSelect.v0.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.VarSelect.v1.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.ZonalSum.assign_memory.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.ZonalSum.class_name.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.ZonalSum.evaluate.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.ZonalSum.get_names.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.ZonalSum.n.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.ZonalSum.parse.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.ZonalSum.shape.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.ZonalSum.size.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.ZonalSum.update.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.ZonalSum.v.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.ZonalSum.v0.rst +6 -0
- docs/source/_generated/_generated/ams.core.service.ZonalSum.v1.rst +6 -0
- docs/source/_generated/_generated/ams.interface.Dynamic.is_tds.rst +6 -0
- docs/source/_generated/_generated/ams.interface.Dynamic.link_andes.rst +6 -0
- docs/source/_generated/_generated/ams.interface.Dynamic.receive.rst +6 -0
- docs/source/_generated/_generated/ams.interface.Dynamic.send.rst +6 -0
- docs/source/_generated/_generated/ams.opt.constraint.Constraint.class_name.rst +6 -0
- docs/source/_generated/_generated/ams.opt.constraint.Constraint.e.rst +6 -0
- docs/source/_generated/_generated/ams.opt.constraint.Constraint.evaluate.rst +6 -0
- docs/source/_generated/_generated/ams.opt.constraint.Constraint.n.rst +6 -0
- docs/source/_generated/_generated/ams.opt.constraint.Constraint.parse.rst +6 -0
- docs/source/_generated/_generated/ams.opt.constraint.Constraint.shape.rst +6 -0
- docs/source/_generated/_generated/ams.opt.constraint.Constraint.size.rst +6 -0
- docs/source/_generated/_generated/ams.opt.constraint.Constraint.v.rst +6 -0
- docs/source/_generated/_generated/ams.opt.exprcalc.ExpressionCalc.class_name.rst +6 -0
- docs/source/_generated/_generated/ams.opt.exprcalc.ExpressionCalc.e.rst +6 -0
- docs/source/_generated/_generated/ams.opt.exprcalc.ExpressionCalc.evaluate.rst +6 -0
- docs/source/_generated/_generated/ams.opt.exprcalc.ExpressionCalc.get_idx.rst +6 -0
- docs/source/_generated/_generated/ams.opt.exprcalc.ExpressionCalc.n.rst +6 -0
- docs/source/_generated/_generated/ams.opt.exprcalc.ExpressionCalc.parse.rst +6 -0
- docs/source/_generated/_generated/ams.opt.exprcalc.ExpressionCalc.shape.rst +6 -0
- docs/source/_generated/_generated/ams.opt.exprcalc.ExpressionCalc.size.rst +6 -0
- docs/source/_generated/_generated/ams.opt.exprcalc.ExpressionCalc.v.rst +6 -0
- docs/source/_generated/_generated/ams.opt.expression.Expression.class_name.rst +6 -0
- docs/source/_generated/_generated/ams.opt.expression.Expression.e.rst +6 -0
- docs/source/_generated/_generated/ams.opt.expression.Expression.evaluate.rst +6 -0
- docs/source/_generated/_generated/ams.opt.expression.Expression.get_idx.rst +6 -0
- docs/source/_generated/_generated/ams.opt.expression.Expression.n.rst +6 -0
- docs/source/_generated/_generated/ams.opt.expression.Expression.parse.rst +6 -0
- docs/source/_generated/_generated/ams.opt.expression.Expression.shape.rst +6 -0
- docs/source/_generated/_generated/ams.opt.expression.Expression.size.rst +6 -0
- docs/source/_generated/_generated/ams.opt.expression.Expression.v.rst +6 -0
- docs/source/_generated/_generated/ams.opt.objective.Objective.class_name.rst +6 -0
- docs/source/_generated/_generated/ams.opt.objective.Objective.e.rst +6 -0
- docs/source/_generated/_generated/ams.opt.objective.Objective.evaluate.rst +6 -0
- docs/source/_generated/_generated/ams.opt.objective.Objective.n.rst +6 -0
- docs/source/_generated/_generated/ams.opt.objective.Objective.parse.rst +6 -0
- docs/source/_generated/_generated/ams.opt.objective.Objective.shape.rst +6 -0
- docs/source/_generated/_generated/ams.opt.objective.Objective.size.rst +6 -0
- docs/source/_generated/_generated/ams.opt.objective.Objective.v.rst +6 -0
- docs/source/_generated/_generated/ams.opt.omodel.OModel.class_name.rst +6 -0
- docs/source/_generated/_generated/ams.opt.omodel.OModel.evaluate.rst +6 -0
- docs/source/_generated/_generated/ams.opt.omodel.OModel.finalize.rst +6 -0
- docs/source/_generated/_generated/ams.opt.omodel.OModel.init.rst +6 -0
- docs/source/_generated/_generated/ams.opt.omodel.OModel.initialized.rst +6 -0
- docs/source/_generated/_generated/ams.opt.omodel.OModel.parse.rst +6 -0
- docs/source/_generated/_generated/ams.opt.omodel.OModel.update.rst +6 -0
- docs/source/_generated/_generated/ams.opt.omodel.OModelBase.class_name.rst +6 -0
- docs/source/_generated/_generated/ams.opt.omodel.OModelBase.evaluate.rst +6 -0
- docs/source/_generated/_generated/ams.opt.omodel.OModelBase.finalize.rst +6 -0
- docs/source/_generated/_generated/ams.opt.omodel.OModelBase.init.rst +6 -0
- docs/source/_generated/_generated/ams.opt.omodel.OModelBase.initialized.rst +6 -0
- docs/source/_generated/_generated/ams.opt.omodel.OModelBase.parse.rst +6 -0
- docs/source/_generated/_generated/ams.opt.omodel.OModelBase.update.rst +6 -0
- docs/source/_generated/_generated/ams.opt.optbase.OptzBase.class_name.rst +6 -0
- docs/source/_generated/_generated/ams.opt.optbase.OptzBase.evaluate.rst +6 -0
- docs/source/_generated/_generated/ams.opt.optbase.OptzBase.n.rst +6 -0
- docs/source/_generated/_generated/ams.opt.optbase.OptzBase.parse.rst +6 -0
- docs/source/_generated/_generated/ams.opt.optbase.OptzBase.shape.rst +6 -0
- docs/source/_generated/_generated/ams.opt.optbase.OptzBase.size.rst +6 -0
- docs/source/_generated/_generated/ams.opt.param.Param.class_name.rst +6 -0
- docs/source/_generated/_generated/ams.opt.param.Param.evaluate.rst +6 -0
- docs/source/_generated/_generated/ams.opt.param.Param.n.rst +6 -0
- docs/source/_generated/_generated/ams.opt.param.Param.parse.rst +6 -0
- docs/source/_generated/_generated/ams.opt.param.Param.shape.rst +6 -0
- docs/source/_generated/_generated/ams.opt.param.Param.size.rst +6 -0
- docs/source/_generated/_generated/ams.opt.param.Param.update.rst +6 -0
- docs/source/_generated/_generated/ams.opt.var.Var.class_name.rst +6 -0
- docs/source/_generated/_generated/ams.opt.var.Var.evaluate.rst +6 -0
- docs/source/_generated/_generated/ams.opt.var.Var.get_idx.rst +6 -0
- docs/source/_generated/_generated/ams.opt.var.Var.n.rst +6 -0
- docs/source/_generated/_generated/ams.opt.var.Var.parse.rst +6 -0
- docs/source/_generated/_generated/ams.opt.var.Var.shape.rst +6 -0
- docs/source/_generated/_generated/ams.opt.var.Var.size.rst +6 -0
- docs/source/_generated/_generated/ams.opt.var.Var.v.rst +6 -0
- docs/source/_generated/_generated/ams.routines.dcopf.DCOPF.addConstrs.rst +6 -0
- docs/source/_generated/_generated/ams.routines.dcopf.DCOPF.addRParam.rst +6 -0
- docs/source/_generated/_generated/ams.routines.dcopf.DCOPF.addService.rst +6 -0
- docs/source/_generated/_generated/ams.routines.dcopf.DCOPF.addVars.rst +6 -0
- docs/source/_generated/_generated/ams.routines.dcopf.DCOPF.class_name.rst +6 -0
- docs/source/_generated/_generated/ams.routines.dcopf.DCOPF.dc2ac.rst +6 -0
- docs/source/_generated/_generated/ams.routines.dcopf.DCOPF.disable.rst +6 -0
- docs/source/_generated/_generated/ams.routines.dcopf.DCOPF.doc.rst +6 -0
- docs/source/_generated/_generated/ams.routines.dcopf.DCOPF.enable.rst +6 -0
- docs/source/_generated/_generated/ams.routines.dcopf.DCOPF.export_csv.rst +6 -0
- docs/source/_generated/_generated/ams.routines.dcopf.DCOPF.get.rst +6 -0
- docs/source/_generated/_generated/ams.routines.dcopf.DCOPF.init.rst +6 -0
- docs/source/_generated/_generated/ams.routines.dcopf.DCOPF.run.rst +6 -0
- docs/source/_generated/_generated/ams.routines.dcopf.DCOPF.set.rst +6 -0
- docs/source/_generated/_generated/ams.routines.dcopf.DCOPF.solve.rst +6 -0
- docs/source/_generated/_generated/ams.routines.dcopf.DCOPF.summary.rst +6 -0
- docs/source/_generated/_generated/ams.routines.dcopf.DCOPF.unpack.rst +6 -0
- docs/source/_generated/_generated/ams.routines.dcopf.DCOPF.update.rst +6 -0
- docs/source/_generated/_generated/ams.routines.pflow.PFlow.addConstrs.rst +6 -0
- docs/source/_generated/_generated/ams.routines.pflow.PFlow.addRParam.rst +6 -0
- docs/source/_generated/_generated/ams.routines.pflow.PFlow.addService.rst +6 -0
- docs/source/_generated/_generated/ams.routines.pflow.PFlow.addVars.rst +6 -0
- docs/source/_generated/_generated/ams.routines.pflow.PFlow.class_name.rst +6 -0
- docs/source/_generated/_generated/ams.routines.pflow.PFlow.dc2ac.rst +6 -0
- docs/source/_generated/_generated/ams.routines.pflow.PFlow.disable.rst +6 -0
- docs/source/_generated/_generated/ams.routines.pflow.PFlow.doc.rst +6 -0
- docs/source/_generated/_generated/ams.routines.pflow.PFlow.enable.rst +6 -0
- docs/source/_generated/_generated/ams.routines.pflow.PFlow.export_csv.rst +6 -0
- docs/source/_generated/_generated/ams.routines.pflow.PFlow.get.rst +6 -0
- docs/source/_generated/_generated/ams.routines.pflow.PFlow.init.rst +6 -0
- docs/source/_generated/_generated/ams.routines.pflow.PFlow.run.rst +6 -0
- docs/source/_generated/_generated/ams.routines.pflow.PFlow.set.rst +6 -0
- docs/source/_generated/_generated/ams.routines.pflow.PFlow.solve.rst +6 -0
- docs/source/_generated/_generated/ams.routines.pflow.PFlow.summary.rst +6 -0
- docs/source/_generated/_generated/ams.routines.pflow.PFlow.unpack.rst +6 -0
- docs/source/_generated/_generated/ams.routines.pflow.PFlow.update.rst +6 -0
- docs/source/_generated/_generated/ams.routines.routine.RoutineBase.addConstrs.rst +6 -0
- docs/source/_generated/_generated/ams.routines.routine.RoutineBase.addRParam.rst +6 -0
- docs/source/_generated/_generated/ams.routines.routine.RoutineBase.addService.rst +6 -0
- docs/source/_generated/_generated/ams.routines.routine.RoutineBase.addVars.rst +6 -0
- docs/source/_generated/_generated/ams.routines.routine.RoutineBase.class_name.rst +6 -0
- docs/source/_generated/_generated/ams.routines.routine.RoutineBase.dc2ac.rst +6 -0
- docs/source/_generated/_generated/ams.routines.routine.RoutineBase.disable.rst +6 -0
- docs/source/_generated/_generated/ams.routines.routine.RoutineBase.doc.rst +6 -0
- docs/source/_generated/_generated/ams.routines.routine.RoutineBase.enable.rst +6 -0
- docs/source/_generated/_generated/ams.routines.routine.RoutineBase.export_csv.rst +6 -0
- docs/source/_generated/_generated/ams.routines.routine.RoutineBase.get.rst +6 -0
- docs/source/_generated/_generated/ams.routines.routine.RoutineBase.init.rst +6 -0
- docs/source/_generated/_generated/ams.routines.routine.RoutineBase.run.rst +6 -0
- docs/source/_generated/_generated/ams.routines.routine.RoutineBase.set.rst +6 -0
- docs/source/_generated/_generated/ams.routines.routine.RoutineBase.solve.rst +6 -0
- docs/source/_generated/_generated/ams.routines.routine.RoutineBase.summary.rst +6 -0
- docs/source/_generated/_generated/ams.routines.routine.RoutineBase.unpack.rst +6 -0
- docs/source/_generated/_generated/ams.routines.routine.RoutineBase.update.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.add.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.as_dict.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.calc_pu_coeff.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.call_models.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.collect_config.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.collect_ref.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.connectivity.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.e_clear.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.f_update.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.fg_to_dae.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.find_devices.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.find_models.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.from_ipysheet.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.g_islands.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.g_update.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.get_z.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.import_groups.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.import_models.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.import_routines.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.import_types.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.init.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.j_islands.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.j_update.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.l_update_eq.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.l_update_var.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.link_ext_param.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.precompile.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.prepare.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.reload.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.remove_pycapsule.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.report.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.reset.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.s_update_post.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.s_update_var.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.save_config.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.set_address.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.set_config.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.set_dae_names.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.set_output_subidx.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.set_var_arrays.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.setup.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.store_adder_setter.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.store_existing.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.store_no_check_init.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.store_sparse_pattern.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.store_switch_times.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.summary.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.supported_models.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.supported_routines.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.switch_action.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.to_andes.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.to_ipysheet.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.undill.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.vars_to_dae.rst +6 -0
- docs/source/_generated/_generated/ams.system.System.vars_to_models.rst +6 -0
- docs/source/_generated/_generated/ams.utils.paths.DisplayablePath.display_filename_prefix_last.rst +6 -0
- docs/source/_generated/_generated/ams.utils.paths.DisplayablePath.display_filename_prefix_middle.rst +6 -0
- docs/source/_generated/_generated/ams.utils.paths.DisplayablePath.display_parent_prefix_last.rst +6 -0
- docs/source/_generated/_generated/ams.utils.paths.DisplayablePath.display_parent_prefix_middle.rst +6 -0
- docs/source/_generated/_generated/ams.utils.paths.DisplayablePath.displayable.rst +6 -0
- docs/source/_generated/_generated/ams.utils.paths.DisplayablePath.displayname.rst +6 -0
- docs/source/_generated/_generated/ams.utils.paths.DisplayablePath.make_tree.rst +6 -0
- docs/source/_generated/ams.cli.create_parser.rst +6 -0
- docs/source/_generated/ams.cli.main.rst +6 -0
- docs/source/_generated/ams.cli.preamble.rst +6 -0
- docs/source/_generated/ams.cli.rst +32 -0
- docs/source/_generated/ams.core.model.Model.rst +56 -0
- docs/source/_generated/ams.core.model.rst +30 -0
- docs/source/_generated/ams.core.param.RParam.rst +49 -0
- docs/source/_generated/ams.core.param.rst +30 -0
- docs/source/_generated/ams.core.service.LoadScale.rst +51 -0
- docs/source/_generated/ams.core.service.MinDur.rst +53 -0
- docs/source/_generated/ams.core.service.NumExpandDim.rst +53 -0
- docs/source/_generated/ams.core.service.NumHstack.rst +53 -0
- docs/source/_generated/ams.core.service.NumOp.rst +53 -0
- docs/source/_generated/ams.core.service.NumOpDual.rst +53 -0
- docs/source/_generated/ams.core.service.RBaseService.rst +51 -0
- docs/source/_generated/ams.core.service.ROperationService.rst +51 -0
- docs/source/_generated/ams.core.service.RampSub.rst +53 -0
- docs/source/_generated/ams.core.service.ValueService.rst +51 -0
- docs/source/_generated/ams.core.service.VarReduction.rst +53 -0
- docs/source/_generated/ams.core.service.VarSelect.rst +53 -0
- docs/source/_generated/ams.core.service.ZonalSum.rst +53 -0
- docs/source/_generated/ams.core.service.rst +42 -0
- docs/source/_generated/ams.interface.Dynamic.rst +41 -0
- docs/source/_generated/ams.interface.build_group_table.rst +6 -0
- docs/source/_generated/ams.interface.make_link_table.rst +6 -0
- docs/source/_generated/ams.interface.parse_addfile.rst +6 -0
- docs/source/_generated/ams.interface.replace_dev.rst +6 -0
- docs/source/_generated/ams.interface.rst +43 -0
- docs/source/_generated/ams.interface.sync_adsys.rst +6 -0
- docs/source/_generated/ams.interface.to_andes.rst +6 -0
- docs/source/_generated/ams.interface.verify_pf.rst +6 -0
- docs/source/_generated/ams.io.guess.rst +6 -0
- docs/source/_generated/ams.io.json.rst +30 -0
- docs/source/_generated/ams.io.json.write.rst +6 -0
- docs/source/_generated/ams.io.matpower.mpc2system.rst +6 -0
- docs/source/_generated/ams.io.matpower.read.rst +6 -0
- docs/source/_generated/ams.io.matpower.rst +33 -0
- docs/source/_generated/ams.io.matpower.system2mpc.rst +6 -0
- docs/source/_generated/ams.io.matpower.testlines.rst +6 -0
- docs/source/_generated/ams.io.parse.rst +6 -0
- docs/source/_generated/ams.io.psse.rst +23 -0
- docs/source/_generated/ams.io.pypower.ppc2system.rst +6 -0
- docs/source/_generated/ams.io.pypower.py2ppc.rst +6 -0
- docs/source/_generated/ams.io.pypower.read.rst +6 -0
- docs/source/_generated/ams.io.pypower.rst +34 -0
- docs/source/_generated/ams.io.pypower.system2ppc.rst +6 -0
- docs/source/_generated/ams.io.pypower.testlines.rst +6 -0
- docs/source/_generated/ams.io.rst +45 -0
- docs/source/_generated/ams.io.xlsx.rst +30 -0
- docs/source/_generated/ams.io.xlsx.write.rst +6 -0
- docs/source/_generated/ams.main.config_logger.rst +6 -0
- docs/source/_generated/ams.main.demo.rst +6 -0
- docs/source/_generated/ams.main.doc.rst +6 -0
- docs/source/_generated/ams.main.edit_conf.rst +6 -0
- docs/source/_generated/ams.main.find_log_path.rst +6 -0
- docs/source/_generated/ams.main.load.rst +6 -0
- docs/source/_generated/ams.main.misc.rst +6 -0
- docs/source/_generated/ams.main.print_license.rst +6 -0
- docs/source/_generated/ams.main.remove_output.rst +6 -0
- docs/source/_generated/ams.main.rst +44 -0
- docs/source/_generated/ams.main.run.rst +6 -0
- docs/source/_generated/ams.main.run_case.rst +6 -0
- docs/source/_generated/ams.main.save_conf.rst +6 -0
- docs/source/_generated/ams.main.selftest.rst +6 -0
- docs/source/_generated/ams.main.set_logger_level.rst +6 -0
- docs/source/_generated/ams.main.versioninfo.rst +6 -0
- docs/source/_generated/ams.opt.constraint.Constraint.rst +43 -0
- docs/source/_generated/ams.opt.constraint.rst +30 -0
- docs/source/_generated/ams.opt.exprcalc.ExpressionCalc.rst +46 -0
- docs/source/_generated/ams.opt.exprcalc.rst +30 -0
- docs/source/_generated/ams.opt.expression.Expression.rst +46 -0
- docs/source/_generated/ams.opt.expression.rst +30 -0
- docs/source/_generated/ams.opt.objective.Objective.rst +43 -0
- docs/source/_generated/ams.opt.objective.rst +30 -0
- docs/source/_generated/ams.opt.omodel.OModel.rst +48 -0
- docs/source/_generated/ams.opt.omodel.OModelBase.rst +48 -0
- docs/source/_generated/ams.opt.omodel.rst +31 -0
- docs/source/_generated/ams.opt.optbase.OptzBase.rst +41 -0
- docs/source/_generated/ams.opt.optbase.ensure_mats_and_parsed.rst +6 -0
- docs/source/_generated/ams.opt.optbase.ensure_symbols.rst +6 -0
- docs/source/_generated/ams.opt.optbase.rst +38 -0
- docs/source/_generated/ams.opt.param.Param.rst +44 -0
- docs/source/_generated/ams.opt.param.rst +30 -0
- docs/source/_generated/ams.opt.rst +40 -0
- docs/source/_generated/ams.opt.var.Var.rst +45 -0
- docs/source/_generated/ams.opt.var.rst +30 -0
- docs/source/_generated/ams.routines.dcopf.DCOPF.rst +83 -0
- docs/source/_generated/ams.routines.dcopf.rst +30 -0
- docs/source/_generated/ams.routines.pflow.PFlow.rst +83 -0
- docs/source/_generated/ams.routines.pflow.rst +30 -0
- docs/source/_generated/ams.routines.routine.RoutineBase.rst +83 -0
- docs/source/_generated/ams.routines.routine.collect_data.rst +6 -0
- docs/source/_generated/ams.routines.routine.initialize_data_dict.rst +6 -0
- docs/source/_generated/ams.routines.routine.rst +38 -0
- docs/source/_generated/ams.system.System.rst +189 -0
- docs/source/_generated/ams.system.disable_method.rst +6 -0
- docs/source/_generated/ams.system.disable_methods.rst +6 -0
- docs/source/_generated/ams.system.example.rst +6 -0
- docs/source/_generated/ams.system.rst +39 -0
- docs/source/_generated/ams.utils.paths.DisplayablePath.rst +42 -0
- docs/source/_generated/ams.utils.paths.ams_root.rst +6 -0
- docs/source/_generated/ams.utils.paths.cases_root.rst +6 -0
- docs/source/_generated/ams.utils.paths.confirm_overwrite.rst +6 -0
- docs/source/_generated/ams.utils.paths.get_case.rst +6 -0
- docs/source/_generated/ams.utils.paths.get_config_path.rst +6 -0
- docs/source/_generated/ams.utils.paths.get_dot_andes_path.rst +6 -0
- docs/source/_generated/ams.utils.paths.get_log_dir.rst +6 -0
- docs/source/_generated/ams.utils.paths.get_pkl_path.rst +6 -0
- docs/source/_generated/ams.utils.paths.get_pycode_path.rst +6 -0
- docs/source/_generated/ams.utils.paths.list_cases.rst +6 -0
- docs/source/_generated/ams.utils.paths.rst +47 -0
- docs/source/_generated/ams.utils.paths.tests_root.rst +6 -0
- docs/source/_templates/autosummary/base.rst +5 -0
- docs/source/_templates/autosummary/class.rst +35 -0
- docs/source/_templates/autosummary/module.rst +65 -0
- docs/source/_templates/autosummary/module_toctree.rst +66 -0
- docs/source/api.rst +102 -0
- docs/source/conf.py +203 -0
- docs/source/examples/index.rst +34 -0
- docs/source/genmodelref.py +61 -0
- docs/source/genroutineref.py +47 -0
- docs/source/getting_started/copyright.rst +20 -0
- docs/source/getting_started/formats/index.rst +20 -0
- docs/source/getting_started/formats/matpower.rst +183 -0
- docs/source/getting_started/formats/psse.rst +46 -0
- docs/source/getting_started/formats/pypower.rst +223 -0
- docs/source/getting_started/formats/xlsx.png +0 -0
- docs/source/getting_started/formats/xlsx.rst +23 -0
- docs/source/getting_started/index.rst +76 -0
- docs/source/getting_started/install.rst +234 -0
- docs/source/getting_started/overview.rst +26 -0
- docs/source/getting_started/testcase.rst +45 -0
- docs/source/getting_started/verification.rst +13 -0
- docs/source/groupdoc/ACLine.rst +92 -0
- docs/source/groupdoc/ACShort.rst +51 -0
- docs/source/groupdoc/ACTopology.rst +66 -0
- docs/source/groupdoc/Collection.rst +84 -0
- docs/source/groupdoc/Cost.rst +135 -0
- docs/source/groupdoc/DG.rst +204 -0
- docs/source/groupdoc/Horizon.rst +97 -0
- docs/source/groupdoc/Information.rst +36 -0
- docs/source/groupdoc/RenGen.rst +63 -0
- docs/source/groupdoc/Reserve.rst +135 -0
- docs/source/groupdoc/StaticGen.rst +229 -0
- docs/source/groupdoc/StaticLoad.rst +53 -0
- docs/source/groupdoc/StaticShunt.rst +45 -0
- docs/source/groupdoc/Undefined.rst +63 -0
- docs/source/groupdoc/VSG.rst +125 -0
- docs/source/images/dcopf_time.png +0 -0
- docs/source/images/sponsors/CURENT_Logo_NameOnTrans.png +0 -0
- docs/source/images/sponsors/CURENT_Logo_Transparent.png +0 -0
- docs/source/images/sponsors/CURENT_Logo_Transparent_Name.png +0 -0
- docs/source/images/sponsors/doe.png +0 -0
- docs/source/index.rst +108 -0
- docs/source/modeling/_generated/_generated/ams.opt.Constraint.class_name.rst +6 -0
- docs/source/modeling/_generated/_generated/ams.opt.Constraint.e.rst +6 -0
- docs/source/modeling/_generated/_generated/ams.opt.Constraint.evaluate.rst +6 -0
- docs/source/modeling/_generated/_generated/ams.opt.Constraint.n.rst +6 -0
- docs/source/modeling/_generated/_generated/ams.opt.Constraint.parse.rst +6 -0
- docs/source/modeling/_generated/_generated/ams.opt.Constraint.shape.rst +6 -0
- docs/source/modeling/_generated/_generated/ams.opt.Constraint.size.rst +6 -0
- docs/source/modeling/_generated/_generated/ams.opt.Constraint.v.rst +6 -0
- docs/source/modeling/_generated/_generated/ams.opt.OModel.class_name.rst +6 -0
- docs/source/modeling/_generated/_generated/ams.opt.OModel.evaluate.rst +6 -0
- docs/source/modeling/_generated/_generated/ams.opt.OModel.finalize.rst +6 -0
- docs/source/modeling/_generated/_generated/ams.opt.OModel.init.rst +6 -0
- docs/source/modeling/_generated/_generated/ams.opt.OModel.initialized.rst +6 -0
- docs/source/modeling/_generated/_generated/ams.opt.OModel.parse.rst +6 -0
- docs/source/modeling/_generated/_generated/ams.opt.OModel.update.rst +6 -0
- docs/source/modeling/_generated/_generated/ams.opt.Objective.class_name.rst +6 -0
- docs/source/modeling/_generated/_generated/ams.opt.Objective.e.rst +6 -0
- docs/source/modeling/_generated/_generated/ams.opt.Objective.evaluate.rst +6 -0
- docs/source/modeling/_generated/_generated/ams.opt.Objective.n.rst +6 -0
- docs/source/modeling/_generated/_generated/ams.opt.Objective.parse.rst +6 -0
- docs/source/modeling/_generated/_generated/ams.opt.Objective.shape.rst +6 -0
- docs/source/modeling/_generated/_generated/ams.opt.Objective.size.rst +6 -0
- docs/source/modeling/_generated/_generated/ams.opt.Objective.v.rst +6 -0
- docs/source/modeling/_generated/_generated/ams.opt.Var.class_name.rst +6 -0
- docs/source/modeling/_generated/_generated/ams.opt.Var.evaluate.rst +6 -0
- docs/source/modeling/_generated/_generated/ams.opt.Var.get_idx.rst +6 -0
- docs/source/modeling/_generated/_generated/ams.opt.Var.n.rst +6 -0
- docs/source/modeling/_generated/_generated/ams.opt.Var.parse.rst +6 -0
- docs/source/modeling/_generated/_generated/ams.opt.Var.shape.rst +6 -0
- docs/source/modeling/_generated/_generated/ams.opt.Var.size.rst +6 -0
- docs/source/modeling/_generated/_generated/ams.opt.Var.v.rst +6 -0
- docs/source/modeling/_generated/ams.opt.Constraint.rst +43 -0
- docs/source/modeling/_generated/ams.opt.OModel.rst +48 -0
- docs/source/modeling/_generated/ams.opt.Objective.rst +43 -0
- docs/source/modeling/_generated/ams.opt.Var.rst +45 -0
- docs/source/modeling/example.rst +159 -0
- docs/source/modeling/index.rst +17 -0
- docs/source/modeling/model.rst +210 -0
- docs/source/modeling/routine.rst +122 -0
- docs/source/modeling/system.rst +51 -0
- docs/source/modelref.rst +66 -0
- docs/source/release-notes.rst +385 -0
- docs/source/routineref.rst +38 -0
- docs/source/typedoc/ACED.rst +91 -0
- docs/source/typedoc/DCED.rst +1869 -0
- docs/source/typedoc/DCUC.rst +899 -0
- docs/source/typedoc/DED.rst +390 -0
- docs/source/typedoc/PF.rst +376 -0
- docs/source/typedoc/UndefinedType.rst +8 -0
- icebar/ips/ips.py +668 -0
- ltbams-1.0.0.dist-info/METADATA +231 -0
- ltbams-1.0.0.dist-info/RECORD +725 -0
- {ltbams-0.9.9.dist-info → ltbams-1.0.0.dist-info}/WHEEL +1 -1
- ltbams-1.0.0.dist-info/top_level.txt +5 -0
- tests/__init__.py +0 -0
- tests/test_1st_system.py +33 -0
- tests/test_addressing.py +40 -0
- tests/test_andes_mats.py +61 -0
- tests/test_case.py +266 -0
- tests/test_cli.py +34 -0
- tests/test_export_csv.py +89 -0
- tests/test_group.py +83 -0
- tests/test_interface.py +216 -0
- tests/test_io.py +32 -0
- tests/test_jumper.py +27 -0
- tests/test_known_good.py +267 -0
- tests/test_matp.py +437 -0
- tests/test_model.py +54 -0
- tests/test_omodel.py +119 -0
- tests/test_paths.py +22 -0
- tests/test_report.py +245 -0
- tests/test_repr.py +21 -0
- tests/test_routine.py +178 -0
- tests/test_rtn_dcopf.py +101 -0
- tests/test_rtn_dcpf.py +77 -0
- tests/test_rtn_ed.py +275 -0
- tests/test_rtn_pflow.py +219 -0
- tests/test_rtn_rted.py +273 -0
- tests/test_rtn_uc.py +248 -0
- tests/test_service.py +73 -0
- ltbams-0.9.9.dist-info/LICENSE +0 -692
- ltbams-0.9.9.dist-info/METADATA +0 -859
- ltbams-0.9.9.dist-info/RECORD +0 -14
- ltbams-0.9.9.dist-info/top_level.txt +0 -1
- {ltbams-0.9.9.dist-info → ltbams-1.0.0.dist-info}/entry_points.txt +0 -0
tests/test_interface.py
ADDED
@@ -0,0 +1,216 @@
|
|
1
|
+
"""
|
2
|
+
Test interface.
|
3
|
+
"""
|
4
|
+
|
5
|
+
import unittest
|
6
|
+
import numpy as np
|
7
|
+
|
8
|
+
import andes
|
9
|
+
import ams
|
10
|
+
|
11
|
+
from ams.interface import (build_group_table, make_link_table, to_andes,
|
12
|
+
parse_addfile, verify_pf)
|
13
|
+
|
14
|
+
|
15
|
+
class TestAndesConversion(unittest.TestCase):
|
16
|
+
"""
|
17
|
+
Tests conversion from AMS to ANDES.
|
18
|
+
"""
|
19
|
+
ad_cases = [
|
20
|
+
'ieee14/ieee14_full.xlsx',
|
21
|
+
'ieee39/ieee39_full.xlsx',
|
22
|
+
'npcc/npcc.xlsx',
|
23
|
+
]
|
24
|
+
am_cases = [
|
25
|
+
'ieee14/ieee14.json',
|
26
|
+
'ieee39/ieee39.xlsx',
|
27
|
+
'npcc/npcc_uced.xlsx',
|
28
|
+
]
|
29
|
+
|
30
|
+
def setUp(self) -> None:
|
31
|
+
"""
|
32
|
+
Test setup.
|
33
|
+
"""
|
34
|
+
|
35
|
+
def test_basic_functions(self):
|
36
|
+
"""
|
37
|
+
Test basic functions defined in ANDES Interop.
|
38
|
+
"""
|
39
|
+
for ad_case in self.ad_cases:
|
40
|
+
sa = andes.load(andes.get_case(ad_case),
|
41
|
+
setup=True, no_output=True, default_config=True,)
|
42
|
+
# --- test build_group_table ---
|
43
|
+
ssa_stg = build_group_table(adsys=sa,
|
44
|
+
grp_name='StaticGen',
|
45
|
+
param_name=['u', 'name', 'idx', 'bus'],
|
46
|
+
mdl_name=[])
|
47
|
+
self.assertEqual(ssa_stg.shape,
|
48
|
+
(sa.StaticGen.n, 4))
|
49
|
+
|
50
|
+
ssa_gov = build_group_table(adsys=sa, grp_name='TurbineGov',
|
51
|
+
param_name=['idx', 'syn'],
|
52
|
+
mdl_name=[])
|
53
|
+
self.assertEqual(ssa_gov.shape,
|
54
|
+
(sa.TurbineGov.n, 2))
|
55
|
+
# --- test make_link_table ---
|
56
|
+
link_table = make_link_table(adsys=sa)
|
57
|
+
stg_idx = [str(i) for i in sa.PV.idx.v + sa.Slack.idx.v]
|
58
|
+
self.assertSetEqual(set(stg_idx),
|
59
|
+
set(link_table['stg_idx'].values))
|
60
|
+
bus_idx = [str(i) for i in sa.PV.bus.v + sa.Slack.bus.v]
|
61
|
+
self.assertSetEqual(set(bus_idx),
|
62
|
+
set(link_table['bus_idx'].values))
|
63
|
+
|
64
|
+
def test_convert(self):
|
65
|
+
"""
|
66
|
+
Test conversion from AMS case to ANDES case.
|
67
|
+
"""
|
68
|
+
for ad_case, am_case in zip(self.ad_cases, self.am_cases):
|
69
|
+
sp = ams.load(ams.get_case(am_case),
|
70
|
+
setup=True, no_output=True, default_config=True,)
|
71
|
+
# before addfile
|
72
|
+
sa = to_andes(sp, setup=False)
|
73
|
+
self.assertEqual(set(sp.PV.idx.v), set(sa.PV.idx.v))
|
74
|
+
self.assertEqual(set(sp.Bus.idx.v), set(sa.Bus.idx.v))
|
75
|
+
self.assertEqual(set(sp.Line.idx.v), set(sa.Line.idx.v))
|
76
|
+
self.assertEqual(np.sum(sp.PQ.p0.v), np.sum(sa.PQ.p0.v))
|
77
|
+
|
78
|
+
# after addfile
|
79
|
+
sa = parse_addfile(adsys=sa, amsys=sp,
|
80
|
+
addfile=andes.get_case(ad_case))
|
81
|
+
sa.setup()
|
82
|
+
set1 = set(sa.GENROU.gen.v)
|
83
|
+
set2 = set(sp.StaticGen.get_all_idxes())
|
84
|
+
# set2 includes set1, ensure GENROU.gen are all in StaticGen.idx
|
85
|
+
self.assertEqual(set1, set1 & set2)
|
86
|
+
|
87
|
+
# ensure PFlow models consistency
|
88
|
+
pflow_mdls = list(sa.PFlow.models.keys())
|
89
|
+
for mdl in pflow_mdls:
|
90
|
+
self.assertTrue(sp.models[mdl].as_df().equals(sa.PFlow.models[mdl].as_df()))
|
91
|
+
|
92
|
+
def test_convert_after_update(self):
|
93
|
+
"""
|
94
|
+
Test conversion from AMS case to ANDES case after updating parameters.
|
95
|
+
"""
|
96
|
+
for am_case in self.am_cases:
|
97
|
+
sp = ams.load(ams.get_case(am_case),
|
98
|
+
setup=True, no_output=True, default_config=True,)
|
99
|
+
# record initial values
|
100
|
+
pq_idx = sp.PQ.idx.v
|
101
|
+
p0 = sp.PQ.p0.v.copy()
|
102
|
+
sa = to_andes(sp, setup=False, no_output=True, default_config=True)
|
103
|
+
# before update
|
104
|
+
np.testing.assert_array_equal(sp.PQ.p0.v, sa.PQ.p0.v)
|
105
|
+
# after update
|
106
|
+
sp.PQ.alter(src='p0', idx=pq_idx, value=0.9*p0)
|
107
|
+
sa = to_andes(sp, setup=False, no_output=True, default_config=True)
|
108
|
+
np.testing.assert_array_equal(sp.PQ.p0.v, sa.PQ.p0.v)
|
109
|
+
|
110
|
+
def test_extra_dyn(self):
|
111
|
+
"""
|
112
|
+
Test conversion when extra dynamic models exist.
|
113
|
+
"""
|
114
|
+
sp = ams.load(ams.get_case('ieee14/ieee14_uced.xlsx'),
|
115
|
+
setup=True, no_output=True, default_config=True,)
|
116
|
+
sa = to_andes(sp, addfile=andes.get_case('ieee14/ieee14_full.xlsx'),
|
117
|
+
setup=True, no_output=True, default_config=True,
|
118
|
+
verify=False, tol=1e-3)
|
119
|
+
self.assertGreaterEqual(sa.PVD1.n, 0)
|
120
|
+
|
121
|
+
def test_verify_pf(self):
|
122
|
+
"""
|
123
|
+
Test verification of power flow results.
|
124
|
+
"""
|
125
|
+
sp = ams.load(ams.get_case('matpower/case300.m'),
|
126
|
+
setup=True, no_output=True, default_config=True,)
|
127
|
+
sa = to_andes(sp,
|
128
|
+
setup=True, no_output=True, default_config=True,
|
129
|
+
verify=False, tol=1e-3)
|
130
|
+
self.assertTrue(verify_pf(amsys=sp, adsys=sa, tol=1e-7))
|
131
|
+
|
132
|
+
def test_to_andes_toggle(self):
|
133
|
+
"""
|
134
|
+
Test conversion when there is Toggle in ANDES case.
|
135
|
+
"""
|
136
|
+
sp = ams.load(ams.get_case('5bus/pjm5bus_demo.xlsx'),
|
137
|
+
setup=True,
|
138
|
+
no_output=True,
|
139
|
+
default_config=True)
|
140
|
+
sa = sp.to_andes(setup=True,
|
141
|
+
addfile=andes.get_case('5bus/pjm5bus.xlsx'),
|
142
|
+
verify=False)
|
143
|
+
self.assertGreater(sa.Toggle.n, 0)
|
144
|
+
|
145
|
+
def test_to_andes_alter(self):
|
146
|
+
"""
|
147
|
+
Test conversion when there is Alter in ANDES case.
|
148
|
+
"""
|
149
|
+
sp = ams.load(ams.get_case('ieee14/ieee14_uced.xlsx'),
|
150
|
+
setup=True,
|
151
|
+
no_output=True,
|
152
|
+
default_config=True)
|
153
|
+
sa = sp.to_andes(setup=True,
|
154
|
+
addfile=andes.get_case('ieee14/ieee14_alter.xlsx'),
|
155
|
+
verify=False)
|
156
|
+
self.assertGreater(sa.Alter.n, 0)
|
157
|
+
|
158
|
+
def test_to_andes_fault(self):
|
159
|
+
"""
|
160
|
+
Test conversion when there is Toggle in ANDES case.
|
161
|
+
"""
|
162
|
+
sp = ams.load(ams.get_case('ieee14/ieee14_uced.xlsx'),
|
163
|
+
setup=True,
|
164
|
+
no_output=True,
|
165
|
+
default_config=True)
|
166
|
+
sa = sp.to_andes(setup=True,
|
167
|
+
addfile=andes.get_case('ieee14/ieee14_fault.xlsx'),
|
168
|
+
verify=False)
|
169
|
+
self.assertGreater(sa.Fault.n, 0)
|
170
|
+
|
171
|
+
|
172
|
+
class TestDataExchange(unittest.TestCase):
|
173
|
+
"""
|
174
|
+
Tests for data exchange between AMS and ANDES.
|
175
|
+
"""
|
176
|
+
|
177
|
+
def setUp(self) -> None:
|
178
|
+
"""
|
179
|
+
Test setup. This is executed before each test case.
|
180
|
+
"""
|
181
|
+
self.sp = ams.load(ams.get_case('ieee14/ieee14_uced.xlsx'),
|
182
|
+
setup=True,
|
183
|
+
no_output=True,
|
184
|
+
default_config=True,)
|
185
|
+
self.sp.RTED.run(solver='CLARABEL')
|
186
|
+
self.sp.RTED.dc2ac()
|
187
|
+
self.stg_idx = self.sp.RTED.pg.get_all_idxes()
|
188
|
+
|
189
|
+
def test_data_exchange(self):
|
190
|
+
"""
|
191
|
+
Test data exchange between AMS and ANDES.
|
192
|
+
"""
|
193
|
+
sa = to_andes(self.sp, setup=True,
|
194
|
+
addfile=andes.get_case('ieee14/ieee14_full.xlsx'),
|
195
|
+
no_output=True,
|
196
|
+
default_config=True,)
|
197
|
+
# alleviate limiter
|
198
|
+
sa.TGOV1.set(src='VMAX', idx=sa.TGOV1.idx.v, attr='v', value=100*np.ones(sa.TGOV1.n))
|
199
|
+
sa.TGOV1.set(src='VMIN', idx=sa.TGOV1.idx.v, attr='v', value=np.zeros(sa.TGOV1.n))
|
200
|
+
|
201
|
+
# --- test before PFlow ---
|
202
|
+
self.sp.dyn.send(adsys=sa, routine='RTED')
|
203
|
+
p0 = sa.StaticGen.get(src='p0', attr='v', idx=self.stg_idx)
|
204
|
+
pg = self.sp.RTED.get(src='pg', attr='v', idx=self.stg_idx)
|
205
|
+
np.testing.assert_array_equal(p0, pg)
|
206
|
+
|
207
|
+
# --- test after TDS ---
|
208
|
+
self.assertFalse(self.sp.dyn.is_tds)
|
209
|
+
sa.PFlow.run()
|
210
|
+
sa.TDS.init()
|
211
|
+
self.assertTrue(self.sp.dyn.is_tds)
|
212
|
+
|
213
|
+
sa.TDS.config.tf = 1
|
214
|
+
sa.TDS.run()
|
215
|
+
self.sp.dyn.send(adsys=sa, routine='RTED')
|
216
|
+
self.sp.dyn.receive(adsys=sa, routine='RTED', no_update=False)
|
tests/test_io.py
ADDED
@@ -0,0 +1,32 @@
|
|
1
|
+
"""
|
2
|
+
Test file input/output.
|
3
|
+
"""
|
4
|
+
|
5
|
+
import unittest
|
6
|
+
import numpy as np
|
7
|
+
|
8
|
+
import ams
|
9
|
+
|
10
|
+
|
11
|
+
class TestMATPOWER(unittest.TestCase):
|
12
|
+
|
13
|
+
def setUp(self):
|
14
|
+
self.mpc5 = ams.io.matpower.m2mpc(ams.get_case('matpower/case5.m'))
|
15
|
+
self.mpc14 = ams.io.matpower.m2mpc(ams.get_case('matpower/case14.m'))
|
16
|
+
|
17
|
+
def test_m2mpc(self):
|
18
|
+
self.assertTupleEqual(self.mpc5['gencost'].shape, (5, 6))
|
19
|
+
self.assertTupleEqual(self.mpc14['gencost'].shape, (5, 7))
|
20
|
+
|
21
|
+
def test_mpc2system(self):
|
22
|
+
system5 = ams.system.System()
|
23
|
+
ams.io.matpower.mpc2system(self.mpc5, system5)
|
24
|
+
# In case5.m, the gencost has type 2 cost model, with 2 parameters.
|
25
|
+
np.testing.assert_array_equal(system5.GCost.c2.v,
|
26
|
+
np.zeros(system5.StaticGen.n))
|
27
|
+
|
28
|
+
system14 = ams.system.System()
|
29
|
+
ams.io.matpower.mpc2system(self.mpc14, system14)
|
30
|
+
# In case14.m, the gencost has type 2 cost model, with 3 parameters.
|
31
|
+
np.testing.assert_array_less(np.zeros(system14.StaticGen.n),
|
32
|
+
system14.GCost.c2.v,)
|
tests/test_jumper.py
ADDED
@@ -0,0 +1,27 @@
|
|
1
|
+
"""
|
2
|
+
Test `Jumper` class.
|
3
|
+
"""
|
4
|
+
|
5
|
+
import unittest
|
6
|
+
|
7
|
+
import ams
|
8
|
+
|
9
|
+
|
10
|
+
class TessJumper(unittest.TestCase):
|
11
|
+
"""
|
12
|
+
Test `Jumper` class.
|
13
|
+
"""
|
14
|
+
|
15
|
+
def setUp(self) -> None:
|
16
|
+
"""
|
17
|
+
Test setup.
|
18
|
+
"""
|
19
|
+
self.sp = ams.load(ams.get_case("5bus/pjm5bus_jumper.xlsx"),
|
20
|
+
setup=True, no_output=True, default_config=True)
|
21
|
+
|
22
|
+
def test_to_andes(self):
|
23
|
+
"""
|
24
|
+
Test `to_andes` method when `Jumper` exists.
|
25
|
+
"""
|
26
|
+
sa = self.sp.to_andes()
|
27
|
+
self.assertEqual(sa.Jumper.n, 1)
|
tests/test_known_good.py
ADDED
@@ -0,0 +1,267 @@
|
|
1
|
+
import logging
|
2
|
+
import unittest
|
3
|
+
|
4
|
+
import json
|
5
|
+
|
6
|
+
import numpy as np
|
7
|
+
|
8
|
+
from andes.shared import rad2deg
|
9
|
+
import ams
|
10
|
+
from ams.shared import nan
|
11
|
+
|
12
|
+
logger = logging.getLogger(__name__)
|
13
|
+
|
14
|
+
|
15
|
+
class TestKnownResults(unittest.TestCase):
|
16
|
+
|
17
|
+
def setUp(self) -> None:
|
18
|
+
with open(ams.get_case('matpower/benchmark.json'), 'r') as file:
|
19
|
+
self.mpres = json.load(file)
|
20
|
+
|
21
|
+
self.sp = ams.load(ams.get_case('matpower/case14.m'),
|
22
|
+
setup=True, no_output=True, default_config=True)
|
23
|
+
|
24
|
+
def test_DCPF_case14(self):
|
25
|
+
"""
|
26
|
+
Test DC power flow for case14.
|
27
|
+
"""
|
28
|
+
self.sp.DCPF.run()
|
29
|
+
np.testing.assert_allclose(self.sp.DCPF.aBus.v * rad2deg,
|
30
|
+
np.array(self.mpres['case14']['DCPF']['aBus']).reshape(-1),
|
31
|
+
rtol=1e-2, atol=1e-2)
|
32
|
+
|
33
|
+
np.testing.assert_allclose(self.sp.DCPF.pg.v * self.sp.config.mva,
|
34
|
+
np.array(self.mpres['case14']['DCPF']['pg']).reshape(-1),
|
35
|
+
rtol=1e-2, atol=1e-2)
|
36
|
+
|
37
|
+
def test_PFlow_case14(self):
|
38
|
+
"""
|
39
|
+
Test power flow for case14.
|
40
|
+
"""
|
41
|
+
self.sp.PFlow.run()
|
42
|
+
np.testing.assert_allclose(self.sp.PFlow.aBus.v * rad2deg,
|
43
|
+
np.array(self.mpres['case14']['PFlow']['aBus']).reshape(-1),
|
44
|
+
rtol=1e-2, atol=1e-2)
|
45
|
+
np.testing.assert_allclose(self.sp.PFlow.vBus.v,
|
46
|
+
np.array(self.mpres['case14']['PFlow']['vBus']).reshape(-1),
|
47
|
+
rtol=1e-2, atol=1e-2)
|
48
|
+
np.testing.assert_allclose(self.sp.PFlow.pg.v.sum() * self.sp.config.mva,
|
49
|
+
np.array(self.mpres['case14']['PFlow']['pg']).sum(),
|
50
|
+
rtol=1e-2, atol=1e-2)
|
51
|
+
|
52
|
+
def test_DCOPF_case14(self):
|
53
|
+
"""
|
54
|
+
Test DCOPF for case14.
|
55
|
+
"""
|
56
|
+
self.sp.DCOPF.run(solver='CLARABEL')
|
57
|
+
self.assertAlmostEqual(self.sp.DCOPF.obj.v,
|
58
|
+
self.mpres['case14']['DCOPF']['obj'],
|
59
|
+
places=4)
|
60
|
+
np.testing.assert_allclose(self.sp.DCOPF.pi.v / self.sp.config.mva,
|
61
|
+
np.array(self.mpres['case14']['DCOPF']['pi']).reshape(-1),
|
62
|
+
rtol=1e-2, atol=1e-2)
|
63
|
+
|
64
|
+
def test_Matrices_case14(self):
|
65
|
+
"""
|
66
|
+
Test matrices for case14.
|
67
|
+
"""
|
68
|
+
ptdf = self.sp.mats.build_ptdf()
|
69
|
+
lodf = self.sp.mats.build_lodf()
|
70
|
+
|
71
|
+
ptdf_mp = load_ptdf(self.mpres, 'case14')
|
72
|
+
lodf_mp = load_lodf(self.mpres, 'case14')
|
73
|
+
|
74
|
+
ptdf[np.isnan(ptdf_mp)] = nan
|
75
|
+
lodf[np.isnan(lodf_mp)] = nan
|
76
|
+
|
77
|
+
np.testing.assert_allclose(ptdf, ptdf_mp,
|
78
|
+
equal_nan=True, rtol=1e-2, atol=1e-2)
|
79
|
+
|
80
|
+
np.testing.assert_allclose(lodf, lodf_mp,
|
81
|
+
equal_nan=True, rtol=1e-2, atol=1e-2)
|
82
|
+
|
83
|
+
|
84
|
+
class TestKnownResultsIEEE39(unittest.TestCase):
|
85
|
+
|
86
|
+
def setUp(self) -> None:
|
87
|
+
with open(ams.get_case('matpower/benchmark.json'), 'r') as file:
|
88
|
+
self.mpres = json.load(file)
|
89
|
+
|
90
|
+
self.sp = ams.load(ams.get_case('matpower/case39.m'),
|
91
|
+
setup=True, no_output=True, default_config=True)
|
92
|
+
|
93
|
+
def test_DCPF_case39(self):
|
94
|
+
"""
|
95
|
+
Test DC power flow for case39.
|
96
|
+
"""
|
97
|
+
self.sp.DCPF.run()
|
98
|
+
np.testing.assert_allclose(self.sp.DCPF.aBus.v * rad2deg,
|
99
|
+
np.array(self.mpres['case39']['DCPF']['aBus']).reshape(-1),
|
100
|
+
rtol=1e-2, atol=1e-2)
|
101
|
+
|
102
|
+
np.testing.assert_allclose(self.sp.DCPF.pg.v.sum() * self.sp.config.mva,
|
103
|
+
np.array(self.mpres['case39']['DCPF']['pg']).sum(),
|
104
|
+
rtol=1e-2, atol=1e-2)
|
105
|
+
|
106
|
+
def test_PFlow_case39(self):
|
107
|
+
"""
|
108
|
+
Test power flow for case39.
|
109
|
+
"""
|
110
|
+
self.sp.PFlow.run()
|
111
|
+
np.testing.assert_allclose(self.sp.PFlow.aBus.v * rad2deg,
|
112
|
+
np.array(self.mpres['case39']['PFlow']['aBus']).reshape(-1),
|
113
|
+
rtol=1e-2, atol=1e-2)
|
114
|
+
np.testing.assert_allclose(self.sp.PFlow.vBus.v,
|
115
|
+
np.array(self.mpres['case39']['PFlow']['vBus']).reshape(-1),
|
116
|
+
rtol=1e-2, atol=1e-2)
|
117
|
+
np.testing.assert_allclose(self.sp.PFlow.pg.v.sum() * self.sp.config.mva,
|
118
|
+
np.array(self.mpres['case39']['PFlow']['pg']).sum(),
|
119
|
+
rtol=1e-2, atol=1e-2)
|
120
|
+
|
121
|
+
def test_DCOPF_case39(self):
|
122
|
+
"""
|
123
|
+
Test DCOPF for case39.
|
124
|
+
"""
|
125
|
+
self.sp.DCOPF.run(solver='CLARABEL')
|
126
|
+
self.assertAlmostEqual(self.sp.DCOPF.obj.v,
|
127
|
+
self.mpres['case39']['DCOPF']['obj'],
|
128
|
+
places=2)
|
129
|
+
np.testing.assert_allclose(self.sp.DCOPF.pi.v / self.sp.config.mva,
|
130
|
+
np.array(self.mpres['case39']['DCOPF']['pi']).reshape(-1),
|
131
|
+
rtol=1e-2, atol=1e-2)
|
132
|
+
|
133
|
+
def test_Matrices_case39(self):
|
134
|
+
"""
|
135
|
+
Test matrices for case39.
|
136
|
+
"""
|
137
|
+
ptdf = self.sp.mats.build_ptdf()
|
138
|
+
lodf = self.sp.mats.build_lodf()
|
139
|
+
|
140
|
+
ptdf_mp = load_ptdf(self.mpres, 'case39')
|
141
|
+
lodf_mp = load_lodf(self.mpres, 'case39')
|
142
|
+
|
143
|
+
ptdf[np.isnan(ptdf_mp)] = nan
|
144
|
+
lodf[np.isnan(lodf_mp)] = nan
|
145
|
+
|
146
|
+
np.testing.assert_allclose(ptdf, ptdf_mp,
|
147
|
+
equal_nan=True, rtol=1e-2, atol=1e-2)
|
148
|
+
|
149
|
+
np.testing.assert_allclose(lodf, lodf_mp,
|
150
|
+
equal_nan=True, rtol=1e-2, atol=10)
|
151
|
+
|
152
|
+
|
153
|
+
class TestKnownResultsIEEE118(unittest.TestCase):
|
154
|
+
|
155
|
+
def setUp(self) -> None:
|
156
|
+
with open(ams.get_case('matpower/benchmark.json'), 'r') as file:
|
157
|
+
self.mpres = json.load(file)
|
158
|
+
|
159
|
+
self.sp = ams.load(ams.get_case('matpower/case118.m'),
|
160
|
+
setup=True, no_output=True, default_config=True)
|
161
|
+
|
162
|
+
def test_DCPF_case118(self):
|
163
|
+
"""
|
164
|
+
Test DC power flow for case118.
|
165
|
+
"""
|
166
|
+
self.sp.DCPF.run()
|
167
|
+
aBus_mp = np.array(self.mpres['case118']['DCPF']['aBus']).reshape(-1)
|
168
|
+
aBus_mp -= aBus_mp[0]
|
169
|
+
np.testing.assert_allclose((self.sp.DCPF.aBus.v - self.sp.DCPF.aBus.v[0]) * rad2deg,
|
170
|
+
aBus_mp,
|
171
|
+
rtol=1e-2, atol=1e-2)
|
172
|
+
|
173
|
+
np.testing.assert_allclose(self.sp.DCPF.pg.v.sum() * self.sp.config.mva,
|
174
|
+
np.array(self.mpres['case118']['DCPF']['pg']).sum(),
|
175
|
+
rtol=1e-2, atol=1e-2)
|
176
|
+
|
177
|
+
def test_PFlow_case118(self):
|
178
|
+
"""
|
179
|
+
Test power flow for case118.
|
180
|
+
"""
|
181
|
+
self.sp.PFlow.run()
|
182
|
+
np.testing.assert_allclose(self.sp.PFlow.aBus.v * rad2deg,
|
183
|
+
np.array(self.mpres['case118']['PFlow']['aBus']).reshape(-1),
|
184
|
+
rtol=1e-2, atol=1e-2)
|
185
|
+
np.testing.assert_allclose(self.sp.PFlow.vBus.v,
|
186
|
+
np.array(self.mpres['case118']['PFlow']['vBus']).reshape(-1),
|
187
|
+
rtol=1e-2, atol=1e-2)
|
188
|
+
np.testing.assert_allclose(self.sp.PFlow.pg.v.sum() * self.sp.config.mva,
|
189
|
+
np.array(self.mpres['case118']['PFlow']['pg']).sum(),
|
190
|
+
rtol=1e-2, atol=1e-2)
|
191
|
+
|
192
|
+
def test_DCOPF_case118(self):
|
193
|
+
"""
|
194
|
+
Test DCOPF for case118.
|
195
|
+
"""
|
196
|
+
self.sp.DCOPF.run(solver='CLARABEL')
|
197
|
+
self.assertAlmostEqual(self.sp.DCOPF.obj.v,
|
198
|
+
self.mpres['case118']['DCOPF']['obj'],
|
199
|
+
places=2)
|
200
|
+
np.testing.assert_allclose(self.sp.DCOPF.pi.v / self.sp.config.mva,
|
201
|
+
np.array(self.mpres['case118']['DCOPF']['pi']).reshape(-1),
|
202
|
+
rtol=1e-2, atol=1e-2)
|
203
|
+
|
204
|
+
def test_Matrices_case118(self):
|
205
|
+
"""
|
206
|
+
Test matrices for case118.
|
207
|
+
"""
|
208
|
+
ptdf = self.sp.mats.build_ptdf()
|
209
|
+
lodf = self.sp.mats.build_lodf()
|
210
|
+
|
211
|
+
ptdf_mp = load_ptdf(self.mpres, 'case118')
|
212
|
+
lodf_mp = load_lodf(self.mpres, 'case118')
|
213
|
+
|
214
|
+
ptdf[np.isnan(ptdf_mp)] = nan
|
215
|
+
lodf[np.isnan(lodf_mp)] = nan
|
216
|
+
|
217
|
+
np.testing.assert_allclose(ptdf, ptdf_mp,
|
218
|
+
equal_nan=True, rtol=1e-2, atol=1e-2)
|
219
|
+
|
220
|
+
np.testing.assert_allclose(lodf, lodf_mp,
|
221
|
+
equal_nan=True, rtol=1e-2, atol=10)
|
222
|
+
|
223
|
+
|
224
|
+
def load_ptdf(mpres, case):
|
225
|
+
"""
|
226
|
+
Load PTDF from mpres.
|
227
|
+
|
228
|
+
Parameters
|
229
|
+
----------
|
230
|
+
mpres : dict
|
231
|
+
The result dictionary.
|
232
|
+
case : str
|
233
|
+
The case name.
|
234
|
+
|
235
|
+
Returns
|
236
|
+
-------
|
237
|
+
ptdf : np.ndarray
|
238
|
+
The PTDF matrix.
|
239
|
+
"""
|
240
|
+
ptdf_data = np.array(mpres[case]['PTDF'])
|
241
|
+
ptdf = np.array([[0 if val == "_NaN_" else val for val in row] for row in ptdf_data],
|
242
|
+
dtype=float)
|
243
|
+
return ptdf
|
244
|
+
|
245
|
+
|
246
|
+
def load_lodf(mpres, case):
|
247
|
+
"""
|
248
|
+
Load LODF from mpres.
|
249
|
+
|
250
|
+
Parameters
|
251
|
+
----------
|
252
|
+
mpres : dict
|
253
|
+
The result dictionary.
|
254
|
+
case : str
|
255
|
+
The case name.
|
256
|
+
|
257
|
+
Returns
|
258
|
+
-------
|
259
|
+
lodf : np.ndarray
|
260
|
+
The LODF matrix.
|
261
|
+
"""
|
262
|
+
lodf_data = np.array(mpres[case]['LODF'])
|
263
|
+
lodf = np.array([[nan if val in ["_NaN_", "-_Inf_", "_Inf_"] else val for val in row] for row in lodf_data],
|
264
|
+
dtype=float)
|
265
|
+
# NOTE: force the diagonal to be -1
|
266
|
+
np.fill_diagonal(lodf, -1)
|
267
|
+
return lodf
|