mirror of
https://github.com/dragonpilot/dragonpilot.git
synced 2026-06-25 16:02:14 +08:00
update tici power monitor
This commit is contained in:
@@ -1,15 +1,16 @@
|
||||
#!/usr/bin/env python3
|
||||
import sys
|
||||
import time
|
||||
import numpy as np
|
||||
import datetime
|
||||
from typing import List
|
||||
|
||||
from common.realtime import Ratekeeper
|
||||
from common.filter_simple import FirstOrderFilter
|
||||
|
||||
def average(avg, sample):
|
||||
# Weighted avg between existing value and new sample
|
||||
return ((avg[0] * avg[1] + sample) / (avg[1] + 1), avg[1] + 1)
|
||||
|
||||
def read_power():
|
||||
with open("/sys/bus/i2c/devices/0-0040/hwmon/hwmon1/power1_input") as f:
|
||||
return int(f.read()) / 1e6
|
||||
|
||||
def sample_power(seconds=5) -> List[float]:
|
||||
rate = 123
|
||||
@@ -17,8 +18,7 @@ def sample_power(seconds=5) -> List[float]:
|
||||
|
||||
pwrs = []
|
||||
for _ in range(rate*seconds):
|
||||
with open("/sys/bus/i2c/devices/0-0040/hwmon/hwmon1/power1_input") as f:
|
||||
pwrs.append(int(f.read()) / 1e6)
|
||||
pwrs.append(read_power())
|
||||
rk.keep_time()
|
||||
return pwrs
|
||||
|
||||
@@ -27,47 +27,30 @@ def get_power(seconds=5):
|
||||
return np.mean(pwrs)
|
||||
|
||||
|
||||
if __name__ == '__main__':
|
||||
|
||||
sample_time = None
|
||||
if __name__ == "__main__":
|
||||
duration = None
|
||||
if len(sys.argv) > 1:
|
||||
sample_time = int(sys.argv[1])
|
||||
duration = int(sys.argv[1])
|
||||
|
||||
rate = 23
|
||||
rk = Ratekeeper(rate, print_delay_threshold=None)
|
||||
fltr = FirstOrderFilter(0, 5, 1. / rate, initialized=False)
|
||||
|
||||
measurements = []
|
||||
start_time = time.monotonic()
|
||||
|
||||
try:
|
||||
voltage_average = (0, 0) # average, count
|
||||
current_average = (0, 0)
|
||||
power_average = (0, 0)
|
||||
while sample_time is None or time.monotonic() - start_time < sample_time:
|
||||
with open("/sys/bus/i2c/devices/0-0040/hwmon/hwmon1/in1_input") as f:
|
||||
voltage_total = int(f.read()) / 1000.
|
||||
|
||||
with open("/sys/bus/i2c/devices/0-0040/hwmon/hwmon1/curr1_input") as f:
|
||||
current_total = int(f.read())
|
||||
|
||||
# SOM measurements are questionable
|
||||
#with open("/sys/class/power_supply/bms/voltage_now") as f:
|
||||
# voltage = int(f.read()) / 1e6 # volts
|
||||
#with open("/sys/class/power_supply/bms/current_now") as f:
|
||||
# current = int(f.read()) / 1e3 # ma
|
||||
|
||||
power_total = voltage_total*current_total
|
||||
|
||||
# compute averages
|
||||
voltage_average = average(voltage_average, voltage_total)
|
||||
current_average = average(current_average, current_total)
|
||||
power_average = average(power_average, power_total)
|
||||
|
||||
print(f"now: {power_total:.2f} mW, avg: {power_average[0]:.2f} mW")
|
||||
time.sleep(0.25)
|
||||
while duration is None or time.monotonic() - start_time < duration:
|
||||
fltr.update(read_power())
|
||||
if rk.frame % rate == 0:
|
||||
measurements.append(fltr.x)
|
||||
t = datetime.timedelta(seconds=time.monotonic() - start_time)
|
||||
avg = sum(measurements) / len(measurements)
|
||||
print(f"Now: {fltr.x:.2f} W, Avg: {avg:.2f} W over {t}")
|
||||
rk.keep_time()
|
||||
except KeyboardInterrupt:
|
||||
pass
|
||||
finally:
|
||||
stop_time = time.monotonic()
|
||||
print("\n----------------------Average-----------------------------------")
|
||||
voltage = voltage_average[0]
|
||||
current = current_average[0]
|
||||
power = power_average[0]
|
||||
print(f"{voltage:.2f} volts {current:12.2f} ma {power:12.2f} mW {power_total:12.2f} mW")
|
||||
print(f" {stop_time - start_time:.2f} Seconds {voltage_average[1]} samples")
|
||||
print("----------------------------------------------------------------")
|
||||
|
||||
t = datetime.timedelta(seconds=time.monotonic() - start_time)
|
||||
avg = sum(measurements) / len(measurements)
|
||||
print(f"\nAverage power: {avg:.2f}W over {t}")
|
||||
|
||||
Reference in New Issue
Block a user