Matrice600pro не вращается на OSDK в реальном мире - PullRequest
0 голосов
/ 28 ноября 2018

Я разрабатываю программное обеспечение Matrice600pro osdk.

, когда я пытался повернуть БПЛА с помощью этого кода:

bool rotateToTargetYaw(float targetYaw)
{
    float nowYaw;
    float yawDiff;
    bool blnEmergencyAvoidanceOccured;
    int responseTimeout    = 1;
    int timeoutInMilSec    = 10000;
    int controlFreqInHz    = 50; // Hz
    int cycleTimeInMs      = 1000 / controlFreqInHz;
    int elapsedTimeInMs    = 0;
    int brakeCounter        = 0;
    int withinControlBoundsTimeReqmt = 50 * cycleTimeInMs;
    int withinBoundsCounter = 0;
    int outOfBounds         = 0;
    int outOfControlBoundsTimeLimit  = 10 * cycleTimeInMs; // 10 cycles

    //! Main closed-loop receding setpoint position control
    while (elapsedTimeInMs < timeoutInMilSec)
    {
        uint8_t ctrl_flag = ( Control::VERTICAL_VELOCITY | Control::HORIZONTAL_VELOCITY | Control::YAW_ANGLE | Control::HORIZONTAL_BODY | Control::STABLE_ENABLE);
        Control::CtrlData data(ctrl_flag, 0, 0, 0, targetYaw);
        gVehicle->control->flightCtrl(data);
        usleep(cycleTimeInMs * 1000);
        elapsedTimeInMs += cycleTimeInMs;

        nowYaw =  Util::GetYawDeg();

        yawDiff = std::abs(Util::degRangeConv(nowYaw - targetYaw));

        if(yawDiff < 1.0){
              withinBoundsCounter += cycleTimeInMs;
              Util::log("withinBoundsCounter add (=%d)\n",withinBoundsCounter);
        } else {
            if (withinBoundsCounter != 0){
                outOfBounds += cycleTimeInMs;
                Util::log("outOfBounds add(=%d)\n",outOfBounds);
            }
          }
        //! 3. Reset withinBoundsCounter if necessary
        if (outOfBounds > outOfControlBoundsTimeLimit)
        {
            Util::log("withinBoundsCounter and outOfBounds reset\n");
            withinBoundsCounter = 0;
            outOfBounds         = 0;
        }

        if (withinBoundsCounter >= withinControlBoundsTimeReqmt)
        {
            Util::log("goal withinBoundsCounter(%d)withinControlBoundsTimeReqmt(%d)\n",withinBoundsCounter,withinControlBoundsTimeReqmt);
            break;
        }
    }

    //! Set velocity to zero, to prevent any residual velocity from position
    //! command
    while (brakeCounter < withinControlBoundsTimeReqmt)    {
        gVehicle->control->emergencyBrake();
        usleep(cycleTimeInMs * 10);
        brakeCounter += cycleTimeInMs;
    }

    return ACK::SUCCESS;
}


// return current Yaw(deg)
float Util::GetYawDeg() {
    TypeMap<TOPIC_QUATERNION>::type  quaternion;

    quaternion   = gVehicle->subscribe->getValue<TOPIC_QUATERNION>();

    float yawDeg   = std::atan2(
                2.0 * (quaternion.q3 * quaternion.q0 + quaternion.q1 * quaternion.q2) ,
                - 1.0 + 2.0 * (quaternion.q0 * quaternion.q0 + quaternion.q1 * quaternion.q1));
    return yawDeg * RAD2DEG;
} 

rotateToTargetYaw () работает, когда я вызываю эту функцию с помощью симулятора (DJI)Помощник), но он вообще не работает в реальном мире.

Подписка на QUATERNION работает без проблем.

Я проверил, что для параметра «Контроль API включено» установлено значение True с DJI Assistant.

У кого-нибудь есть совет?

...