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.

admm_step()[source]

Performs an entire ADMM optimization.

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.

reset_participants_ready()[source]

Sets the ready status of all participating agents to False.

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:
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.

field shared_variable_fields: list[str] = ['outputs', 'controls']
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.

de_register()[source]
empty_memory()[source]
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:
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.

field shared_variable_fields: list[str] = ['outputs', 'controls']
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.

class agentlib_mpc.modules.dmpc.admm.admm.ModuleStatus(value, names=None, *, module=None, qualname=None, type=None, start=1, boundary=None)[source]

Bases: Enum

at_registration = 3
not_started = 1
optimizing = 4
sleeping = 7
syncing = 2
updating = 5
waiting_for_other_agents = 6
class agentlib_mpc.modules.dmpc.admm.admm.ParticipantStatus(value, names=None, *, module=None, qualname=None, type=None, start=1, boundary=None)[source]

Bases: Enum

available = 2
confirmed = 3
not_available = 4
not_participating = 1

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.

get_new_measurement()[source]

Retrieve new measurement from relevant sensors Returns:

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:

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.

registration_callback(variable: AgentVariable)[source]

callback for registration

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:
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.

field shared_variable_fields: list[str] = ['messages_out', 'outputs', 'controls']
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.

get_results() DataFrame[source]

Reads the results on iteration data if they were saved.

optim_results_callback(variable: AgentVariable)[source]

Saves the results of a local optimization. :param variable:

Returns:

register_agent(variable: AgentVariable)[source]

Registers the agent, after it sent its initial guess with correct vector length.

registration_callback(variable: AgentVariable)[source]
trigger_optimizations()[source]

Triggers the optimization for all agents with status ready. 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:
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.

field shared_variable_fields: list[str] = ['messages_out']
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]