# distributed/parallel_sampler.py
"""
Simple multiprocessing-based parallel sampler to run generation tasks across CPU/GPU workers.
This is a minimal implementation for local multi-process runs. For multi-node use a job scheduler.
"""
import multiprocessing as mp
import os

def worker_task(task_queue, result_queue, worker_id):
    while True:
        task = task_queue.get()
        if task is None:
            break
        prompt, model_name = task
        # placeholder: generate a dummy result
        res = {"prompt": prompt, "model": model_name, "time_s": 0.01}
        result_queue.put(res)

def run_parallel(prompts, model_name="EGP", n_workers=4):
    manager = mp.Manager()
    task_q = manager.Queue()
    res_q = manager.Queue()
    procs = []
    for i in range(n_workers):
        p = mp.Process(target=worker_task, args=(task_q, res_q, i))
        p.start()
        procs.append(p)
    for p in prompts:
        task_q.put((p, model_name))
    # send terminators
    for _ in procs:
        task_q.put(None)
    results = []
    finished = 0
    while finished < len(prompts):
        r = res_q.get()
        results.append(r)
        finished += 1
    for p in procs:
        p.join()
    return results
