タコ 駆動側 

Dependencies:   2017NHKpin_config FEP R1307 PID ikarashiMDC omni_wheel

Fork of NHK2017_octopus2 by NagaokaRoboticsClub_mbedTeam

bot/bot.cpp

Committer:
number_key
Date:
2017-11-23
Revision:
54:7176e6a08600
Parent:
52:320f910ca6ca
Child:
55:52b2cb45f21f

File content as of revision 54:7176e6a08600:

#include "bot.h"

Bot::Bot() :
    pad(XBee1TX, XBee1RX, ADDR1),
    RS485(MDTX, MDRX, 115200),
    RS485Controller(PWM1),
    powerSwitch(MDstop),
    quadOmni(&RS485Controller, &RS485),
    plane(),
    axis(),
    receiveSuccessed(0),
    frontDegree(0),
    debugSerial(USBTX, USBRX, 115200)
{
    debugSerial.printf("OK\r\n");

    quadOmni.moveXY(0, 0, 0);
    powerSwitch = true;
}

void Bot::confirmPad()
{
    receiveSuccessed = pad.receiveState();
    if(!pad.getButton2(0) && !pad.getButton2(1)) {
        powerSwitch = 0;
    }
    if(!pad.getButton2(2) && !pad.getButton2(3)) {
        powerSwitch = 1;
    }
    if(!receiveSuccessed) {
        quadOmni.moveXY(0, 0, 0);
    }
}

void Bot::controllDrive()
{
    if(receiveSuccessed) {
        float moment = 0;
        //debugSerial.printf("%d\n\r", plane.getRawDegree());
        /*if(pad.getNorm(0) > 0.5) {
            plane.setPoint((pad.getRadian(0) - M_PI / 2) * (180.0 / M_PI));
            plane.confirm();
        }*/
        plane.confirm();
        if(pad.getStick(0)) {
          moment = -pad.getStick(0) / 2.0;
          plane.resetOffset();
        } else {
          moment = -plane.getCalculationResult();
        }
        debugSerial.printf("%f\r\n",moment);
        quadOmni.moveXY(
                pad.getStick(2),
                -pad.getStick(3),
                0,
                0,
                moment
                );
    } else {
        quadOmni.moveXY(0, 0, 0);
    }
}

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

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

  if((beforestick >= 0.2 && pad.getStick(0) < 0.2) || (beforestick <= -0.2 && pad.getStick(0) > -0.2)) {
      plane.setPoint(0.0);
      plane.resetOffset();
  }
  /*if(!pad.getButton2(1)&&pad.getButton2(3)) {
        plane.setPoint((M_PI / 4)*(180.0 / M_PI));
      } else if(pad.getButton2(1)&&!pad.getButton2(3)){
        plane.setPoint(-(M_PI / 4)*(180.0 / M_PI));
      } else {
        plane.setPoint(0.0);
  }*/
  if(pad.getStick(0) > 0.2 || pad.getStick(0) < -0.2) {
      moment = pad.getStick(0) / 2.0;
  } else  {
      moment = plane.getCalculationResult();

  }
  if(pad.getButton1(0)) {
      norm = pad.getNorm(1);
  } else {
      norm = pad.getNorm(1) / 2.0;
  }
  if(receiveSuccessed) {
      quadOmni.moveCircular(
              norm,
              pad.getRadian(1) - axis.getCurrentDegree() /1.0 * (M_PI / 180.0) + M_PI,
              0.0,
              0.0,
              -moment
              );
  } else {
      quadOmni.moveXY(0, 0, 0);
  }
  beforestick = pad.getStick(0);
}

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(2),
                pad.getStick(3),
                0.0,
                0.0,
                -pad.getStick(0)/2.0
                );
    } else {
        quadOmni.moveXY(0, 0, 0);
    }
}

void Bot::calibrate()
{
}

void Bot::checkConnection()
{
  if(receiveSuccessed == 1) debugSerial.printf("ON \r\n");
  else  debugSerial.printf("OFF \r\n");
}

void Bot::checkDegree()
{
    debugSerial.printf("%f %f\r\n",plane.getRawDegree(), plane.getCalculationResult());
}


void Bot::checkReceiveData()
{
  debugSerial.printf("%f %f %f %f\r\n",pad.getStick(0),pad.getStick(1),pad.getStick(2),pad.getStick(3));
}