Difference between revisions of "S19: CANT Bus"
| Proj user4 (talk | contribs)  (→Hardware Design) | Proj user4 (talk | contribs)   (→Hardware Design) | ||
| Line 394: | Line 394: | ||
| [[File:ServoD645.png|thumb|400px|left|Figure X: Architecture of Motor Controller]][[File:brushmotor.png|thumb|400px|center|Figure X: Architecture of Motor Controller]] | [[File:ServoD645.png|thumb|400px|left|Figure X: Architecture of Motor Controller]][[File:brushmotor.png|thumb|400px|center|Figure X: Architecture of Motor Controller]] | ||
| [[File:hallsensor.png|thumb|400px|right|Figure X: Architecture of Motor Controller]][[File:Motordriver.png|thumb|400px|center|Figure X: Architecture of Motor Controller]] | [[File:hallsensor.png|thumb|400px|right|Figure X: Architecture of Motor Controller]][[File:Motordriver.png|thumb|400px|center|Figure X: Architecture of Motor Controller]] | ||
| + | |||
| + | The servo that we are using is the Hitech645MW, along with a brushless motor, hall sensor, and 12-bit PWM/Servo Driver - I2C interface - PCA9685. After all devices are properly powered up the motor driver will connect to the brushless motor to provide a PWM signal of 100Hz, with duty cycles (60%(backwards)-70%(stop)-80%(forward))is used to control the speed. The servo is directly connected the SJone board using a PWM pin setting the frequency at 50Hz (with dutycycles ranging from 8%(left), 6%(middle), 4%(right)) to control the direction of the RC car. Lastly, the hall sensor was connected directly to the SJone board using a GPIO pin set up as an interrupt. | ||
| === Software Design === | === Software Design === | ||
Revision as of 00:51, 23 May 2019
Contents
Grading Criteria
- How well is Software & Hardware Design described?
- How well can this report be used to reproduce this project?
- Code Quality
-   Overall Report Quality:
- Software Block Diagrams
-   Hardware Block Diagrams
- Schematic Quality
 
- Quality of technical challenges and solutions adopted.
 
Project Title
[C]ompile [A]nother [N]on-[T]rivial Bus
Abstract
Design and implement an autonomous car to navigate to a destined location chosen by the user using a phone application. The user will set gps coordinates via an Android application while the current location is processed. The RC car should be able to use these coordinates to navigate itself to the destined location avoiding obstacles and providing useful data on the way. Several objectives need to be completed in order for the RC car to function properly: integrate proximity sensors, gps, compass, lcd screen, motor driver board, esp32 communication, hall sensor, and overall integration in order for the RC car to be able to determine where it is, the speed it's going, and the environment around it to successfully navigate to the final destination.
Introduction
The purpose of this project was to convert a RC car into a self driving vehicle that can navigate itself to a destination sent via an Android mobile app. To achieve this, the project was divided into 7 modules: Avoidance, Motor, Master Driver, Localize, Comms, and Android Application. The Avoidance module contains 8 IR sensors that allow the car to see the world around it. This module finds objects and measures the distance between it and the object. Motor controls a brushed motor which drives the car at various speeds and a servo to turn the car. In addition, Motor also contains a hall effect sensor that keeps track of the cars speed. Localize tells the car where it is in relation to where it needs to go. It contains a GPS and Compass to provide current coordinates and heading. Comms houses the wireless device that talks to the the mobile app as well as an LCD display to show various car data such as speed and destination. The mobile app is where the user can enter GPS coordinates as a destination point, or alter the current destination with a way-point. Lastly, the Driver receives the data from all modules and decides how the car shall react. In order to complete these modules basic knowledge of I2C, UART, SPI, and CAN bus protocols, gpio control, PWM control, phone application development, and pathing algorithms was required. While each peripheral in the modules used their own form of communication, each of the modules was connected using the CAN bus protocol.
Team Members & Responsibilities
-  Kevin Chan
- IR sensors (Proximity), Compass (Localize), GPS(Localize), Code Review
 
-  Khrysta Finch
- Chassis, Driver (Driver), LCD display (Comms), Schematic, Telemetry (Comms)
 
-  Andrew Javier
- Hall Sensor (Motor), Wireless communications via esp32(Comms), GPS (Localize), Chassis
 
-  Aaron Lee
- GPS (Localize), Pathing Algorithm (Comms)
 
-  Jonathan Rojas
- Motor (Motor), Servo (Motor), Motor driver board (Motor), hall sensor (Motor), Cable Management, Chassis
 
-  Vijay Vanapalli
- GPS (Localize), Wireless communications via esp32(Comms), Mobile app (Comms)
 
-  Nelson Wong
- Team Leader, Driver (Driver), Telemetry (Comms), PCB/Schematic, Chassis, Mobile App (Comms), Power, Code Review
 
Source Code
Modules
- Driver
- Proximity
- Motor
-  Localize
- Vijay Vanapalli
- Aaron Lee
- Andrew Javier
- Kevin Chan
 
-  Comms
- Andrew Javier
- Vijay Vanapalli
- Khrysta Finch
 
-  Android Application
- Vijay Vanapalli
 
-  Testing Team
- Kevin Chan
- Nelson Wong
 
Schedule
Show a simple table or figures that show your scheduled as planned before you started working on the project. Then in another table column, write down the actual schedule so that readers can see the planned vs. actual goals. The point of the schedule is for readers to assess how to pace themselves if they are doing a similar project.
| Week# | Start Date | End Date | Task Description | Status | Completion Date | 
|---|---|---|---|---|---|
| 1 | 3/4 | 3/10 | 
 | Complete | |
| 2 | 3/11 | 3/17 | 
 | ||
| 3 | 3/18 | 3/24 | 
 | ||
| 4 | 3/25 | 3/31 | 
 | ||
| 5 | 4/1 | 4/7 | 
 | ||
| 6 | 4/8 | 4/14 | 
 | ||
| 7 | 4/15 | 4/21 | 
 | ||
| 8 | 4/22 | 4/28 | 
 | ||
| 9 | 4/29 | 5/5 | 
 | ||
| 10 | 5/6 | 5/12 | 
 | 
Parts List & Cost
| Item# | Part Desciption | Vendor | Qty | Cost | 
|---|---|---|---|---|
| 1 | RC Car | Traxxas | 1 | $250.00 | 
| 2 | CAN Transceivers MCP2551-I/P | Microchip [1] | 8 | Free Samples | 
Printed Circuit Board
<Picture and information, including links to your PCB>
CAN Communication
CAN BUS Messages
The DBC file that was used to generate our CAN messages can be found below. Each message has a priority ID assigned to it that is used by the CAN protocol to see which device to listen to first in cases of bus arbitration; the lower the ID number the higher priority it has. In our case, the message with the highest priority at 10 is KILL_MOTOR. Since we are using LiPO (Lithium Polymer) batteries, the desire to disconnect all power for the battery depleted was high on the list. Should the car be driving at that time, the KILL_MOTOR_cmd shuts off the motor immediately, allowing us to catch up to the car and swap out batteries. The KILL_MOTOR_REMOTE message follows the KILL_MOTOR message in priority. This is simply a redundancy we built in to have the message delivered to the mobile app and notifying us that the battery is low.
The priority decreases from there with HEARTBEAT from the Driver being the next highest. Since the Driver doesn't send many messages and it's there to collect data from all the other modules, it needs to let the others know it's still available. MOTOR_CMD follows as we wanted the car to move as quickly as possible, which leads to AVOIDANCE_LIDAR as the next highest. Knowing when we were in close proximity to an object is key to making sure we don't run into it. Note that while this message has "LIDAR" as part of the name, this is legacy nomenclature from when we initially had LIDAR for the car. They are now IR sensors.
GPS, Compass, and Speed were assigned the lowest priorities. While knowing where we are in relation to where we are going is important, it was less demanding that knowing if we are about to hit something or if the battery was depleted. Overall, this choice in priority has served well in providing a functional autonomous car.
???? not sure what is going on here
VERSION "0.1.0"
BU_: MASTER SENSOR MOTORIO GEO APP
BO_ 101 MOTOR_CMD: 2 DRIVER
SG_ MOTOR_CMD_steer : 0|3@1+ (1,-1) [-1|1] "degrees" MOTOR SG_ MOTOR_CMD_drive : 8|4@1+ (1,-2) [-2|5] "" MOTOR
BO_ 200 AVOIDANCE_LIDAR: 8 AVOIDANCE
SG_ LIDAR_f_right : 0|8@1+ (1,0) [0|0] "cm" DRIVER SG_ LIDAR_f_middle : 8|8@1+ (1,0) [0|0] "cm" DRIVER SG_ LIDAR_f_left : 16|8@1+ (1,0) [0|0] "cm" DRIVER SG_ LIDAR_b_right : 24|8@1+ (1,0) [0|0] "cm" DRIVER SG_ LIDAR_b_middle : 32|8@1+ (1,0) [0|0] "cm" DRIVER SG_ LIDAR_b_left : 40|8@1+ (1,0) [0|0] "cm" DRIVER
BO_ 301 LOCALIZE_IMU: 8 LOCALIZE
SG_ IMU_STATUS : 0|8@1+ (1,0) [0|0] "" DRIVER,COMMS SG_ IMU_COMPASS : 8|12@1+ (0.1,0) [0|360.0] "degrees" DRIVER,COMMS
BO_ 500 SET_WAYPOINT: 8 COMMS
SG_ SET_WAYPOINT_LAT : 0|24@1+ (0.000001,37.000000 [37.000000|38.000000] "degrees" DRIVER SG_ SET_WAYPOINT_LONG : 24|24@1- (0.000001,-122.000000) [-122.000000|-121.000000] "degrees" DRIVER
CM_ BU_ DRIVER "The Driver controller of the car";
CM_ BU_ MOTOR "The motor controller of the car";
CM_ BU_ AVOIDANCE "The avoidance controller of the car";
CM_ BU_ LOCALIZE "The localize controller of the car";
CM_ BU_ COMMS "The Bluetooth/App controller of the car";
Hardware Design
<Show your CAN bus hardware design>
CAN DBC File
243.dbc
VERSION "1.0"
NS_ :
    BA_
    BA_DEF_
    BA_DEF_DEF_
    BA_DEF_DEF_REL_
    BA_DEF_REL_
    BA_DEF_SGTYPE_
    BA_REL_
    BA_SGTYPE_
    BO_TX_BU_
    BU_BO_REL_
    BU_EV_REL_
    BU_SG_REL_
    CAT_
    CAT_DEF_
    CM_
    ENVVAR_DATA_
    EV_DATA_
    FILTER
    NS_DESC_
    SGTYPE_
    SGTYPE_VAL_
    SG_MUL_VAL_
    SIGTYPE_VALTYPE_
    SIG_GROUP_
    SIG_TYPE_REF_
    SIG_VALTYPE_
    VAL_
    VAL_TABLE_
BS_:
BU_: COMMS DRIVER LOCALIZE MOTOR AVOIDANCE
BO_ 10 KILL_MOTOR: 1 DRIVER
 SG_ KILL_MOTOR_cmd : 0|8@1+ (1,0) [0|0] "" MOTOR,COMMS
 
BO_ 11 KILL_MOTOR_REMOTE: 1 COMMS
 SG_ KILL_MOTOR_cmd : 0|8@1+ (1,0) [0|0] "" DRIVER 
 
BO_ 100 DRIVER_HEARTBEAT: 1 DRIVER
 SG_ DRIVER_HEARTBEAT_cmd : 0|8@1+ (1,0) [0|0] "" LOCALIZE,COMMS,AVOIDANCE,MOTOR 
BO_ 101 MOTOR_CMD: 2 DRIVER
 SG_ MOTOR_CMD_steer : 0|6@1+ (1,-30) [-30|30] "degrees" MOTOR
 SG_ MOTOR_CMD_drive : 8|7@1+ (1,0) [0|100] "" MOTOR
BO_ 200 AVOIDANCE_LIDAR: 8 AVOIDANCE
 SG_ LIDAR_f_right : 0|8@1+ (1,0) [0|0] "cm" DRIVER
 SG_ LIDAR_f_middle : 8|8@1+ (1,0) [0|0] "cm" DRIVER
 SG_ LIDAR_f_left : 16|8@1+ (1,0) [0|0] "cm" DRIVER
 SG_ LIDAR_b_right : 24|8@1+ (1,0) [0|0] "cm" DRIVER
 SG_ LIDAR_b_middle : 32|8@1+ (1,0) [0|0] "cm" DRIVER
 SG_ LIDAR_b_left : 40|8@1+ (1,0) [0|0] "cm" DRIVER
BO_ 300 LOCALIZE_GPS: 8 LOCALIZE
 SG_ GPS_STATUS : 0|8@1+ (1,0) [0|0] "" DRIVER,COMMS
 SG_ GPS_TX_LATITUDE : 8|24@1+ (0.000001,37.000000) [37.000000|38.000000] "degrees" DRIVER,COMMS
 SG_ GPS_TX_LONGITUDE : 32|24@1- (0.000001,-122.000000) [-122.000000|-121.000000] "degrees" DRIVER,COMMS
BO_ 301 LOCALIZE_IMU: 8 LOCALIZE
 SG_ IMU_STATUS : 0|8@1+ (1,0) [0|0] "" DRIVER,COMMS
 SG_ IMU_COMPASS : 8|12@1+ (0.1,0) [0|360.0] "degrees" DRIVER,COMMS
 
BO_ 302 SPEED: 8 LOCALIZE
 SG_ SPEED_kph : 0|16@1- (0.001,0) [-5|10] "kph" COMMS,DRIVER
 
BO_ 400 MOTOR_STATUS: 1 MOTOR
 SG_ MOTOR_STATUS_data : 0|8@1+ (1,0) [0|0] "" COMMS,DRIVER
 
BO_ 500 SET_WAYPOINT: 8 COMMS
 SG_ SET_WAYPOINT_LAT : 0|24@1+ (0.000001,37.000000) [37.000000|38.000000] "degrees" DRIVER
 SG_ SET_WAYPOINT_LONG : 24|24@1- (0.000001,-122.000000) [-122.000000|-121.000000] "degrees" DRIVER
BO_ 501 SET_STATUS: 1 COMMS
 SG_ SET_STATUS_cmd : 0|8@1+ (1,0) [0|0] "" DRIVER
CM_ BU_ DRIVER "The driver controller driving the car";
CM_ BU_ MOTOR "The motor controller of the car";
CM_ BU_ LOCALIZE "The localization controller of the car";
CM_ BU_ AVOIDANCE "The collision avoidance controller of the car";
CM_ BU_ COMMS "The wireless comms and telemetry controller of the car";
CM_ BO_ 100 "Sync message used to synchronize the controllers";
CM_ BO_ 501 "0: stop, 1: ready, 2: navigate, 3: skip/next"
BA_DEF_ "BusType" STRING ;
BA_DEF_ BO_ "GenMsgCycleTime" INT 0 0;
BA_DEF_ SG_ "FieldType" STRING ;
BA_DEF_DEF_ "BusType" "CAN";
BA_DEF_DEF_ "FieldType" "";
BA_DEF_DEF_ "GenMsgCycleTime" 0;
BA_ "GenMsgCycleTime" BO_ 500 100;
BA_ "GenMsgCycleTime" BO_ 100 1000;
BA_ "GenMsgCycleTime" BO_ 101 100;
BA_ "GenMsgCycleTime" BO_ 400 100;
BA_ "GenMsgCycleTime" BO_ 200 100;
BA_ "FieldType" SG_ 500 DBC_TEST1_enum "DBC_TEST1_enum";
BA_ "FieldType" SG_ 100 DRIVER_HEARTBEAT_cmd "DRIVER_HEARTBEAT_cmd";
VAL_ 500 DBC_TEST1_enum 2 "DBC_TEST1_enum_val_two" 1 "DBC_TEST1_enum_val_one" ;
VAL_ 100 DRIVER_HEARTBEAT_cmd 2 "DRIVER_HEARTBEAT_cmd_REBOOT" 1 "DRIVER_HEARTBEAT_cmd_SYNC" 0 "DRIVER_HEARTBEAT_cmd_NOOP" ;Proximity ECU
<Picture and link to Gitlab>
The Proximity ECU was also known as the Avoidance module and can be found on GitLab here. It's sole purpose is to monitor the environment around the car and take measurements of objects that break the threshold.
Hardware Design
Avoidance contains eight VL53L0X infrared sensors.
<enter block diagram here...>
Software Design
<List the code modules that are being called periodically.>
Technical Challenges
<Bullet or Headings of a module>
Unreliable sonor sensors
<Problem Summary> <Problem Resolution>
Motor ECU
Hardware Design
The servo that we are using is the Hitech645MW, along with a brushless motor, hall sensor, and 12-bit PWM/Servo Driver - I2C interface - PCA9685. After all devices are properly powered up the motor driver will connect to the brushless motor to provide a PWM signal of 100Hz, with duty cycles (60%(backwards)-70%(stop)-80%(forward))is used to control the speed. The servo is directly connected the SJone board using a PWM pin setting the frequency at 50Hz (with dutycycles ranging from 8%(left), 6%(middle), 4%(right)) to control the direction of the RC car. Lastly, the hall sensor was connected directly to the SJone board using a GPIO pin set up as an interrupt.
Software Design
Motor
| Periodic Init
-  Initializes CAN, servo PWM (50Hz), motor driver board PWM (100Hz), interrupt for hall sensor, and speed calibration
1Hz Task
-  Used to check the state of CAN and reset.
10Hz Task
- Receive CAN message for Motor Control
- Send Motor Status
- Send Motor Speed
| Technical Challenges
 Motor and Servo Frequencies<Problem Summary> 
 Using PWM on the SJOne board only allows for one PWM frequency on all the PWM pins. For Motor, we required two different frequencies (motor (100Hz) and servo (50Hz)). We solved this by using a motor driver board using i2c to create a second PWM frequency. 
 The PWM for MOTOR varied by a few Hz depending on the environment causing the duty cycle to control the motor to change. We set the frequency to be 100Hz, but varied between 98.7Hz. This caused the dutycycle to change from 70% to 80% to initiate the motor. 
 
 We solved this by using a motor driver board using i2c to create a second PWM frequency. 
 In order to be able to deal with any situation and environment the RC car will be in we created a function to manually calibrate the first speed by increasing the dutycycle by 1% using push buttons and automatically incrementing the higher speeds with it. Hall Sensor Speed Determination<Problem Summary> 
 Using mount with enough magnets and enough space between them so that the hall sensor has enough time to reset and not seem as one long interrupt. Giving the hall sensor and interrupt enough time to collect data if not it will keep resetting only being able to detect 0 or 1 interrupt. 
 <Problem Resolution> 
 This problem was solved by creating a custom mount with a magnet ring with different polarities. Placing the speed determination in the 10Hz task gave the HW and SW enough time to detect more than one interrupt. 
 Localize ECUHardware DesignThe localization controller (SJOne board) was connected to a compass and GPS module. The compass that we are using for this project is an MPU-9255 which consist of an accelerometer, gyrometer, and three-axis magnetometer. For our purpose, only the magnetometer is used to find the direction of where the car is facing, which connects to the geographical controller via I2C. As you can see in the block diagram from this module, we will only need to connect to the AUX_DA (EDA) and AUX_CL (ECL), from the compass, to the SDA2 and SCL2, respectively. The connections to the auxiliary ports of this module will bypass the accelerometer and gyrometer completely. The GPS module that was selected was a Ublox Neo-6M module. The GPS communicates with the geographical controller via UART. Software DesignFor the compass, the get_data() modules is being called periodically in the c_periodic_callbacks file in the 100 Hz function. We want the sensor data to be sent to the CAN bus at a 20 Hz frequency, which is implemented by using an if-statement and a modulo 5 on the count variable which results to updated sensor value at 20 Hz: if(count % 5 == 1){} The get_data() function will return a structure called 'compass_t'. In this structure, it groups three data values for the heading of the compass, the x and y-raw value of the magnetic flux density as a signed 16-bit integer and the calculated heading, which returns as a float. When calling the get_data() functions, it retrieves the X and Y-raw values of the magnetic flux density and then calculates the heading as shown in the diagram below. Technical Challenges
 
 
 
 <Bullet or Headings of a module> Unreliable GPS lock<Problem Summary> <Problem Resolution> 
 Comms ECU & LCD<Picture and link to Gitlab> Hardware DesignSoftware Design<List the code modules that are being called periodically.> Technical Challenges<Bullet or Headings of a module> Insane Bug<Problem Summary> <Problem Resolution> 
 Driver Module<Picture and link to Gitlab> Hardware DesignSoftware Design<List the code modules that are being called periodically.> Technical Challenges<Bullet or Headings of a module> Improper Unit Testing<Problem Summary> <Problem Resolution> 
 Mobile Application<Picture and link to Gitlab> Hardware DesignSoftware Design<List the code modules that are being called periodically.> Technical Challenges<Bullet or Headings of a module> Wifi Link Reliability<Problem Summary> <Problem Resolution> 
 Conclusion<Organized summary of the project> <What did you learn?> Project VideoProject Source Codehttps://gitlab.com/cant-bus/cant-bus Advise for Future Students<Bullet points and discussion> AcknowledgementReferences | 








 
							