タコ 駆動側 

Dependencies:   2017NHKpin_config FEP R1307 PID ikarashiMDC omni_wheel

Fork of NHK2017_octopus2 by NagaokaRoboticsClub_mbedTeam

bot/bot.cpp

Committer:
takeuchi
Date:
2017-10-27
Revision:
45:a3ff2bc0574b
Parent:
44:3466b8e98fd9
Child:
46:9b714d4acdac

File content as of revision 45:a3ff2bc0574b:

#include "bot.h"

Bot::Bot() :
    pad(XBee2TX, XBee2RX, ADDR),
    RS485(MDTX, MDRX, 38400),
    RS485Controller(PWM1),
    powerSwitch(MDstop),
    quadOmni(&RS485Controller, &RS485),
    slider(&RS485Controller, &RS485),
    armMotor({
            ikarashiMDC({&RS485Controller, 1, 1, SM, &RS485}),
            ikarashiMDC({&RS485Controller, 1, 2, SM, &RS485}),
            ikarashiMDC({&RS485Controller, 1, 3, SM, &RS485})
            }),
    receiveSuccessed(0),
    frontDegree(0),
    led({DebugLED3, DebugLED4, DebugLED5}),
    debugSerial(USBTX, USBRX, 115200)
{
    for(int i = 0; i < 3; i++) {
        armMotor[i].braking = true;
    }

    quadOmni.moveXY(0, 0, 0);

    powerSwitch = true;
    for(int i = 0; i < 3; i++) {
        led[i] = true;
        wait(0.1);
        led[i] = false;
    }
}

void Bot::confirmAll()
{
    receiveSuccessed = pad.receiveState();
    if(!pad.getButton2(3) && !pad.getButton2(0)) {
        powerSwitch = 0;
    }
    led[0] = receiveSuccessed;
    if(!receiveSuccessed) {
        quadOmni.moveXY(0, 0, 0);
        slider.slide(0);
        for(int i = 0; i < 3; i++) {
            armMotor[i].setSpeed(0);
        }
    }
}

void Bot::controllDrive()
{
    if(receiveSuccessed) {
        debugSerial.printf("%d\n\r", plane.getRawDegree());
        led[1] = !led[1];
        if(pad.getNorm(1) > 0.5) {
            plane.setSetPoint((pad.getRadian(1) - M_PI / 2) * (180.0 / M_PI));
            plane.confirm();
        }
        quadOmni.moveXY(
                pad.getStick(0),
                -pad.getStick(1),
                0,
                0,
                - pad.getStick(2) / 3.0 // PIDC::calculationResult
                );
    } else {
        quadOmni.moveXY(0, 0, 0);
    }
}

void Bot::controllDrive2()
{
    plane.confirm();
    axis.confirm();
    float moment = 0;
    float norm = 0;
    static float beforestick = pad.getStick(2);

    if(!pad.getButton2(4)) {
        axis.resetOffset();
        debugSerial.printf("Force RESeT\n\r");
    }

    if((beforestick >= 0.2 && pad.getStick(2) < 0.2) || (beforestick <= -0.2 && pad.getStick(2) > -0.2)) {
        plane.setSetPoint(0.0);
        plane.resetOffset();
    }

    if(pad.getStick(2) > 0.2 || pad.getStick(2) < -0.2) {
        moment = pad.getStick(2) / 4.0;
    } else  {
        moment = plane.getCalculationResult();
    }
    if(pad.getButton1(0)) {
        norm = pad.getNorm(0) / 2.0;
    } else {
        norm = pad.getNorm(0);
    }
    if(receiveSuccessed) {
        led[1] = !led[1];
        quadOmni.moveCircular(
                norm,
                pad.getRadian(0) + axis.getCurrentDegree() / 10.0 * (M_PI / 180.0) + M_PI,
                0.0,
                0.0,
                -moment
                );
    } else {
        quadOmni.moveXY(0, 0, 0);
    }
    beforestick = pad.getStick(2);
}

void Bot::controllDrive3()
{
    static int rollR = 0;
    static int rollL = 0;
    static int mode = 1;
    if(receiveSuccessed) {
        if(rollR && !pad.getButton2(2)) {
            frontDegree += ADJUST_DEGREE;
        }
        rollR = pad.getButton2(2);

        if(rollL && !pad.getButton2(0)) {
            frontDegree -= ADJUST_DEGREE;
        }
        rollL = pad.getButton2(0);

        if(!pad.getButton2(4)) {
            mode = 1;
        }

        if(!pad.getButton2(5)) {
            mode = 2;
        }

        if(mode == 1) {
            plane.setPoint(frontDegree);
            plane.confirm();

            quadOmni.moveXY(
                    pad.getStick(0),
                    -pad.getStick(1),
                    0.5,
                    0.5,
                    -plane.getCalculationResult()
                    );
        }
        if(mode == 2) {
            plane.setPoint(90.0 + frontDegree);
            plane.confirm();

            quadOmni.moveXY(
                    -pad.getStick(1),
                    -pad.getStick(0),
                    0.5,
                    0.5,
                    -plane.getCalculationResult()
                    );
        }
    } else {
        quadOmni.moveXY(0, 0, 0);
    }
}

void Bot::controllDrive4()
{
    if(receiveSuccessed) {
        quadOmni.moveXY(
                pad.getStick(0),
                pad.getStick(1),
                0.0,
                0.0,
                -pad.getStick(2)/2.0
                );
    } else {
        quadOmni.moveXY(0, 0, 0);
    }
}
void Bot::controllMech()
{
    if(receiveSuccessed) {
        if(!pad.getButton1(2)) {
            debugSerial.printf("ROLL+\n\r");
            armMotor[ROLL].setSpeed(1.0);
        } else if(!pad.getButton1(4)) {
            debugSerial.printf("ROLL-\n\r");
            armMotor[ROLL].setSpeed(-1.0);
        }
        if(pad.getButton1(2) && pad.getButton1(4)) {
            armMotor[ROLL].setSpeed(0.0);
        }

        if(!pad.getButton2(3)) {
            debugSerial.printf("FUKUDA\n\r");
            armMotor[SWORD].setSpeed(1.0);
        }
        if(!pad.getButton2(2)) {
            debugSerial.printf("FUKUDA\n\r");
            armMotor[SWORD].setSpeed(-1.0);
        }
        if(pad.getButton2(3) && pad.getButton2(2)) armMotor[SWORD].setSpeed(0.0);

        slider.slide(-pad.getStick(3));

        if(!pad.getButton2(1)) {
            debugSerial.printf("DESTROYYY\n\r");
            armMotor[DESTROY].setSpeed(-1.0);
        } else {
            armMotor[DESTROY].setSpeed(0.0);
        }
    } else {
        slider.slide(0);
        for(int i = 0; i < 3; i++) {
            armMotor[i].setSpeed(0);
        }
    }
}


void Bot::calibrate()
{
    if(receiveSuccessed &&
            !pad.getButton2(4) &&
            !pad.getButton2(5)
      ){
        t.start();
        t.reset();
        plane.calibration(HMC6352_ENTER_CALIB);
        while(t.read() < 5.0) {
            quadOmni.moveXY(0, 0, 0.4);
            slider.slide(0);
            for(int i = 0; i < 3; i++) {
                armMotor[i].setSpeed(0);
            }
        }
        t.stop();
        quadOmni.moveXY(0, 0, 0);
        plane.calibration(HMC6352_EXIT_CALIB);
    }
}