import os
import time
def run(test_params):

    log_file, log_name = get_log_name(test_params)

    print(log_file, log_name)
    # cmd = f"python3 -u main.py \
    # cmd = f"nohup python3 -u main-combat-reconstruct.py \
    # cmd = f"nohup python3 -u combat-PG.py \
    cmd = f"nohup python3 -u main/combat_clean-diff-corpus-random-order.py \
        --eval_model_code {test_params['eval_model_code']}\
        --eval_dataset {test_params['eval_dataset']}\
        --split {test_params['split']}\
        --query_results_dir {test_params['query_results_dir']}\
        --model_name {test_params['model_name']}\
        --top_k {test_params['top_k']}\
        --use_truth {test_params['use_truth']}\
        --gpu_id {test_params['gpu_id']}\
        --attack_method {test_params['attack_method']}\
        --adv_per_query {test_params['adv_per_query']}\
        --score_function {test_params['score_function']}\
        --repeat_times {test_params['repeat_times']}\
        --M {test_params['M']}\
        --seed {test_params['seed']}\
        --name {log_name}\
        > {log_file} &"
        
    os.system(cmd)


def get_log_name(test_params):
    # Generate a log file name
    os.makedirs(f"logs/{test_params['query_results_dir']}_logs", exist_ok=True)

    if test_params['use_truth']:
        log_name = f"{test_params['eval_dataset']}-{test_params['eval_model_code']}-{test_params['model_name']}-Truth--M{test_params['M']}x{test_params['repeat_times']}"
    else:
        log_name = f"{test_params['eval_dataset']}-{test_params['eval_model_code']}-{test_params['model_name']}-Top{test_params['top_k']}--M{test_params['M']}x{test_params['repeat_times']}"
    
    if test_params['attack_method'] != None:
        log_name += f"-adv-{test_params['attack_method']}-{test_params['score_function']}-{test_params['adv_per_query']}-{test_params['top_k']}"

    if test_params['note'] != None:
        log_name = test_params['note']
    moment = time.strftime("%Y%m%d_%H%M")
    return f"logs/{test_params['query_results_dir']}_logs/{moment}_{log_name}.txt", log_name


model_name = "llama8b"  # "vicuna7b" "llama3b" "llama8b" "phi4" "gpt3.5" "gpt4o"
test_params = {
    # beir_info
    'eval_model_code': "contriever",
    'eval_dataset': "nq",
    'split': "test",
    # 'query_results_dir': 'main',
    # 'query_results_dir': 'combat-random-gpt3.5',
    # 'query_results_dir': 'combat-random-gpt4o',
    'query_results_dir': f'combat-random-order',

    # LLM setting
    # 'model_name': 'palm2', 
    # 'model_name': 'llama8b',
    # 'model_name': 'llama3b',
    'model_name': model_name,
    # 'model_name': 'gpt3.5',
    # 'model_name': 'gpt4o',
    'use_truth': False,
    'top_k': 5,
    # 'top_k': 10,
    'gpu_id': 0,

    # attack
    'attack_method': 'LM_targeted',
    # 'attack_method': 'hotflip',
    'adv_per_query': 5,
    'score_function': 'dot',
    # 'score_function': 'cos_sim',
    'repeat_times': 10,
    'M': 10,
    'seed': 12,

    'note': None
}

# for dataset in ['nq', 'hotpotqa', 'msmarco']:
for dataset in ['nq']:
    test_params['eval_dataset'] = dataset
    run(test_params)