#!/usr/bin/env python3
import asyncio
import sys
import os
from pathlib import Path

TASKS_PER_GPU = 7

async def run_task(arch, dataset, conv_sparsity, linear_sparsity, dropout, one_fc, device, gpu, sem):
    async with sem:
        env = os.environ.copy()
        env["CUDA_VISIBLE_DEVICES"] = str(gpu)
        cmd = [
            "stdbuf", "-oL", "python", "trainer.py",
            "--conv_sparsity", str(conv_sparsity),
            "--architecture", arch,
            "--dataset", dataset,
            "--dropout", str(dropout),
            "--save",
            "--epochs", "100",
            "--lr", "0.025",
            "--bs", "128",
            "--use_scheduler",
            *(["--one_fc"] if one_fc else []),
            "--device", device,
            "--update_interval", "1",
            "--linear_sparsity", str(linear_sparsity),
            "--zeta", "0.3",
            "--adaptive_zeta",
            "--chain_removal",
            "--linear_remove_method", "weight_magnitude_soft",
            "--linear_regrow_method", "CH2_L3n_soft"
        ]
        logdir = Path(f"../input_cnn/logs/{arch}/{dataset}/conv_{conv_sparsity}")
        logdir.mkdir(parents=True, exist_ok=True)
        logfile = logdir / f"s_{linear_sparsity}_d{dropout}_onefc_{one_fc}_.log"
        print(f"[START] {arch} {dataset} conv={conv_sparsity} linear={linear_sparsity} one_fc={one_fc} on GPU {gpu}")

        proc = await asyncio.create_subprocess_exec(
            *cmd,
            stdout=asyncio.subprocess.PIPE,
            stderr=asyncio.subprocess.STDOUT,
            env=env
        )
        with logfile.open("wb") as f:
            async for line in proc.stdout:
                f.write(line)
        rc = await proc.wait()

        if rc == 0:
            print(f"[FINISH] {arch} {dataset} conv={conv_sparsity} linear={linear_sparsity} finished on GPU {gpu}")
        else:
            print(f"[ERROR] {arch} {dataset} conv={conv_sparsity} linear={linear_sparsity} failed on GPU {gpu}")

async def main():
    if len(sys.argv) < 4:
        print(f"用法: {sys.argv[0]} <architecture> <dataset> <gpu_list>")
        sys.exit(1)

    arch, dataset, gpu_list = sys.argv[1], sys.argv[2], sys.argv[3]
    gpus = gpu_list.split(',')

    sems = {gpu: asyncio.Semaphore(TASKS_PER_GPU) for gpu in gpus}

    sparsities = [0.0, 0.5, 0.7, 0.9, 0.95, 0.99]
    fcs = [True, False]
    dropouts = [0.0, 0.3]

    tasks = []
    for one_fc in fcs:
        for dropout in dropouts:
            # linear_sparsity = 0.0 (original intends as first special case)
            tasks.append((0.0, 0.0, dropout, one_fc))
            for conv_sp in sparsities:
                tasks.append((0.5, conv_sp, dropout, one_fc))

    coros = []
    for conv_sparsity, linear_sparsity, dropout, one_fc in tasks:
        for gpu in gpus:
            coros.append(run_task(arch, dataset, conv_sparsity, linear_sparsity, dropout, one_fc, "cuda:0", gpu, sems[gpu]))

    await asyncio.gather(*coros)
    print("sensitivity test finish.")

if __name__ == "__main__":
    asyncio.run(main())
