-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathcuda_utils.py
26 lines (23 loc) · 1.03 KB
/
cuda_utils.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
import os
import time
import datetime
import numpy as np
import GPUtil
def get_device_name():
gpus = GPUtil.getGPUs()
return gpus[0].name
def dynamic_cuda_allocation():
gpus = GPUtil.getGPUs()
os.environ["CUDA_VISIBLE_DEVICES"] = str(np.argmax([gpu.memoryFree for gpu in gpus]))
def block_until_cuda_memory_free(required_mem, interval=30):
start_time = time.time()
gpus = GPUtil.getGPUs()
available_mem = max([gpu.memoryFree for gpu in gpus])
while available_mem < required_mem:
blocked_time = str(datetime.timedelta(seconds=int(time.time()-start_time)))
print(f"{time.ctime()} \t {available_mem} MiB < {required_mem} MiB : blocked for {blocked_time}", end="\r")
time.sleep(interval)
gpus = GPUtil.getGPUs()
available_mem = max([gpu.memoryFree for gpu in gpus])
blocked_time = str(datetime.timedelta(seconds=int(time.time()-start_time)))
print(f"{time.ctime()} \t {available_mem} MiB >= {required_mem} MiB : passed after {blocked_time}", end="\r")