class Param():
    
    def __init__(self, args):
        
        self.common_param = self._get_common_parameters(args)
        self.hyper_param = self._get_hyper_parameters(args)

    def _get_common_parameters(self, args):
        """
            padding_mode (str): The mode for sequence padding ('zero' or 'normal').
            padding_loc (str): The location for sequence padding ('start' or 'end'). 
            eval_monitor (str): The monitor for evaluation ('loss' or metrics, e.g., 'f1', 'acc', 'precision', 'recall').  
            need_aligned: (bool): Whether to perform data alignment between different modalities.
            train_batch_size (int): The batch size for training.
            eval_batch_size (int): The batch size for evaluation. 
            test_batch_size (int): The batch size for testing.
            wait_patience (int): Patient steps for Early Stop.
        """
        common_parameters = {
            'padding_mode': 'zero',
            'padding_loc': 'end',
            'need_aligned': False,
            'eval_monitor': 'f1',
            'train_batch_size': 16,
            'eval_batch_size': 8,
            'test_batch_size': 8,
            'wait_patience': 3,
            'concepts_path': {
                'train': [
                    'notations/MIntRec/filtered_scored_text_train.pt',
                    'notations/MIntRec/filtered_scored_audio_train.pt',
                    'notations/MIntRec/filtered_scored_video_train.pt'
                ],
                'dev': [
                    'notations/MIntRec/filtered_scored_text_dev.pt',
                    'notations/MIntRec/filtered_scored_audio_dev.pt',
                    'notations/MIntRec/filtered_scored_video_dev.pt'
                ],
                'test': [
                    'notations/MIntRec/filtered_scored_text_test.pt',
                    'notations/MIntRec/filtered_scored_audio_test.pt',
                    'notations/MIntRec/filtered_scored_video_test.pt'
                ]
            },
            'weight_path': {'paths':[
                'notations/MIntRec/text_concepts_relevants.json',
                'notations/MIntRec/audio_concepts_relevants.json',
                'notations/MIntRec/video_concepts_relevants.json'
            ]}
            
        }
        return common_parameters

    def _get_hyper_parameters(self, args):
        """
        Args:

        """
        
        hyper_parameters = {
            'num_train_epochs': 100,
            'num_epochs': 100,
            'num_warmup': 10,
            't_concept_num': 100,
            'a_concept_num': 100,
            'v_concept_num': 100,
            'num_head': 8,
            't_num_layers': 2,
            'v_num_layers': 2,
            'a_num_layers': 2,
            'concept_num_layers': [4],
            'attn_dropout': 0.,
            'relu_dropout': 0.2,
            'embed_dropout': 0.1,
            'final_dropout': 0.1,
            'grad_clip': [1.0],
            'use_mask': True,
            'lr_main': [2e-5],
            'lr_concept': [1e-4],
            'lr_t_weight': 8e-4,
            'lr_a_weight': 8e-4,
            'lr_v_weight': [8e-4],
            'l2reg_t': [5e-4],
            'l2reg_a': 1e-4,
            'l2reg_v': [5e-4],
        }
        return hyper_parameters