Ardupilot2/Tools/scripts/CAN/fix2_gap.py
2023-09-02 13:27:25 +10:00

45 lines
1.4 KiB
Python
Executable File

#!/usr/bin/env python3
'''
test script to check if all CAN GPS nodes are producing Fix2 frames at the expected rate
'''
import dronecan, time
from dronecan import uavcan
# get command line arguments
from argparse import ArgumentParser
parser = ArgumentParser(description='Fix2 gap example')
parser.add_argument("--bitrate", default=1000000, type=int, help="CAN bit rate")
parser.add_argument("--node-id", default=100, type=int, help="CAN node ID")
parser.add_argument("--max-gap", default=0.25, type=float, help="max gap in seconds")
parser.add_argument("port", default=None, type=str, help="serial port or mavcan URI")
args = parser.parse_args()
# Initializing a DroneCAN node instance.
node = dronecan.make_node(args.port, node_id=args.node_id, bitrate=args.bitrate)
# Initializing a node monitor
node_monitor = dronecan.app.node_monitor.NodeMonitor(node)
last_fix2 = {}
def handle_fix2(msg):
nodeid = msg.transfer.source_node_id
tstamp = msg.transfer.ts_real
if nodeid not in last_fix2:
last_fix2[nodeid] = tstamp
return
dt = tstamp - last_fix2[nodeid]
last_fix2[nodeid] = tstamp
if dt > args.max_gap:
print("Node %u gap=%.3f" % (nodeid, dt))
# callback for printing ESC status message to stdout in human-readable YAML format.
node.add_handler(dronecan.uavcan.equipment.gnss.Fix2, handle_fix2)
while True:
try:
node.spin()
except Exception as ex:
print(ex)