Tools: sitl_calibration: add sitl_accelcal command
This commit is contained in:
parent
363f241e9a
commit
fcc80de20a
@ -120,6 +120,124 @@ class CalController(object):
|
|||||||
self.handle_simstate(m)
|
self.handle_simstate(m)
|
||||||
|
|
||||||
|
|
||||||
|
class AccelcalController(CalController):
|
||||||
|
state_data = {
|
||||||
|
'level': dict(
|
||||||
|
name='Level',
|
||||||
|
attitude=(0, 0, 0),
|
||||||
|
),
|
||||||
|
'LEFT': dict(
|
||||||
|
name='Left side',
|
||||||
|
attitude=(-math.pi / 2, 0, 0),
|
||||||
|
),
|
||||||
|
'RIGHT': dict(
|
||||||
|
name='Right side',
|
||||||
|
attitude=(math.pi / 2, 0, 0),
|
||||||
|
),
|
||||||
|
'DOWN': dict(
|
||||||
|
name='Nose down',
|
||||||
|
attitude=(0, -math.pi / 2, 0),
|
||||||
|
),
|
||||||
|
'UP': dict(
|
||||||
|
name='Nose up',
|
||||||
|
attitude=(0, math.pi / 2, 0),
|
||||||
|
),
|
||||||
|
'BACK': dict(
|
||||||
|
name='Back',
|
||||||
|
attitude=(math.pi, 0, 0),
|
||||||
|
),
|
||||||
|
}
|
||||||
|
|
||||||
|
def __init__(self, mpstate):
|
||||||
|
super(AccelcalController, self).__init__(mpstate)
|
||||||
|
self.state = None
|
||||||
|
|
||||||
|
def reset(self):
|
||||||
|
super(AccelcalController, self).reset()
|
||||||
|
|
||||||
|
def start(self):
|
||||||
|
super(AccelcalController, self).start()
|
||||||
|
if self.state:
|
||||||
|
self.set_side_state(self.state)
|
||||||
|
|
||||||
|
def side_from_msg(self, m):
|
||||||
|
text = str(m.text)
|
||||||
|
if text.startswith('Place '):
|
||||||
|
for side in self.state_data:
|
||||||
|
if side in text:
|
||||||
|
return side
|
||||||
|
return None
|
||||||
|
|
||||||
|
def report_from_msg(self, m):
|
||||||
|
'''Return true if successful, false if failed, None if unknown'''
|
||||||
|
text = str(m.text)
|
||||||
|
if 'Calibration successful' in text:
|
||||||
|
return True
|
||||||
|
elif 'Calibration FAILED' in text:
|
||||||
|
return False
|
||||||
|
return None
|
||||||
|
|
||||||
|
def set_side_state(self, side):
|
||||||
|
self.state = side
|
||||||
|
|
||||||
|
if not self.active:
|
||||||
|
return
|
||||||
|
|
||||||
|
data = self.state_data[side]
|
||||||
|
|
||||||
|
def callback():
|
||||||
|
self.mpstate.console.set_status(
|
||||||
|
name='sitl_accelcal',
|
||||||
|
text='sitl_accelcal: %s ready - Waiting for user input' % data['name'],
|
||||||
|
row=4,
|
||||||
|
fg='blue',
|
||||||
|
)
|
||||||
|
self.mpstate.console.writeln('sitl_accelcal: attitude detected, please press any key..')
|
||||||
|
|
||||||
|
self.mpstate.console.writeln('sitl_accelcal: sending attitude, please wait..')
|
||||||
|
|
||||||
|
roll, pitch, yaw = data['attitude']
|
||||||
|
self.set_attitute(roll, pitch, yaw, callback=callback)
|
||||||
|
|
||||||
|
self.mpstate.console.set_status(
|
||||||
|
name='sitl_accelcal',
|
||||||
|
text='sitl_accelcal: %s - Waiting for attitude' % data['name'],
|
||||||
|
row=4,
|
||||||
|
fg='orange',
|
||||||
|
)
|
||||||
|
|
||||||
|
def mavlink_packet(self, m):
|
||||||
|
super(AccelcalController, self).mavlink_packet(m)
|
||||||
|
|
||||||
|
if m.get_type() != 'STATUSTEXT':
|
||||||
|
return
|
||||||
|
|
||||||
|
side = self.side_from_msg(m)
|
||||||
|
if side:
|
||||||
|
self.set_side_state(side)
|
||||||
|
else:
|
||||||
|
success = self.report_from_msg(m)
|
||||||
|
if success is None:
|
||||||
|
return
|
||||||
|
|
||||||
|
self.state = None
|
||||||
|
if success:
|
||||||
|
self.mpstate.console.set_status(
|
||||||
|
name='sitl_accelcal',
|
||||||
|
text='sitl_accelcal: Calibration successful',
|
||||||
|
row=4,
|
||||||
|
fg='blue',
|
||||||
|
)
|
||||||
|
else:
|
||||||
|
self.mpstate.console.set_status(
|
||||||
|
name='sitl_accelcal',
|
||||||
|
text='sitl_accelcal: Calibration failed',
|
||||||
|
row=4,
|
||||||
|
fg='red',
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
class SitlCalibrationModule(mp_module.MPModule):
|
class SitlCalibrationModule(mp_module.MPModule):
|
||||||
def __init__(self, mpstate):
|
def __init__(self, mpstate):
|
||||||
super(SitlCalibrationModule, self).__init__(mpstate, "sitl_calibration")
|
super(SitlCalibrationModule, self).__init__(mpstate, "sitl_calibration")
|
||||||
@ -135,6 +253,11 @@ class SitlCalibrationModule(mp_module.MPModule):
|
|||||||
'apply angular velocity on the vehicle with a rotation axis and a '+
|
'apply angular velocity on the vehicle with a rotation axis and a '+
|
||||||
'magnitude in degrees/s',
|
'magnitude in degrees/s',
|
||||||
)
|
)
|
||||||
|
self.add_command(
|
||||||
|
'sitl_accelcal',
|
||||||
|
self.cmd_sitl_accelcal,
|
||||||
|
'actuate on the simulator vehicle for accelerometer calibration',
|
||||||
|
)
|
||||||
self.add_command(
|
self.add_command(
|
||||||
'sitl_stop',
|
'sitl_stop',
|
||||||
self.cmd_sitl_stop,
|
self.cmd_sitl_stop,
|
||||||
@ -143,6 +266,7 @@ class SitlCalibrationModule(mp_module.MPModule):
|
|||||||
|
|
||||||
self.controllers = dict(
|
self.controllers = dict(
|
||||||
generic_controller=CalController(mpstate),
|
generic_controller=CalController(mpstate),
|
||||||
|
accelcal_controller=AccelcalController(mpstate),
|
||||||
)
|
)
|
||||||
|
|
||||||
self.current_controller = None
|
self.current_controller = None
|
||||||
@ -192,6 +316,9 @@ class SitlCalibrationModule(mp_module.MPModule):
|
|||||||
def cmd_sitl_stop(self, args):
|
def cmd_sitl_stop(self, args):
|
||||||
self.set_controller('generic_controller')
|
self.set_controller('generic_controller')
|
||||||
|
|
||||||
|
def cmd_sitl_accelcal(self, args):
|
||||||
|
self.set_controller('accelcal_controller')
|
||||||
|
|
||||||
def mavlink_packet(self, m):
|
def mavlink_packet(self, m):
|
||||||
for c in self.controllers.values():
|
for c in self.controllers.values():
|
||||||
c.mavlink_packet(m)
|
c.mavlink_packet(m)
|
||||||
|
Loading…
Reference in New Issue
Block a user