Difference between revisions of "F17: Alpha"

From Embedded Systems Learning Academy
Jump to: navigation, search
(Android Application)
(Software Design)
Line 403: Line 403:
  
 
=== Software Design ===
 
=== Software Design ===
Show your software design. For example, if you are designing an MP3 Player, show the tasks that you are using, and what they are doing at a high level. Do not show the details of the code. For example, do not show exact code, but you may show psuedocode and fragments of code. Keep in mind that you are showing DESIGN of your software, not the inner workings of it.
+
1. Bluetooth: Bluetooth allows wirelessly exchange data with another Bluetooth device. Here, We are using Bluetooth to communicate between our self-driving car and mobile application.
 +
 
 +
1.1. Enable Bluetooth : Bluetooth of mobile phone programmatically enabled using BluetoothAdapter. If Bluetooth of mobile is not enabled than enable it.
 +
 
 +
1.2. Connect to Bluetooth on Alpha : A new Socket created using UUID of Bluetooth device on Alpha. Connection request sent by calling connect method on created socket. Here, Connect is blocking call which will return if connection request is accepted and connection established or exception thrown. To establish automatic connection between alpha and mobile device a separate thread is created which continuously check the connection and try make connection in case Alpha is not connected. A connection indicator is used to show connection status.
 +
 
 +
1.3. Read from Alpha : Read the data from input-stream and convert it in accurate Latitude, Longitude and Heading angle. A separate thread is used to continuously read data and update it on the screen.
 +
 
 +
1.4. Write to Alpha : Write the data on output stream so that it can be available on Alpha. In this application Start bit, Stop bit and routing check points are sent to move alpha.
  
 
=== Implementation ===
 
=== Implementation ===

Revision as of 06:39, 12 December 2017

Project Title

Alpha - Self-navigating RC car using CAN communication based on FreeRTOS.

Git Link - ALPHA
Git Users:

  • Anirudh1313
  • chhavi17
  • DoyalPatel
  • jigar29
  • kthnptl
  • rajvisharia
  • ShubhamKulkarni93
  • SnehaSharma
  • SushmaSJSU
  • SuchetaCiyer

Abstract

This section should be a couple lines to describe what your project does.

Objectives & Introduction

Show list of your objectives. This section includes the high level details of your project. You can write about the various sensors or peripherals you used to get your project completed.

Team Members & Responsibilities

  • Master Controller
    • Jigar Agarwal
    • Sucheta Iyer
  • Geographical Controller
    • Krishna Sai Anirudh Katamreddy
    • Chhavi Mehta
  • Sensor Controller
    • Sneha Sharma
    • Sushma Macha
  • Communication Bridge Controller + LCD
    • Kathan Patel
  • Android Application
    • Doyal Patel
    • Sneha Sharma
  • Testing
    • Doyal Patel
    • Jigar Agarwal
    • Sucheta Iyer

Schedule

Week# Start Date End Date Task Status
1 09/15/2017 09/16/2017
  • Read previous projects, gather information and discuss among the group members.
  • Distribute modules to each team member.
Completed
2 09/17/2017 10/03/2017
  • Set up individual Git accounts and perform individual git commits on a GIT file.
  • Create a project report template on Wiki.
  • Finalize the scope of each individual modules.
  • Study the datasheet and prepare the high-level design.
  • Order an RC Car (appropriate height and suspension), rechargeable batteries, sensors, GPS and compass module.
Completed
3 10/04/2017 10/10/2017
  • Sensor: Interface individual sensor and observe the sensor readings under different conditions. Determine pins and architecture of board for all four sensors.
  • Motor: Test DC and servo motors using RC Transmitter and Receiver.
  • Master: CAN bus test interface with the sensor.
  • Communication Bridge Controller: Refer previous projects and get an overview of ‘Communication Bridge Controller’. Deciding the Bluetooth module and place orders based on the requirements.
  • Geo: Testing GPS and compass modules by checking connections from the datasheet.
  • Android: Android development environment setup and basic Android application development.
Completed
4 10/11/2017 10/17/2017
  • Sensor: Generate a DBC structure and acceptance filter for the sensor, and send the distance of an obstacle if any over the CAN bus. Interface multiple sensors and experiment with the angles of the sensors to have minimum interference.
  • Motor: Get the motors running using SJOne board based on the observation of the PWM waveforms for DC and servo motors on the Oscilloscope.
  • Master: Finalizing the PCB design and general hardware model layout. Brainstorming on CAN message details like ID, priority, etc.
  • Communication Bridge Controller: Understanding the RFCOMM Protocol for Bluetooth communication and Bluetooth hardware. Configure Bluetooth module using Bluetooth terminal.
  • Android: Work towards enabling Bluetooth in the Android environment and create a basic application for controlling a Bluetooth-enabled phone.
Completed
5 10/18/2017 10/24/2017
  • Complete all the Hardware setup for the project and prepare sensor stands of suitable height (positioned at suitable angle on the car).
  • Sensor: Develop an algorithm to trigger all the sensors sequentially i.e., MIDDLE, LEFT, RIGHT, and BACK. Interface sensors with LEDs to indicate the direction to be taken.
  • Motor: Get the motors to move Left, Right, Forward and Reverse through CAN communication from Master module (pressing the switches on Master module).
  • Master: Establish CAN communication between all the modules.
  • Communication Bridge Controller: Interfacing Bluetooth module with SJOne board and test the working of the module.
  • Geo: Interface GPS module to SJOne board using UART and collect the data from GPS and calcualte bearing angle.
  • Android: Establish basic communication between SJOne and mobile application.
Completed
6 10/25/2017 10/31/2017
  • Sensor: Calculate minimum and maximum range of obstacle detection and send the values to Master module. Interface the sensors to RC Car and take real-time readings on a moving car.
  • Motor: Design a robust algorithm to avoid obstacles based on the communication with Master and Sensor modules.
  • Master: Interfacing with the Motor Module and Sensor Module.
  • Communication Bridge Controller & Android: Bi-directional communication between SJOne board and Android application.
  • Geo: Take checkpoints at varios locations on the campus.
Completed
7 11/01/2017 11/07/2017
  • 3D print the sensor stands and place them on the board at proper angle and orientation.
  • Sensor: Test the obstacle detection algorithm with various obstacles like hard flat surfaces, curved surface etc. Stress test the sensors under different temperatures.
  • Motor: Get wheel feedback using RPM sensor values for vehicular movement on the slope.
  • Communication Bridge Controller: Interfacing Bluetooth module with the Master module over the CAN Bus.
  • Geo: Integrate GPS module with the compass and calibrating them with SJOne board as per the values obtained. Send Latitude and Longitude of the current position of the car on CAN Bus.
  • Android: Get important data required for the Android application over CAN Bus with the help of the Bluetooth module.
Completed
8 11/08/2017 11/14/2017
  • Motor: Modify the code to move slight left/right, half left/right, full left/right, straight or stop as per the GPS data sent by the Master module.
  • Master: Develop an algorithm to calculate the servo motor angle as er the data from Geo controller in order to move the car closer to the destination.
  • Geo: Send the heading and bearing angle difference based on the current position and next position to the Master module.
  • Communication Bridge Controller: Interfacing Bluetooth module with GPS module over the CAN bus.
  • Android: Add Google map to the application and get current location of the car. Implement an algorithm to find the shortest path by using different position marker on the Google map.
Completed
9 11/15/2017 11/21/2017
  • Car: Get Destination and Routing Path from the Android app. Develop an algorithm to move the car in the given routing path as well as avoiding the obstacles on its way.
  • Android: Communication between Android application and Master node to pass GPS coordinates and routing details.
Completed
10 11/22/2017 11/29/2017
  • Add additional functionalities and indicators on the car.
  • Integrating RC Car controllers as a single unit. Start with the testing, debugging and optimization process.
  • Make the PCB design for the entire unit. Give extra Vcc and ground pins at the ends for added functionalities like headlights and indicators.
In Progress
11 11/30/2017 12/14/2017
  • Completion of the final Wiki page and the report.
  • Further testing and optimization of the project on campus routes.
In Progress
**************Final Demonstration.*************** To Do

Parts List & Cost

Item# Part Desciption Vendor Datasheet Qty Cost
1 RC Car 1
2 CAN Transceivers MCP2551-I/P Microchip [1] MCP2551-I/P Datasheet 8 Free Samples
3 Sonar Sensor Amazon [2] Maxbotix EZ1 MB 1010 Datasheet 4 $24.95
4 Headlights
5 NiMH Battery From seniors 2
6 Charger for NiMH/NiCd Battery From seniors 1
7 Character LCD Display

Sensor Module

The sensor module refers to the sensors and the embedded board that controls the sensors. In this project we have used four Maxbotix EZ0 ultrasonic sensors. Each of these is mounted in four positions. Three sensors face the front of the car and are positioned in the centre, the left edge and right edge of the car. One sensor is mounted on the back of the car.

The main goal of the sensor module is to detect the distance to an obstacle, from the car and provide this information to the driver module so that it can successfully avoid the obstacle.

Hardware Design

The sensors used are LV-MaxSonar-EZ1 Ultrasonic Range Finder MB1010.

The valid sensors output is a value between 6 and 254. This value is in inches and represents the distance to the obstacle, from the sensor. It is to be noted that if the obstacle is closer than 6 inches from the sensor it will not be detected.

The sensor provides output in three forms; As a pulse on the PW pin, where pulse width represents the distance to obstacle; As an analog voltage on the AN pin; As a digital output on the TX pin, in RS-232 format. We have used the PW pin in this project to receive the input from the sensor.

It is to be noted that if two sensors which are placed so that their beams/detection areas overlap, are ranging at the same time, they cause each other interference and hence incorrect values. Hence we trigger each sensor separately one by one so that at any time, only one sensor is ranging.

<insert image of sensor here. mark all the pins - vcc gnd tx rx pw> <insert image of two sensors placed close by so that their beams are overlapping>

Pin connections - middle sensor

Hardware Interface

Pin connections for each sensor is as follows:

PW (Pin 2) - GPIO Pin configured as interrupt to receive input from sensor

RX (Pin 4) - GPIO Pin configured as output to trigger the sensor

VCC (Pin 6) - +5V

GND (Pin 7) - GND

Pin connections for the middle sensor are displayed.






Software Design

Sensor CAN message

As described in the previous section, the sensors are triggered one by one to prevent corruption of data. In our implementation the sensors are triggered in the following order: middle, right, left and back. The back and left sensors are triggered together since they would not interfere with each other.

Every sensor needs a power up time of 250 ms and some time to calibrate and take the first reading. After this period the sensor can provide a reading every 49 ms. In our implementation, all 4 sensor values are taken every 120 ms and put on the CAN bus. The format of the CAN message is shown in the following snippet taken from the DBC file. It can be observed that the sensor message has a high priority since it is critical to the operation of the car.

Implementation

The following steps are followed to get a valid sensor reading.

1. Initialize the sensors - account for power up and calibration delay.

2. Enable falling edge interrupts and setup callback functions - this is to record the pulse width output of the sensor

3. Trigger each sensor and record the current time. This is the start time.

4. When falling edge interrupt occurs record the time. This is the end time.

5. Calculate pulse width using the start and end time. This pulse width would indicate the distance to the obstacle.

Sensor operation flowchart

Testing & Technical Challenges

There were a few difficulties during implementation and testing of the sensors. Lessons learned include the following:

1. Research different types of sensors, find out the strengths and weaknesses of each before making a decision.

2. Ultrasonic sensors need to be slightly tilted upwards when mounted on the car to prevent them from accidentally detecting ground as an obstacle. This becomes especially necessary when testing on a slope/ramp.

3. Ultrasonic sensors are very sensitive and care needs to be taken while soldering them. Accidental overheating can cause them to be destroyed.

4. The ultrasonic sensors provide more range when +5V is used as supply rather than +3.3V.

5. Testing both indoors and outdoors is necessary to check if the sensor readings are accurate in both conditions.


Motor Module

Motor module is one of the five controllers used in our self-driving car. Motor controller is responsible for driving the car forward and for steering the vehicle. The motor module has two motors viz.DC motor and Servo motor. DC motor makes the car move forward and reverse. Servo motor steers the car either left or right. Along with the two motors we have the rpm speed sensor which is interfaced with our controller to control the speed of DC and move the car at a desired speed in Miles per Hour(MPH).

Team Members

Hardware Design

Hardware Interface

Software Design

Implementation

The following steps

1.

2.

Testing & Technical Challenges

There were a few difficulties during implementation and testing of motors

1.

2.

Geographical Controller

The design section can go over your hardware and software design. Organize this section using sub-sections that go over your design and implementation.

Hardware Design

Discuss your hardware design here. Show detailed schematics, and the interface here.

Hardware Interface

In this section, you can describe how your hardware communicates, such as which BUSes used. You can discuss your driver implementation here, such that the Software Design section is isolated to talk about high level workings rather than inner working of your project.

Software Design

Show your software design. For example, if you are designing an MP3 Player, show the tasks that you are using, and what they are doing at a high level. Do not show the details of the code. For example, do not show exact code, but you may show psuedocode and fragments of code. Keep in mind that you are showing DESIGN of your software, not the inner workings of it.

Implementation

This section includes implementation, but again, not the details, just the high level. For example, you can list the steps it takes to communicate over a sensor, or the steps needed to write a page of memory onto SPI Flash. You can include sub-sections for each of your component implementation.

Testing & Technical Challenges

Describe the challenges of your project. What advise would you give yourself or someone else if your project can be started from scratch again? Make a smooth transition to testing section and described what it took to test your project.

Include sub-sections that list out a problem and solution, such as:

<Bug/issue name>

Discuss the issue and resolution.

Android Application

An google map based android application is developed to provide information to Alpha which is required to reach destination like routing information between source and destination as well as software based commands to start and to stop Alpha. This application also displays information about current position and heading angle of Alpha.

Hardware Design

N/A

Hardware Interface

Interfaced to Bluetooth module (As explained in Bluetooth Module).

Software Design

1. Bluetooth: Bluetooth allows wirelessly exchange data with another Bluetooth device. Here, We are using Bluetooth to communicate between our self-driving car and mobile application.

1.1. Enable Bluetooth : Bluetooth of mobile phone programmatically enabled using BluetoothAdapter. If Bluetooth of mobile is not enabled than enable it.

1.2. Connect to Bluetooth on Alpha : A new Socket created using UUID of Bluetooth device on Alpha. Connection request sent by calling connect method on created socket. Here, Connect is blocking call which will return if connection request is accepted and connection established or exception thrown. To establish automatic connection between alpha and mobile device a separate thread is created which continuously check the connection and try make connection in case Alpha is not connected. A connection indicator is used to show connection status.

1.3. Read from Alpha : Read the data from input-stream and convert it in accurate Latitude, Longitude and Heading angle. A separate thread is used to continuously read data and update it on the screen.

1.4. Write to Alpha : Write the data on output stream so that it can be available on Alpha. In this application Start bit, Stop bit and routing check points are sent to move alpha.

Implementation

This section includes implementation, but again, not the details, just the high level. For example, you can list the steps it takes to communicate over a sensor, or the steps needed to write a page of memory onto SPI Flash. You can include sub-sections for each of your component implementation.

Testing & Technical Challenges

Describe the challenges of your project. What advise would you give yourself or someone else if your project can be started from scratch again? Make a smooth transition to testing section and described what it took to test your project.

Conclusion

Conclude your project here. You can recap your testing and problems. You should address the "so what" part here to indicate what you ultimately learnt from this project. How has this project increased your knowledge?

Project Video

Upload a video of your project and post the link here.

Project Source Code

References

Acknowledgement

Any acknowledgement that you may wish to provide can be included here.

References Used

List any references used in project.

Appendix

You can list the references you used.