自己位置推定機能を追加

Dependencies:   SBDBT arrc_mbed BNO055

main.cpp

Committer:
kazumayamanaka
Date:
2022-02-23
Revision:
7:a0b9b6e71e41
Parent:
2:e189d55ef292
Child:
8:f2407caf81ba

File content as of revision 7:a0b9b6e71e41:

#include "mbed.h"
#include "rotary_inc.hpp"
#include "PIDco.hpp"
#include "TARGETco.hpp"
#include "DUALSHOCKco.hpp"
#include "Odmetry.hpp"
#include "sbdbt.hpp"
#include "BNO055.h"
#define SDA D3
#define SCL D6
#define PI 3.1415926535897

Serial pc(USBTX,USBRX);

RotaryInc data_1(PA_14,PA_15,0);
RotaryInc data_2(PA_12,PC_5,0);
RotaryInc data_3(PC_0,PC_1,0);
RotaryInc data_4(PC_2,PC_3,0);

RotaryInc MW_1(PA_13,PC_4,0);
RotaryInc MW_2(PC_10,PC_11,0);
RotaryInc MW_3(PA_7,PA_6,0);
RotaryInc MW_4(PA_8,PA_9,0);

PIDco pid_1;
PIDco pid_2;
PIDco pid_3;
PIDco pid_4;

TARGETco TG;
BNO055 bno(SDA,SCL);
DUALSHOCKco DS;
Odmetry odmetry;
sbdbt sb(PA_0,PA_1);

Timer Time;
bool mode=false;
double timer;
double theta;
double automaticsX(double PosX);
double automaticsY(double PosY);
double automaticsTHETA(double THETA);
void automatics();

int main(){
    Time.start();
    bno.reset();
    
    while(1){
        timer = Time.read_us();
        bno.setmode(OPERATION_MODE_IMUPLUS);
        bno.get_angles();
        
        if(sb.circle()!=0){
            mode = true;
        }
        if(sb.square()!=0){
            mode = false;
        }
        
        theta = bno.euler.yaw * (PI / 180);
        
        if(theta > PI){
            theta = -(2 * PI - theta);
        }
        
        theta = theta - PI / 4;
        
        if(mode == false){
            DS.pass_val(sb.rsx(),sb.rsy(),sb.r2An(),sb.l2An());
        
            if(DS.cal_input() == true){
                TG.pass_val(DS.obt_X(),DS.obt_Y(),theta);
            }
            else{
                TG.pass_target(DS.obt_X());
            }
        }
        else{
            automatics();
        }
        
        pid_1.pass_val(data_1.get(),TG.obt_target1());
        pid_2.pass_val(data_2.get(),TG.obt_target2());
        pid_3.pass_val(data_3.get(),TG.obt_target3());
        pid_4.pass_val(data_4.get(),TG.obt_target4());
        
        pid_1.wheel_ctl(PC_9,PC_8);
        pid_2.wheel_ctl(PB_14,PB_13);
        pid_3.wheel_ctl(PB_5,PB_4);
        pid_4.wheel_ctl(PB_7,PB_6);
        
        odmetry.pass_pulse(MW_1.get(),MW_2.get(),MW_3.get(),MW_4.get());
        odmetry.pass_angle(theta);
        odmetry.print_Pos();
        //pc.printf("%lf,%lf,%lf,%lf,%lf,%lf,%lf,%lf\n",TG.obt_target1(),TG.obt_target2(),TG.obt_target3(),TG.obt_target4(),pid_1.obt_spd(),pid_2.obt_spd(),pid_3.obt_spd(),pid_4.obt_spd());
        while(Time.read_us() - timer <= 50 * 1000);
        }
        automatics();
}

double automaticsX(double PosX){
    if(PosX > 0){
        if(PosX <= odmetry.obt_CurrentPosX())return 0;
        else return 100;
    }
    else{
        if(PosX >= odmetry.obt_CurrentPosX())return 0;
        else return -100;
    }
}
double automaticsY(double PosY){
    if(PosY > 0){
        if(PosY <= odmetry.obt_CurrentPosY())return 0;
        else return -100;
    }
    else{
        if(PosY >= odmetry.obt_CurrentPosY())return 0;
        else return 100;
    }
}
double automaticsTHETA(double THETA){
    if(THETA > 0){
        if(THETA <= odmetry.obt_CurrentTheta())return 0;
        else return -70;
    }
    else{
        if(THETA >= odmetry.obt_CurrentTheta())return 0;
        else return 70;
    }
}
void automatics(){
    if(automaticsY(100) != 0 || automaticsX(500) !=0){ 
        TG.pass_val(automaticsY(100),automaticsX(500),theta);
    }
    else{
        TG.pass_target(automaticsTHETA(PI / 4));
    }
}
    

//BNOのピン(PB_3,PB_10)