from RoboMemory.VariableManager.GlobalVariableManager import GlobalVariableManager

class ALFERDVariableManager(GlobalVariableManager):
    def __init__(self):
      
        super().__init__()
        
        #   (     )
        self.task = None
        
        #     
        self.global_step = 0
        self.current_img = None
        self.score = 0
        self.done = False
        self.current_info = None
        self.truncated = False
        
        #         
        self.rewards = []
        
        # info        
        self.task_success = 0
        self.task_progress = 0.0
        self.env_feedback_info = "task started"
        
        
        # actor  
        self.actor_CoT = None
        self.subgoal = None
        self.action_plan = None
        
        # critic  
        self.critic_CoT = None
        self.action_suitability = True #        True
        self.critic_reflection = None
        
        #   /AC    
        self.current_action = None
        self.action_list = []
        
        #   /AC      
        self.last_action = "No action, the task has just started."
        self.last_env_feedback_info = None
        
        # Memory   
        self.current_belief : dict[str, str] = {"TemporalShortTermMemory": "No belief yet."}
        
        # infoprocess   
        self.current_step_summary = None
        self.current_spatial_queries : str = None # spatial querys
        self.current_semantic_queries : str = None # semantic querys
        self.current_episodic_queries : str = None # episodic querys
        
        # Log   
        self.actor_params = None
        self.actor_return = None
        self.critic_params = None
        self.critic_return = None
        
        #       
        self.max_progress = -1
        self.run_time = -1
        
        
    def __ensure_exist(self, variable: str):
      
        if not hasattr(self, variable):
            raise AttributeError(f"Variable '{variable}' does not exist.")
        return variable
        
        
        
    def __preprocess(self, **kwargs):
      
        
        if self.__ensure_exist('env_feedback_info') in kwargs:
            self.last_env_feedback_info = self.env_feedback_info 
        
    def __postprocess(self, **kwargs):
      
        if self.__ensure_exist('score') in kwargs:
            self.rewards.append(self.score)
        
        if self.__ensure_exist('current_action') in kwargs:    
            self.action_list.append(self.current_action)
            self.last_action = self.current_action #        last action   current action         
            
        if self.__ensure_exist('current_info') in kwargs:
            if self.global_step == 0:
                self.task = self.current_info['instruction']
                
            if self.global_step > 0: #         > 0         feedback 
                if 'env_feedback' in self.current_info:  
                    self.env_feedback_info = self.current_info['env_feedback']
                if 'task_success' in self.current_info:  
                    self.task_success = self.current_info['task_success']
                if 'task_progress' in self.current_info:  
                    self.task_progress = self.current_info['task_progress']
                    if self.task_progress > self.max_progress:
                        self.max_progress = self.task_progress #       
        
    def update_variables(self, **kwargs):
     
        
        self.__preprocess(**kwargs)
        
        super().update_variables(**kwargs)
        
        #                    
        self.__postprocess(**kwargs)