How to set the state with different variables in properties?
3 次查看(过去 30 天)
显示 更早的评论
I am writing the custom reinforcement learning environment via template. I want to initialize state within properties. The following is from my current scripts. The scripts are based on the class called rl.env.MATLABEnvironment. The properties of this class can't accept the structure definition.
properties
% Initialize system state [schedule,ppath,completionTime,computeDuring]'
% schedule = [];
% ppath = [];
% completionTime = Inf;
% computeDuring = 0;
State = zeros(4,1)
end
However, I don't know how to definite State. In the above case, State consists of schedule, ppath, completionTime and computerDuring, where schedule and ppath are vectors, while completionTime and computerDuring are numbers. If I just define them as zeros(4,1), it doesn't work.
0 个评论
采纳的回答
Emmanouil Tzorakoleftherakis
2023-3-6
Hi Yang,
We have an example in Reinforcement Learning Toolbox that does training based on nonhomogeneous observations, and specifically a combination of scalars and images. This example is available as a predefined environment and you can actually check the code to see how we implemented it. If you do
edit rl.env.AbstractSimplePendlumWithImage
you will see that we create the state in the properties similar to what you do but this is only for the scalar states of the dynamical equations. The nonhomogeneous observations are passed internally as cell arrays starting from the 'reset' function.
Hope that helps
0 个评论
更多回答(1 个)
Luca Ferro
2023-3-6
编辑:Luca Ferro
2023-3-6
use a struct:
state.schedule= [];
state.path=[];
state.completionTime=Inf;
state.computerDuring=0;
this will create a struct with said fields. You can access them by using state.schedule, state.path etc
另请参阅
类别
在 Help Center 和 File Exchange 中查找有关 Environments 的更多信息
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!