
import argparse

parser = argparse.ArgumentParser(description='sp')
parser.add_argument('--outdir', type=str, default='llava_vicuna_7B_mid_mix665k')
args = parser.parse_args()

import os
from concurrent.futures import ThreadPoolExecutor

s = 0
e = 84000 - 1
for i in range(50):
    s = 0 + 12000 * i
    e = 0 + 12000 * (i+1) - 1
    gpus = [[0, 1]]

    num_p = len(gpus)
    outdir = '/ge_data/all_ckpt/{}/llava_665k_{}_{}_mubf16'.format(args.outdir, s, e)

    def split_range(start, end, n, over=False):
        length = end - start + 1  # Include the end
        base_interval = length // n
        additional = length % n  # Get the remainder of the division
        intervals = []
        previous = start

        for i in range(n):
            current_interval = base_interval + (1 if i < additional else 0)
            if over:
                intervals.append((previous, previous + current_interval))
            else:
                intervals.append((previous, previous + current_interval - 1))  # '-1' because the end is inclusive
            previous += current_interval

        return intervals


    def run_command(cmd):
        os.system(cmd)

    if not os.path.exists(outdir):
        os.makedirs(outdir)

    data_a = split_range(s, e, num_p, over=True)
    commands = [] 
    for i in range(num_p):
        index = i
        start = data_a[i][0]
        end = data_a[i][1]
        gpu_index = gpus[i]
        gpu_index_str = ' '.join(map(str, gpu_index))
        command = "python ge_data_all_llava_mix665k.py --start={} --end={} --index={} --gpu_index {} --outdir {}".format(start, end, index, gpu_index_str, outdir)
        commands.append(command)

    with ThreadPoolExecutor(max_workers=len(commands)) as executor:
        for command in commands:
            executor.submit(run_command, command)
            print(command)
