Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
Ardupilot
GitHub Repository: Ardupilot/ardupilot
Path: blob/master/Tools/scripts/CAN/fix2_gap.py
9463 views
1
#!/usr/bin/env python3
2
3
# flake8: noqa
4
5
'''
6
test script to check if all CAN GPS nodes are producing Fix2 frames at the expected rate
7
'''
8
9
import dronecan, time
10
from dronecan import uavcan
11
12
# get command line arguments
13
from argparse import ArgumentParser
14
parser = ArgumentParser(description='Fix2 gap example')
15
parser.add_argument("--bitrate", default=1000000, type=int, help="CAN bit rate")
16
parser.add_argument("--node-id", default=100, type=int, help="CAN node ID")
17
parser.add_argument("--max-gap", default=0.25, type=float, help="max gap in seconds")
18
parser.add_argument("port", default=None, type=str, help="serial port or mavcan URI")
19
args = parser.parse_args()
20
21
# Initializing a DroneCAN node instance.
22
node = dronecan.make_node(args.port, node_id=args.node_id, bitrate=args.bitrate)
23
24
# Initializing a node monitor
25
node_monitor = dronecan.app.node_monitor.NodeMonitor(node)
26
27
last_fix2 = {}
28
29
def handle_fix2(msg):
30
nodeid = msg.transfer.source_node_id
31
tstamp = msg.transfer.ts_real
32
if nodeid not in last_fix2:
33
last_fix2[nodeid] = tstamp
34
return
35
dt = tstamp - last_fix2[nodeid]
36
last_fix2[nodeid] = tstamp
37
if dt > args.max_gap:
38
print("Node %u gap=%.3f" % (nodeid, dt))
39
40
# callback for printing ESC status message to stdout in human-readable YAML format.
41
node.add_handler(dronecan.uavcan.equipment.gnss.Fix2, handle_fix2)
42
43
while True:
44
try:
45
node.spin()
46
except Exception as ex:
47
print(ex)
48
49