Spaces:
Starting
on
T4
Starting
on
T4
File size: 2,778 Bytes
fb4a881 eb442cd fb4a881 |
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 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 |
import psutil
import platform
import getpass
import datetime
from pynvml import *
from pprint import pprint
def physical_system_time():
return {"system_time": datetime.datetime.fromtimestamp(psutil.boot_time()).strftime("%Y-%m-%d %H:%M:%S")}
def physical_username():
return {
"system_user": getpass.getuser()
}
def physical_platfrom_system():
u_name = platform.uname()
return {"system_name": u_name.system, "system_version": u_name.version}
def physical_cpu():
return {"system_cpu_count": psutil.cpu_count(logical=False)}
def physical_memory():
# return round(psutil.virtual_memory().total / (1024.0 * 1024.0 * 1024.0), 2)
return {"system_memory": round(psutil.virtual_memory().total, 2)}
def physical_hard_disk():
result = []
for disk_partition in psutil.disk_partitions():
o_usage = psutil.disk_usage(disk_partition.device)
result.append(
{
"device": disk_partition.device,
"fstype":disk_partition.fstype,
"opts": disk_partition.opts,
"total": o_usage.total,
}
)
return {"system_hard_disk": result}
def nvidia_info():
nvidia_dict = {
"state": True,
"nvidia_version": "",
"nvidia_count": 0,
"gpus": []
}
try:
nvmlInit()
nvidia_dict["nvidia_version"] = nvmlSystemGetDriverVersion()
nvidia_dict["nvidia_count"] = nvmlDeviceGetCount()
for i in range(nvidia_dict["nvidia_count"]):
handle = nvmlDeviceGetHandleByIndex(i)
memory_info = nvmlDeviceGetMemoryInfo(handle)
gpu = {
"gpu_name": nvmlDeviceGetName(handle),
"total": memory_info.total,
"free": memory_info.free,
"used": memory_info.used,
"temperature": f"{nvmlDeviceGetTemperature(handle, 0)}℃",
"powerStatus": nvmlDeviceGetPowerState(handle)
}
nvidia_dict['gpus'].append(gpu)
except NVMLError as e1:
nvidia_dict["state"] = False
print(f'nvidia_error_1_{e1}')
except Exception as e2:
nvidia_dict["state"] = False
print(f'nvidia_erro_2_{e2}')
finally:
try:
nvmlShutdown()
except:
pass
return nvidia_dict
def merge(info_list):
data = {}
for item in info_list:
data.update(
item()
)
return data
def computer_info():
data = merge(
[
physical_system_time,
physical_username,
physical_platfrom_system,
physical_cpu,
physical_memory,
# physical_hard_disk,
nvidia_info
]
)
pprint(data)
|