Embodiments described herein relate to methods and apparatuses for controlling a multi-agent reinforcement learning environment.
Reinforcement learning (RL) is an area of machine learning (ML) concerned with how software agents ought to take actions in an environment in order to maximize the notion of cumulative reward. RL is a technique which finds many uses in different applications. An agent may be configured to find an optimal policy to take actions in order to obtain a high reward from the environment it is interacting with.
RL assumes the underlying process is stochastic and follows Markov Decision Process. In Markov Decision Process it is assumed that the current state of the system depends only on one past previous state and not on all previous states. The underlying process is called a “model” in the RL context. Quite often, the underlying model of the system is unknown. In these cases, model-less RL methods such as Q-learning, SARSA etc may be used. There are two functions in RL what are known as a policy function and a value function. The policy function may be described as defining a mapping from perceived states of the environment to actions to be taken when in those states. The value function may be described as defining the expected return if you start in a state or state-action pair and then act according to the policy function thereafter. In many cases the user may specify the value function as computing may not be easy for the system with many actions and states. In some examples, a neural network (deep model) can be used to approximate the value function. This is known as deep RL.
The skilled person will be familiar with neural networks, but in brief, neural networks are a type of supervised machine learning model that can be trained to predict a corresponding output for given input data. Neural networks are trained by providing training data comprising example input data and the corresponding “correct” or ground truth outcome that is desired. Neural networks comprise a plurality of neurons, each neuron representing a mathematical operation that is applied to the input data. The neurons are arranged in a sequential structure such as a layered structure, whereby the output of neurons in each layer in the neural network is fed into the next layer in the sequence to produce an output. The neurons are associated with weights (or parameters) and biases which describe how and when each neuron “fires”. During training, the weights and biases associated with the neurons are adjusted (e.g. using techniques such as backpropagation and gradient descent) until the optimal weightings are found that produce predictions for the training examples that best reflect the corresponding ground truths.
The neural network here takes the states as input and outputs a Q-value for action. A Q-value illustrates how good a certain action is, given a state, for an agent following a policy function. The optimal Q-value function (Q*) describes a maximum return achievable from a given state-action pair by any policy function.
Based on the output Q-value for each available action, the agent will select an action which generates high reward (i.e. has a high Q-value). Here the neural network may be updated based on the actual reward obtained and expected reward. The network is trained when the agent reaches terminal state or number of episodes completed or for a fixed batch size.
In a multi-agent scenario, different agents participate together and work either collaboratively or competitively. A competitive environment is one in which each local agent has its own goals, and those goals may not be complementary to each other in all states.
Most problems in multi-agent environments are more complex than the linear graphical analysis expressed in
A recent paper “Social Influence as Intrinsic Motivation for Multi-Agent Deep Reinforcement Learning” by Natasha Jaques et al of MIT (https://arxiv.orq/abs/1810.08647) attempts to solve the problem by determining the causal influence of one agent's actions on other agents' actions. While this is interesting, often the causal influence may not be visible or is non-existent. For example, if one agent tries to optimize throughput and another agent tries to optimize interference, it may not be possible to find a causal relationship between the two actions or rewards.
Also, for the case of many agents, drawing Pareto curve to determine the weightings is difficult and requires extreme knowledge of the system.
According to some embodiments there is provided a computer-implemented method of determining a controlling a multi-agent reinforcement learning environment. The method comprising obtaining a plurality of loss functions comprising: a first loss function associated with a first reinforcement learning, RL, model performed by a first local agent, wherein the first loss function is a function of one or more first parameters; and a second loss function associated with a second RL model at a second local agent, wherein the second loss function is a function of one or more second parameters; determining a combined loss function based on the plurality of loss functions; minimizing the combined loss function with respect to the first parameters and the second parameters to determine updated values for the first parameters and updated values for the second parameters; initiating execution of a first updated action by the first local agent based on the updated values of the first parameters; and initiating execution of a second updated action by the second local agent based on the updated values of the second parameters.
According to some embodiments there is provided a method in a local agent, wherein the local agent is configured to perform a reinforcement learning, RL, model in an environment. The method comprises transmitting, to a global agent, either a loss function associated with the RL model or a replay experience of the agent, wherein the replay experience comprises a state, an action, a reward and a next state, wherein the action is determined based on a maximum Q-value for the state given current values of parameters of the environment; transmitting current values of the parameters to the global agent; receiving updated values of the parameters from the global agent; determining an updated action based on the updated values of the parameters; and performing the updated action.
According to some embodiments there is provided a global agent for controlling a multi-agent reinforcement learning environment. The global agent comprises processing circuitry configured to obtain a plurality of loss functions comprising: a first loss function associated with a first reinforcement learning, RL, model performed by a first local agent, wherein the first loss function is a function of one or more first parameters; and a second loss function associated with a second RL model at a second local agent, wherein the second loss function is a function of one or more second parameters; determine a combined loss function based on the plurality of loss functions; minimize the combined loss function with respect to the first parameters and the second parameters to determine updated values for the first parameters and updated values for the second parameters; initiate execution of a first updated action by the first local agent based on the updated values of the first parameters; and initiate execution of a second updated action by the second local agent based on the updated values of the second parameters.
According to some embodiments there is provided a local agent, wherein the local agent is configured to perform a reinforcement learning, RL, model in an environment. The local agent comprises processing circuitry configured to: transmit, to a global agent, either a loss function associated with the RL model or a replay experience of the agent, wherein the replay experience comprises a state, an action, a reward and a next state, wherein the action is determined based on a maximum Q-value for the state given current values of parameters of the environment; transmit current values of the parameters to the global agent; receive updated values of the parameters from the global agent; determine an updated action based on the updated values of the parameters; and perform the updated action.
The embodiments described above enable for the handling of multiple RL environments, and the trade of between the goals of the multiple agents by converting the multiple RL optimization problems into a single optimization problem that can be solved centrally.
Generally, all terms used herein are to be interpreted according to their ordinary meaning in the relevant technical field, unless a different meaning is clearly given and/or is implied from the context in which it is used. All references to a/an/the element, apparatus, component, means, step, etc. are to be interpreted openly as referring to at least one instance of the element, apparatus, component, means, step, etc., unless explicitly stated otherwise. The steps of any methods disclosed herein do not have to be performed in the exact order disclosed, unless a step is explicitly described as following or preceding another step and/or where it is implicit that a step must follow or precede another step. Any feature of any of the embodiments disclosed herein may be applied to any other embodiment, wherever appropriate. Likewise, any advantage of any of the embodiments may apply to any other embodiments, and vice versa. Other objectives, features and advantages of the enclosed embodiments will be apparent from the following description.
For a better understanding of the embodiments of the present disclosure, and to show how it may be put into effect, reference will now be made, by way of example only, to the accompanying drawings, in which:
The following sets forth specific details, such as particular embodiments or examples for purposes of explanation and not limitation. It will be appreciated by one skilled in the art that other examples may be employed apart from these specific details. In some instances, detailed descriptions of well-known methods, nodes, interfaces, circuits, and devices are omitted so as not obscure the description with unnecessary detail. Those skilled in the art will appreciate that the functions described may be implemented in one or more nodes using hardware circuitry (e.g., analog and/or discrete logic gates interconnected to perform a specialized function, ASICs, PLAs, etc.) and/or using software programs and data in conjunction with one or more digital microprocessors or general purpose computers. Nodes that communicate using the air interface also have suitable radio communications circuitry. Moreover, where appropriate the technology can additionally be considered to be embodied entirely within any form of computer-readable memory, such as solid-state memory, magnetic disk, or optical disk containing an appropriate set of computer instructions that would cause a processor to carry out the techniques described herein.
Hardware implementation may include or encompass, without limitation, digital signal processor (DSP) hardware, a reduced instruction set processor, hardware (e.g., digital or analogue) circuitry including but not limited to application specific integrated circuit(s) (ASIC) and/or field programmable gate array(s) (FPGA(s)), and (where appropriate) state machines capable of performing such functions.
Embodiments described herein use distributed learning based reinforcement learning, RL, to compute a trade-off between the local policy functions by creating and minimising a combined loss function. In some embodiments, the combined loss function also ensures the local agents do not try to attempt a conflicting action in the same state. Here, the local agents are assumed to find their own optimal policy by fitting a deep RL model. It will be appreciated that the term “local agent” is used herein to define any software or hardware utilised to implement a deep RL model.
The combined loss function is a single loss function which may be computed in a global agent in order to obtain a global optima. This converts multiple RL optimization problems into a single optimization problem. At every step of the iteration (or every N steps, where N is an integer), based on the combined loss function, individual action values are determined for each of the agents, and the actions are taken by agents. The trade-off is therefore obtained by solving both problems at same time. The method can be extended to any number of local agents easily as the computation may be performed in the cloud which can normally be assumed to be available.
In step 201, the method comprises obtaining a plurality of loss functions. The plurality of loss functions comprises a first loss function associated with a first reinforcement learning, RL, model performed by a first local agent, wherein the first loss function is a function of one or more first parameters; and a second loss function associated with a second RL model at a second local agent, wherein the second loss function is a function of one or more second parameters.
In some examples, the global agent may comprise one or more of the first local agent and the second local agent. In other words, in some examples the global agent may also perform one or both of the first RL model and the second RL model.
It will be appreciated that the plurality of loss functions may comprise any number of loss functions associated with RL models performed by respective local agents.
For example, the first loss function may be calculated based on a first replay experience of the first local agent, wherein the first replay experience comprises a first state, s1,t a first action, a1,t, a first reward, r1,t+1, and a first next state, s1,t+1. Similarly, the second loss function may be calculated based on a second replay experience of the second local agent. The second replay experience comprises a second state, s2,t a second action, a2,t, a second reward, r2,t+1, and a second next state, s2,t+1.
More generically, a replay experience from an ith agent (where i=1 . . . N, and N is an integer value) used to calculate a local loss function may be denoted (si,t, ai,t+1, si,t+1)
The first replay experience and the second replay experience may be sampled from replay buffers of the first local agent and the second local agent respectively.
For example, a local loss function for an ith agent may be calculated as (Qi,actual−Qi,pred)2, where Qi,actual is the target Q-value for the neural network of the agent, and Qi,pred is the predicted Q-value for the neural network of the agent.
In particular:
Q
i,actual
−{r
1,t+1+γia
where θi are the parameters (or weights) of the neural network of the agent i, and γi is a weighting factor. Adjusting the value of γi will diminish or increase the contribution of future rewards to the target Q-value.
In some examples, the global agent receives the values of the local loss functions (Qi,actual−Qi,pred)2 from the each ith agent. In some examples, the global agent receives the replay experiences (e.g. the first replay experience and the second replay experience) and network weights (θi) from the agents i and calculates the loss functions.
In step 202, the method comprises determining a combined loss function based on the plurality of loss functions.
For example, the combined loss function may comprise a sum of the plurality of loss functions.
In some examples, therefore, the combined loss function may be calculated as:
where Σi−1Nβi=1 and the weighting factors βi weight the contribution of the agents to the combined loss. The weighting factors βi can be either static values depending on the underlying Markov Decision Process, MDP, or may be dependent of rewards collected from past time step. It will be appreciated that in some examples, the agents sum may not be a weighted sum.
In step 203, the method comprises minimizing the combined loss function with respect to the first parameters and the second parameters to determine updated values for the first parameters and updated values for the second parameters. For example, step 203 may comprise performing gradient descent on the combined loss function, or any other suitable optimization method.
More generally, the combined loss function may be minimized with respect to the parameters θi for all agents i=1→N to determine updated values for the parameters θi,updated.
However, the local agents are taking concurrent actions and transitioning to new states without an explicit knowledge of what the next state-action pair of other local agents is.
It may therefore be beneficial to prevent the local agents planning to exploit the same state, as this would be sub-optimal and in many cases counter-productive (For example, you cannot increase and decrease the magnitude of a parameter at same time).
In some examples, therefore the combined loss function further comprises a regularization component, wherein the value of regularization component increases when the first next state, s1,t+1 and the second next state, s2,t+1, are closer together.
The regularization component therefore discourages the agents to arrive at a same belief state at the same time. By preventing the agents from arriving at the same belief state at the same time, the method can prevent the agents from colliding.
The regularization component may therefore tries to keep the states of the agents separate from each other throughout the iterations. In a warehouse robot example, this prevents the same robots from attempting to pick the same item and trying to move them to different racks (or even same racks).
For the example of two local agents the combined loss function may be calculated as:
Where,
is the regularisation component, δ is a regularisation weighting factor (in some cases the regularisation component is not weighted), and the distance d(s1,s2) between two states s1 and s2 may be calculated as:
d(s1,s2)=aϵAmax{|ras
Where ras
Based on this equation, for the first local agent and the second local agent, step 202 may therefore further comprise: determining the regularization component by determining a distance, d(s1,t+1, s2,t+1), between the first next state and the second next state by:
For each available action aϵA: calculating a reward difference, |ras
However, in some examples, the method then further comprises calculating a Kantorovich distance between the probability Ps
By including the underlying MDP process of all the states in the determination of the distance d(s1,t÷1, s2,t+1) greater differentiation between states is provided.
If d(s1,t+1, s2,t+1) is very small or nearly zero then the regularization component will have a high value and consequently the combined loss will be high. Hence given this expression, the minimization of the combined loss in step 203 will try to keep the states further apart and at the same time try to move Qi,pred closer to Ci,actual for both agents.
For N local agents, the combined loss function may be generalized as:
where
is the regularisation component, and
The Frobenius norm ensures all the distances are squared and summed. Since the distances are summed up twice the value is divided by 2 to ensure normalization.
In other words, in some examples the plurality of loss functions comprises N loss functions, where N is an integer, each associated with a respective RL model performed by an ith agent, where i=1, . . . , N, wherein the ith loss function is calculated based on a ith replay experience of the ith agent, wherein the ith replay experience comprises an state, an ith action, an ith reward and an ith next state. In this case, the step of determining the regularization component may comprise calculating distances between each combination of possible pairs of states in: the first next state to the Nth next state; calculating a Frobenius norm of a matrix comprising the distances; and setting the regularization component as a square of the Frobenius norm divided by 2.
In step 204, the method comprises initiating execution of a first updated action by the first local agent based on the updated values of the first parameters.
In step 205, the method comprises initiating execution of a second updated action by the second local agent based on the updated values of the second parameters.
In general, the method may comprise initiating execution of updated actions by all N agents based on the updated parameters θi,updated for i=1, . . . , N.
In some examples the global agent initiates execution of an ith updated action by transmitting the updated values of the ith parameters to the ith agent. The ith agent may then utilize the ith RL model with the ith updated parameters to execute the ith updated action. The updated replay experience of the ith agent may then be transmitted back to the global agent.
The global agent may then repeat the method as described with reference to
The updated local RL models with their terminal parameters may then be used to perform actions in real time.
There are N individual local agents 3001 to 300N which, in steps 301, 302, 303 transmit the current belief state information they are in, actions they took in the last time step and reward they obtained (e.g. the replay experience) to the global agent 320.
The N individual local agents 3001 to 300N also transmit the weights (parameters) θi of the deep RL network they have to the global agent in steps 304, 305 and 306. All this information may be transmitted to the global agent 320 which may be hosted, for example, in the cloud or common server.
In step 307 the global agent 320 computes the combined loss function for example as describe above with reference to
In steps 308, 309 and 310, the global agent 320 transmits updated weights back to the N individual local agents 3001 to 300N.
In steps 311, 312 and 313, the local agents 3001 to 300N will take the updated weights and execute updated actions computed using those updated weights. The local agents will then compute the next state information and will transmit the next relay experience to the global agent 320. The process may then repeat until a terminal state is reached.
In step 401, the local agent transmits, to a global agent, either a loss function associated with the RL model or a replay experience of the local agent, wherein the replay experience comprises a state, an action, a reward and a next state. The action is determined based on a maximum Q-value for the state given current values of parameters of the environment. For example, the parameters comprise the weights of a neural network of the RL model.
In step 402, the local agent transmits current values of the parameters to the global agent.
In step 403, the local agent receives updated values of the parameters from the global agent.
In step 404, the local agent determines an updated action based on the updated values of the parameters.
In step 405, the local agent performs the updated action.
It may be assumed that the plurality of agents are working towards the same global goal i.e. either in competing way or collaborating way. In some cases, the local goals of the agents are collaborating and in some cases the local goals of the agents are competitive. In this way, it may be ensured that there exists some correlation between agents at any time. If no correlation exists between some agents, in some examples, only the agents which have correlation are included in the combined loss function.
The proposed approach may be applied to three different perspectives:
1—Multiple Agents with Rewards in a Single Dimension Space, but Actions in Different Dimensions (i.e. Different Agents are Performing Different Actions)
In this perspective, each agent in the system has their own action space and state space. An example may be varying of different KPI's influence on the global state of the process. In this example, it can be seen that two KPI's may affect each other i.e. if one KPI increases, automatically another KPI decreases and vice versa. In this perspective there is only one single reward function which maps the whole system.
For example, consider Transmission Power and Tilt of Antenna in an antenna system. A first local agent may be configured to control a transmission power of an antenna to decrease a Signal-to-Interference-plus-Noise Ratio, SINR, of the antenna, and a second local agent is configuration to control a tilt of the antenna to decrease the SINR of the antenna.
Each agent may therefore receive a reward in terms of SINR decrease, but each agent may need to operate in such a way that action of both agents globally optimize the SINR. Therefore, by utilising the combined loss function, the SINR may be globally optimised.
Consider a different example in which a first local agent is configured to control radio access network counters to minimize handover rate in the radio access network, and a second local agent is configuration to control radio access network counters to maximize Reference Signal Received Power, RSRP, values in the network.
Overall, the global intent is to improve the performance of the tower. This global intent is translated to two local intents (i) RSRP and (ii) hand over rate. These are two local intents which are to be maintained at some specified level to maintain good performance. However, the local intents are contradicting to each other. For example, if the RSRP is increased, then it increases the handover rate of the network and vice versa. Hence, to improve the global performance of the local models the two conflicting parameters may need to be maintained at some specified level.
By utilising the combined loss function as described above, the local agents may try to maximize their individual performance i.e. the second local agent will try to maximize the RSRP (the local policy of the RSRP intent) and the first local agent will try to minimize the hand over rate (the local policy of the hand over rate intent).
To arrive at a state which fully satisfies both the policies is not possible. Hence, it may be desirable to find global state i.e. state of the entire system, as trade-off between these local systems.
In this case, the global system state is measured on the global performance of the state, for example, the value of the packet loss.
Now consider employing the method as described with reference to
The states of the first local agent is the handover rate, and the states of the second local agent is the value of RSRP. To simplify problem, the state space may be discretized for both the local agents. The action space may also be discretized for both the local agents.
Based on the experience replay, the two local deep RL problems are run locally. Further, with every iteration of the deep RL problems locally, the loss functions of the local models are sent to the global agent, and the combined loss function is calculated. The combined loss function is then minimised using the state information obtained from the local agents. Further, the global state information e.g. packet loss may also be obtained from the system and may be used to update the best action obtained from system. In some examples, the global state information may be included as a term in the combined loss function.
Both RSRP and handover rate depend on actions taken on Radio Access Network (RAN) counters. The available actions for both local agents may well have few counters in common. It may therefore be beneficial to ensure that the local agents do not modify the same counter and hence the regularisation component of the combined loss function comes into use.
Another aspect of the regularisation component is that it will prevent the local agents from coming to the same belief state. In this way, the local agents will be prevented from taking an action which takes the system back to a state which another local agent has already seen. This is achieved by encouraging the local agents to keep a distance between their belief states.
As previously mentioned, the state information in this example is the respective increase in the variables RSRP and Hand over rate. The actions are the values chosen for the RAN counters. In this case, the actions taken are binary: either an increase to the specific counter or a decrease. Without applying the method of
The use of the proposed method of
Another example is a Multi-Control Water tank system. In this example, it may be assumed that there exists an open water tank (opened to sky) and that the goal is to control both the level of the water in the tank, and the temperature of the water in the tank. Here there are two local agents which work independently to control the level and temperature of the tank.
However, there is interaction between these two local agents. For example, if temperature of the system starts decreasing, the local agent which monitors temperature may perform an action to switch on a heater. This action may result in more evaporation of the water inside tank and thus the level of the water decreases, negatively affecting the other local agent. In another case, if one local agent increases the level of the water, the temperature of the water may decrease, negatively affecting the other local agent and vice versa. In this way, the actions of the local agents are inter-linked with each other and can affect each-others performance in negative way.
In this example, for the temperature local agent the action space is {switch on heater, switch off heater} and the state space is {temperature greater than a predetermined threshold, temperature lower than a predetermined threshold}. For the water level agent, the action space is {switch on pump, switch off pump} and the state space is {level greater than a predetermined threshold, level lower than a predetermined threshold}.
The global reward is the summation of the closed loop control of water level and temperature systems.
As illustrated in
As described with reference to
In this way, the performance of both the local agents can be improved.
2—Multi—Agent but the Reward is in a Multiple Dimension Space Whilst the Actions are in Same Dimension (i.e. Different Local Agents Performing the Same Actions)
In this perspective, the system may be designed as a multi-agent problem with the system trying to optimize two goals, where the individual reward function is measured in different dimensions. Since there are a plurality of agents, the local agents may provide two different recommendations for an action, but only a single action can be employed. The reward is measured in multiple dimension space. For example, consider a car where one local agent is trying to optimise performance and another local agent is trying to optimise safety at same time. The action is limited to either pressing the gas pedal or pressing the brake. Which action to take may be decided based on a global agent and not by the individual local agents. Of course, both objectives may be competing with each other, and the global reward may be measured by optimizing the reward function across both dimensions e.g. in terms of performance and safety.
The aforementioned problem may also be considered as a single agent performing one action, but where the single agent has to satisfy two different competing conditions. For example, if we want to drive the car with high speed but safely, we can perform single action i.e. input to the vehicle and however the reward is measured in two different tasks.
The car is attempting to travel from a starting point 602 to the destination 601 in a minimum number of time steps. In each of the time steps, the car either go forward, go backwards or be idle. The car has a minimum engine power and has to go backwards up the first mountain 603 to climb the second mountain 604 as high as possible. Of course, with every time step, it will consume more fuel and another objective is to reach the destination using a minimum amount of fuel.
The global goal is therefore to reach the destination in the fastest possible time with the minimum fuel consumption. Of course, these two objectives are conflicting and therefore the method of
The global reward is total reward obtained in reaching destination. The first local agent 701 aims to reach destination quickly by moving the car backwards and then forwards until it reaches the destination. The second local agent 702 aims to stay idle since making a step backwards or forwards (when not in idle) consumes fuel.
According to method of
In a starting of episode the global reward is initialized to zero. For every action in a time step for first local agent 701 either to move forward, backward or idle, the reward from the first RL model is, for example, −1. For every reverse action (or forward action when not in idle) the reward from the second RL model is, for example, −1. Overall, the goal is to maximize the global reward of the system by satisfying both the first local agent and the second local agent requirements.
The first local agent 701 will try to move the car backwards as much as possible to start with to gain potential energy to reach the destination as quickly as possible. However, this implies negative reward for the second local agent 702 as it consumes more fuel. Hence, it may be desirable to obtain a trade-off between these local agents to obtain much higher global reward.
In this example, the single dimension action space is: Forward, Backward and idle. The state space is: Position, Velocity of the vehicle. The Global Reward is: Sum of fuel agent reward and destination agent reward.
To start the process, the local agents 701 and 702 transmit the replay experiences to the global agent 703 (in some examples, the local agents calculate the local loss functions (loss function 1 and loss function 2) and transmit the local loss functions to the global agent). The global agent 703 then determines the combined loss function.
The global agent 703 may then minimise the combined loss function as described with reference to
3—Multi Agent Having a Shared State Space, where the Action Space May or May not be Same, and the Reward is Measured in Same Dimension.
In this context the overall state space available to the local agents may be same or partially same. The rewards are also measured in same dimension. Hence there may be a need to optimize the total cost and plan efficiently so as to exploit the rewards collaboratively without competing for them.
An example of this scenario is illustrated in
Imagine a warehouse where items are to be moved from the floor of the warehouse to shelving 802 or to transportation 803 where they are to be arranged in racks.
The robots 801a to 801c are aware of the items lying on the floor of the warehouse by the use of sensors, and the robots then each use a local RL model to plan to put the objects into the racks in the minimum possible time expending the minimum amount of energy. Therefore, each robot gets a certain positive reward for putting an item in the rack, and a small negative reward for each step taken (given energy is expended). In this example therefore both the first local agent (in one robot) and the second local agent (in another robot) have the same or similar local RL models with the same aim.
The global goal is for the robots to collectively put all the boxes in the racks in fastest possible way whilst expending the minimum amount of total energy. Whilst individual robots may need to be efficient, it may also be beneficial to ensure that each robot does not attempt to pick up an object at the same time as another robot. Also, by utilising heuristics, it may be possible to keep the robots as far apart as possible so that they can collectively scan the as much of the room as possible in any time instance. Here the overall reward would be optimized by combined loss function which tries to reduce the number of items on the floor while at the same time the regularisation component ensures the robots do not come close to each other and do not exploit the same location (which would be sub-optimal). In other words, the regularisation component ensures that the robots do not enter the same state and attempt to execute a common action from that state.
5G Slicing Examples
In 5G slicing each network slice may be controlled by a local agent. Each local agent may try to obtain as many resources as possible to meet the requirements of the slice. But utilizing the claimed invention to solve a combined loss function for a plurality of network slices, a trade-off between the services provided by the slices can be achieved.
Briefly, the processing circuitry 901 of the global agent 900 is configured to: obtain a plurality of loss functions comprising: a first loss function associated with a first reinforcement learning, RL, model performed by a first local agent, wherein the first loss function is a function of one or more first parameters; and a second loss function associated with a second RL model at a second local agent, wherein the second loss function is a function of one or more second parameters; determine a combined loss function based on the plurality of loss functions; minimize the combined loss function with respect to the first parameters and the second parameters to determine updated values for the first parameters and updated values for the second parameters; initiate execution of a first updated action by the first local agent based on the updated values of the first parameters; and initiate execution of a second updated action by the second local agent based on the updated values of the second parameters.
In some embodiments, the global agent 900 may optionally comprise a communications interface 902. The communications interface 902 of the global agent 900 can be for use in communicating with other nodes, such as other virtual nodes. For example, the communications interface 902 of the global agent 900 can be configured to transmit to and/or receive from other nodes requests, resources, information, data, signals, or similar. The processing circuitry 901 of global agent 900 may be configured to control the communications interface 902 of the global agent 900 to transmit to and/or receive from other nodes requests, resources, information, data, signals, or similar.
Optionally, the global agent 900 may comprise a memory 903. In some embodiments, the memory 903 of the global agent 900 can be configured to store program code that can be executed by the processing circuitry 901 of the global agent 900 to perform the method described herein in relation to the global agent 900. Alternatively, or in addition, the memory 903 of the global agent 900, can be configured to store any requests, resources, information, data, signals, or similar that are described herein. The processing circuitry 901 of the global agent 900 may be configured to control the memory 903 of the global agent 900 to store any requests, resources, information, data, signals, or similar that are described herein.
Briefly, the processing circuitry 1001 of the local agent 1000 is configured to: transmit, to a global agent, either a loss function associated with the RL model or a replay experience of the agent, wherein the replay experience comprises a state, an action, a reward and a next state, wherein the action is determined based on a maximum Q-value for the state given current values of parameters of the environment; transmit current values of the parameters to the global agent; receive updated values of the parameters from the global agent; determine an updated action based on the updated values of the parameters; and perform the updated action.
In some embodiments, the local agent 1000 may optionally comprise a communications interface 1002. The communications interface 1002 of the local agent 1000 can be for use in communicating with other nodes, such as other virtual nodes. For example, the communications interface 1002 of the local agent 1000 can be configured to transmit to and/or receive from other nodes requests, resources, information, data, signals, or similar. The processing circuitry 1001 of local agent 1000 may be configured to control the communications interface 1002 of the local agent 1000 to transmit to and/or receive from other nodes requests, resources, information, data, signals, or similar.
Optionally, the local agent 1000 may comprise a memory 1003. In some embodiments, the memory 1003 of the local agent 1000 can be configured to store program code that can be executed by the processing circuitry 1001 of the local agent 1000 to perform the method described herein in relation to the local agent 1000. Alternatively, or in addition, the memory 1003 of the local agent 1000, can be configured to store any requests, resources, information, data, signals, or similar that are described herein. The processing circuitry 1001 of the local agent 1000 may be configured to control the memory 1003 of the local agent 1000 to store any requests, resources, information, data, signals, or similar that are described herein.
Embodiments described herein therefore provide methods and apparatuses to solve multi-objective RL problem which can solve two or more local agents simultaneously to obtain trade-off between two or more local agents. Furthermore, some embodiments described herein provide a combined loss function having a regularisation component designed to handle conflicting situations among local agents.
It should be noted that the above-mentioned embodiments illustrate rather than limit the invention, and that those skilled in the art will be able to design many alternative embodiments without departing from the scope of the appended claims. The word “comprising” does not exclude the presence of elements or steps other than those listed in a claim, “a” or “an” does not exclude a plurality, and a single processor or other unit may fulfil the functions of several units recited in the claims. Any reference signs in the claims shall not be construed so as to limit their scope.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/IN2020/051039 | 12/22/2020 | WO |