Pathfinder Fall 2016 Final Summary

Table of Contents

Project Overview

By Sabina Subedi, Project Manager

Project Objective

The Pathfinder is an autonomous rover that is self-sufficient using solar panels. The design of the Pathfinder is inspired by the twin Mars rovers “Spirit and Opportunity.” The Pathfinder will utilize navigation waypoints on Arxterra control panel to traverse through the defined course, articulating ultrasonic range finders and LiDar sensor for obstacle avoidance. Digital slip differential will be implemented for unmanned turning of the rover during it’s course. In order to save battery, the Pathfinder will integrate sensors that will send signals to the motors to stop the wheels from spinning under no load conditions.

Mission Profile

The Pathfinder must successfully navigate a 0.18 mile (roundtrip) course to and from the solar panel charging station defined by the solar panel subproject group. The mapped out course contains 2 staircases with 3 steps each, then concrete path leading to solar panels charging station. The Pathfinder shall travel up and down the steps. The Pathfinder shall avoid any obstacles along the way, using ultrasonic and LiDAR sensors. Pathfinder shall complete its mission in one evening.  The pathfinder shall conduct its mission at night for better operation of the LiDar sensor.

The Design

one

Project Features:

  • Rocker Bogie suspension system
    • High clearance chassis
    • Superior stability on uneven surfaces
    • Obstacle climbing capability
  • Pan and tilt system
    • 2 servos for the rotation of the system, one for pan & one for tilt
    • Provides live video feed utilizing a cellular phone camera
    • Enclosed to protect the phone from external environment
  • GPS Navigation Mode with obstacle avoidance

System Design: 

By Jose Alcantar, Electronics and Controls Engineer

uno

The system block diagram above generalizes how the sensors and actuators will interface through the Arduino Leonardo. First, the Bluetooth receives and transmits any data and the Arduino decodes the data and takes action. The Arduino will either receive sensor data or drive the motors, depending on the commands sent. The diagram also shows the I/O expander is used to control the motor drivers and servos.

Experimental Results:

By Jose Alcantar, Electronics and Controls Engineer

No load conditions threshold:

picture3

The plot above shows the current draw data from one motor driven by the VNH5019. The purpose of this experiment was to find a threshold for finding the current drawn at no load conditions. From the graph, the no load current draw is about 500 mA and when a load is applied the motor draws about 1.3A. The threshold is necessary to set the threshold and shut off the motors when the current draw falls below this threshold.  

Field of View test for Ultrasonic Sensor:

picture1

Purpose:

Testing the field of view on the HC-SR04 to find a suitable mounting position for the two ultrasonic sensors along the front of the rover.

Procedure:

An object was placed in front of the ultrasonic sensor about 25 inches away; the position of the object was marked and moved in increments of 5 inches until the object was out of view. When the object was no longer detected the position was marked. The angle of the field of view was then calculated.

Results:

Based on the experiment, the angle of the field of view was found to be 18 degrees when measuring an object 25 inches away. The position of the sensors was determined by considering the clearance needed on each side of the rover. When considering the solar panels, the two ultrasonic sensors need to detect obstacles at least 5 inches to each side of the chassis. This will allow the pathfinder to avoid obstacles that may bump into the solar panels.

Subsystem Design:

By Jose Alcantar, Electronics and Controls Engineer

Interface Definition:

quatro

The above table shows the main pinout from the Arduino Leonardo. The main interfacing boards are the three VNH5019 motor drivers the PCA9685 I/O expander, the Bluetooth module, the LEDS, Ultrasonic sensors and the LIDAR.

cinco

The above table shows the interconnections of the PCA96805 I/O expander. The majority of the pins control the direction pins of the 6 H-Bridges and the pan and tilt servos.

Software Design:

By Jose Alcantar, Electronics and Controls Engineer

seis

The above flowchart demonstrates how the Arduino receives the incoming data from the Arxterra App and acts based on the commands sent. When a command is sent the command, decoder determines which function to begin. Depending on the mode the Pathfinder will go into either Manual mode, GPS navigation mode or charging state. The called function will drive the motors and read sensor values to complete the requested action.

siete

The flow chart demonstrates how the pathfinder will act when avoiding obstacles. The pathfinder will read sensor values and go into either state 1, 2 or 3 depending on the reading of the sensor values. The rover will then either avoid left, avoid right or move forward.

Waypoint Navigation Mode:

ocho

For waypoint navigation mode, the Arduino reads the waypoint coordinates and current coordinates of the pathfinder. Then the distance and heading to the next waypoint is calculated the rover then begins moving to its destination while actively avoiding obstacles and continously updating coordinate data. Once the waypoint is reached the waypoint data is deleted and manual mode is activated.

For more detail on the Waypoint navigatioin algotithm see:

http://arxterra.com/waypoint-navigation/

Manual Mode Flowchart:

nueve

The flowchart shows the basic algorithm to drive the motors when the direction pad is used to control the pathfinder and pan and tilt servos.

For a more detailed explanation of the MOVE functions see:

http://arxterra.com/implementing-move-command-firmware/

Cable Tree

By Nick Lukin, Design and Manufacturing

The cable tree shows approximately where the wires outside of the main PCB will be laid out on the Pathfinder. It includes connectors for items that can be taken on and off the chassis.

cabletree2cabletree3 cabletree

Hardware Design

By Nicholas Lukin, Design and Manufacturing Engineer

Introduction

The overall mechanical design consisted of various key features that ensured the customers design requirements were met. The first feature is the pan and tilt phone system. The customer required that the Pathfinder come equipped with an electronically controlled pan and tilt phone holding mechanism. The next feature is the rocker bogie suspension system. This suspension system helped fulfill the requirement of going over rough desert terrain and makes it possible to climb up and down obstacles such as stairs and rocks. The next feature is that the Pathfinder is made out of material that can withstand desert conditions as per the requirement stated by the customer. The final feature is the seamless interfacing areas on the chassis that makes it possible to properly interface with the solar panels that will be attached to the top of the chassis.

one

Form Factor

 

Rocker Bogie Suspension System

 two

Figure 1: Exploded View

 Figure 1 shows the exploded view of the entire chassis including the rocker bogie suspension system. The system itself allows the pathfinder to go over uneven surfaces while maintaining stability and traction. There are two pivot points located in the suspension system. The middle pivot point is attached directly to the top plate of the chassis and allows the plate to stay level while traversing up and down obstacles such as stairs. The back pivot point allows for a further range of motion when going over various obstacles. Having two independent suspension sides allows the Pathfinder to go over a variety of terrain. Each side reacts independently to obstacles which allows the center of mass to stay relativity stable and low.

 

Tube Leg Design and Material

  three

Figure 2: Tube Leg Design

In order to make the Pathfinder look as close as possible to the Spirit/Opportunity rovers it was decided to make the legs of the rocker bogie suspension system out of tubing instead of plate like the previous Pathfinder designs. Not only did this make the Pathfinder look more realistic but it also added more strength to the overall design. It was decided that the material used for the design would be 6061-T6 aluminum because of its high corrosion resistance and overall strength. Figure 2 shows the overall mass properties of the Pathfinder.

four

Figure 3: Mass Properties

The overall weight of the Pathfinder is about 25 pounds as shown in figure 2. This weight it light enough to ensure that the motors do not get overworked. If non aerospace grade aluminum was used such as plain 6061 the weight would be around 32 pounds which is a 20% increase.

Fabrication of Overall Chassis

 five

Figure 3: 2-D Drawing for Fabrication

 

The first step in the fabrication process was to obtain the proper 2-D drawing in order to figure out what material needed to be machined and what needed to be welded. It was decided that the back legs, the top plate and the top side plate would all need to be cut and machined. Figure 4 below shows the machining process.

six seven

Figure 4: Machining Legs and Top Plate

 

eight

Figure 5: Fabricating Legs

 

Proper measuring tools had to be used in order to make sure the legs were the correct size and that the overall chassis would be straight when it was planted on all six wheels. Tubing needed to be cut at the proper angles (135 degrees) and welded. Special attention needed to be given while welding to ensure the metal did not warp and create an unwanted dimension.

nine

Figure 6: Final Leg Fabrication

Figure 6 shows the final leg fabrication. Each leg was nearly identical to one another. This helped achieve the goal of keeping symmetry throughout the entire design and made sure the Pathfinder would achieve the proper form factor as required by the customer.

ten

Figure 7: Light/Sensor Bar

 It was a requirement that the Pathfinder was equipped with some type of lighting and ultrasonic sensors. In order to properly attach the lights and sensors to the chassis it was necessary to custom fabricate some type of holding mechanism. A light/sensor bar was machined in order to properly attach the critical lights and sensors. Figure 7 shows the final product.

eleven

Figure 8: Final Chassis Design

 Figure 8 shows the final chassis completed with the pan and tilt phone system, wheels and electrical all attached. The final design looks nearly identical to the solid works model. Careful preparation and precise fabrication achieved a design that is accurate and that meets the customers’ expectations. 

Pan and Tilt Phone System

 

twelve 

Figure 9: Pan and Tilt Phone Holder

 

In order for the Pathfinder to see where it is going and to properly connect to the Arxterra control panel the customer required that a Pan and Tilt phone system be built. The system would need to house a Samsung Galaxy S7 edge and be able to withstand a desert environment. The design of the system can be seen in figure 9. The system is controlled through the Arxterra control panel via two servos. We decided to make the phone holder out of 6061-T6 material just like the chassis. This would ensure that the phone would be properly protected and that it was light enough so the servos could move it.

thirteen

Figure 10: Pan and Tilt Exploded

It was also necessary to attach a lidar sensor to the front of the phone case. Lidar was needed in order to properly implement an autonomous driving mode system. The front plate of the phone holder was designed to leave room for the cameras of the phone, to house the lidar sensor and to properly expose the communication antennas of the phone. All these features can be seen in figure 10.

 

fourteen

Figure 11: Fabricating Phone Holder

Figure 11 shows the fabrication of the camera view holes of the front case of the phone holder. It was necessary to properly measure the distance between the top of the phone to the end of the camera to make sure that there was no interference between the metal and the camera.

 

fifteen

Figure 12: Final Product

Figure 12 shows the final build of the pan and tilt phone holder mechanism. It was necessary to utilize an off the shelf gimbal system to mechanically drive the pan motion of the holder. This part was connected to the pan servo and ensured smooth lateral operation of the entire system.

Interfacing the Solar Panels

 sixteen

Figure 13: Solar Panels Interfacing

It was necessary that the chassis and solar panels seamlessly interface as per the requirement of the customer. Proper interfacing was achieved by creating mounting stand offs on the top plate of the chassis of the Pathfinder. The solar panels would then have holes that would properly align with the mounting pads and a small thumb screw would be used in order to properly secure the connection. These stand offs can be seen on the top plate of the chassis in Figure 13. The pan and tilt phone holder would also need to come off by hand in order to properly interface. This was achieved by machining a threaded stud to the top of the phone holder stand. The customer could then easily screw the phone holder on and off by hand.

 

Figure 14: Actual Interfacing

Figure 14 shows the actual interfacing of the solar panels and the chassis assembly. The 4 thumb screws that were utilized can be seen in figure 14. It was also noticeable that the proper form factor was achieved between the solar panels and the chassis.

 

PCB Layout

eighteen

Figure 15: Final PCB Design

A custom PCB design was required in order to interface all of the boards that were utilized to control the Pathfinder. The overall function of the board was to take various pins from the Arduino and rout those pins to other boards that could directly connect to the custom PCB. Two ultrasonic sensors, a Bluetooth module, a servo driver board, a LED interface, a LIDAR connection and 3 motor driver boards would all be able to directly connect to the board. The board would also implement a buck converter in order to step down the main battery supply voltage from 12V down to 6V to properly charge the phone in the phone holder system.

Interface Design

In order to properly route all the wires from the Arduino pins to the proper locations it was necessary to lay the board out in an efficient manner. All the pins that required headers were laid out as close to the edge of the board as possible. They were also spaced apart so that room was left for whatever connectors would be used. 45 degree bends were utilized on all traces in order to maintain a clean and professional looking PCB. A ground plane was utilized for all ground connections and a power bus was used in order to properly connect VCC across all pin connections. A power plane could not be used since the buck converter would also be on the same board and would be utilizing a different voltage level at its input.

Buck Converter

 nineteen

Figure 16: Typical Buck Design

 The LM2596 chip was selected for the buck converter. This chip allows a maximum of 3 amps to be passed through it and has an input voltage range of up to 40 volts and can step down voltages as low as 3.3 volts. For the phone charger we designed the buck converter to output 6 volts to properly charge the Samsung Galaxy S7 edge. All surface mount components were utilized for the design and attention to detail was key during the lay out process. Per the data sheet it was necessary to place the inductor and capacitors as close to the chip as possible. It was also necessary to use the correct size power traces to prevent overheating and possible damage to the board. The buck converter was designed to output a max of 1 amps and therefore a maximum power trace of .032 inches was used. This thick trace can be seen on figure 15 at the input of the buck converter. A micro usb was used on the output of the buck so the phone could easily plug into the charger.

 

Soldering Process

 

Figure 17: Soldering the Board 

The custom PCB was soldered by hand and then was tested for proper functionality. It was noticed that there was a direct short between ground and Vcc. Initially it was thought that the soldering process caused the short but upon further inspection it was determined that the board came shorted from the factory. Two other boards that were not yet soldered were tested and they both had direct shorts between Vcc and ground.

Verification and Validation Test

https://drive.google.com/open?id=0Bzq09K9mZabrd0E4a01mUElLdlE

Work Breakdown Structure (WBS)

wbs

Resource Reports

Please refer to the Project Resources section to find the resource reports, including Mass, Cost and Power Report.

Top Level Schedule

schedule

The general top level schedule was created using the generic rubric provided on the class website. The top level schedule specific to the Pathfinder (Chassis subproject) was created using the Work Breakdown Structure above and the general top level schedule. This schedule consists of all tasks that are to be completed before the end of the semester, December 15th, 2016. The project milestones are broken down into four phases: Planning, Design, Assembly and Project Launch. The tasks within the different phases are then divided up by the divisions. All division members are assigned specific tasks that they are responsible for, per “Job Descriptions” document available on the class website. Main tasks then were broken down into sub-tasks, if applicable. All tasks include start and finish dates, as well as percent complete. 

Conclusion and Future Plans

Overall the project was a success as we were able to build a functioning rover that achieved the majority of the requirements that were established by the customer. The mechanical design worked as expected with only some small issues. One improvement that is necessary is adding stops to the back pivot point of the rocker bogie suspension system. The range of motion needs to be limited at some point in order to properly go up obstacles such as stairs. Another improvement would be to possibly get bigger wheels. The larger the wheels the better it can go up and over obstacles. I believe that the current design is sufficient for future students to build off of and improve upon.

Project Resources

 

Fall 2016 Solar Panels: Project Summary

By Inna Echual (Project Manager)

Table of Contents

Project Overview

Executive Summary

Project Objective

The design of the Fall 2016 Pathfinder project was taken directly from NASA’s Mars Exploration Rovers, Opportunity and Spirit. The Pathfinder will be designed to be self-sufficient using solar panels, as well as implement the solar deployment mechanism employed by the two aforementioned rovers. The solar panels should able recharge the Pathfinder’s battery allowing it to traverse rough terrain. The solar panels must also articulate to track the sun, maximizing the amount of solar power received.

Mission Profile

The project will be demonstrated by parking the Pathfinder in the Central Quad on California State University, Long Beach located at 33°46’40.7″N 118°06’48.9″W.  In addition to the location near the defined travel course, the parking spot was chosen as it had low traffic and free of shading. The parking spot is indicated in Figure 1.

unnamed-1

Figure 1: Pathfinder Charging Spot

img_7656

Figure 2: Pathfinder Charging Spot (Magnified)

Project Features

  • Customized Solar Panels

    This will be done using 5 strings in parallel of 30 solar cells stringed together in series to fit the customized solar shape of the aforementioned rovers (see compare our layout in Figure 3 with Spirit’s layout in Figure 4).

snapchat-406817528

Figure 3: Fall 2016 Solar Panels 

spirit_rover_cleaned

Figure 4: Spirit Rover Panels

  • Panel Proportionality

    The solar panels will be configured to be identical to the form factor of the solar panels on the Opportunity and Spirit rovers (see Figure 5).

proportionaliry

Figure 5: Form Factor Consideration

Experiments Checklist

  • Experiments on Solar Cell Cutting and Efficiency to determine stringing
  • Back of the Envelope calculations to determine stringing and layout
  • Experiment using MPU 6050 to determine rover balance
  • Experiment using DC motor as a stepper motor with an encoder
  • I2C – test communication between Arduino Uno and Arduino Mega
  • Sun tracking with photo resistors

 

 

System Design

System Block Diagram

sbd_updated

Figure 6: Updated System Block Diagram from CDR

Updated System Block Diagram from CDR brief.

Subsystem Design

Interface Definition

Interface Matrix

screen-shot-2016-12-17-at-6-09-53-am

Figure 7: Interface Matrix

Interface Control Document

As defined in the mission profile, the Pathfinder will be allowed to travel a course on the upper campus of CSULB. This system is designed to replicate the Spirit & Opportunity Mars Rovers. The program objective is to be self-sufficient. In order for this system to be successful with it’s mission, the two systems; Chassis & Solar Panel, must work together with one another. The Solar Panel will be in charge of supplying power to the battery, and the Chassis will then be able to use this battery and travel the course.

The Interface Control Document will be used to provide an outline for the responsibilities aligned with each system. It also sets out the interfacing requirements to help move the design forward for each of our systems in the following disciplines: Mechanical Interfacing, Power Transactions, and Control Mechanism & Data Transfer. It also includes some constraints, assumptions, and possible risks involved in these factors.

Interface Control Document

Mission Command and Control

Software Block Diagram

screen-shot-2016-12-16-at-2-20-18-pm

Figure 7: Software Block Diagram

The software block diagram in Figure 7 explains an overall understanding of what the Solar Panel system’s software entails. It also includes a portion of the Chassis system and how we are interfacing with one another electronically, along with a legend on the bottom left to help detect what the different colors mean.

Software Block Diagram Update

Electronics Design

Motor Trade-Off Study

DC Motor With Encoder Experiment

I2C Communication Experiment

Creating a Port Expander Using IC MCP23017

Firmware

 

PCB Schematic

fritzing1

Figure 8: Fritzing Diagram for Motor Driver

fritzing2

Figure 9: Fritzing Diagram for I2C Communication

bread1

Figure 10: Breadboard for Motor Driver

sche

Figure 11: Schematic

PCB Layout

PCB Layout

Hardware Design

Folding Mechanism Trade-Off Study

Mechanical Design

Choosing Panel Thickness / Stress Tests

Verification and Validation Test Plan

Verification Test Plan

Project Status

Power Allocation

screen-shot-2016-12-17-at-10-01-34-am

Mass Allocation

screen-shot-2016-12-17-at-9-47-54-am

Cost Report

screen-shot-2016-12-17-at-11-04-33-am

Concluding Thoughts

Lessons Learned

  1. Being the project manager helped me learn a lot about group and project management. Because this project is an integrated project with the Thursday class, it was very difficult to coordinate meeting times together or even contact the other group, therefore our project would fall back at times.
  2. It is hard to manage the conflicts among cost, schedule and performance. Our pathfinder team was having trouble on getting all the parts we wanted on time. Because we were short on time, there were sacrifices we had to make in terms of which parts of the project we wanted to get working depending on how many requirements it could fulfill.
  3. I learned too late that I should be stricter on tasks I wanted to get done to keep the project on schedule.

Resources

[1] Project Video

[2] Critical Design Review (CDR)

[3] Preliminary Design Review (PDR)

[4] Project Schedule

[5] Verification and Validation Documents

[6] SolidWorks Files (zipped)

[7] Fritzing Files (zipped)

[8] EagleCAD Files (zipped)

[9] Ardino / C++ Code

[10] Bill of Materials

[11] Final Interface Control Document (dated 12/13/16)

References

[1] Spirit Rover Cleaned: https://commons.wikimedia.org/wiki/File:Spirit_Rover_Cleaned.jpg

Fall 2016 Solar Panels: Mechanical Design *

By Ridwan Maassarani (Design and Manufacturing)

Approved by Inna Echual (Project Manager)

As a requirement, solar panels had to be manufactured that is of the same form factor as the spirit and opportunity mars rovers that were designed by NASA. To accomplish this, my team and I visited JPL and was able to find model at their museum. In addition, a small scale model was purchased from the gift shop for taking measurements later on if needed.

smallscale

Figure 1: Small-Scale Model from JPL

hqmodel

Figure 2: High-Quality Rendering Photo (top view)

scaledmodel

Figure 3: Spirit Rover Dimensionas

I was also able to obtain a schematic picture by contacting the same individual who made the high quality rendering pictures. Here’s is the website for more information: http://v5.nicksotiriadis.gr/mars-rover-project/

From all this information, I took measurements and a ratio of 10 was used based on the requirement that the panels needed to fit a 19-inch-wide cabinet and to the panels were scaled accordingly in SolidWorks using the scale feature.

After the dimensions of the panels was established, a folding mechanism had to be devised to fulfill the cocooning state requirement. From my earlier blog post, I go over the various type of gears and types of mechanism that could perform a folding motion but utilizing worm gears for their high torque and self-locking feature was the best choice. First, torque needed to be transferred to the panels from the gears. The best option was to schedule an appointment with the mechanical design center and weld the rod to one leaf of the hinge. I tried to do this many times but failed since Electrical Engineering students do not normally get help from the mechanical center so there was no fluid was to get help. This forced the use of an epoxy called JB weld, used as a welding alternative for metals which by the end of the semester failed. In future 400D project, I hope the mechanical center will become a place where students can get their designs manufactured with ease. I have stablished some kind of relationship with Joe, the person who runs all the equipment such as welding, drilling, and plasma cutting. Here’s are my panels cut using their plasma cutter:

plasmacutter

al-panels

After making a connection from rod to panel, the gear needed to be attached firmly to the rod so that when the worm rod spins, torque is delivered to the gear, rod, and finally the panel. Ideally, metal gears need to have a press fit such as stepper motors in a printer. Press fitting gears is a science and there was no time nor the budget to get custom sized gears. So, a hollow rod was purchased from home depot and fitted in the gears bore to get a better fit from gear to rod as well as from worm rod to stepper shaft. The gears came with a set screw; this was used to secure the gears further. Since this is not the best method of connecting these gears, epoxy was used again for safe measure. For the next semester, I would recommend researching how to securely connect the gear to the shaft, rod to hinge, and worm rod to stepper shaft. Another improvement would be to make a gear box for these gears, this will serve as an encasement as well as a place to fill grease so that they are always lubed. Having lubed gears will prevent any friction between the teeth, it is crucial for metal gears.

panels

In conclusion, another improvement would be to limit the amount of freedom the hinge has when unfolded. This can be done by welding some metal between the main panel and the right panel, this will help when the rover is being operated at the same time the panels are installed. It will remove the additional torque generated when the rover is being operated.

 

 

Fall 2016 Solar Panels: PCB Layout *

By Ridwan Maassarani (Design and Manufacturing)

Approved by Inna Echual (Project Manager)

A custom PCB that can drive five stepper motors was needed to reduce the footprint on the rover. The custom PCB would also cut down on cost since stepper motor drivers that can run 3 or more motors can gen expensive. It was also difficult to find a motor driver than can run five motors. So, a custom PCB was made based on the A4988 stepper motor drivers capable of driving two coils.

pcb-front pcb-bottom

Waypoint Navigation

Waypoint Navigation for the Pathfinder

By Jose Alcantar, Electronics and Controls Engineer

Introduction:

This blog post covers the proposed waypoint navigation algorithm along with some issues regarding how the GPS data was transmitted and decoded by the Arduino. Sample code and navigational calculations are included.

Navigation Algorithm:

When the pathfinder travel mode is to Autopilot, the Arxterra App begins transmitting heading information, current coordinate information of the smartphone and waypoint coordinates, if any. The basic control logic is as follows:

  1. If Autopilot mode is engaged, begin Waypoint Navigation
  2. Process any new GPS information and update the course and distance to the target waypoint.
  3. Read heading information to get current bearing and decide the desired direction to turn the pathfinder.
  4. Begin moving the pathfinder and check for any obstacles to avoid.
  5. If waypoint is reached, switch to manual control.

The code to handle each of these was written in separate functions.

Autopilot Mode:

When the autopilot mode is engaged the WAYPOINT_ON command is called, which begins the Navigation algorithm. The first function called retrieves the heading information from the smartphone which is sent as a data packet containing the command id and the heading information in hex values. For more detail regarding formatting the data see link below,

http://arxterra.com/heading-and-gps-coordinates-formatting/

After the heading is retrieved, a function is called to calculate the difference between the current heading and the heading to the desired waypoint.

The following code demonstrates how to calculate the turn:

 

// returns distance in meters between two positions, both specified

// as signed decimal-degrees latitude and longitude. Uses great-circle

// distance computation for hypothetical sphere of radius 6372795 meters.

// Because Earth is no exact sphere, rounding errors may be up to 0.5

 

void calcDesiredTurn(void)

{

//calculate where we need to turn to head to destination

headingError = targetHeading – currentHeading;

 

//adjust for compass wrap

if (headingError < -180)

headingError += 360;

if (headingError > 180)

headingError -= 360;

// calculate which way to turn to intercept the targetHeading

if (abs(headingError) <= HEADING_TOLERANCE) // if within tolerance dont turn

turnDirection = straight; // GO FORWARD

else if (headingError < 0)

turnDirection = left;     // TURN LEFT

else if (headingError > 0)

turnDirection = right;    // TURN RIGHT

else

turnDirection = straight; // GO FORWARD

} // calcDesiredTurn()

 

After the target heading is calculated, the distance to the target waypoint is calculated using the following code:

int distanceToWaypoint()

{

 

float delta = radians(currentLon – waypointLon);

float sdlong = sin(delta);

float cdlong = cos(delta);

float lat1 = radians(currentLat);

float lat2 = radians(waypointLat);

float slat1 = sin(lat1);

float clat1 = cos(lat1);

float slat2 = sin(lat2);

float clat2 = cos(lat2);

delta = (clat1 * slat2) – (slat1 * clat2 * cdlong);

delta = sq(delta);

delta += sq(clat2 * sdlong);

delta = sqrt(delta);

float denom = (slat1 * slat2) + (clat1 * clat2 * cdlong);

delta = atan2(delta, denom);

distanceToTarget =  delta * 6372795;

//————-Edit to turn off navigation———-//

// check to see if we have reached the current waypoint

if (distanceToTarget <= WAYPOINT_DIST_TOLERANCE)

waypoint_on = 0;

//—————————————————//

return distanceToTarget;

}  // distanceToWaypoint()

 

 

The previous functions return the new heading in degrees and the distance in meters

the next function, checkSonar() is called to read the ultrasonic sensor distance values.

 

void checkSonar(void)

{

distR = 0; distL = 0;

digitalWrite(11,LOW);

delayMicroseconds(2);

digitalWrite(11,HIGH);

delayMicroseconds(10);

digitalWrite(11, LOW);

 

pulse_width = pulseIn(8, HIGH);

 

distR = (pulse_width/2)/29.1;

delay(60);

 

digitalWrite(10,LOW);

delayMicroseconds(2);

digitalWrite(10,HIGH);

delayMicroseconds(10);

digitalWrite(10, LOW);

 

pulse_width = pulseIn(4, HIGH);

distL = (pulse_width/2)/29.1;

 

delay(60);

 

if( distR > MAX_DISTANCE_IN && distL > MAX_DISTANCE_IN)

{

distR = MAX_DISTANCE_IN;

distL = MAX_DISTANCE_IN;

}

 

}  //checkSonar()

After calculating the distance, target heading and reading the sensor values the moveAndAvoid() function is called to move the pathfinder to its destination while avoiding obstacles.

void moveAndAvoid(void)

{

if(distL >= SAFE_DISTANCE && distR >= SAFE_DISTANCE)    //no close objects in front

{

if(turnDirection == straight)

{

speedLeft = FAST_SPEED;         //PWM SIGNAL FOR BOTH MOTORS

speedRight = FAST_SPEED;

left_forward();

right_forward();

}

else if(turnDirection == left)

{

speedLeft = TURN_SPEED * .85;         //PWM RATIO FOR BOTH MOTORS

speedRight = TURN_SPEED;

left_forward();

right_forward();

}

else if(turnDirection == right)

{

speedLeft = TURN_SPEED;

speedRight = TURN_SPEED * .85;

left_forward();

right_forward();

//driveMotor->setSpeed(speed);

//driveMotor->run(FORWARD);    // turn direction

//turnMotor->run(turnDirection);

//else(turnDirection == right)

//speed = TURN_SPEED;

}

return;

}

if ((distL > TURN_DISTANCE || distR > TURN_DISTANCE)  && (distL < SAFE_DISTANCE || distR < SAFE_DISTANCE)) //not yet time to turn, but slow down

{

if(turnDirection == straight)

{

speedLeft = NORMAL_SPEED;   // PWM FOR MOTORS

speedRight = NORMAL_SPEED;

left_forward();

right_forward();

}

else if(turnDirection == left)

{

speedLeft = TURN_SPEED * .85;     //SPEED RATIO FOR MOTORS

speedRight = TURN_SPEED;

left_forward();

right_forward();

// already turning to navigate —-> Direction to turn

}

else if(turnDirection == right)

{

speedLeft = TURN_SPEED;

speedRight = TURN_SPEED * .85;

left_forward();

right_forward();

}

return;

}

if ((distL < TURN_DISTANCE || distR < TURN_DISTANCE) && (distL > STOP_DISTANCE || distR > STOP_DISTANCE)) // getting close, time to turn to avoid object

{

speedLeft = SLOW_SPEED;     //PWM FOR MOTORS

speedRight = SLOW_SPEED;

left_forward();

right_forward();

switch(turnDirection) // decides whether to turn left or right

{

case straight:        // going straight

{

if (headingError <= 0)

turnDirection = left;

else

turnDirection = right;

speedLeft = SLOW_SPEED;

speedRight = SLOW_SPEED * .85;

left_forward();

right_forward();

//turnMotor->run(turnDirection);  // turn in the new direction

break;

}

case left:                        // if already turning left, try right

{

speedLeft = SLOW_SPEED;

speedRight = SLOW_SPEED * .85;

left_forward();

right_forward();

//turnMotor ->run(TURN_RIGHT);

break;

}

case right:

{

speedLeft = SLOW_SPEED * .85;

speedRight = SLOW_SPEED;

left_forward();

right_forward();

//turnMotor ->run(TURN_LEFT);

break;

}

} //end SWITCH

 

return;

}

 

if (distL <  STOP_DISTANCE || distR < STOP_DISTANCE)          // too close, stop and back up

{

left_release();

right_release();

//driveMotor->run(RELEASE);            // stop

//turnMotor->run(RELEASE);             // straighten up

 

turnDirection = straight;

speedLeft = NORMAL_SPEED;

speedRight = NORMAL_SPEED;

left_reverse();

right_reverse();

//driveMotor->setSpeed(NORMAL_SPEED);  // go back at higher speet

//driveMotor->run(BACKWARD);

while (distL < TURN_DISTANCE || distR < TURN_DISTANCE)       // backup until we get safe clearance

{

currentHeading = readCompass();    // get our current heading

calcDesiredTurn();                // calculate how we would optimatally turn, without regard to obstacles

checkSonar();

delay(100);

} // while (sonarDistance < TURN_DISTANCE)

left_release();

right_release();

//driveMotor->run(RELEASE);        // stop backing up

return;

} // end of IF TOO CLOSE

 

 

} //moveAndAvoid

 

NOTES: One of the main issues with the waypoint navigation is that the heading data received does not give the full 0 – 360 degree range. When formatting the data, the heading is given from 0 to 180 degrees (North = 0 and South = 180) going counter clockwise, but any heading past 180 degrees does not transmit correctly. When formatting, the values given from the data packet, the degree range from (180 to 360) loops back, (going counter clockwise) the degree range is North = 180 and South = 360 degrees this causes an issue with calculating the correct heading values. It is recommended that Jeff is contacted to resolve this issue.

 

Conclusion:

With the following algorithm the pathfinder should be able to reach its destination with no issues.

Stress Test

Stress Test

By: Nick Lukin (Design and Manufacturing Engineer) 

Introduction

In order to ensure that the Pathfinder chassis could support the weight of the solar panels in order to properly interface it was necessary to perform a stress/displacement test in Solidworks. The solar panels overall weight was a maximum of 50lbs. The chassis was designed so the panels could sit on top of aluminum standoffs welded to the top plate of the chassis. The force in Newtons was calculated and applied to the standoffs.

 

one

Figure 1: Stress Test Results

two

Figure 2: Stress Test Results Continued

 

Analysis

In order to figure out the appropriate force to apply to the model it was necessary to convert the maximum weight of the solar panels into Newtons (1 Newton = 0.2248 lbs). Therefore 50 lbs converts into about 222 Newtons. This number was used for the simulation in order to see how much the maximum weight of the solar panels would affect the chassis. Figures 1 and 2 show the results of the stress test performed in Solidworks. The test results show an exaggerated view of exactly how and where the chassis would begin to deform. It is noticed that the chassis max deformation is about 8.017e+004 von Mises which is very little. The overall characteristics and shape of the deformation is as expected.

three

Figure 3: Displacement Results

four

Figure 4: Displacement Results

 

Figures 3 and 4 show the displacement of the chassis and further show how the chassis will be affected by the maximum weight of the solar panels. The displacement results give a millimeter value of exactly how much the metal will move. It is noticed that the top plate bends a maximum of 1.226e-003 mm which is very small (less than a millimeter). This number is acceptable and confirms that the design of the chassis can withstand the maximum weight of the solar panels.

Conclusion

After running the appropriate stress tests in Solidworks it was determined that the design shown in the figures above was strong enough to support the weight of the solar panels. Being that the chassis is the base of the entire pathfinder it must support the weight of everything that is attached to it. The stress tests performed show the strength of the chassis and confirm that the requirement of properly interfacing between the chassis and solar panels is achieved.

Form Factor

From Factor

By: Nick Lukin (Design and Manufacturing Engineer)

picture1n

 

Introduction

In order to meet the requirement of the Pathfinder being dimensionally proportional to the actual Spirit and Opportunity rovers it was necessary to develop a measurement method in order to properly scale the overall design.

picture2n

Figure 1: Small Scale Model

Analysis

A small scale model of the actual spirit/opportunity rover was used in order to get base dimensions to work with and to develop an appropriate scale factor. Figure 1 shows the small model that was used to take measurements from. 10 different measurements were taken from the small model. The measurements are summarized in Figure 2.

picture3n

Figure 2: Summary of Measurements/Dimensions

The solar panels group was limited to how wide they could make their overall panels because they needed to be able to fit inside the cabinet in ECS 316. The cabinet is 19 inches wide which meant the max width of the center solar panel was to be 19 inches. Therefore the scale factor of the overall design relied on how wide the solar group decided to make their panels. The final overall width and length of the solar panels was 25.39” and 36.26” respectively. The center panel width was 18.45” which was within the cabinet measurement of 19”. Once the solar panel group finalized their measurements the proper scale factor could be calculated. Dividing the overall solar panel width and length by the small model width and length gave a scale factor of 10.097.

npicture5

Figure 3: Overall Height

In order to find the overall height of the solidworks model the overall height of the small model (29.6mm) needed to be multiplied by 10.097. The result is about 298.88mm or 11.77 inches as shown in figure 3.

npicture1

Figure 4: Overall Width (wheel to wheel)

The overall width wheel to wheel on the small model was 44mm. Multiplying this number by the scale factor yielded a measurement of about 444.29mm or 17.49 inches as shown in figure 4.

npicture2

Figure 5: Length (wheel middle to front)

The length between the center of the front wheel and the middle wheel on the small model was 30.2mm. Multiplying this number by the scale factor yielded a measurement of about 304.9mm or 12.01 inches as shown in figure 5.

npicture3

Figure 6: Length (wheel middle to back)

The length between the center of the middle wheel to the center of the rear wheel on the small model was 20.4mm. Multiplying this number by the scale factor yielded a value of 205.99mm or 8.11 inches as shown in figure 6.

picture1n

Figure 7: Side Solar

The measurement between the end of the side solar panel and the edge of the wheel on the small model was 22.8mm. This number was multiplied by the scale factor to get a number of about 230.22mm or 9.05 inches as shown in figure 7.

npicture11

Figure 8: Front Solar Measurement

The measurement between the front of the solar panel edge and the front edge of the wheel was 4.4mm on the small model. After multiplying by the scale factor the measurement came out to 44.43mm or 1.75 inches as shown in figure 8.

npicture

Figure 9: Back Solar Measurement

The measurement between the back solar panel edge and the edge of the back wheel on the small model was 3.5mm. Mulitplying by the scale factor yielded a measurement of 35.34mm or 1.39 inches as shown in figure 9.

 

npicture9 npicture10

Figure 10: Length/Width Solar Panels

The overall length and width of the small model solar panels was 92.5 and 63 mm respectively. Multiplying by the scale factor yielded measurements of 36.26 and 25.39 inches respectively as shown in figure 10.

 

npicture11

Figure 11: Phone Holder Height

The measurement of the phone holder from the top plate of the chassis to the very top of the phone on the small scale model was 34.4mm. Multiplying by the scale factor yielded a value of 347.35mm or 13.68 inches as shown in figure 11.

Conclusion

Overall we were successful in creating a model in solidworks that matched the proper form factor of the spirit/opportunity rovers. In order to properly achieve the correct proportions it was necessary to assume that the small scale model that was used was accurately proportional to the actual spirit/opportunity rovers. If this is the case our model meets the requirement of achieving the proper form factor. A plus or minus 0.25 tolerance was put on the actual building of the model to account for any errors during the fabrication process.

Fall 2016 Solar Panels: Requirements Update

By Stephan Khamis (Missions, Systems, and Test)

Approved by Inna Echual (Project Manager)

Introduction

This blog post contains our most up-to-date requirements for the Solar Panel system of the Pathfinder project. Within this blog post you will learn about the changes we have made since the CDR to update this document.

Updated Requirements

Solar Panel Requirements

  1. The Pathfinder shall be self-sufficient using solar panels.
    • According to accuweather the sun rises at 6:50 AM and sets at 4:46 PM on December 15, 2016. The Pathfinder will start to explore at 2:45 PM.
    • Starting at 80% battery life, the Solar Panels shall be able to charge the battery system to 95% in under 8 hours.
      • The solar panel shall be wired to produce at least 12 Volts and 300 mA to charge our battery system.
      • The battery will have a charge controller to prevent the battery from exceeding 12 Volts of charge, which is the maximum capacity of the battery system.
  1. The solar panels shall be able to enter and exit a cocoon state.
    • The motorized folding mechanism shall be done using a stepper motor, a motor bracket, a worm gear, and a piano hinge for each of the 3 folds.
  2. The Solar Panels will have a fixed north/south orientation for the panels to track the east to west movement of the sun.
    • Two main side panels consisting of two smaller panels shall articulate with the sun using stepper motors specified to handle 1188 oz/inch.
      • The solar cells should be used to measure and compare the voltage at an angle using a voltage divider.
    • The Solar Panels will be able to withstand 50 lbs, under the force of gravity.
  3. The form factor of the Solar Panels shall be identical to that of the Spirit and Opportunity
    • Six panels shall be cut proportional to the six panels on the Spirit and Opportunity
    • The solar panels shall use 39 mm x 39 mm polycrystalline solar cells to accommodate the customized shape of the Spirit and Opportunity
  4. The Pathfinder will be able to fit into the east most cabinet in ECS – 317.
    • The Pathfinder shall have dimensions no greater than 19” x 34” x 26” in its closed cocoon state.
    • The Solar Panel component of the Pathfinder shall be able to be added and removed from the Chassis within 20 minutes (wiring and mechanical), without the use of power tools for future separate usage of the Chassis and Solar Panel system.
  5. The Pathfinder shall have requirements agreed between both the Solar Panel and Chassis group within the Interface Control Document (ICD).
    • The Solar Panel group will provide 5.76 inches from the front top plate towards the center to accommodate the placement of the Chassis’ Pan & Tilt Mechanism.
    • The Solar Panel group will provide an availability of 10 inches between side panel motors required by the Chassis group.
    • The base of the Solar Panel will have four equally spaced 0.5” holes to establish a concentric interfacing point with the Chassis
    • The Solar Panel group will be allowed a power allocation of 2 Amps at 12 Volts, while the Chassis group will be allowed a power allocation of 11.4 Amps at 12 Volts.
    • The Solar Panels will not exceed 50 lbs as required by the Chassis group.
  6. The Pathfinder should be able to ride itself back up using the side Solar Panels and Custom Command; Cocoon.
  7. The expenses of the Solar Panel system should be limited to $200.
  8. The Solar Panel System shall be completed by December 14, 2016.
  9. The Solar Panel system shall use a custom PCB.
  10. The Solar Panel system shall use custom commands.
  11. The Solar Panel system should use custom telemetry.

Above are the Solar Panel system’s most up-to-date requirements. These requirements are more than just sentences asking what needs to be done, they’re directing the path we are taking in order to complete this project. These are requirements that we must meet and must be able to verify and validate. Requirements must satisfy two of three questions:

  1. Is it verifiable?
    1. Meaning is this a requirement that we are capable of verifying?
  2. Is it quantifiable?
    1. Meaning is this a requirement that we can quantify in numbers and test.
  3. Is it realizable?
    1. Given the fact that we have only 16 weeks in this course to design and build, some things just aren’t realizable to do within that timeframe.

Throughout the semester, we have been refining our requirements and finalized them by CDR. But, after speaking with the customer, president, and systems divison manager, we added a few requirements that would help us in creating a test plan. The added requirements are the last few; 7-12. These are requirements to help show that we will have the project completed by a certain date, under a budget, interfacing requirements, and some custom commands/telemetry the customer would like.

Past Requirements 

As stated before, we have added quite a few requirements since CDR. These requirements stemmed from speaking with the customer, president, and systems division manager while creating a test plan matrix for the final on December 14 & 15, 2016.

Future Updates

As of now, we have no plans to updating or changing anything. But, to speak for what I think should be done in the following semester, there could be work done. I believe these are decent requirements but, they are not perfect.

Fall 2016 Solar Panels: System Block Diagram Update

By Stephan Khamis (Mission, Systems, and Test)

Approved By Inna Echual (Project Manager)

Table of Contents

Introduction

As a result the feedback we received during the critical design review (CDR), we decided the system block diagram for our system. This blog post contains our most up-to-date system block diagram for the Solar Panel system of the Pathfinder project. Within this blog post you will learn about the changes we have made since the CDR to update this document.

Previous System Block Diagram

sybd_cdr

Figure 1: System Block Diagram Presented During CDR

Figure 1 shows our the System Block Diagram that we presented during our CDR. The first major difference we had to make was the switch from an Arduino Leonardo to an Arduino Micro. Per the customer, the use of the MPU – 6050 was told to be removed because the panels never had an explicit requirement for autonomous recovery if the rover fell over. We also added around 32 solar cells to help us make our 12V 1A mark of charge to charge our battery system. We also decreased the number of motorized folds to 3 rather than 5 because the stepper motors on the sub sided panels would be completely destroyed if they tried to recover the rover to an upright position.

Updated System Block Diagram

sbd_updated

Figure 2: Updated System Block Diagram

Figure 2 shows our solar panel system’s updated system block diagram. The system block diagram explains an overall understanding of what the Solar Panel system entails. Because the pathfinder is an integrated project,  also includes a portion of the Chassis system and how we are interfacing with one another electronically and a legend on the top right to help detect what the different colors and arrows mean.

On the left-hand side, you will notice the Solar Panel System, and on the right-hand side, you will notice the Chassis system. Since the Solar Panel is our priority and project, it is much more detailed than the basic interfacing that is shown on the Chassis system. Both the Solar Panel and Chassis system are using an Arduino But, the Solar Panel is using an Arduino Micro rather than a Leonardo. The two Arduinos will be interfacing with one another via an I2C. We also decided to add an MPC-23017 in order to make room for our reed switches, which will be used to prevent the cocooning mechanism from hitting the adjacent panels, which can possibly damage the cells.

Looking on the left-hand side of the overall System Block Diagram, it shows the power connections between the solar cells, battery, Pololu – A4988 motor drivers. Connecting to the motor drivers are the 3 stepper motors that will be used to help cocoon the Solar Panels. Connected to the solar cells is a charge controller that will help prevent the solar cells from providing more than 12V of charge, which is the maximum capacity of the battery.

Now looking at the right-hand side you will see the interfacing and communication going on between the Chassis and Solar Panel systems. Through the I2C connection of the Arduino Leonardo and Micro, the Leonardo will be able to help send commands to our Arduino Micro using the Arxterra Application/Control Panel. The Arxterra application will be controlled through an Android phone (Provided by the Chassis group) and will connect to the Arduino Leonardo via HM-10 BLE Bluetooth.

Future Updates

As of now, there are no future updates that I plan to change within the now updated System Block Diagram.

Fall 2016 Solar Panels: Product Breakdown Structure Update

By Stephan Khamis (Mission, Systems, and Test)

Approved by Inna Echual (Project Manager)

Table of Contents

Introduction

This blog post contains our most up-to-date product breakdown structure for the Solar Panel system of the Pathfinder project. Within this blog post you will learn about the changes we have made since the critical design review (CDR) to update this document.

Updated Product Breakdown Structure

pbs_updated

Figure 1: Updated Product Breakdown Structure

Due to feedback we got during the CDR presentation, our Product Breakdown Structure was updated to reflect our project. This Product Breakdown structure states all the item’s that we have used to create our Solar Panels. This flow down structure is helpful as it explains where the items are used for. I will also state why we decided to use some of these items.

As stated before, this is a flow down diagram. The Pathfinder is the main overall system and a part of that, is the Solar Panel (in which we care about). Within the Solar Panel system, you’ll find four main systems that were used to help complete this project: Control System, Mobility System, Charging System, and PCB.

Control System

The main idea for the Control System is to be able to control our Solar Panels—in other words, we should be able send commands and receive telemetry data. The first main product in which we are utilizing is Professor Hill’s Arxterra Control Panel. The corresponding app will be used so the joint Pathfinder group will be using an android phone. Most of the other projects used a 3Dot board which has Bluetooth LTE built into it. The Android Phone uses an HM-10 Bluetooth connection.

Three Pololu-A4988 Motor Drivers will be attached to our Arduino Micro, which will be used to control our stepper motors, and an MPC-23017 chip to make room on the Micro for our reed sensors. These reed sensors will stop the stepper motors and prevent the panels from overfolding and hit/damage the adjacent panel.

Mobility System

Within our mobility system, we will be using stepper motors (3), motor brackets (3), hinges (5), worm gears (5). These products are key to satisfying our cocooning mechanism. The stepper motors will be used to control the three folds that we have going on in our cocooning mechanism. The motor brackets will be used to connect our motors to the aluminum panels. The hinges will be used to fold the panels together. And the worm gears are also used in conjunction of our motors and hinges. We chose the hinges because it provided a low input, high output torque.

Charging System

The charging sufficient is the key to satisfying our mission profile, which is to have the Pathfinder be self-sufficient. The products within this system are as follows: 12-V 7000-mAh Lead Acid Battery, aluminum panels (6), solar cells (181), rubber insolation layer, sticker paper cavities, 24 AWG wires, tabbing wire, and charge controller. We decided to salvage and use the battery from the previous semester because it was still in great shape. One of the main requirements was to have our solar panels represent the form factor of the Spirit & Opportunity rovers. The two aforementioned rovers consists of six differently shaped panels. This leads to why we chose 39 mm x 39 mm polycrystalline solar cells. Not only are polycrystalline cells efficient but these were small enough to help us complete the form factor of the Spirit & Opportunity rovers. We also added an insulating layer and acrylic plating to protect the environment from the elements when it undergoes its mission. The cells were connected together using tabbing wire. A concern of charging a battery is allowing more voltage which can destroy the battery, so we decided to counter this with a charge controller that will not allow the voltage going into the battery to exceed 12-V.

PCB

We used a custom PCB board because essentially, it’s clean and small. This will help save us space within the electrical box that we shared with the Chassis group

Future Updates

As of now, we are not planning on updating our PBS. But, I may suggest for the next semester to be wise about the sizing and solar cells they choose to use. Some are very fragile and will break more often than not when soldering. They also don’t output the stated output on the website. It’s very unlikely it will ever hit those perfect conditions. I suggest using bigger solar cells, because at the end of the day, it’s best to complete the mission of charging a battery no matter what it looks like.