forked from Cooperative-IA/CooperativeGPT
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrun_simulations.py
33 lines (28 loc) · 1.11 KB
/
run_simulations.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
import subprocess
import time
from concurrent.futures import ProcessPoolExecutor
from datetime import datetime
def run_simulation(simulation_id, start_delay):
time.sleep(start_delay) # Delay for the staggered start time
command = [
"python", "main.py",
"--substrate=commons_harvest_open",
"--scenario=",
"--agents_bio_config=all_coop",
"--world_context=context_with_definitions",
"--llm_model=gpt-3.5",
f"--simulation_id=sim_{str(simulation_id).format(2)}",
]
subprocess.run(command)
def main(simulations_count):
start_timestamp = datetime.now()
print(f"The first simulation started at: {start_timestamp}")
with ProcessPoolExecutor() as executor:
futures = [executor.submit(run_simulation, i, i*5) for i in range(1, simulations_count + 1)]
# Wait until all simulations are completed
for future in futures:
future.result()
print("All simulations have been completed.")
if __name__ == "__main__":
simulations_count = int(input("Enter the number of simulations to run: "))
main(simulations_count)