import torch
import torch.nn as nn
import torch.nn.functional as F

from .rnn_cnn_generative_listener import RNNCNNGenerativeListener
from ..networks import choose_architecture, layer_init, hasnan, BetaVAE


class LSTMCNNGenerativeListener(RNNCNNGenerativeListener):
    def __init__(self,
                 kwargs, 
                 obs_shape, 
                 vocab_size=100, 
                 max_sentence_length=10, 
                 agent_id='l0', 
                 logger=None):
        """
        :param obs_shape: tuple defining the shape of the stimulus following `(nbr_distractors+1, nbr_stimulus, *stimulus_shape)`
                          where, by default, `nbr_distractors=1` and `nbr_stimulus=1` (static stimuli). 
        :param vocab_size: int defining the size of the vocabulary of the language.
        :param max_sentence_length: int defining the maximal length of each sentence the speaker can utter.
        :param agent_id: str defining the ID of the agent over the population.
        :param logger: None or somee kind of logger able to accumulate statistics per agent.
        """
        super(LSTMCNNGenerativeListener, self).__init__(
            obs_shape=obs_shape, 
            vocab_size=vocab_size, 
            max_sentence_length=max_sentence_length, 
            agent_id=agent_id, 
            logger=logger, 
            kwargs=kwargs,
            rnn_type='lstm',
        )
        