Six crescent shaped legs

Dependencies:   mbed

main.cpp

Committer:
phairero
Date:
2016-05-17
Revision:
30:476ab400d765
Parent:
29:f905e66e1a6f
Child:
31:8d8d31b6d8cd

File content as of revision 30:476ab400d765:

#include "mbed.h"
#include "EncoderMotor.hpp"
#include "SyncGroup.hpp"

InterruptIn bt(USER_BUTTON);
Serial pc(PA_0, PA_1); //RF
//Serial pc(SERIAL_TX, SERIAL_RX);
//Serial pc(USBTX, USBRX);

//PIDData speedPIDData = {0.3f, 2.0f, 0.02f};
//PIDData turnPIDData = {5.0f, 0.1f, 0.04f};
PIDData speedPIDData = {0.5f, 0.0f, 0.0f};
PIDData turnPIDData = {30.0f, 0.01f, 1.0f};
SyncGroup sync;

/*
PWM timer channel
M1 1 2N
M2 4 2
M3 2 1
M4 4 4
M5 1 3N
M6 2 2
*/
    
// 1
MotorData m1Data = {PB_0, PC_0, PC_3}; //PWM, Dir1, Dir2
EncoderData enc1Data = {PC_1, PA_4, 102.083 * 64}; //EncA, encB  // https://www.pololu.com/product/2826
EncoderMotor m1(m1Data, enc1Data, speedPIDData, turnPIDData, NULL);

// 2
MotorData m2Data = {PB_7, PC_14, PC_13};  //PB7 = fault
EncoderData enc2Data = {PC_15, PH_0, 102.083 * 64};
EncoderMotor m2(m2Data, enc2Data, speedPIDData, turnPIDData, NULL);

// 3
MotorData m3Data = {PA_15, PC_11, PC_10}; 
EncoderData enc3Data = {PC_12, PA_13, 102.083 * 64};
EncoderMotor m3(m3Data, enc3Data, speedPIDData, turnPIDData, NULL);

// 4
MotorData m4Data = {PB_8, PC_6, PC_9}; 
EncoderData enc4Data = {PC_5, PA_12, 102.083 * 64};
EncoderMotor m4(m4Data, enc4Data, speedPIDData, turnPIDData, NULL);

// 5
MotorData m5Data = {PB_15, PB_1, PB_2}; 
EncoderData enc5Data = {PB_14, PB_13, 102.083 * 64};
EncoderMotor m5(m5Data, enc5Data, speedPIDData, turnPIDData, NULL);

// 6
MotorData m6Data = {PB_3, PA_10, PA_2};  //PA_2 = TX; PA_3 (m6-fault) = RX
EncoderData enc6Data = {PB_5, PB_4, 102.083 * 64};
EncoderMotor m6(m6Data, enc6Data, speedPIDData, turnPIDData, NULL); 

const int MOTORS = 6;
EncoderMotor* ms[MOTORS] = {&m1, &m2, &m3, &m4, &m5, &m6};
volatile int active = 0;

Ticker ticker;

void rise()
{
    //pc.printf("rise\n");
    //m1.drive(0);
}

void fall()
{
    //pc.printf("fall\n");
    //m1.drive(0.25);
}

void tick()
{
    for (int i = 0; i < MOTORS; i++)
        ms[i]->tick();
}

const float tickTime = 1.f / 60;

int main()
{   
    printf("MAIN\n");
    bt.rise(&rise);
    bt.fall(&fall);
    
    //ms[active]->drive(0.25);
    
    ticker.attach(&tick, tickTime);
    
    float rot, speed;
    
    while(1)
    {
        /*int oldactive = active;
        scanf("%d", &active);
        active--;
        ms[oldactive]->drive(0);
        ms[active]->drive(0.25);*/
        
        for (int i = 0; i < MOTORS; i++)
            pc.printf("%ld ", ms[i]->encoder.getCount());
        pc.printf("\n");
        
        //pc.printf("%d", active);
        //scanf("%f", &turn);
        //m.rotate(turn, 0.2);
        //scanf("%f %f", &rot, &speed);
        //m1.rotate(rot, speed);
        //m.drive(speed);
        //printf("%f %f\n", s.getTurnSpeed(), m.getSetSpeed());
        //printf("%f %f\n", m.s, m.getSetSpeed());
        //printf("%ld %f %f\n", m1.getEncoder().getCount(), m1.getEncoder().getTurn(), m1.getSetTurn());
        //printf("%f %f\n", m.getEncoder().getTurn(), m.getSetTurn());
        wait(1.f / 10);
    }
}