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': 4,
            'concepts_path': {
                'train': [
                    'notations/MIntRec2.0/filtered_scored_text_train.pt',
                    'notations/MIntRec2.0/filtered_scored_audio_train.pt',
                    'notations/MIntRec2.0/filtered_scored_video_train.pt'
                ],
                'dev': [
                    'notations/MIntRec2.0/filtered_scored_text_dev.pt',
                    'notations/MIntRec2.0/filtered_scored_audio_dev.pt',
                    'notations/MIntRec2.0/filtered_scored_video_dev.pt'
                ],
                'test': [
                    'notations/MIntRec2.0/filtered_scored_text_test.pt',
                    'notations/MIntRec2.0/filtered_scored_audio_test.pt',
                    'notations/MIntRec2.0/filtered_scored_video_test.pt'
                ]
            },
            'weight_path': {'paths': [
                'notations/MIntRec2.0//text_concepts_relevants.json',
                'notations/MIntRec2.0/audio_concepts_relevants.json',
                'notations/MIntRec2.0/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': 8,
            't_concept_num': 150,
            'a_concept_num': 150,
            'v_concept_num': 150,
            'num_head': 8,
            't_num_layers': 2,
            'v_num_layers': 3,
            'a_num_layers': 4,
            'concept_num_layers': 4,
            'attn_dropout': 0.2,
            'relu_dropout': 0.3,
            'embed_dropout': 0.2,
            'final_dropout': 0.2,
            'grad_clip': [1.0],
            'use_mask': True,
            'lr_main': [1.5e-6],
            'lr_concept': [3e-3],
            'lr_t_weight': 1e-4,
            'lr_a_weight': 1e-4,
            'lr_v_weight': 1e-4,
            'l2reg_t': 5e-3,
            'l2reg_a': 1e-4,
            'l2reg_v': 5e-3,
        }
        return hyper_parameters