agentlib_mpc.modules.dmpc.admm package
Submodules
agentlib_mpc.modules.dmpc.admm.admm module
Holds functionality for ADMM modules.
- class agentlib_mpc.modules.dmpc.admm.admm.ADMM(config: dict, agent)[source]
Bases:
DistributedMPC
This class represents a module participating in a fully decentralized Consensus-ADMM optimization for distributed MPC. Agents autonomously send the values of their coupling variables, register other participants and perform update steps.
- all_coupling_statuses() Iterable[ADMMParticipation] [source]
Gives and iterator of all ADMMParticipation that are registered.
- assert_mpc_variables_are_in_model()[source]
Checks whether all variables of var_ref are contained in the model. Returns names of model variables not contained in the var_ref, sorted by keys: ‘states’, ‘inputs’, ‘outputs’, ‘parameters’.
- collect_couplings_for_optimization()[source]
Collects updated AgentVariables only of the coupling variables.
- collect_variables_for_optimization(var_ref: VariableReference = None) dict[str, agentlib.core.datamodels.AgentVariable] [source]
Gets all variables noted in the var ref and puts them in a flat dictionary.
- property cons_and_exchange: List[ExchangeEntry | CouplingEntry]
- deregister_all_participants()[source]
Sets the participating status of all participating agents to False.
- get_participants_values(coupling_alias: str) List[Series] [source]
Get the values of all agents for a coupling variable.
- get_results() DataFrame | None [source]
Read the results that were saved from the optimization backend and returns them as Dataframe.
- Returns:
(results, stats) tuple of Dataframes.
- participant_callback(variable: AgentVariable)[source]
Puts received variables in the correct queue, depending on registration status of this agent.
- property penalty_factor_var: MPCVariable
- process()[source]
This abstract method must be implemented in order to sync the module with the other processes of the agent and the whole MAS.
- receive_participant(variable: AgentVariable)[source]
Set the participation to true for the given coupling input.
- property registered_participants: Dict[str, Dict[str, ADMMParticipation]]
Dictionary containing all other agents this agent shares variables with. Ordered in a two-layer form, with variables at the first layer and agents at the second layer. Contains ADMMParticipation objects at the base layer.
Examples
self.registered_participants = {‘coupling_var_1’: {‘src_of_agent1’: status_1,
‘src_of_agent2’: status_2, ‘src_of_agent3’: status_3}
- ‘coupling_var_1’: {‘src_of_agent3’: status_a,
‘src_of_agent2’: status_b, ‘src_of_agent4’: status_c}
} here, <status> refers to an ADMMParticipation object.
- send_coupling_values(solution: Results)[source]
Sets the coupling outputs to the data_broker, which automatically sends them.
- Parameters:
solution – Output dictionary from optimization_backend.solve().
- send_coupling_variable(name: str, value: int | float | list[Union[int, float]] | Series | ndarray)[source]
Sends an admm coupling variable through the data_broker and sets its value locally
- update_lambda()[source]
Performs the update of the lagrange multipliers. lambda^k+1 := lambda^k - rho*(z-x_i)
- var_ref: VariableReference
- pydantic model agentlib_mpc.modules.dmpc.admm.admm.ADMMConfig[source]
Bases:
DistributedMPCConfig
- Config:
arbitrary_types_allowed: bool = True
validate_assignment: bool = True
extra: str = forbid
frozen: bool = True
- Fields:
- Validators:
check_valid_fields
»shared_variable_fields
check_valid_level
»log_level
- field controls: mpc_datamodels.MPCVariables = []
List of all control variables of the MPC.
- Validated by:
- field couplings: List[MPCVariable] = []
- Validated by:
- field exchange: List[MPCVariable] = []
- Validated by:
- field inputs: mpc_datamodels.MPCVariables = []
List of all input variables of the MPC. Includes predictions for disturbances, set_points, dynamic constraint boundaries etc.
- Validated by:
- field iteration_timeout: float = 20
Maximum computation + waiting time for one iteration.
- Constraints:
ge = 0
- field log_level: str | None = None
The log level for this Module. Default uses the root-loggers level.Options: DEBUG; INFO; WARNING; ERROR; CRITICAL
- Validated by:
check_valid_level
- field max_iterations: float = 20
Maximum number of ADMM iterations before termination of control step.
- Constraints:
ge = 0
- field module_id: str [Required]
The unqiue id of the module within an agent, used only to communicate withing the agent.
- field optimization_backend: dict [Required]
- field outputs: mpc_datamodels.MPCVariables = []
List of all shared outputs of the MPC.
- Validated by:
- field parameters: mpc_datamodels.MPCVariables = []
List of model parameters of the MPC. They are constant over the horizon. Parameters not listed here will have their default from the model file.
- Validated by:
- field penalty_factor: float = 10
Penalty factor of the ADMM algorithm. Should be equal for all agents.
- Constraints:
ge = 0
- field prediction_horizon: int = 5
Prediction horizon of the MPC.
- Constraints:
ge = 0
- field r_del_u: dict[str, float] = {}
Weights that are applied to the change in control variables.
- Validated by:
- field registration_period: float = 2
Time spent on registration before each optimization
- Constraints:
ge = 0
- field sampling_time: float | None = None
Sampling interval for control steps. If None, will be the same as time step. Does not affect the discretization of the MPC, only the interval with which there will be optimization steps.
- Validated by:
- field set_outputs: bool = False
Sets the full output time series to the data broker.
- Validated by:
check_valid_fields
- field states: mpc_datamodels.MPCVariables = []
List of all differential states of the MPC. The entries can define the boundaries and the source for the measurements
- Validated by:
- field time_step: float = 60
Time step of the MPC.
- Constraints:
ge = 0
- field type: str | Dict[str, str] [Required]
The type of the Module. Used to find the Python-Object from all agentlib-core and plugin Module options. If a dict is given,it must contain the keys ‘file’ and ‘class_name’. ‘file’ is the filepath of a python file containing the Module.’class_name’ is the name of the Module class within this file.
- field validate_incoming_values: bool | None = True
If true, the validator of the AgentVariable value is called when receiving a new value from the DataBroker.
- validator check_prefixes_of_variables » exchange, parameters, couplings, inputs, states, outputs, controls[source]
Ensures no user provided variable is named with the reserved ADMM prefix.
- model_post_init(context: Any, /) None
We need to both initialize private attributes and call the user-defined model_post_init method.
- class agentlib_mpc.modules.dmpc.admm.admm.ADMMParticipation(variable)[source]
Bases:
object
Holds data for the status of a shared variable of another system.
- class agentlib_mpc.modules.dmpc.admm.admm.LocalADMM(config: dict, agent)[source]
Bases:
ADMM
- process()[source]
This abstract method must be implemented in order to sync the module with the other processes of the agent and the whole MAS.
- property registration_delay: float
Timeout value used to wait one on registration. Waits in real time (time.sleep)
- property sync_delay: float
Timeout value used to sync local admm processes. Should be very small.
- pydantic model agentlib_mpc.modules.dmpc.admm.admm.LocalADMMConfig[source]
Bases:
ADMMConfig
- Config:
arbitrary_types_allowed: bool = True
validate_assignment: bool = True
extra: str = forbid
frozen: bool = True
- Fields:
- Validators:
check_valid_fields
»shared_variable_fields
check_valid_level
»log_level
- field controls: mpc_datamodels.MPCVariables = []
List of all control variables of the MPC.
- Validated by:
- field couplings: List[mpc_datamodels.MPCVariable] = []
- Validated by:
- field exchange: List[mpc_datamodels.MPCVariable] = []
- Validated by:
- field inputs: mpc_datamodels.MPCVariables = []
List of all input variables of the MPC. Includes predictions for disturbances, set_points, dynamic constraint boundaries etc.
- Validated by:
- field iteration_timeout: float = 20
Maximum computation + waiting time for one iteration.
- Constraints:
ge = 0
- field log_level: str | None = None
The log level for this Module. Default uses the root-loggers level.Options: DEBUG; INFO; WARNING; ERROR; CRITICAL
- Validated by:
check_valid_level
- field max_iterations: float = 20
Maximum number of ADMM iterations before termination of control step.
- Constraints:
ge = 0
- field module_id: str [Required]
The unqiue id of the module within an agent, used only to communicate withing the agent.
- field optimization_backend: dict [Required]
- field outputs: mpc_datamodels.MPCVariables = []
List of all shared outputs of the MPC.
- Validated by:
- field parameters: mpc_datamodels.MPCVariables = []
List of model parameters of the MPC. They are constant over the horizon. Parameters not listed here will have their default from the model file.
- Validated by:
- field penalty_factor: float = 10
Penalty factor of the ADMM algorithm. Should be equal for all agents.
- Constraints:
ge = 0
- field prediction_horizon: int = 5
Prediction horizon of the MPC.
- Constraints:
ge = 0
- field r_del_u: dict[str, float] = {}
Weights that are applied to the change in control variables.
- Validated by:
- field registration_delay: float = 0.1
- field registration_period: float = 2
Time spent on registration before each optimization
- Constraints:
ge = 0
- field sampling_time: float | None = None
Sampling interval for control steps. If None, will be the same as time step. Does not affect the discretization of the MPC, only the interval with which there will be optimization steps.
- Validated by:
- field set_outputs: bool = False
Sets the full output time series to the data broker.
- Validated by:
check_valid_fields
- field states: mpc_datamodels.MPCVariables = []
List of all differential states of the MPC. The entries can define the boundaries and the source for the measurements
- Validated by:
- field sync_delay: float = 0.001
- field time_step: float = 60
Time step of the MPC.
- Constraints:
ge = 0
- field type: str | Dict[str, str] [Required]
The type of the Module. Used to find the Python-Object from all agentlib-core and plugin Module options. If a dict is given,it must contain the keys ‘file’ and ‘class_name’. ‘file’ is the filepath of a python file containing the Module.’class_name’ is the name of the Module class within this file.
- field validate_incoming_values: bool | None = True
If true, the validator of the AgentVariable value is called when receiving a new value from the DataBroker.
- model_post_init(context: Any, /) None
We need to both initialize private attributes and call the user-defined model_post_init method.
agentlib_mpc.modules.dmpc.admm.admm_coordinated module
Module implementing the coordinated ADMM module, which works together with a coordinator.
- class agentlib_mpc.modules.dmpc.admm.admm_coordinated.CoordinatedADMM(*, config: dict, agent: Agent)[source]
Bases:
MiniEmployee
,ADMM
Module to implement an ADMM agent, which is guided by a coordinator. Only optimizes based on callbacks.
- init_iteration_callback(variable: AgentVariable)[source]
Callback that answers the coordinators init_iteration flag.
- optimize(variable: AgentVariable)[source]
Performs the optimization given the mean trajectories and multipliers from the coordinator. Replies with the local optimal trajectories. Returns:
- pydantic model agentlib_mpc.modules.dmpc.admm.admm_coordinated.CoordinatedADMMConfig[source]
Bases:
MiniEmployeeConfig
,ADMMConfig
- Config:
arbitrary_types_allowed: bool = True
validate_assignment: bool = True
extra: str = forbid
frozen: bool = True
- Fields:
- Validators:
check_valid_fields
»shared_variable_fields
check_valid_level
»log_level
- field controls: mpc_datamodels.MPCVariables = []
List of all control variables of the MPC.
- Validated by:
- field coordinator: Source [Required]
Define the agents coordinator
- field couplings: List[mpc_datamodels.MPCVariable] = []
- Validated by:
- field exchange: List[mpc_datamodels.MPCVariable] = []
- Validated by:
- field inputs: mpc_datamodels.MPCVariables = []
List of all input variables of the MPC. Includes predictions for disturbances, set_points, dynamic constraint boundaries etc.
- Validated by:
- field iteration_timeout: float = 20
Maximum computation + waiting time for one iteration.
- Constraints:
ge = 0
- field log_level: str | None = None
The log level for this Module. Default uses the root-loggers level.Options: DEBUG; INFO; WARNING; ERROR; CRITICAL
- Validated by:
check_valid_level
- field max_iterations: float = 20
Maximum number of ADMM iterations before termination of control step.
- Constraints:
ge = 0
- field messages_in: AgentVariables = [AgentVariable(name='registration_coordinator_to_agent', type=None, timestamp=None, unit='Not defined', description='Not defined', ub=inf, lb=-inf, clip=False, allowed_values=[], value=None, alias='registration_coordinator_to_agent', source=Source(agent_id=None, module_id=None), shared=None, rdf_class=None), AgentVariable(name='startIteration_coordinator_to_agent', type=None, timestamp=None, unit='Not defined', description='Not defined', ub=inf, lb=-inf, clip=False, allowed_values=[], value=None, alias='startIteration_coordinator_to_agent', source=Source(agent_id=None, module_id=None), shared=None, rdf_class=None), AgentVariable(name='optimization_coordinator_to_agent', type=None, timestamp=None, unit='Not defined', description='Not defined', ub=inf, lb=-inf, clip=False, allowed_values=[], value=None, alias='optimization_coordinator_to_agent', source=Source(agent_id=None, module_id=None), shared=None, rdf_class=None)]
- field messages_out: AgentVariables = [AgentVariable(name='registration_agent_to_coordinator', type=None, timestamp=None, unit='Not defined', description='Not defined', ub=inf, lb=-inf, clip=False, allowed_values=[], value=None, alias='registration_agent_to_coordinator', source=Source(agent_id=None, module_id=None), shared=None, rdf_class=None), AgentVariable(name='startIteration_agent_to_coordinator', type=None, timestamp=None, unit='Not defined', description='Not defined', ub=inf, lb=-inf, clip=False, allowed_values=[], value=None, alias='startIteration_agent_to_coordinator', source=Source(agent_id=None, module_id=None), shared=None, rdf_class=None), AgentVariable(name='optimization_agent_to_coordinator', type=None, timestamp=None, unit='Not defined', description='Not defined', ub=inf, lb=-inf, clip=False, allowed_values=[], value=None, alias='optimization_agent_to_coordinator', source=Source(agent_id=None, module_id=None), shared=None, rdf_class=None)]
- field module_id: str [Required]
The unqiue id of the module within an agent, used only to communicate withing the agent.
- field optimization_backend: dict [Required]
- field outputs: mpc_datamodels.MPCVariables = []
List of all shared outputs of the MPC.
- Validated by:
- field parameters: mpc_datamodels.MPCVariables = []
List of model parameters of the MPC. They are constant over the horizon. Parameters not listed here will have their default from the model file.
- Validated by:
- field penalty_factor: float = 10
Penalty factor of the ADMM algorithm. Should be equal for all agents.
- Constraints:
ge = 0
- field prediction_horizon: int = 5
Prediction horizon of the MPC.
- Constraints:
ge = 0
- field r_del_u: dict[str, float] = {}
Weights that are applied to the change in control variables.
- Validated by:
- field registration_interval: float = 10
Interval in seconds after which a registration attempt is made.
- Constraints:
ge = 0
- field registration_period: float = 2
Time spent on registration before each optimization
- Constraints:
ge = 0
- field request_frequency: float = 1
Wait time between signup_requests
- field sampling_time: float | None = None
Sampling interval for control steps. If None, will be the same as time step. Does not affect the discretization of the MPC, only the interval with which there will be optimization steps.
- Validated by:
- field set_outputs: bool = False
Sets the full output time series to the data broker.
- Validated by:
check_valid_fields
- field states: mpc_datamodels.MPCVariables = []
List of all differential states of the MPC. The entries can define the boundaries and the source for the measurements
- Validated by:
- field time_step: float = 60
Time step of the MPC.
- Constraints:
ge = 0
- field type: str | Dict[str, str] [Required]
The type of the Module. Used to find the Python-Object from all agentlib-core and plugin Module options. If a dict is given,it must contain the keys ‘file’ and ‘class_name’. ‘file’ is the filepath of a python file containing the Module.’class_name’ is the name of the Module class within this file.
- field validate_incoming_values: bool | None = True
If true, the validator of the AgentVariable value is called when receiving a new value from the DataBroker.
- validator couplings_should_have_values » exchange, couplings[source]
Asserts that couplings and exchange have values, as they are needed for initial guess.
- model_post_init(context: Any, /) None
We need to both initialize private attributes and call the user-defined model_post_init method.
- agentlib_mpc.modules.dmpc.admm.admm_coordinated.coupInput
alias of
coup_input
agentlib_mpc.modules.dmpc.admm.admm_coordinator module
Defines classes that coordinate an ADMM process.
- class agentlib_mpc.modules.dmpc.admm.admm_coordinator.ADMMCoordinator(*, config: dict, agent: Agent)[source]
Bases:
Coordinator
- cleanup_results()[source]
Deletes all files this module created.
Override this method, if your module creates e.g. results files etc.
- optim_results_callback(variable: AgentVariable)[source]
Saves the results of a local optimization. :param variable:
Returns:
- pydantic model agentlib_mpc.modules.dmpc.admm.admm_coordinator.ADMMCoordinatorConfig[source]
Bases:
CoordinatorConfig
Hold the config for ADMMCoordinator
- Config:
arbitrary_types_allowed: bool = True
validate_assignment: bool = True
extra: str = forbid
frozen: bool = True
- Fields:
- Validators:
check_valid_fields
»shared_variable_fields
check_valid_level
»log_level
- field abs_tol: float = 0.001
Absolute stopping criterion.
- field admm_iter_max: int = 20
Maximum number of ADMM iterations before termination of control step.
- field dual_tol: float = 0.001
Absolute dual stopping criterion.
- field log_level: str | None = None
The log level for this Module. Default uses the root-loggers level.Options: DEBUG; INFO; WARNING; ERROR; CRITICAL
- Validated by:
check_valid_level
- field maxIter: int = 10
Maximum number of iterations
- field messages_in: AgentVariables = [AgentVariable(name='registration_agent_to_coordinator', type=None, timestamp=None, unit='Not defined', description='Not defined', ub=inf, lb=-inf, clip=False, allowed_values=[], value=None, alias='registration_agent_to_coordinator', source=Source(agent_id=None, module_id=None), shared=None, rdf_class=None), AgentVariable(name='startIteration_agent_to_coordinator', type=None, timestamp=None, unit='Not defined', description='Not defined', ub=inf, lb=-inf, clip=False, allowed_values=[], value=None, alias='startIteration_agent_to_coordinator', source=Source(agent_id=None, module_id=None), shared=None, rdf_class=None), AgentVariable(name='optimization_agent_to_coordinator', type=None, timestamp=None, unit='Not defined', description='Not defined', ub=inf, lb=-inf, clip=False, allowed_values=[], value=None, alias='optimization_agent_to_coordinator', source=Source(agent_id=None, module_id=None), shared=None, rdf_class=None)]
- field messages_out: AgentVariables = [AgentVariable(name='registration_coordinator_to_agent', type=None, timestamp=None, unit='Not defined', description='Not defined', ub=inf, lb=-inf, clip=False, allowed_values=[], value=None, alias='registration_coordinator_to_agent', source=Source(agent_id=None, module_id=None), shared=None, rdf_class=None), AgentVariable(name='startIteration_coordinator_to_agent', type=None, timestamp=None, unit='Not defined', description='Not defined', ub=inf, lb=-inf, clip=False, allowed_values=[], value=None, alias='startIteration_coordinator_to_agent', source=Source(agent_id=None, module_id=None), shared=None, rdf_class=None), AgentVariable(name='optimization_coordinator_to_agent', type=None, timestamp=None, unit='Not defined', description='Not defined', ub=inf, lb=-inf, clip=False, allowed_values=[], value=None, alias='optimization_coordinator_to_agent', source=Source(agent_id=None, module_id=None), shared=None, rdf_class=None)]
- field module_id: str [Required]
The unqiue id of the module within an agent, used only to communicate withing the agent.
- field penalty_change_factor: float = 2
Factor to vary the penalty parameter with.
- field penalty_change_threshold: float = -1
When the primal residual is x times higher, vary the penalty parameter and vice versa.
- field penalty_factor: float = 10
Penalty factor of the ADMM algorithm. Should be equal for all agents.
- field prediction_horizon: int = 10
Prediction horizon of participating agents.
- field primal_tol: float = 0.001
Absolute primal stopping criterion.
- field registration_period: float = 5
Time spent on registration before each optimization
- field rel_tol: float = 0.001
Relative stopping criterion.
- field sampling_time: float | None = None
Sampling interval for control steps. If None, will be the same as time step. Does not affect the discretization of the MPC, only the interval with which there will be optimization steps.
- Validated by:
- field save_iter_interval: int = 1000
- field save_solve_stats: bool = False
When True, saves the solve stats to a file.
- Validated by:
check_valid_fields
- field solve_stats_file: str = 'admm_stats.csv'
File name for the solve stats.
- Validated by:
- field time_out_non_responders: float = 1
Maximum wait time for subsystems in seconds
- field time_step: float = 600
Sampling interval of between two control steps. Will be used in the discretization for MPC.
- field type: str | Dict[str, str] [Required]
The type of the Module. Used to find the Python-Object from all agentlib-core and plugin Module options. If a dict is given,it must contain the keys ‘file’ and ‘class_name’. ‘file’ is the filepath of a python file containing the Module.’class_name’ is the name of the Module class within this file.
- field use_relative_tolerances: bool = True
If True, use abs_tol and rel_tol, if False us prim_tol and dual_tol.
- field validate_incoming_values: bool | None = True
If true, the validator of the AgentVariable value is called when receiving a new value from the DataBroker.
- field wait_time_on_start_iters: float = 0.1
wait_on_start_iterations
- validator default_sampling_time » sampling_time[source]
- model_post_init(context: Any, /) None
We need to both initialize private attributes and call the user-defined model_post_init method.
- validator solve_stats_file_is_csv » solve_stats_file[source]