-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathAVERAGE_TEMP.py
127 lines (94 loc) · 4.07 KB
/
AVERAGE_TEMP.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
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
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
from HardwareMonitor.Hardware import * # equivalent to 'using LibreHardwareMonitor.Hardware;'
import time
import matplotlib.pyplot as plt
import matplotlib.animation as animation
from collections import deque
import datetime
import matplotlib.dates as mdates
# namespace LibreHardwareMonitor.Hardware.Storage;
computer = Computer() # settings can not be passed as constructor argument (following below)
computer.IsMotherboardEnabled = False
computer.IsControllerEnabled = False
computer.IsCpuEnabled = True
computer.IsGpuEnabled = True
computer.IsBatteryEnabled = False
computer.IsMemoryEnabled = False
computer.IsNetworkEnabled = False
computer.IsStorageEnabled = False
computer.Open()
class UpdateVisitor(IVisitor):
__namespace__ = "TestHardwareMonitor" # must be unique among implementations of the IVisitor interface
def VisitComputer(self, computer: IComputer):
computer.Traverse(self)
def VisitHardware(self, hardware: IHardware):
hardware.Update()
for subHardware in hardware.SubHardware:
subHardware.Update()
def VisitParameter(self, parameter: IParameter): pass
def VisitSensor(self, sensor: ISensor): pass
def get_temp() -> list[int]: #[cpu_max_tmp, cpu_average_tmp, gpu_max_temp, gpu_average_temp]
computer.Accept(UpdateVisitor())
time.sleep(1)
# for cpu:↓ ↓for max cpu temp <-sensor
cpu_max_tmp = int(computer.Hardware[0].Sensors[83].Value)
# for cpu:↓ ↓for average cpu temp <-sensor
cpu_average_tmp = int(computer.Hardware[0].Sensors[84].Value)
# for gpu:↓ ↓for max gpu temp <-sensor
gpu_max_temp = int(computer.Hardware[1].Sensors[19].Value)
# for gpu:↓ ↓for gpu temp <-sensor
gpu_average_temp = int(computer.Hardware[1].Sensors[0].Value)
returnList = [cpu_max_tmp, cpu_average_tmp, gpu_max_temp, gpu_average_temp]
return returnList
def pwm_tuner(average_temp) -> str:
if average_temp < 40:
return "0"
if average_temp > 90:
return "255"
return str(int(246/(1+60000*(2**(-float(average_temp)/4)))+11))
# Example queue length
queue_len = 30
# Initialize the queues
time_queue = deque(maxlen=queue_len)
temp_queue = deque(maxlen=queue_len)
pwm_queue = deque(maxlen=queue_len)
# Convert Unix time to datetime objects for better plotting
def convert_times(unix_times):
return [datetime.datetime.fromtimestamp(ts) for ts in unix_times]
# Create the figure and axis
fig, ax1 = plt.subplots()
ax2 = ax1.twinx()
# Format the axes
ax1.set_xlabel('Time')
ax1.set_ylabel('AverageTemperature (°C)', color='red')
ax2.set_ylabel('PWM', color='blue')
ax1.xaxis.set_major_formatter(mdates.DateFormatter('%M:%S'))
ax1.xaxis.set_major_locator(mdates.SecondLocator(interval=10))
weights = [1.2, 0.8, 1.2, 0.8] # <=[cpu_max_tmp, cpu_average_tmp, gpu_max_temp, gpu_average_temp]
temps = None
sum_weights = weights[0]+weights[1]+weights[2]+weights[3]
# Create the data curves
temp_line, = ax1.plot([], [], color="red", label='Temperature')
pwm_line, = ax2.plot([], [], color="blue", label='PWM')
def init():
temp_line.set_data([], [])
pwm_line.set_data([], [])
return temp_line, pwm_line
def update(frame):
current_time = time.time()
temps = get_temp()
new_temp = int((temps[0]*weights[0]+temps[1]*weights[1]+temps[2]*weights[2]+temps[3]*weights[3])/sum_weights)
new_pwm = int(pwm_tuner(new_temp))
time_queue.append(current_time)
temp_queue.append(new_temp)
pwm_queue.append(new_pwm)
times = convert_times(time_queue)
times_num = mdates.date2num(times)
temp_line.set_data(times_num, list(temp_queue))
pwm_line.set_data(times_num, list(pwm_queue))
ax1.set_xlim(times_num[0], times_num[-1])
ax1.set_ylim(min(temp_queue) - 5, max(temp_queue) + 5)
ax2.set_ylim(min(pwm_queue) - 20, max(pwm_queue) + 20)
fig.autofmt_xdate()
return temp_line, pwm_line
ani = animation.FuncAnimation(fig, update, init_func=init, blit=False, interval=5000, cache_frame_data=False)
plt.show()