aboutsummaryrefslogtreecommitdiff
path: root/mavlink/share/pyshared/pymavlink/examples/magtest.py
diff options
context:
space:
mode:
Diffstat (limited to 'mavlink/share/pyshared/pymavlink/examples/magtest.py')
-rw-r--r--mavlink/share/pyshared/pymavlink/examples/magtest.py120
1 files changed, 120 insertions, 0 deletions
diff --git a/mavlink/share/pyshared/pymavlink/examples/magtest.py b/mavlink/share/pyshared/pymavlink/examples/magtest.py
new file mode 100644
index 000000000..8b910f8fd
--- /dev/null
+++ b/mavlink/share/pyshared/pymavlink/examples/magtest.py
@@ -0,0 +1,120 @@
+#!/usr/bin/env python
+
+'''
+rotate APMs on bench to test magnetometers
+
+'''
+
+import sys, os, time
+from math import radians
+
+# allow import from the parent directory, where mavlink.py is
+sys.path.insert(0, os.path.join(os.path.dirname(os.path.realpath(__file__)), '..'))
+
+import mavlink, mavutil
+
+from optparse import OptionParser
+parser = OptionParser("rotate.py [options]")
+
+parser.add_option("--device1", dest="device1", default=None, help="mavlink device1")
+parser.add_option("--device2", dest="device2", default=None, help="mavlink device2")
+parser.add_option("--baudrate", dest="baudrate", type='int',
+ help="master port baud rate", default=115200)
+(opts, args) = parser.parse_args()
+
+if opts.device1 is None or opts.device2 is None:
+ print("You must specify a mavlink device")
+ sys.exit(1)
+
+def set_attitude(rc3, rc4):
+ global mav1, mav2
+ values = [ 65535 ] * 8
+ values[2] = rc3
+ values[3] = rc4
+ mav1.mav.rc_channels_override_send(mav1.target_system, mav1.target_component, *values)
+ mav2.mav.rc_channels_override_send(mav2.target_system, mav2.target_component, *values)
+
+
+# create a mavlink instance
+mav1 = mavutil.mavlink_connection(opts.device1, baud=opts.baudrate)
+
+# create a mavlink instance
+mav2 = mavutil.mavlink_connection(opts.device2, baud=opts.baudrate)
+
+print("Waiting for HEARTBEAT")
+mav1.wait_heartbeat()
+mav2.wait_heartbeat()
+print("Heartbeat from APM (system %u component %u)" % (mav1.target_system, mav1.target_system))
+print("Heartbeat from APM (system %u component %u)" % (mav2.target_system, mav2.target_system))
+
+print("Waiting for MANUAL mode")
+mav1.recv_match(type='SYS_STATUS', condition='SYS_STATUS.mode==2 and SYS_STATUS.nav_mode==4', blocking=True)
+mav2.recv_match(type='SYS_STATUS', condition='SYS_STATUS.mode==2 and SYS_STATUS.nav_mode==4', blocking=True)
+
+print("Setting declination")
+mav1.mav.param_set_send(mav1.target_system, mav1.target_component,
+ 'COMPASS_DEC', radians(12.33))
+mav2.mav.param_set_send(mav2.target_system, mav2.target_component,
+ 'COMPASS_DEC', radians(12.33))
+
+
+set_attitude(1060, 1160)
+
+event = mavutil.periodic_event(30)
+pevent = mavutil.periodic_event(0.3)
+rc3_min = 1060
+rc3_max = 1850
+rc4_min = 1080
+rc4_max = 1500
+rc3 = rc3_min
+rc4 = 1160
+delta3 = 2
+delta4 = 1
+use_pitch = 1
+
+MAV_ACTION_CALIBRATE_GYRO = 17
+mav1.mav.action_send(mav1.target_system, mav1.target_component, MAV_ACTION_CALIBRATE_GYRO)
+mav2.mav.action_send(mav2.target_system, mav2.target_component, MAV_ACTION_CALIBRATE_GYRO)
+
+print("Waiting for gyro calibration")
+mav1.recv_match(type='ACTION_ACK')
+mav2.recv_match(type='ACTION_ACK')
+
+print("Resetting mag offsets")
+mav1.mav.set_mag_offsets_send(mav1.target_system, mav1.target_component, 0, 0, 0)
+mav2.mav.set_mag_offsets_send(mav2.target_system, mav2.target_component, 0, 0, 0)
+
+def TrueHeading(SERVO_OUTPUT_RAW):
+ p = float(SERVO_OUTPUT_RAW.servo3_raw - rc3_min) / (rc3_max - rc3_min)
+ return 172 + p*(326 - 172)
+
+while True:
+ mav1.recv_msg()
+ mav2.recv_msg()
+ if event.trigger():
+ if not use_pitch:
+ rc4 = 1160
+ set_attitude(rc3, rc4)
+ rc3 += delta3
+ if rc3 > rc3_max or rc3 < rc3_min:
+ delta3 = -delta3
+ use_pitch ^= 1
+ rc4 += delta4
+ if rc4 > rc4_max or rc4 < rc4_min:
+ delta4 = -delta4
+ if pevent.trigger():
+ print "hdg1: %3u hdg2: %3u ofs1: %4u, %4u, %4u ofs2: %4u, %4u, %4u" % (
+ mav1.messages['VFR_HUD'].heading,
+ mav2.messages['VFR_HUD'].heading,
+ mav1.messages['SENSOR_OFFSETS'].mag_ofs_x,
+ mav1.messages['SENSOR_OFFSETS'].mag_ofs_y,
+ mav1.messages['SENSOR_OFFSETS'].mag_ofs_z,
+ mav2.messages['SENSOR_OFFSETS'].mag_ofs_x,
+ mav2.messages['SENSOR_OFFSETS'].mag_ofs_y,
+ mav2.messages['SENSOR_OFFSETS'].mag_ofs_z,
+ )
+ time.sleep(0.01)
+
+# 314M 326G
+# 160M 172G
+