Old working code

Dependencies:   mbed QEI ros_lib_melodic

main.cpp

Committer:
florine_van
Date:
2019-10-30
Revision:
8:57aa8a35d983
Parent:
7:2cf57f28255d
Child:
10:be9de79cf6b0

File content as of revision 8:57aa8a35d983:

#include "mbed.h"
#include <ros.h>
#include <std_msgs/Empty.h>
#include <std_msgs/Int32.h>
#include <mbed_custom_msgs/lidar_msg.h>

#include "Sensor.h"
#include "Motor.h"

// Set up serial to pc
//Serial pc(SERIAL_TX, SERIAL_RX); 

// Set up I²C on the STM32 NUCLEO-401RE 
#define addr1   (0x29) 
#define addr2   (0x2A)  
#define addr3   (0x2B)
#define addr4   (0x2C)

#define S1 PC_8
#define S2 PC_9
#define S3 PC_10
#define S4 PC_11
#define S5 PC_12
#define S6 PD_2
#define S7 PG_2
#define S8 PG_3 

// VL6180x sensors
Sensor sensor_back(I2C_SDA, I2C_SCL, S1);
Sensor sensor_left(I2C_SDA, I2C_SCL, S3);
Sensor sensor_forward(I2C_SDA, I2C_SCL, S5);
Sensor sensor_right(I2C_SDA, I2C_SCL, S7);

// Motors
Motor motor_left(PC_6, PB_15, PB_13);
Motor motor_right(PA_15, PC_7, PB_4);
    
    /*
void avoidObstacle(const std_msgs::Empty& avoid_obstacle_msg)
{    
    // When obstacle ahead
    if (sensor_forward.getIsObstacle())
    {
        if ( (sensor_right.getIsObstacle()) && (sensor_left.getIsObstacle()) )
        {
            //Turn backward
            while(!sensor_back.getIsObstacle())
            {
                motor_left.moveForward();
                motor_right.moveBackward();  
            }
        }
        if (sensor_left.getIsObstacle())
        {
            //Turn to the right
            motor_left.moveForward();
            motor_right.moveBackward();
        }
        else 
        {
            // By default : turn to the left
            motor_left.moveBackward();
            motor_right.moveForward();      
        }
    }
    // No obstacle
    else
    {
        motor_left.moveForward();
        motor_right.moveForward();
    }
}
*/

//ros::Subscriber<std_msgs::Empty> avoid_obstacle_sub("avoid_obstacle", &avoidObstacle);

int main() 
{
    ros::NodeHandle  nh;
    nh.initNode();
    
    mbed_custom_msgs::lidar_msg int_lidar_msg;
    ros::Publisher lidar_pub("lidar_reading", &int_lidar_msg);
    nh.advertise(lidar_pub);
  
  /*
    std_msgs::Int32 int1_sensor_msg;
    ros::Publisher range_forward_pub("sensor_forward", &int1_sensor_msg);
    nh.advertise(range_forward_pub);
    
    std_msgs::Int32 int2_sensor_msg;
    ros::Publisher range_back_pub("sensor_back", &int2_sensor_msg);
    nh.advertise(range_forward_pub);
    
    std_msgs::Int32 int3_sensor_msg;
    ros::Publisher range_left_pub("sensor_left", &int3_sensor_msg);
    nh.advertise(range_forward_pub);
    
    std_msgs::Int32 int4_sensor_msg;
    ros::Publisher range_right_pub("sensor_right", &int4_sensor_msg);
    nh.advertise(range_forward_pub);
    
    nh.subscribe(avoid_obstacle_sub);

    int range1; 
    int range2;
    int range3;
    int range4; 
*/

    // load settings onto VL6180X sensors 
    sensor_forward.init();
    // change default address of sensor 2
    sensor_forward.changeAddress(addr2);
    
    sensor_right.init();
    // change default address of sensor 3
    sensor_right.changeAddress(addr3);

    sensor_back.init();
    // change default address of sensor 4
    sensor_back.changeAddress(addr4);
    
    sensor_left.init();
    
    //Set Speeds
    motor_left.setSpeed(0.5f);
    motor_right.setSpeed(0.5f);
  
    while (1)
    {            
        int_lidar_msg.sensor_forward  = sensor_forward.read();
        int_lidar_msg.sensor_right  = sensor_right.read();
        int_lidar_msg.sensor_back  = sensor_back.read();
        int_lidar_msg.sensor_left  = sensor_left.read();         

        lidar_pub.publish(&int_lidar_msg);
        //pc.printf("Range forward = %d | range back = %d | range right = %d | range left = %d\r\n",range1, range3, range2, range4); 
                  
        /*
        int1_sensor_msg.data = range1;
        int2_sensor_msg.data = range3;
        int3_sensor_msg.data = range4;
        int4_sensor_msg.data = range2;  
        range_forward_pub.publish(&int1_sensor_msg);     
        range_back_pub.publish(&int2_sensor_msg);  
        range_left_pub.publish(&int3_sensor_msg);     
        range_right_pub.publish(&int4_sensor_msg);  
        */
        
        nh.spinOnce();
        
        //avoidObstacle();
              
        wait_ms(10); 
    } 
}