"""
Base encoder module for multimodal feature extraction.

This module provides the abstract base class for different types of encoders
that extract features from various modalities such as audio, video, and text.
"""

import torch
from torch import nn


class BaseEncoder(nn.Module):
    """
    Abstract base class for multimodal feature encoders.
    
    This class defines the common interface and utilities for encoder modules
    that process different input modalities and extract meaningful representations
    for downstream multimodal learning tasks.
    """
    
    def __init__(self, encoders_configs, device):
        """
        Initialize the base encoder with common configurations.
        
        Args:
            encoders_configs (dict): Configuration parameters for the encoder
            device (torch.device or str): Device for computation (CPU/GPU)
        """
        super(BaseEncoder, self).__init__()
        self.device = device
        self.seg_len = encoders_configs.get('seg_len', 10)  # Segment length in seconds
        self.cache_dir = encoders_configs.get('cache_dir', './cache')  # Cache directory for models
        
    def freeze(self, model):
        """
        Freeze all parameters of the given model to prevent training updates.
        
        This method sets requires_grad=False for all parameters and puts the model
        in evaluation mode, useful for feature extraction without fine-tuning.
        
        Args:
            model (nn.Module): The model to freeze
        """
        for name, param in model.named_parameters():
            param.requires_grad = False
        model.eval()
        
    def encode(self, inputs):
        """
        Abstract method for encoding inputs into feature representations.
        
        This method should be implemented by subclasses to define the specific
        encoding strategy for their respective modalities.
        
        Args:
            inputs: Input data to be encoded (format depends on modality)
            
        Returns:
            torch.Tensor: Encoded feature representations
            
        Raises:
            NotImplementedError: This method must be implemented by subclasses
        """
        raise NotImplementedError("Subclasses must implement the encode method")
    