from transformers import (
    AutoTokenizer, AutoConfig,
    GPT2Tokenizer, GPT2LMHeadModel,
    LlamaForCausalLM, LlamaTokenizer, AutoModelForCausalLM
)


def model_constructor(model_name, model_max_length):
    if model_name.lower() == 'llama3.1-8b':
        tokenizer = AutoTokenizer.from_pretrained(
            "/path/to/model", 
            model_max_length=model_max_length
        )
        model = LlamaForCausalLM.from_pretrained(
            "/path/to/model",
        )
    elif model_name.lower() == 'llama2-7b':
        tokenizer = LlamaTokenizer.from_pretrained(
            "/path/to/model", 
            model_max_length=model_max_length
        )
        model = LlamaForCausalLM.from_pretrained(
            "/path/to/model",
        )
    elif model_name.lower() == 'qwen3-4b':
        tokenizer = AutoTokenizer.from_pretrained(
            "/path/to/model", 
            model_max_length=model_max_length
        )
        model = AutoModelForCausalLM.from_pretrained(
            "/path/to/model",
        )
    elif model_name.lower() == 'qwen3-8b':
        tokenizer = AutoTokenizer.from_pretrained(
            "/path/to/model", 
            model_max_length=model_max_length
        )
        model = AutoModelForCausalLM.from_pretrained(
            "/path/to/model",
        )
    else:
        raise ValueError(f"Model {model_name} not supported")
    if tokenizer.pad_token is None:
        tokenizer.add_special_tokens({'pad_token': '[PAD]'})
        model.resize_token_embeddings(len(tokenizer))
    return model, tokenizer #, model_config
