from EscapeEnv.common.base_agent import BaseAgent
from EscapeEnv.boot_dqn.estimator import BootDQNEstimator
from EscapeEnv.common.torch_layers import EnsembleNet
from EscapeEnv.common.buffers import BaseBuffer

class BootDQN(BaseAgent):
    def __init__(self, 
                 env,
                 estimator_class=BootDQNEstimator, 
                 buffer_class=BaseBuffer,
                 network_class=EnsembleNet, 
                 **kwargs):
        super().__init__(env, estimator_class, buffer_class, network_class, **kwargs)
    def _build_network(self):
        self.network = self.network_class(n_heads=self.estimator_kwargs['n_heads'], input_size=self.state_dim, output_size=self.num_actions, net_arch=self.net_arch, activation_fn=self.activation_fn)
    
    def _build_estimator(self):
        self.q_estimator = self.estimator_class(self.network, self.batch_size, self.learning_rate, self.loops_per_train, optimizer_kwargs=self.optimizer_kwargs, estimator_kwargs=self.estimator_kwargs, device=self.device)
        
    def _build_buffer(self):
        self.buffer = self.buffer_class(size=self.buffer_size, batch_size=self.batch_size)
        
        
if __name__ == '__main__':
    pass