mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-18 06:38:29 -04:00
HAL_SITL: use motor mask for noise checking for motors
This commit is contained in:
parent
c42acd553e
commit
1871c6bef7
@ -808,8 +808,12 @@ void SITL_State::_simulator_servos(struct sitl_input &input)
|
|||||||
// do a little quadplane dance
|
// do a little quadplane dance
|
||||||
float hover_throttle = 0.0f;
|
float hover_throttle = 0.0f;
|
||||||
uint8_t running_motors = 0;
|
uint8_t running_motors = 0;
|
||||||
for (uint8_t i=0; i < sitl_model->get_num_motors() - 1; i++) {
|
uint32_t mask = _sitl->state.motor_mask;
|
||||||
float motor_throttle = constrain_float((input.servos[sitl_model->get_motors_offset() + i] - 1000) / 1000.0f, 0.0f, 1.0f);
|
uint8_t bit;
|
||||||
|
while ((bit = __builtin_ffs(mask)) != 0) {
|
||||||
|
uint8_t motor = bit-1;
|
||||||
|
mask &= ~(1U<<motor);
|
||||||
|
float motor_throttle = constrain_float((input.servos[motor] - 1000) / 1000.0f, 0.0f, 1.0f);
|
||||||
// update motor_on flag
|
// update motor_on flag
|
||||||
if (!is_zero(motor_throttle)) {
|
if (!is_zero(motor_throttle)) {
|
||||||
hover_throttle += motor_throttle;
|
hover_throttle += motor_throttle;
|
||||||
@ -831,8 +835,12 @@ void SITL_State::_simulator_servos(struct sitl_input &input)
|
|||||||
} else {
|
} else {
|
||||||
// run checks on each motor
|
// run checks on each motor
|
||||||
uint8_t running_motors = 0;
|
uint8_t running_motors = 0;
|
||||||
for (uint8_t i=0; i < sitl_model->get_num_motors(); i++) {
|
uint32_t mask = _sitl->state.motor_mask;
|
||||||
float motor_throttle = constrain_float((input.servos[i] - 1000) / 1000.0f, 0.0f, 1.0f);
|
uint8_t bit;
|
||||||
|
while ((bit = __builtin_ffs(mask)) != 0) {
|
||||||
|
const uint8_t motor = bit-1;
|
||||||
|
mask &= ~(1U<<motor);
|
||||||
|
float motor_throttle = constrain_float((input.servos[motor] - 1000) / 1000.0f, 0.0f, 1.0f);
|
||||||
// update motor_on flag
|
// update motor_on flag
|
||||||
if (!is_zero(motor_throttle)) {
|
if (!is_zero(motor_throttle)) {
|
||||||
throttle += motor_throttle;
|
throttle += motor_throttle;
|
||||||
|
Loading…
Reference in New Issue
Block a user