mirror of
https://github.com/sunnypilot/sunnypilot.git
synced 2026-02-22 13:33:55 +08:00
* locationd at 20hz * update ref * bump cereal * dont modify global state * add scons files * ecef2geodetic and geodetic2ecef * Finish local coords class * Add header file * Add orientation.cc * cleanup * Add functions to header file * Add cython wrapper * y u no work? * This passes the tests * test rot2quat and quat2rot * Teste euler2rot and rot2euler * rot_matrix * test ecef_euler_from_ned and ned_euler_from_ecef * add benchmark * Add test * Consistent newlines * no more radians supported in geodetic * test localcoord single * test localcoord single * all tests pass * Unused import * Add alternate namings * Add source for formulas * no explicit tests needed * remove benchmark * Add release files * Typo * Remove print statement * no access to raw transform matrix * temporarily add tolerance * handcode quat2euler * update ref
82 lines
2.0 KiB
Python
Executable File
82 lines
2.0 KiB
Python
Executable File
#!/usr/bin/env python3
|
|
import bz2
|
|
import os
|
|
import sys
|
|
import numbers
|
|
|
|
import dictdiffer
|
|
if "CI" in os.environ:
|
|
def tqdm(x):
|
|
return x
|
|
else:
|
|
from tqdm import tqdm # type: ignore
|
|
|
|
from tools.lib.logreader import LogReader
|
|
|
|
|
|
def save_log(dest, log_msgs):
|
|
dat = b""
|
|
for msg in tqdm(log_msgs):
|
|
dat += msg.as_builder().to_bytes()
|
|
dat = bz2.compress(dat)
|
|
|
|
with open(dest, "wb") as f:
|
|
f.write(dat)
|
|
|
|
|
|
def remove_ignored_fields(msg, ignore):
|
|
msg = msg.as_builder()
|
|
for key in ignore:
|
|
attr = msg
|
|
keys = key.split(".")
|
|
if msg.which() not in key and len(keys) > 1:
|
|
continue
|
|
|
|
for k in keys[:-1]:
|
|
try:
|
|
attr = getattr(msg, k)
|
|
except AttributeError:
|
|
break
|
|
else:
|
|
v = getattr(attr, keys[-1])
|
|
if isinstance(v, bool):
|
|
val = False
|
|
elif isinstance(v, numbers.Number):
|
|
val = 0
|
|
else:
|
|
raise NotImplementedError
|
|
setattr(attr, keys[-1], val)
|
|
return msg.as_reader()
|
|
|
|
|
|
def compare_logs(log1, log2, ignore_fields=None, ignore_msgs=None):
|
|
if ignore_fields is None:
|
|
ignore_fields = []
|
|
|
|
if ignore_msgs is None:
|
|
ignore_msgs = []
|
|
log1, log2 = [list(filter(lambda m: m.which() not in ignore_msgs, log)) for log in (log1, log2)]
|
|
assert len(log1) == len(log2), "logs are not same length: " + str(len(log1)) + " VS " + str(len(log2))
|
|
|
|
diff = []
|
|
for msg1, msg2 in tqdm(zip(log1, log2)):
|
|
if msg1.which() != msg2.which():
|
|
print(msg1, msg2)
|
|
raise Exception("msgs not aligned between logs")
|
|
|
|
msg1_bytes = remove_ignored_fields(msg1, ignore_fields).as_builder().to_bytes()
|
|
msg2_bytes = remove_ignored_fields(msg2, ignore_fields).as_builder().to_bytes()
|
|
|
|
if msg1_bytes != msg2_bytes:
|
|
msg1_dict = msg1.to_dict(verbose=True)
|
|
msg2_dict = msg2.to_dict(verbose=True)
|
|
dd = dictdiffer.diff(msg1_dict, msg2_dict, ignore=ignore_fields)
|
|
diff.extend(dd)
|
|
return diff
|
|
|
|
|
|
if __name__ == "__main__":
|
|
log1 = list(LogReader(sys.argv[1]))
|
|
log2 = list(LogReader(sys.argv[2]))
|
|
print(compare_logs(log1, log2, sys.argv[3:]))
|