can i decide the RL agents actions

3 Ansichten (letzte 30 Tage)
Sourabh
Sourabh am 2 Sep. 2023
Kommentiert: Sourabh am 28 Okt. 2023
I am training a PPO agent and issue is it keeps on searching for a better value even after reaching close to stable state.
what i mean is I want my agent to keep applying last action values as soon as the error values reaches <= 0.05 (to prevent oscillations and offset near the set point as shown in shared image.)
my question is can i do it in matlab because i know you can do it in python for sure. any help would be really really helpfull :)
  3 Kommentare
Sourabh
Sourabh am 3 Sep. 2023
actually i saw it in a IEEE paper and when i asked that guy he told me he was using python.
I dont have any code with me right now but surely there can be a way to decide the action of my agent i feel.
Sourabh
Sourabh am 4 Sep. 2023
okay i might get some code after a week or so
but all i want is to limit the actions of my PPO agent to settle after some time, not act like as shown in image attached.

Melden Sie sich an, um zu kommentieren.

Antworten (2)

Sam Chak
Sam Chak am 4 Sep. 2023
I believe that it has something to do with the StopTrainingCriteria and StopTrainingValue options of your rlTrainingOptions object. Is the condition "steady-state error ≤ 0.05" reflected in the training termination condition? Typically, the agent will continue to train until MaxEpisodes is reached when the stopping condition is not satisfied.
maxepisodes = 6000;
maxsteps = 150;
trainingOpts = rlTrainingOptions(...
'MaxEpisodes', maxepisodes,...
'MaxStepsPerEpisode', maxsteps,...
'ScoreAveragingWindowLength', 5, ...
'Verbose', false,...
'Plots', 'training-progress',...
'StopTrainingCriteria', 'AverageReward',...
'StopTrainingValue', 1500);
Also, please note that the rewards obtained by the final agents are not necessarily the greatest achieved during the training episodes. You need to save the agents that meet the "steady-state error ≤ 0.05" condition during training by specifying the SaveAgentCriteria and SaveAgentValue properties in the rlTrainingOptions object.
See also:
  2 Kommentare
Sourabh
Sourabh am 4 Sep. 2023
then y r DDPG and TD3 agents working fine?
it has nothing to do with stop training criteria. i just want to settle my agent outputs to previous value as soon as error value reaches 0.05 in training episode.
Sourabh
Sourabh am 28 Okt. 2023

Melden Sie sich an, um zu kommentieren.


Emmanouil Tzorakoleftherakis
Bearbeitet: Emmanouil Tzorakoleftherakis am 25 Sep. 2023
It seems like the paper you saw uses some logic to implement the behavior you mention. You could do the same with an if statement in MATLAB.
  1 Kommentar
Sourabh
Sourabh am 26 Sep. 2023
you mean in my script or in my environment.
like can u give an example

Melden Sie sich an, um zu kommentieren.

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by