How to set the state with different variables in properties?
    4 visualizaciones (últimos 30 días)
  
       Mostrar comentarios más antiguos
    
    Yang Chen
 el 5 de Mzo. de 2023
  
    
    
    
    
    Respondida: Emmanouil Tzorakoleftherakis
    
 el 6 de Mzo. de 2023
            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 comentarios
Respuesta aceptada
  Emmanouil Tzorakoleftherakis
    
 el 6 de Mzo. de 2023
        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 comentarios
Más respuestas (1)
  Luca Ferro
      
 el 6 de Mzo. de 2023
        
      Editada: Luca Ferro
      
 el 6 de Mzo. de 2023
  
      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
Ver también
Categorías
				Más información sobre Deep Learning Toolbox en Help Center y File Exchange.
			
	Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!


