2
0
mirror of https://github.com/team2059/Dent synced 2025-01-07 22:14:14 -05:00

Merge branch 'develop'

This commit is contained in:
Austen Adler 2015-03-20 18:42:05 -04:00
commit 42fbba836a
52 changed files with 2790 additions and 259 deletions

3
.gitignore vendored
View File

@ -1,8 +1,9 @@
*.o *.o
Debug
bin bin
wpilib wpilib
CMakeCache.txt CMakeCache.txt
CMakeFiles CMakeFiles
cmake_install.cmake cmake_install.cmake
vision vision
latex
html

View File

@ -1,25 +0,0 @@
#include "CommandBase.h"
#include "Subsystems/Drivetrain.h"
#include "Subsystems/Collector.h"
#include "Subsystems/Elevator.h"
#include "Subsystems/BinElevator.h"
#include "Subsystems/Pneumatics.h"
Drivetrain* CommandBase::drivetrain = NULL;
Collector* CommandBase::collector = NULL;
Elevator* CommandBase::elevator = NULL;
BinElevator* CommandBase::binElevator = NULL;
Pneumatics* CommandBase::pneumatics=NULL;
OI* CommandBase::oi = NULL;
CommandBase::CommandBase(char const *name) : Command(name) {
}
CommandBase::CommandBase() : Command() {
}
void CommandBase::init(){
drivetrain = new Drivetrain();
collector = new Collector();
elevator = new Elevator();
binElevator = new BinElevator();
pneumatics = new Pneumatics();
oi = new OI();
}
// vim: ts=2:sw=2:et

View File

@ -1,26 +0,0 @@
#ifndef COMMAND_BASE_H
#define COMMAND_BASE_H
#include <string>
#include "Subsystems/Drivetrain.h"
#include "Subsystems/Collector.h"
#include "Subsystems/Elevator.h"
#include "Subsystems/BinElevator.h"
#include "Subsystems/Pneumatics.h"
#include "OI.h"
#include "WPILib.h"
class CommandBase: public Command {
public:
CommandBase(char const *name);
CommandBase();
static void init();
static Drivetrain *drivetrain;
static Collector *collector;
static Elevator *elevator;
static BinElevator *binElevator;
static Pneumatics *pneumatics;
static OI *oi;
};
#endif
// vim: ts=2:sw=2:et

View File

@ -1,23 +1,26 @@
#include "AutoDrive.h" #include "AutoDrive.h"
#include "../../DentRobot.h" #include "../../DentRobot.h"
// Drive for a short while then stop. Just for testing // Drive for a short while then stop. Just for testing
AutoDrive::AutoDrive(double duration, double xtmp=0, double ytmp=-0.75) : Command("AutoDrive"){ AutoDrive::AutoDrive(double duration, double xtmp, double ytmp, double ztmp, bool useGyro): Command("AutoDrive"){
Requires(DentRobot::drivetrain); Requires(DentRobot::drivetrain);
SetTimeout(duration); SetTimeout(duration);
x=xtmp; x=xtmp;
y=ytmp; y=ytmp;
z=ztmp;
gyro=useGyro;
} }
void AutoDrive::Initialize(){ void AutoDrive::Initialize(){
DentRobot::drivetrain->ResetGyro();
} }
void AutoDrive::Execute(){ void AutoDrive::Execute(){
//X axis, Y axis, Z axis, sensitivity, speed threshold (usually throttle), gyro //X axis, Y axis, Z axis, sensitivity, speed threshold (usually throttle)
DentRobot::drivetrain->DriveMecanum(x, y, 0.0, 0.9, 0.0); DentRobot::drivetrain->DriveMecanum(x, y, z, 0.9, gyro);
} }
bool AutoDrive::IsFinished(){ bool AutoDrive::IsFinished(){
return IsTimedOut(); return IsTimedOut();
} }
void AutoDrive::End(){ void AutoDrive::End(){
DentRobot::drivetrain->DriveMecanum(0.0, 0.0, 0.0, 0.9, 0.0); DentRobot::drivetrain->DriveMecanum(0.0, 0.0, 0.0, 0.9);
} }
void AutoDrive::Interrupted(){ void AutoDrive::Interrupted(){
End(); End();

View File

@ -2,20 +2,53 @@
#define AUTODRIVE_H #define AUTODRIVE_H
#include "Commands/Command.h" #include "Commands/Command.h"
#include "../../CommandBase.h" #include "../../DentRobot.h"
#include "../../DentRobot.h" #include "../../DentRobot.h"
#include "WPILib.h" #include "WPILib.h"
/**
* @brief Drives the robot without a joystick
*
* Drives the robot given a timeout and joystick values
*/
class AutoDrive: public Command{ class AutoDrive: public Command{
private: private:
double x, y; double x, //<! The x value of the simulated joystick value
y, //<! The y value of the simulated joystick value
z; //<! The z value of the simulated joystick value
bool gyro;
public: public:
AutoDrive(double); /**
AutoDrive(double, double, double); * @brief Constructs AutoDrive
*
* @param duration Timeout in seconds
* @param xtmp Joystick x value (default: 0.0)
* @param ytmp Joystick y value (default: 0.75)
* @param ztmp Joystick z value (default: 0.0)
* @param useGyro Use the gyro when driving
*/
AutoDrive(double duration, double xtmp = 0.0, double ytmp = -0.75, double ztmp = 0.0, bool useGyro = true);
/**
* @brief Initializes the class
*/
void Initialize(); void Initialize();
/**
* @brief Drives the robot
*/
void Execute(); void Execute();
/**
* @brief Checks if the command is finished
*
* @return True only if the timeout was reached
*/
bool IsFinished(); bool IsFinished();
/**
* @brief Sets the drivetrain to stop
*/
void End(); void End();
/**
* @brief Calls End()
*/
void Interrupted(); void Interrupted();
}; };
#endif #endif

View File

@ -11,50 +11,81 @@
#include "CollectTote.h" #include "CollectTote.h"
#include "ReleaseTote.h" #include "ReleaseTote.h"
Autonomous::Autonomous(int seq){ Autonomous::Autonomous(int seq){
//SmartDashboard::GetNumber("Auto Wait Time"); Wait(SmartDashboard::GetNumber("Auto Wait Time"));
switch(seq){ switch(seq){
case 0: case 0:
// Just for testing // Just for testing
// Strafe at .25 power // Turn testing
AddSequential(new AutoDrive(0.5, 0.25, 0.0)); AddSequential(new Turn(3.8));
break; break;
case 1: case 1:
// Drive to Auto Zone (TM) // Drive to Auto Zone (TM)
Wait(SmartDashboard::GetNumber("Auto Wait Time")); AddSequential(new AutoDrive(SmartDashboard::GetNumber("Auto Zone Distance"), 0.0, -0.8, 0.01));
AddSequential(new AutoDrive(SmartDashboard::GetNumber("Auto Zone Distance"), 0.0, -0.8)); AddSequential(new Turn(SmartDashboard::GetNumber("TurnAmount")));
break; break;
case 2: case 2:
// Collect a tote, turn, drive to Auto Zone (TM) // Lower BinElevator, collect bin, turn, drive to AutoZone (TM)
Wait(SmartDashboard::GetNumber("Auto Wait Time")); AddSequential(new BinLower(0.5));
AddSequential(new AutoDrive(SmartDashboard::GetNumber("Auto Bin Distance"), 0.0, 0.75));
AddSequential(new BinRaise(1.0));
AddSequential(new Turn(SmartDashboard::GetNumber("TurnAmount")));
AddSequential(new AutoDrive(SmartDashboard::GetNumber("Auto Zone Distance"), 0.0, -0.75));
AddSequential(new Turn(SmartDashboard::GetNumber("TurnAmount")));
break;
case 3:
// Collect a tote with BinElevator, turn, drive to Auto Zone (TM)
AddSequential(new Turn(SmartDashboard::GetNumber("TurnAmount"))); AddSequential(new Turn(SmartDashboard::GetNumber("TurnAmount")));
AddSequential(new BinRaise(1.2)); AddSequential(new BinRaise(1.2));
AddSequential(new AutoDrive(SmartDashboard::GetNumber("Auto Zone Distance"), 0.0, -0.75)); AddSequential(new AutoDrive(SmartDashboard::GetNumber("Auto Zone Distance"), 0.0, -0.75));
AddSequential(new BinLower(1.0)); AddSequential(new BinLower(1.0));
AddSequential(new Turn(SmartDashboard::GetNumber("TurnAmount"))); AddSequential(new Turn(SmartDashboard::GetNumber("TurnAmount")));
break; break;
case 3: case 4:
// Collect three totes, drive to Auto Zone (TM) // Collect one, two, or three totes, drive to Auto Zone (TM), release totes
printf("Waiting: %f\n", SmartDashboard::GetNumber("Auto Wait Time")); AddSequential(new CollectTote(SmartDashboard::GetNumber("CollectToteTurn")));
Wait(SmartDashboard::GetNumber("Auto Wait Time")); if(SmartDashboard::GetBoolean("Two totes")){
printf("Done"); AddParallel(new Turn(0.81));
AddSequential(new AutoDrive(SmartDashboard::GetNumber("Auto Tote Distance"), 0, 0.75)); AddSequential(new Raise(3.5));
AddSequential(new AutoDrive(SmartDashboard::GetNumber("Two Tote Distance"), 0.0, 0.75));
AddSequential(new CollectTote()); AddSequential(new CollectTote());
AddSequential(new Raise()); AddSequential(new Lower(3.0));
AddSequential(new AutoDrive(SmartDashboard::GetNumber("Auto Tote Distance"), 0, 0.75)); AddSequential(new Raise(3.5));
AddSequential(new CollectTote());
AddSequential(new Lower());
AddSequential(new Raise());
printf("Three totes?: %d\n", SmartDashboard::GetBoolean("Three totes"));
if(SmartDashboard::GetBoolean("Three totes")){ if(SmartDashboard::GetBoolean("Three totes")){
AddSequential(new AutoDrive(SmartDashboard::GetNumber("Auto Tote Distance"), 0, 0.75)); AddSequential(new Turn(3.8));
AddSequential(new AutoDrive(SmartDashboard::GetNumber("Three Tote Distance"), 0.0, 0.75));
AddSequential(new CollectTote()); AddSequential(new CollectTote());
AddSequential(new Lower()); AddSequential(new Lower(3.0));
AddSequential(new Raise()); AddSequential(new Raise(3.5));
}
} }
AddSequential(new Turn(SmartDashboard::GetNumber("TurnAmount"))); AddSequential(new Turn(SmartDashboard::GetNumber("TurnAmount")));
AddSequential(new AutoDrive(SmartDashboard::GetNumber("Auto Zone Distance"), 0, 0.75)); AddSequential(new AutoDrive(SmartDashboard::GetNumber("Auto Zone Distance"), 0.0, 0.75));
AddSequential(new ReleaseTote()); AddSequential(new ReleaseTote());
break; break;
case 5:
// Same as auto 4, but navigate around bins
//TODO: Implement this
break;
case 6:
// Collect 1 bin and 1 tote
//TODO: Implement this
break;
case 7:
// Same as auto 4 with (Three|Two) totes checked, collect bin, drive to Auto Zone (TM), release totes
//TODO: Implement this
break;
case 8:
//Use rear elevator to move tote
AddSequential(new Turn(1.8));
AddSequential(new AutoDrive(2.3,0.0,-0.75));
AddSequential(new Turn(1.8));
break;
case 9:
//Use rear elevator to move bin
AddSequential(new BinLower(.1));
AddSequential(new AutoDrive(SmartDashboard::GetNumber("Auto Zone Distance"),0.0,0.75));
AddSequential(new Turn(2.1));
break;
default: default:
printf("Invalid seq: %d\n", seq); printf("Invalid seq: %d\n", seq);
break; break;

View File

@ -2,13 +2,32 @@
#define AUTONOMOUS_H #define AUTONOMOUS_H
#include "Commands/CommandGroup.h" #include "Commands/CommandGroup.h"
#include "../../CommandBase.h" #include "../../DentRobot.h"
#include "../../DentRobot.h" #include "../../DentRobot.h"
#include "WPILib.h" #include "WPILib.h"
/**
* @brief The autonomous period of the robot
*
* Contains three sequences selectable from the SmartDashboard
* All sequences will wait for the SmartDashboard value "Auto Wait Time"
*
* Sequence 0: Used for testing only
*
* Sequence 1: Drives forward "Auto Zone Distance" at -0.8 power
*
* Sequence 2: Collects a tote, turns, then drives to the auto zone
*
* Sequence 3: Collects two or three totes then drives to auto zone
*/
class Autonomous: public CommandGroup{ class Autonomous: public CommandGroup{
public: public:
Autonomous(int); /**
* @brief Constructs Autonomous
*
* @param seq The sequence to run
*/
Autonomous(int seq=0);
}; };
#endif #endif
// vim: ts=2:sw=2:et // vim: ts=2:sw=2:et

View File

@ -2,8 +2,8 @@
#include "../../DentRobot.h" #include "../../DentRobot.h"
#include "AutoDrive.h" #include "AutoDrive.h"
#include "../Collector/RollIn.h" #include "../Collector/RollIn.h"
CollectTote::CollectTote(){ CollectTote::CollectTote(double z){
AddParallel(new AutoDrive(1.0, -0.75, 0.0)); AddParallel(new AutoDrive(SmartDashboard::GetNumber("DriveTime"), 0.0, 0.75, z, false));
AddSequential(new RollIn(1.0)); AddSequential(new RollIn(1.0));
} }
// vim: ts=2:sw=2:et // vim: ts=2:sw=2:et

View File

@ -2,13 +2,23 @@
#define COLLECTTOTE_H #define COLLECTTOTE_H
#include "Commands/CommandGroup.h" #include "Commands/CommandGroup.h"
#include "../../CommandBase.h" #include "../../DentRobot.h"
#include "../../DentRobot.h" #include "../../DentRobot.h"
#include "WPILib.h" #include "WPILib.h"
/**
* @brief Collects one tote
*
* Rolls collector wheels in and drives forward in parallel
*/
class CollectTote: public CommandGroup{ class CollectTote: public CommandGroup{
public: public:
CollectTote(); /**
* @brief Constructs CollectTote
*
* @param z Joystick z value (default: 0.0)
*/
CollectTote(double z = 0.0);
}; };
#endif #endif
// vim: ts=2:sw=2:et // vim: ts=2:sw=2:et

View File

@ -3,7 +3,7 @@
#include "AutoDrive.h" #include "AutoDrive.h"
#include "../Collector/RollOut.h" #include "../Collector/RollOut.h"
ReleaseTote::ReleaseTote(){ ReleaseTote::ReleaseTote(){
AddParallel(new RollOut()); AddParallel(new RollOut(2.0));
AddParallel(new AutoDrive(0.5, 0, 0.75)); AddParallel(new AutoDrive(0.5, 0.0, -0.75));
} }
// vim: ts=2:sw=2:et // vim: ts=2:sw=2:et

View File

@ -2,12 +2,20 @@
#define RELEASETOTE_H #define RELEASETOTE_H
#include "Commands/CommandGroup.h" #include "Commands/CommandGroup.h"
#include "../../CommandBase.h" #include "../../DentRobot.h"
#include "../../DentRobot.h" #include "../../DentRobot.h"
#include "WPILib.h" #include "WPILib.h"
/**
* @brief Releases one tote
*
* Rolls collector wheels out and drives backwards in parallel
*/
class ReleaseTote: public CommandGroup{ class ReleaseTote: public CommandGroup{
public: public:
/**
* @brief Constructs ReleaseTote
*/
ReleaseTote(); ReleaseTote();
}; };
#endif #endif

View File

@ -1,22 +1,21 @@
#include "Turn.h" #include "Turn.h"
#include "../../DentRobot.h" #include "../../DentRobot.h"
// Drive for a short while then stop. Just for testing Turn::Turn(double timeout): Command("Turn"){
Turn::Turn(int k) : Command("Turn"){
Requires(DentRobot::drivetrain); Requires(DentRobot::drivetrain);
SetTimeout(k); SetTimeout(timeout);
} }
void Turn::Initialize(){ void Turn::Initialize(){
} }
void Turn::Execute(){ void Turn::Execute(){
//X axis, Y axis, Z axis, sensitivity, speed threshold (usually throttle), gyro //X axis, Y axis, Z axis, sensitivity, speed threshold (usually throttle)
DentRobot::drivetrain->DriveMecanum(0.0, 0.0, 0.6, 0.9, 0.0); DentRobot::drivetrain->DriveMecanum(0.0, 0.0, 0.6, 0.9);
} }
bool Turn::IsFinished(){ bool Turn::IsFinished(){
return IsTimedOut(); return IsTimedOut();
} }
void Turn::End(){ void Turn::End(){
// Stop driving // Stop driving
DentRobot::drivetrain->DriveMecanum(0.0, 0.0, 0.0, 0.9, 0.0); DentRobot::drivetrain->DriveMecanum(0.0, 0.0, 0.0, 0.9);
} }
void Turn::Interrupted(){ void Turn::Interrupted(){
End(); End();

View File

@ -2,19 +2,45 @@
#define TURN_H #define TURN_H
#include "Commands/Command.h" #include "Commands/Command.h"
#include "../../CommandBase.h" #include "../../DentRobot.h"
#include "../../DentRobot.h" #include "../../DentRobot.h"
#include "WPILib.h" #include "WPILib.h"
/**
* @brief Turns the robot
*
* Turns the robot until a timeout is reached
*/
class Turn: public Command{ class Turn: public Command{
private: private:
int degrees;
public: public:
Turn(int); /**
* @brief Constructs Turn
*
* @param timeout Timeout in seconds
*/
Turn(double timeout);
/**
* @brief Initializes the class
*/
void Initialize(); void Initialize();
/**
* @brief Turns the robot
*/
void Execute(); void Execute();
/**
* @brief Checks if the command is finished
*
* @return True only if the timeout was reached
*/
bool IsFinished(); bool IsFinished();
/**
* @brief Sets the drivetrain to stop
*/
void End(); void End();
/**
* @brief Calls End()
*/
void Interrupted(); void Interrupted();
}; };
#endif #endif

View File

@ -1,14 +1,13 @@
#include "BinCloseArms.h" #include "BinCloseArms.h"
#include "../../DentRobot.h" #include "../../DentRobot.h"
#include "../../OI.h" #include "../../OI.h"
BinCloseArms::BinCloseArms() : Command("BinCloseArms"){ BinCloseArms::BinCloseArms(double timeout): Command("BinCloseArms"){
SetTimeout(timeout);
} }
void BinCloseArms::Initialize(){ void BinCloseArms::Initialize(){
//Should never need to use this
SetTimeout(0.5);
} }
void BinCloseArms::Execute(){ void BinCloseArms::Execute(){
DentRobot::pneumatics->SetOpen(true); DentRobot::pneumatics->SetOpen(false);
} }
bool BinCloseArms::IsFinished(){ bool BinCloseArms::IsFinished(){
return true; return true;

View File

@ -4,13 +4,40 @@
#include "Commands/Command.h" #include "Commands/Command.h"
#include "WPILib.h" #include "WPILib.h"
/**
* @brief Closes BinElevatorArms (NOT USED)
*
* Sets the solenoid to close the arms of the BinElevator
*/
class BinCloseArms: public Command{ class BinCloseArms: public Command{
public: public:
BinCloseArms(); /**
* @brief Constructs BinCloseArms
*
* @param timeout The timeout
*/
BinCloseArms(double timeout = 0.5);
/**
* @brief Initializes the class
*/
void Initialize(); void Initialize();
/**
* @brief Sets the solenoid to close the arms
*/
void Execute(); void Execute();
/**
* @brief Returns true to prevent solenoid damage
*
* @return True
*/
bool IsFinished(); bool IsFinished();
/**
* @brief Ends the command
*/
void End(); void End();
/**
* @brief Calls End()
*/
void Interrupted(); void Interrupted();
}; };

View File

@ -1,17 +1,16 @@
#include "BinLower.h" #include "BinLower.h"
#include "../../DentRobot.h" #include "../../DentRobot.h"
#include "../../OI.h" #include "../../OI.h"
BinLower::BinLower(float t) : Command("BinLower"){ BinLower::BinLower(float timeout): Command("BinLower"){
timeout=t; SetTimeout(timeout);
} }
void BinLower::Initialize(){ void BinLower::Initialize(){
SetTimeout(timeout);
} }
void BinLower::Execute(){ void BinLower::Execute(){
DentRobot::binElevator->Run(-1.0); DentRobot::binElevator->Run(-1.0);
} }
bool BinLower::IsFinished(){ bool BinLower::IsFinished(){
if (/*!DentRobot::binElevator->GetElevatorBottom()||*/IsTimedOut()){ if(/*!DentRobot::binElevator->GetElevatorBottom()||*/IsTimedOut()){
printf("Robot stoped BinLowering. Sensor based? %d\n", !DentRobot::binElevator->GetElevatorBottom()); printf("Robot stoped BinLowering. Sensor based? %d\n", !DentRobot::binElevator->GetElevatorBottom());
return true; return true;
}else{ }else{

View File

@ -4,15 +4,39 @@
#include "Commands/Command.h" #include "Commands/Command.h"
#include "WPILib.h" #include "WPILib.h"
/**
* @brief Lowers the bin elevator until a timeout is reached
*/
class BinLower: public Command{ class BinLower: public Command{
private: private:
float timeout;
public: public:
BinLower(float); /**
* @brief Constructs BinLower
*
* @param timeout The timeout
*/
BinLower(float timeout);
/**
* @brief Initializes the class
*/
void Initialize(); void Initialize();
/**
* @brief Lowers the bin elevator at -1.0 power
*/
void Execute(); void Execute();
/**
* @brief Checks if the command is finished
*
* @return True only if the timeout was reached
*/
bool IsFinished(); bool IsFinished();
/**
* @brief Sets the bin elevator to stop
*/
void End(); void End();
/**
* @brief Calls End()
*/
void Interrupted(); void Interrupted();
}; };
#endif #endif

View File

@ -1,11 +1,10 @@
#include "BinOpenArms.h" #include "BinOpenArms.h"
#include "../../DentRobot.h" #include "../../DentRobot.h"
#include "../../OI.h" #include "../../OI.h"
BinOpenArms::BinOpenArms() : Command("BinOpenArms"){ BinOpenArms::BinOpenArms(double timeout): Command("BinOpenArms"){
SetTimeout(timeout);
} }
void BinOpenArms::Initialize(){ void BinOpenArms::Initialize(){
//Should never need to use this
SetTimeout(0.5);
} }
void BinOpenArms::Execute(){ void BinOpenArms::Execute(){
DentRobot::pneumatics->SetOpen(true); DentRobot::pneumatics->SetOpen(true);

View File

@ -4,15 +4,43 @@
#include "Commands/Command.h" #include "Commands/Command.h"
#include "WPILib.h" #include "WPILib.h"
/**
* @brief Opens bin arms (unused)
*/
class BinOpenArms: public Command{ class BinOpenArms: public Command{
public: public:
/**
* @brief Constructs BinOpenArms
*
* @param timeout The timeout
*/
BinOpenArms(double timeout);
/**
* @brief Constructs BinOpenArms
*/
BinOpenArms(); BinOpenArms();
/**
* @brief Initializes the class
*/
void Initialize(); void Initialize();
/**
* @brief Sets the solenoid to open the arms
*/
void Execute(); void Execute();
/**
* @brief Returns true to prevent solenoid damage
*
* @return True
*/
bool IsFinished(); bool IsFinished();
/**
* @brief Ends the command
*/
void End(); void End();
/**
* @brief Calls End()
*/
void Interrupted(); void Interrupted();
}; };
#endif #endif
// vim: ts=2:sw=2:et // vim: ts=2:sw=2:et

View File

@ -1,17 +1,16 @@
#include "BinRaise.h" #include "BinRaise.h"
#include "../../DentRobot.h" #include "../../DentRobot.h"
#include "../../OI.h" #include "../../OI.h"
BinRaise::BinRaise(float t) : Command("BinRaise"){ BinRaise::BinRaise(double timeout): Command("BinRaise"){
timeout=t; SetTimeout(timeout);
} }
void BinRaise::Initialize(){ void BinRaise::Initialize(){
SetTimeout(timeout);
} }
void BinRaise::Execute(){ void BinRaise::Execute(){
DentRobot::binElevator->Run(1.0); DentRobot::binElevator->Run(1.0);
} }
bool BinRaise::IsFinished(){ bool BinRaise::IsFinished(){
if (/*!DentRobot::binElevator->GetElevatorTop()||*/IsTimedOut()){ if(/*!DentRobot::binElevator->GetElevatorTop()||*/IsTimedOut()){
printf("Robot stoped raising. Sensor based? %d\n", !DentRobot::binElevator->GetElevatorTop()); printf("Robot stoped raising. Sensor based? %d\n", !DentRobot::binElevator->GetElevatorTop());
return true; return true;
}else{ }else{

View File

@ -4,17 +4,40 @@
#include "Commands/Command.h" #include "Commands/Command.h"
#include "WPILib.h" #include "WPILib.h"
/**
* @brief Raises the bin elevator until a timeout is reached
*/
class BinRaise: public Command{ class BinRaise: public Command{
private: private:
float timeout;
public: public:
BinRaise(float); /**
* @brief Constructs BinRaise
*
* @param timeout Timeout in seconds
*/
BinRaise(double timeout);
/**
* @brief Initializes the class
*/
void Initialize(); void Initialize();
/**
* @brief Raises the bin elevator at 1.0 power
*/
void Execute(); void Execute();
/**
* @brief Checks if the command is finished
*
* @return True only if the timeout was reached
*/
bool IsFinished(); bool IsFinished();
/**
* @brief Sets the bin elevator to stop
*/
void End(); void End();
/**
* @brief Calls End()
*/
void Interrupted(); void Interrupted();
}; };
#endif #endif
// vim: ts=2:sw=2:et // vim: ts=2:sw=2:et

View File

@ -1,18 +1,19 @@
#include "RollIn.h" #include "RollIn.h"
RollIn::RollIn(double k) : Command("RollIn"){ RollIn::RollIn(double speed): Command("RollIn"){
rawSpeed=k; rawSpeed=speed;
} }
void RollIn::Initialize(){ void RollIn::Initialize(){
printf("Initialized RollIn\n"); printf("Initialized RollIn\n");
SetTimeout(2.0); SetTimeout(2.0);
} }
void RollIn::Execute(){ void RollIn::Execute(){
double cvt=(rawSpeed)*DentRobot::collector->GetSonarDistance()/0.4; //double cvt=(rawSpeed)*DentRobot::collector->GetSonarDistance()/0.4;
if(cvt>=1.0){ //if(cvt<=1.0){
DentRobot::collector->MoveRollers(1.0); // DentRobot::collector->MoveRollers(1.0);
}else{ //}else{
DentRobot::collector->MoveRollers(cvt*1.5); // DentRobot::collector->MoveRollers(cvt*1.5);
} //}
DentRobot::collector->MoveRollers(DentRobot::oi->GetLeftThrottle() * 1.0);
} }
bool RollIn::IsFinished(){ bool RollIn::IsFinished(){
return IsTimedOut(); return IsTimedOut();

View File

@ -2,21 +2,45 @@
#define ROLLIN_H #define ROLLIN_H
#include "Commands/Command.h" #include "Commands/Command.h"
#include "../../CommandBase.h" #include "../../DentRobot.h"
#include "../../DentRobot.h" #include "../../DentRobot.h"
#include "WPILib.h" #include "WPILib.h"
/**
* @brief Rolls collector motors in until a timeout is reached
*/
class RollIn: public Command{ class RollIn: public Command{
private: private:
double rawSpeed; double rawSpeed; //<! Raw speed of the collector
public: public:
RollIn(double); /**
* @brief Constructs RollIn
*
* @param speed Speed to roll the collector
*/
RollIn(double speed);
/**
* @brief Initializes the class
*/
void Initialize(); void Initialize();
/**
* @brief Rolls the four collector motors in
*/
void Execute(); void Execute();
/**
* @brief Checks if the command is finished
*
* @return True only if the timeout was reached
*/
bool IsFinished(); bool IsFinished();
/**
* @brief Sets the collector to stop
*/
void End(); void End();
/**
* @brief Calls End()
*/
void Interrupted(); void Interrupted();
}; };
#endif #endif
// vim: ts=2:sw=2:et // vim: ts=2:sw=2:et

View File

@ -1,15 +1,14 @@
#include "RollOut.h" #include "RollOut.h"
RollOut::RollOut() : Command("RollOut"){ RollOut::RollOut(double timeout): Command("RollOut"){
Requires(DentRobot::collector); Requires(DentRobot::collector);
SetTimeout(timeout);
} }
void RollOut::Initialize(){ void RollOut::Initialize(){
SetTimeout(2.0);
} }
void RollOut::Execute(){ void RollOut::Execute(){
//TODO: figure out how to implement this with an Xbox controller // Divide by 2 twice because this speed should be half the collector speed
//DentRobot::collector->MoveRollers(-DentRobot::oi->GetLeftThrottle() * 0.8); DentRobot::collector->MoveRollers(-DentRobot::oi->GetLeftThrottle() * 0.8);
//Will just move at .8 power for now SmartDashboard::PutNumber("DriveThrottle", -DentRobot::oi->GetLeftThrottle());
DentRobot::collector->MoveRollers(-0.8);
} }
bool RollOut::IsFinished(){ bool RollOut::IsFinished(){
return IsTimedOut(); return IsTimedOut();

View File

@ -2,19 +2,43 @@
#define ROLLOUT_H #define ROLLOUT_H
#include "Commands/Command.h" #include "Commands/Command.h"
#include "../../CommandBase.h" #include "../../DentRobot.h"
#include "../../DentRobot.h" #include "../../DentRobot.h"
#include "WPILib.h" #include "WPILib.h"
/**
* @brief Rolls collector motors out until a timeout is reached
*/
class RollOut: public Command{ class RollOut: public Command{
public: public:
RollOut(); /**
* @brief Constructs RollOut
*
* @param timeout The timeout
*/
RollOut(double timeout=2.0);
/**
* @brief Initializes the class
*/
void Initialize(); void Initialize();
/**
* @brief Rolls the four collector motors out
*/
void Execute(); void Execute();
/**
* @brief Checks if the command is finished
*
* @return True only if the timeout was reached
*/
bool IsFinished(); bool IsFinished();
/**
* @brief Sets the collector to stop
*/
void End(); void End();
/**
* @brief Calls End()
*/
void Interrupted(); void Interrupted();
}; };
#endif #endif
// vim: ts=2:sw=2:et // vim: ts=2:sw=2:et

View File

@ -1,6 +1,6 @@
#include "Drive.h" #include "Drive.h"
#include "../../DentRobot.h" #include "../../DentRobot.h"
Drive::Drive() : Command("Drive"){ Drive::Drive(): Command("Drive"){
Requires(DentRobot::drivetrain); Requires(DentRobot::drivetrain);
} }
void Drive::Initialize(){ void Drive::Initialize(){
@ -10,15 +10,19 @@ void Drive::Execute(){
x = DentRobot::oi->GetLeftAxis("left", "x"); x = DentRobot::oi->GetLeftAxis("left", "x");
y = DentRobot::oi->GetLeftAxis("left", "y"); y = DentRobot::oi->GetLeftAxis("left", "y");
z = DentRobot::oi->GetLeftAxis("right", "x"); z = DentRobot::oi->GetLeftAxis("right", "x");
//Code to lock the x axis when not holding button 1 // Lock the x axis when not holding button 1
//if (DentRobot::oi->GetLeftStick()->GetRawButton(1)){ //if(DentRobot::oi->GetLeftStick()->GetRawButton(1)){
// x=0; // x=0;
//} //}
//if (DentRobot::oi->GetLeftStick()->GetRawButton(2)){ //if(DentRobot::oi->GetLeftStick()->GetRawButton(2)){
// y=0; // y=0;
//} //}
//X axis, Y axis, Z axis, sensitivity, speed threshold (usually throttle), gyro //X axis, Y axis, Z axis, sensitivity, speed threshold (usually throttle)
DentRobot::drivetrain->DriveMecanum(x, y, z, 0.9, 0.0); if(DentRobot::oi->GetLeftStick()->GetRawButton(11)){
x = -x;
y = -y;
}
DentRobot::drivetrain->DriveMecanum(x, y, z, 0.9);
} }
bool Drive::IsFinished(){ bool Drive::IsFinished(){
return IsTimedOut(); return IsTimedOut();

View File

@ -2,17 +2,42 @@
#define DRIVE_H #define DRIVE_H
#include "Commands/Command.h" #include "Commands/Command.h"
#include "../../CommandBase.h" #include "../../DentRobot.h"
#include "../../DentRobot.h" #include "../../DentRobot.h"
#include "WPILib.h" #include "WPILib.h"
/**
* @brief Drives the robot with a joystick
*
* Uses mecanum drive
*/
class Drive: public Command{ class Drive: public Command{
public: public:
/**
* @brief Constructs Drive
*/
Drive(); Drive();
/**
* @brief Initializes the class
*/
void Initialize(); void Initialize();
/**
* @brief Drives the robot with joysticks from OI
*/
void Execute(); void Execute();
/**
* @brief Checks if the command is finished
*
* @return False
*/
bool IsFinished(); bool IsFinished();
/**
* @brief Ends the command
*/
void End(); void End();
/**
* @brief Calls End()
*/
void Interrupted(); void Interrupted();
}; };
#endif #endif

View File

@ -1,17 +1,17 @@
#include "Lower.h" #include "Lower.h"
#include "../../DentRobot.h" #include "../../DentRobot.h"
#include "../../OI.h" #include "../../OI.h"
Lower::Lower() : Command("Lower"){ Lower::Lower(double timeout): Command("Lower"){
SetTimeout(timeout);
} }
void Lower::Initialize(){ void Lower::Initialize(){
SetTimeout(3.0);
} }
void Lower::Execute(){ void Lower::Execute(){
DentRobot::elevator->Run(-1.0); DentRobot::elevator->Run(-1.0);
} }
bool Lower::IsFinished(){ bool Lower::IsFinished(){
if (!DentRobot::elevator->GetElevatorBottom()||IsTimedOut()){ if(!DentRobot::elevator->GetElevatorBottom()||IsTimedOut()){
printf("Robot stoped lowering. Sensor based? %d\n", !DentRobot::elevator->GetElevatorBottom()); printf("Robot stopped lowering. Sensor based? %d\n", !DentRobot::elevator->GetElevatorBottom());
return true; return true;
}else{ }else{
return false; return false;

View File

@ -4,13 +4,36 @@
#include "Commands/Command.h" #include "Commands/Command.h"
#include "WPILib.h" #include "WPILib.h"
/**
* @brief Lowers the elevator until a timeout is reached
*/
class Lower: public Command{ class Lower: public Command{
public: public:
Lower(); /**
* @brief Constructs Lower
*/
Lower(double timeout=3.0);
/**
* @brief Initializes the class
*/
void Initialize(); void Initialize();
/**
* @brief Lowers the elevator at -1.0 power
*/
void Execute(); void Execute();
/**
* @brief Checks if the command is finished
*
* @return True if the timeout was reached or if the bottom elevator sensor was triggered
*/
bool IsFinished(); bool IsFinished();
/**
* @brief Sets the elevator to stop
*/
void End(); void End();
/**
* @brief Calls End()
*/
void Interrupted(); void Interrupted();
}; };
#endif #endif

View File

@ -1,10 +1,10 @@
#include "Raise.h" #include "Raise.h"
#include "../../DentRobot.h" #include "../../DentRobot.h"
#include "../../OI.h" #include "../../OI.h"
Raise::Raise() : Command("Raise"){ Raise::Raise(double timeout): Command("Raise"){
SetTimeout(timeout);
} }
void Raise::Initialize(){ void Raise::Initialize(){
SetTimeout(3.5);
} }
void Raise::Execute(){ void Raise::Execute(){
DentRobot::elevator->Run(1.0); DentRobot::elevator->Run(1.0);
@ -13,12 +13,12 @@ bool Raise::IsFinished(){
//if(!DentRobot::elevator->GetElevatorMiddle()){ //if(!DentRobot::elevator->GetElevatorMiddle()){
// DentRobot::elevator->stoppedAtSensor=true; // DentRobot::elevator->stoppedAtSensor=true;
//} //}
//if ((DentRobot::elevator->stoppedAtSensor)){ //if((DentRobot::elevator->stoppedAtSensor)){
// printf("Stopped at the middle sensor\n"); // printf("Stopped at the middle sensor\n");
// DentRobot::elevator->stoppedAtSensor=false; // DentRobot::elevator->stoppedAtSensor=false;
// return true; // return true;
//}else if (!DentRobot::elevator->GetElevatorTop()) { //}else if(!DentRobot::elevator->GetElevatorTop()){
if (!DentRobot::elevator->GetElevatorTop()||!DentRobot::elevator->GetElevatorMiddle()||IsTimedOut()){ if(!DentRobot::elevator->GetElevatorTop()||!DentRobot::elevator->GetElevatorMiddle()||IsTimedOut()){
printf("Robot stopped raising. Sensor based? %d\n", !DentRobot::elevator->GetElevatorTop()||!DentRobot::elevator->GetElevatorMiddle()); printf("Robot stopped raising. Sensor based? %d\n", !DentRobot::elevator->GetElevatorTop()||!DentRobot::elevator->GetElevatorMiddle());
return true; return true;
}else{ }else{

View File

@ -4,15 +4,37 @@
#include "Commands/Command.h" #include "Commands/Command.h"
#include "WPILib.h" #include "WPILib.h"
/**
* @brief Raises the elevator until a timeout is reached
*/
class Raise: public Command{ class Raise: public Command{
public: public:
Raise(); /**
* @brief Constructs Raise
*/
Raise(double timeout=3.5);
/**
* @brief Initializes the class
*/
void Initialize(); void Initialize();
/**
* @brief Raises the elevator at 1.0 power
*/
void Execute(); void Execute();
/**
* @brief Checks if the command is finished
*
* @return True if the timeout was reached or if the top elevator was triggered or if the middle elevator is triggered
*/
bool IsFinished(); bool IsFinished();
/**
* @brief Sets the elevator to stop
*/
void End(); void End();
/**
* @brief Calls End()
*/
void Interrupted(); void Interrupted();
}; };
#endif #endif
// vim: ts=2:sw=2:et // vim: ts=2:sw=2:et

View File

@ -3,7 +3,7 @@
#include "Commands/CommandGroup.h" #include "Commands/CommandGroup.h"
#include "../../DentRobot.h" #include "../../DentRobot.h"
#include "../../RobotMap.h" #include "../../RobotMap.h"
CheckDrive::CheckDrive(int motorID) : CommandGroup("CheckDrive"){ CheckDrive::CheckDrive(int motorID): CommandGroup("CheckDrive"){
Requires(DentRobot::drivetrain); Requires(DentRobot::drivetrain);
motor = motorID; motor = motorID;
} }

View File

@ -2,19 +2,44 @@
#define CHECKDRIVE_H #define CHECKDRIVE_H
#include "Commands/Command.h" #include "Commands/Command.h"
#include "../../CommandBase.h" #include "../../DentRobot.h"
#include "../../DentRobot.h" #include "../../DentRobot.h"
#include "WPILib.h" #include "WPILib.h"
/**
* @brief TODO
*/
class CheckDrive: public CommandGroup{ class CheckDrive: public CommandGroup{
private: private:
int motor; int motor; //<! TODO
public: public:
/**
* @brief TODO
*
* @param motorID
*/
CheckDrive(int); CheckDrive(int);
/**
* @brief Initializes the class
*/
void Initialize(); void Initialize();
/**
* @brief TODO
*/
void Execute(); void Execute();
/**
* @brief Checks if the command is finished
*
* @return TODO
*/
bool IsFinished(); bool IsFinished();
/**
* @brief TODO
*/
void End(); void End();
/**
* @brief Calls End()
*/
void Interrupted(); void Interrupted();
}; };
#endif #endif

View File

@ -2,12 +2,18 @@
#define CHECKROBOT_H #define CHECKROBOT_H
#include "Commands/CommandGroup.h" #include "Commands/CommandGroup.h"
#include "../../CommandBase.h" #include "../../DentRobot.h"
#include "../../DentRobot.h" #include "../../DentRobot.h"
#include "WPILib.h" #include "WPILib.h"
/**
* @brief TODO
*/
class CheckRobot: public CommandGroup{ class CheckRobot: public CommandGroup{
public: public:
/**
* @brief TODO
*/
CheckRobot(); CheckRobot();
}; };
#endif #endif

View File

@ -23,25 +23,33 @@ DentRobot::DentRobot(){
void DentRobot::RobotInit(){ void DentRobot::RobotInit(){
SmartDashboard::PutNumber("CodeVersion", CODE_VERSION); SmartDashboard::PutNumber("CodeVersion", CODE_VERSION);
// Autonomous // Autonomous
// Calibration
// Amount to turn while collecting the initial tote in auto 4
SmartDashboard::PutNumber("CollectToteTurn", 0.25);
// Amount of time to collect a tote
SmartDashboard::PutNumber("DriveTime", 1.3);
// Sequence of autonomous command // Sequence of autonomous command
SmartDashboard::PutNumber("Auto Sequence", 2.0); SmartDashboard::PutNumber("Auto Sequence", 9.0);
SmartDashboard::PutNumber("Auto Wait Time", 3.0); SmartDashboard::PutNumber("Auto Wait Time", 0.5);
// If the robot will be picking up three totes in sequence 3 // If the robot will be picking up three totes in sequence 3
SmartDashboard::PutBoolean("Three totes", true); SmartDashboard::PutBoolean("Two totes", false);
// TODO: Calibrate the following two values SmartDashboard::PutBoolean("Three totes", false);
// Distance (in time) to auto zone // Distance (in time) to auto zone
SmartDashboard::PutNumber("Auto Zone Distance", 2.8); SmartDashboard::PutNumber("Auto Zone Distance", 2.1);
// Distance (in time) to auto tote (used in sequence 3) // Distance (in time) to auto tote (used in sequence 3)
SmartDashboard::PutNumber("Two Tote Distance", 1.0);
SmartDashboard::PutNumber("Three Tote Distance", 2.5);
SmartDashboard::PutNumber("Auto Tote Distance", 0.5); SmartDashboard::PutNumber("Auto Tote Distance", 0.5);
SmartDashboard::PutNumber("TurnAmount", 2.0); SmartDashboard::PutNumber("TurnAmount", 2.6);
// Elevators // Elevators
SmartDashboard::PutBoolean("Bin Elevator Bottom", false); SmartDashboard::PutBoolean("Bin Elevator Bottom", false);
SmartDashboard::PutBoolean("Bin Elevator Top", false); SmartDashboard::PutBoolean("Bin Elevator Top", false);
SmartDashboard::PutBoolean("Elevator Bottom", false); SmartDashboard::PutBoolean("Elevator Bottom", false);
SmartDashboard::PutBoolean("Elevator Top", false); SmartDashboard::PutBoolean("Elevator Top", false);
//Drive speed //Drive speed
SmartDashboard::PutNumber("DriveSpeedReductionThresh",2); SmartDashboard::PutNumber("DriveSpeedReductionThresh", 2.0);
//Gyro
SmartDashboard::PutNumber("Gyro kP", -0.02);
} }
void DentRobot::DisabledPeriodic(){ void DentRobot::DisabledPeriodic(){
Scheduler::GetInstance()->Run(); Scheduler::GetInstance()->Run();
@ -58,13 +66,13 @@ void DentRobot::AutonomousPeriodic(){
Scheduler::GetInstance()->Run(); Scheduler::GetInstance()->Run();
} }
void DentRobot::TeleopInit(){ void DentRobot::TeleopInit(){
if (aut != NULL){ if(aut != NULL){
aut->Cancel(); aut->Cancel();
} }
} }
void DentRobot::TeleopPeriodic(){ void DentRobot::TeleopPeriodic(){
Scheduler::GetInstance()->Run(); Scheduler::GetInstance()->Run();
// TODO: Calibrate 1.0 to the height we want the elevator to automatically raise //TODO: Calibrate 1.0 to the height we want the elevator to automatically raise
if(elevator->GetUseEncoder()&&elevator->GetHeight()<=-1.0){ if(elevator->GetUseEncoder()&&elevator->GetHeight()<=-1.0){
// Raise the elevator if it dips below elevatorTop // Raise the elevator if it dips below elevatorTop
oi->raise->Start(); oi->raise->Start();

View File

@ -8,24 +8,77 @@
#include "Subsystems/Collector.h" #include "Subsystems/Collector.h"
#include "Subsystems/Pneumatics.h" #include "Subsystems/Pneumatics.h"
#include "Commands/Autonomous/Autonomous.h" #include "Commands/Autonomous/Autonomous.h"
class DentRobot: public IterativeRobot { /**
* @brief The Hitchhikers 2015 robot, Dent
*
* Features a 4-motor collector, 4-motor mecanum drivetrain, two one-motor elevators
*/
class DentRobot: public IterativeRobot{
private: private:
/**
* @brief The default driving command
*/
Command *driveCommand = NULL; Command *driveCommand = NULL;
public: public:
/**
* @brief Constructs DentRobot
*/
DentRobot(); DentRobot();
/**
* @brief The 2-joystick OI
*/
static OI* oi; static OI* oi;
/**
* @brief The 4-motor Collector
*/
static Collector* collector; static Collector* collector;
/**
* @brief The 4-motor mecanum Drivetrain
*/
static Drivetrain* drivetrain; static Drivetrain* drivetrain;
/**
* @brief The main one-motor Elevator for lifting totes
*/
static Elevator* elevator; static Elevator* elevator;
/**
* @brief The back one-motor Elevator for lifting totes or bins
*/
static BinElevator* binElevator; static BinElevator* binElevator;
/**
* @brief The Pneumatics system (unused)
*/
static Pneumatics* pneumatics; static Pneumatics* pneumatics;
/**
* @brief The Autonomous command
*/
static CommandGroup* aut; static CommandGroup* aut;
/**
* @brief Initializes the robot
*/
void RobotInit(); void RobotInit();
/**
* @brief Periodically run when disabled
*/
void DisabledPeriodic(); void DisabledPeriodic();
/**
* @brief Initializes the autonomous period
*/
void AutonomousInit(); void AutonomousInit();
/**
* @brief Periodically run when enabled in autonomous
*/
void AutonomousPeriodic(); void AutonomousPeriodic();
/**
* @brief Initializes the teleop period
*/
void TeleopInit(); void TeleopInit();
/**
* @brief Periodically run when enabled in autonomous
*/
void TeleopPeriodic(); void TeleopPeriodic();
/**
* @brief Periodically run when enabled in test mode
*/
void TestPeriodic(); void TestPeriodic();
}; };
#endif #endif

1890
Doxyfile Normal file

File diff suppressed because it is too large Load Diff

View File

@ -6,7 +6,8 @@ SOURCES=$(shell find -type f -name "*.cpp")
OBJECTS=$(SOURCES:.cpp=.o) OBJECTS=$(SOURCES:.cpp=.o)
WPILIB=/var/frc/wpilib WPILIB=/var/frc/wpilib
EXEC=bin/FRCUserProgram EXEC=bin/FRCUserProgram
CLEANSER=rm -r CLEANSER=rm -f
READER=$(shell which pv||which cat)
all : $(OBJECTS) all : $(OBJECTS)
if [ ! -d bin ];then mkdir bin; fi if [ ! -d bin ];then mkdir bin; fi
@ -19,13 +20,10 @@ clean:
$(CLEANSER) $(OBJECTS) bin/FRCUserProgram $(CLEANSER) $(OBJECTS) bin/FRCUserProgram
deploy: deploy:
@cat bin/FRCUserProgram | ssh admin@$(REMOTEIP) 'cat > /home/lvuser/FRCUserProgram2&&rm /home/lvuser/FRCUserProgram;mv /home/lvuser/FRCUserProgram2 /home/lvuser/FRCUserProgram&&. /etc/profile.d/natinst-path.sh;chmod a+x /home/lvuser/FRCUserProgram' @$(READER) bin/FRCUserProgram | ssh admin@$(REMOTEIP) '(rm /home/lvuser/FRCUserProgram)</dev/null;cat > /home/lvuser/FRCUserProgram;chmod a+x /home/lvuser/FRCUserProgram && /usr/local/frc/bin/frcKillRobot.sh -r -t'
debug: debug:
@cat bin/FRCUserProgram | ssh admin@$(REMOTEIP) 'cat > /home/lvuser/FRCUserProgram2&&rm /home/lvuser/FRCUserProgram;mv /home/lvuser/FRCUserProgram2 /home/lvuser/FRCUserProgram&&. /etc/profile.d/natinst-path.sh;chmod a+x /home/lvuser/FRCUserProgram;/home/lvuser/run.sh' @$(READER) bin/FRCUserProgram | ssh admin@$(REMOTEIP) '(rm /home/lvuser/FRCUserProgram)</dev/null;cat > /home/lvuser/FRCUserProgram;chmod a+x /home/lvuser/FRCUserProgram;/home/lvuser/run.sh'
putkey: putkey:
@test -d ~/.ssh||mkdir ~/.ssh;test -f ~/.ssh/id_rsa||ssh-keygen -t rsa -f ~/.ssh/id_rsa -b 4096 -q -N '';cat ~/.ssh/id_rsa.pub|ssh -v admin@$(REMOTEIP) 'cat >> /tmp/key;mkdir -p ~/.ssh;cat /tmp/key >> ~/.ssh/authorized_keys;rm /tmp/key' @test -d ~/.ssh||mkdir ~/.ssh;test -f ~/.ssh/id_rsa||ssh-keygen -t rsa -f ~/.ssh/id_rsa -b 4096 -q -N '';cat ~/.ssh/id_rsa.pub|ssh -v admin@$(REMOTEIP) 'cat >> /tmp/key;mkdir -p ~/.ssh;cat /tmp/key >> ~/.ssh/authorized_keys;rm /tmp/key'
updatemakefile:
@curl -s https://raw.githubusercontent.com/int0x191f2/nameless/master/configure.sh | sh

2
OI.cpp
View File

@ -10,7 +10,7 @@
#include "Commands/Autonomous/CollectTote.h" #include "Commands/Autonomous/CollectTote.h"
#include "Commands/Autonomous/ReleaseTote.h" #include "Commands/Autonomous/ReleaseTote.h"
#include "Commands/Test/CheckRobot.h" #include "Commands/Test/CheckRobot.h"
OI::OI() { OI::OI(){
// Joysticks // Joysticks
leftController=new Joystick(0); leftController=new Joystick(0);
rightStick=new Joystick(1); rightStick=new Joystick(1);

9
OI.h
View File

@ -5,13 +5,18 @@
#include "string" #include "string"
#include "Commands/Command.h" #include "Commands/Command.h"
class OI /**
{ * @brief Controls the robot with joysticks
*/
class OI{
private: private:
Joystick *leftController, *rightStick; Joystick *leftController, *rightStick;
// Named Xbox buttons // Named Xbox buttons
JoystickButton *leftA, *leftB, *leftX, *leftY, *leftLB, *leftRB, *leftBack, *leftStart, *leftLPress, *leftRPress; JoystickButton *leftA, *leftB, *leftX, *leftY, *leftLB, *leftRB, *leftBack, *leftStart, *leftLPress, *leftRPress;
public: public:
/**
* @brief Constructs OI
*/
OI(); OI();
Command *raise, *lower, *binLower, *binRaise; Command *raise, *lower, *binLower, *binRaise;
float GetLeftAxis(std::string, std::string); float GetLeftAxis(std::string, std::string);

View File

@ -1,29 +1,75 @@
# Dent # Dent
[The Hitchhikers](http://team2059.org) 2015 robot
Dent was designed to have a fast mecanum [drivetrain](Subsystems/Drivetrain.cpp) with ground clearance to traverse the scoring platforms with ease—all while carrying a stack of totes. A main [internal elevator](Subsystems/Elevator.cpp) lifts totes up to six high within the robot, allowing us to move quickly to anywhere on the field without tipping. The [intake system](Subsystems/Collector.cpp) features a ramp leading to the floor with an active roller pulling the totes up to two collector wheels on either side of the robot, both pulling the totes in, and centering them simultaneously. ### Features
#### Subsystems
+ [Mecanum drivetrain](Subsystems/Drivetrain.cpp)
+ [Collector](Subsystems/Collector.cpp) to collect totes in main elevator
+ [Internal elevator](Subsystems/Elevator.cpp) for totes
+ [External elevator](Subsystems/BinElevator.cpp) for bins or totes
+ [Pneumatics](Subsystems/Pneumatics.cpp) for opening/closing bin elevator arms (unused)
But Dent does not stop there; a [taller elevator](Subsystems/BinElevator.cpp) on the back of the robot allows us to lift either recycle containers or totes to a greater height. With this, we can create stacks both internally and externally, with each system providing a backup of the other in case anything breaks. #### Sensors
+ [Ultrasonic](Subsystems/Collector.cpp#L9) to check if a tote is in the robot (unused)
+ [hall effect sensors](Subsystems/Elevator.cpp#L6-L8) to check the elevator's position
Dent is programmed in C++ and uses many sensors to determine what to do. An [ultrasonic sensor](Subsystems/Collector.cpp#L9) mounted on the back of the robot looking forward automatically slows down the collector wheels as the totes fly into the internal elevator. Homemade [hall effect sensors](Subsystems/Elevator.cpp#L6-L8) line the elevator shafts of both elevators, allowing the driver to raise totes and containers to pre-programmed heights. #### Automated Commands
+ [AutoDrive](Commands/Autonomous/AutoDrive.cpp) to drive forward without a joystick
+ [CollectTote](Commands/Autonomous/CollectTote.cpp) to drive forwards and roll in collectors in parallel
+ [ReleaseTote](Commands/Autonomous/ReleaseTote.cpp) to drive backwards and roll out collectors in parallel
+ [Turn](Commands/Autonomous/Turn.cpp) to turn the robot
All aspects of Dents design come together to produce a robot ready to rank in qualifications, and still provide a fast and capable design for elimination rounds. With all parts made an code written for Dent in-house, this truly is a robot designed by, built by, and programmed by the students on Team 2059, [The Hitchhikers](http://team2059.org/). ### Running the code
#### Setup (for Linux)
+ Make sure you have the [toolchain](http://first.wpi.edu/FRC/roborio/toolchains/) installed
+ Edit the path of WPILib and the REMOTEIP on the Makefile
+ Run `make putkey` to put the public key on the rrio for faster deploying (optional)
#### Building
+ Run `make && make deploy`
+ Run `ssh admin@rrio-ip.local '/home/lvuser/FRCUserProgram'` to execute the program
### Controls ### Usage
##### Driver Main Joystick (USB 0) #### Left Joystick (USB 0)
- X-Axis - Drive forwards and backwards + X-Axis - Drive forwards and backwards
- Y-Axis - Strafes left and right + Y-Axis - Strafes left and right
- Z-Axis - Turns left and right + Z-Axis - Turns left and right
- Throttle-Axis - Adjusts collector speed + Throttle - Adjusts collector speed
- Button 1 - Collects totes + Button 1 - Collect totes
- Button 2 - Dispenses totes + Button 2 - Eject totes
- Button 7 - Enable robot test + Button 7 - Check robot
##### Driver Secondary Joystick (USB 1) #### Right Joystick (USB 1)
- Button 3 - Lowers bin elevator + Button 3 - Lowers bin elevator
- Button 4 - Lowers tote elevator + Button 4 - Lowers main elevator
- Button 5 - Raises bin elevator + Button 5 - Raises bin elevator
- Button 6 - Raises tote elevator + Button 6 - Raises main elevator
- Button 7 - Opens bin arms + Button 7 - Opens bin arms (unused)
- Button 8 - Closes bin arms + Button 8 - Closes bin arms (unused)
- Button 12 - Universal cancel button + Button 12 - Cancel raising and lowering for both elevators
### Dashboard
#### Configuration
+ CodeVersion - The current version of the code
+ Auto Wait Time - The amount of time to wait for any autonomous to run (default: 2.0)
+ Two totes - Collect a second tote if using Auto Sequence 4 or 5 (default: true)
+ Three totes - Collect a third tote if using Auto Sequence 4 or 5 (default: false)
+ Auto Zone Distance - Amount of time in seconds to drive to the auto zone (default: 2.1)
+ Auto Tote Distance - Amount of time in seconds to drive to a second or third tote if using Auto Sequence 4, 5, or 7 (default: 0.5)
+ Auto Bin Distance - Amount of time in seconds to drive to a bin if using Auto Sequence 6 or 7 (default: 0.5)
+ TurnAmount - Amount of time in seconds to turn the robot (default: 1.8)
+ Bin Elevator Bottom - Status of the bottom bin elevator sensor (unused)
+ Bin Elevator Top - Status of the top bin elevator sensor (unused)
+ Elevator Bottom - Status of the bottom elevator sensor
+ Elevator Top - Status of the top elevator sensor
+ DriveSpeedReductionThresh - Maximum y value of the joystick when driving
+ Auto Sequence - The sequence of autonomous to run
#### Autonomous
1. Drive to auto zone, turn
2. Lower BinElevator, collect bin, turn, drive to AutoZone, turn
3. Raise BinElevator, turn, drive to AutoZone, turn
4. Collect 1, 2, or 3 totes, turn, drive to AutoZone, turn
5. Same as auto 4, but navigate around bins (not implemented)
6. Collect 1 bin then 1 tote (not implemented)
7. Collect 3 totes, collect bin, drive to AutoZone (not implemented)

View File

@ -3,7 +3,7 @@
#include "WPILib.h" #include "WPILib.h"
#define CODE_VERSION 1.0 #define CODE_VERSION 2.0
// Elevator // Elevator
#define ELEVATOR_CAN 1 #define ELEVATOR_CAN 1
@ -28,6 +28,7 @@
#define DRIVE_BACK_LEFT_CAN 3 #define DRIVE_BACK_LEFT_CAN 3
#define DRIVE_FRONT_RIGHT_CAN 4 #define DRIVE_FRONT_RIGHT_CAN 4
#define DRIVE_BACK_RIGHT_CAN 5 #define DRIVE_BACK_RIGHT_CAN 5
#define DRIVE_GYRO_ANALOG 0
// Collector // Collector
#define COLLECTOR_RAMP_CAN 7 #define COLLECTOR_RAMP_CAN 7

View File

@ -3,19 +3,53 @@
#include "WPILib.h" #include "WPILib.h"
#include "Commands/PIDSubsystem.h" #include "Commands/PIDSubsystem.h"
/**
* @brief Controls the bin elevator
*/
class BinElevator{ class BinElevator{
private: private:
CANTalon *motor; CANTalon *motor; //<! The bin elevator motor
Encoder *elevatorEncoder; Encoder *elevatorEncoder; //<! The bin elevator encoder (unused)
static constexpr double kP_real=4, kI_real=.0f, kP_simulation=18, kI_simulation=.2; DigitalInput *elevatorBottom, //<! The bottom bin elevator sensor (unused)
DigitalInput *elevatorBottom, *elevatorTop; *elevatorTop; //<! The top bin elevator sensor (unused)
public: public:
/**
* @brief Constructs BinElevator
*/
BinElevator(); BinElevator();
/**
* @brief No action
*/
void InitDefaultCommand(); void InitDefaultCommand();
void Run(double); /**
* @brief Runs the bin elevator
*
* @param power The power to run the bin elevator
*
* Ranges from -1.0 to 1.0
*/
void Run(double power);
/**
* @brief Sets the encoder value to 0 (unused)
*/
void ResetEncoder(); void ResetEncoder();
/**
* @brief Gets the height of the bin elevator
*
* @return The height of the bin elevator
*/
double GetHeight(); double GetHeight();
/**
* @brief Gets the status of the top sensor
*
* @return True if the sensor is activated
*/
bool GetElevatorTop(); bool GetElevatorTop();
/**
* @brief Gets the status of the bottom sensor
*
* @return True if the sensor is activated
*/
bool GetElevatorBottom(); bool GetElevatorBottom();
}; };
#endif #endif

View File

@ -1,7 +1,7 @@
#include "Collector.h" #include "Collector.h"
#include "../RobotMap.h" #include "../RobotMap.h"
Collector::Collector() : Subsystem("Collector"){ Collector::Collector(): Subsystem("Collector"){
collectorMotorLeft=new CANTalon(COLLECTOR_LEFT_CAN); collectorMotorLeft=new CANTalon(COLLECTOR_LEFT_CAN);
collectorMotorBottom=new CANTalon(COLLECTOR_BOTTOM_CAN); collectorMotorBottom=new CANTalon(COLLECTOR_BOTTOM_CAN);
collectorMotorRamp=new CANTalon(COLLECTOR_RAMP_CAN); collectorMotorRamp=new CANTalon(COLLECTOR_RAMP_CAN);
@ -10,12 +10,12 @@ Collector::Collector() : Subsystem("Collector"){
} }
void Collector::InitDefaultCommand(){ void Collector::InitDefaultCommand(){
} }
void Collector::MoveRollers(double a){ void Collector::MoveRollers(double power){
collectorMotorLeft->Set(a); collectorMotorLeft->Set(power);
collectorMotorBottom->Set(-a); collectorMotorBottom->Set(-power);
collectorMotorRamp->Set(a); collectorMotorRamp->Set(power);
collectorMotorRight->Set(-a); collectorMotorRight->Set(-power);
printf("Roller power: %f\n", a); printf("Roller power: %f\n", power);
} }
double Collector::GetSonarDistance(){ double Collector::GetSonarDistance(){
return sonarAnalog->GetAverageVoltage(); return sonarAnalog->GetAverageVoltage();

View File

@ -2,16 +2,45 @@
#define COLLECTOR_H #define COLLECTOR_H
#include "WPILib.h" #include "WPILib.h"
class Collector: public Subsystem /**
{ * @brief Collects totes
*
* Uses four motors, two on the sides, one on the bottom, and one on the ramp to collect and eject totes
*/
class Collector: public Subsystem{
private: private:
CANTalon *collectorMotorLeft, *collectorMotorBottom, *collectorMotorRamp, *collectorMotorRight; CANTalon *collectorMotorLeft, //<! Left collector motor
*collectorMotorBottom, //<! Bottom collector motor
*collectorMotorRamp, //<! Ramp collector motor
*collectorMotorRight; //<! Right collector motor
/**
* @brief Analog input for sonar (unused)
*/
AnalogInput *sonarAnalog; AnalogInput *sonarAnalog;
/**
* @brief Digital output for sonar (unused)
*/
DigitalOutput *sonarDigital; DigitalOutput *sonarDigital;
public: public:
/**
* @brief Constructs Collector
*/
Collector(); Collector();
/**
* @brief No action
*/
void InitDefaultCommand(); void InitDefaultCommand();
void MoveRollers(double); /**
* @brief Moves the collectors
*
* @param power The speed to run the collectors
*/
void MoveRollers(double power);
/**
* @brief Gets the distance of the sonar (unused)
*
* @return The sonar distance
*/
double GetSonarDistance(); double GetSonarDistance();
}; };
#endif #endif

View File

@ -2,20 +2,28 @@
#include "../RobotMap.h" #include "../RobotMap.h"
#include "../Commands/Drivetrain/Drive.h" #include "../Commands/Drivetrain/Drive.h"
Drivetrain::Drivetrain() : Subsystem("Drivetrain"){ Drivetrain::Drivetrain(): Subsystem("Drivetrain"){
rightFront = new CANTalon(DRIVE_FRONT_RIGHT_CAN); rightFront = new CANTalon(DRIVE_FRONT_RIGHT_CAN);
leftFront = new CANTalon(DRIVE_FRONT_LEFT_CAN); leftFront = new CANTalon(DRIVE_FRONT_LEFT_CAN);
rightRear = new CANTalon(DRIVE_BACK_RIGHT_CAN); rightRear = new CANTalon(DRIVE_BACK_RIGHT_CAN);
leftRear = new CANTalon(DRIVE_BACK_LEFT_CAN); leftRear = new CANTalon(DRIVE_BACK_LEFT_CAN);
gyro = new Gyro(DRIVE_GYRO_ANALOG);
} }
void Drivetrain::InitDefaultCommand(){ void Drivetrain::InitDefaultCommand(){
SetDefaultCommand(new Drive()); SetDefaultCommand(new Drive());
} }
void Drivetrain::DriveMecanum(float x, float y, float z, float sensitivity, float gyro){ void Drivetrain::DriveMecanum(double x, double y, double z, double sensitivity, bool driveStraight){
//TODO: Find the correct value for kP
double kP=SmartDashboard::GetNumber("Gyro kP");
double correctX = -(sensitivity*(pow(x, 3))+(1-sensitivity)*x); double correctX = -(sensitivity*(pow(x, 3))+(1-sensitivity)*x);
double correctY = -(sensitivity*(pow(y, 3))+(1-sensitivity)*y); double correctY = -(sensitivity*(pow(y, 3))+(1-sensitivity)*y);
double correctZ = -z * 0.5; double correctZ;
// If they're holding the right button, slow down if(driveStraight){
printf("Driving straight at: %f\n", -gyro->GetAngle()*kP);
correctZ = -gyro->GetAngle()*kP;
}else{
correctZ = -z * 0.5;
}
if (DentRobot::oi->GetLeftButton("rb")){ if (DentRobot::oi->GetLeftButton("rb")){
correctY /= SmartDashboard::GetNumber("DriveSpeedReductionThresh"); correctY /= SmartDashboard::GetNumber("DriveSpeedReductionThresh");
} }
@ -24,9 +32,8 @@ void Drivetrain::DriveMecanum(float x, float y, float z, float sensitivity, floa
rightRear->Set((correctX + correctY - correctZ)); rightRear->Set((correctX + correctY - correctZ));
leftRear->Set((-correctX + correctY + correctZ)*-1); leftRear->Set((-correctX + correctY + correctZ)*-1);
} }
//Used in pretest //Used in pretest
void Drivetrain::TestMotor(e_motors motor, float power){ void Drivetrain::TestMotor(e_motors motor, double power){
switch(motor){ switch(motor){
case FRONTRIGHT: case FRONTRIGHT:
rightFront->Set(power); rightFront->Set(power);
@ -44,4 +51,7 @@ void Drivetrain::TestMotor(e_motors motor, float power){
break; break;
} }
} }
void Drivetrain::ResetGyro(){
gyro->Reset();
}
// vim: ts=2:sw=2:et // vim: ts=2:sw=2:et

View File

@ -2,22 +2,57 @@
#define DRIVETRAIN_H #define DRIVETRAIN_H
#include "WPILib.h" #include "WPILib.h"
/**
* @brief Drives the robot
*
* 4 wheel mecanum drive
*/
class Drivetrain: public Subsystem{ class Drivetrain: public Subsystem{
private: private:
CANTalon *rightFront, *leftFront, *rightRear, *leftRear; CANTalon *rightFront, //<! Front right motor
RobotDrive *drive; *leftFront, //<! Front left motor
*rightRear, //<! Back right motor
*leftRear; //<! Back left motor
Gyro *gyro; //<! Gyro
public: public:
/**
* @brief Constructs Drivetrain
*/
Drivetrain(); Drivetrain();
/**
* @brief Current motor to test
*/
enum e_motors{ enum e_motors{
FRONTRIGHT, FRONTRIGHT, //<! Front right motor
FRONTLEFT, FRONTLEFT, //<! Front left motor
BACKRIGHT, BACKRIGHT, //<! Back right motor
BACKLEFT BACKLEFT //<! Back left motor
}; };
/**
* @brief No action
*/
void InitDefaultCommand(); void InitDefaultCommand();
void DriveMecanum(float, float, float, float, float); /**
void DriveArcade(float, float); * @brief Drives the robot with mecanum
void TestMotor(e_motors, float); *
* @param x Joystick x value (-1.0 to 1.0)
* @param y Joystick y value (-1.0 to 1.0)
* @param z Joystick z value (-1.0 to 1.0)
* @param sensitivity Sensitivity (0.0 to 1.0)
* @param driveStraight Overrides z value to correct for motor lag
*/
void DriveMecanum(double x, double y, double z, double sensitivity, bool driveStraight=false);
/**
* @brief Tests one motor
*
* @param motor Motor to test
* @param power Power to set motor
*/
void TestMotor(e_motors motor, double power);
/**
* @brief Sets the gyro value to 0.0
*/
void ResetGyro();
}; };
#endif #endif
// vim: ts=2:sw=2:et // vim: ts=2:sw=2:et

View File

@ -8,7 +8,6 @@ Elevator::Elevator(){
elevatorTop=new DigitalInput(ELEVATOR_TOP_DIO); elevatorTop=new DigitalInput(ELEVATOR_TOP_DIO);
// Checks if the elevator is drifting // Checks if the elevator is drifting
useEncoder=false; useEncoder=false;
stoppedAtSensor=false;
} }
void Elevator::InitDefaultCommand(){ void Elevator::InitDefaultCommand(){
} }
@ -36,8 +35,8 @@ bool Elevator::GetElevatorTop(){
SmartDashboard::PutBoolean("Elevator Top", !elevatorTop->Get()); SmartDashboard::PutBoolean("Elevator Top", !elevatorTop->Get());
return elevatorTop->Get(); return elevatorTop->Get();
} }
void Elevator::SetUseEncoder(bool param){ void Elevator::SetUseEncoder(bool use){
useEncoder=param; useEncoder=use;
} }
bool Elevator::GetUseEncoder(){ bool Elevator::GetUseEncoder(){
return useEncoder; return useEncoder;

View File

@ -2,25 +2,71 @@
#define ELEVATOR_H #define ELEVATOR_H
#include "WPILib.h" #include "WPILib.h"
#include "Commands/PIDSubsystem.h" /**
* @brief The main elevator for lifting totes
*/
class Elevator{ class Elevator{
private: private:
CANTalon *motor; CANTalon *motor; //<! The elevator motor
Encoder *elevatorEncoder; Encoder *elevatorEncoder; //<! The elevator encoder (unused)
static constexpr double kP_real=4, kI_real=.0f, kP_simulation=18, kI_simulation=.2; DigitalInput *elevatorBottom, //<! The bottom elevator sensor
DigitalInput *elevatorBottom, *elevatorMiddle, *elevatorTop; *elevatorMiddle, //<! The middle elevator sensor
bool useEncoder; *elevatorTop; //<! The top elevator sensor
bool useEncoder; //<! Use the elevator encoder (unused)
public: public:
/**
* @brief Constructs Elevator
*/
Elevator(); Elevator();
bool stoppedAtSensor; /**
* @brief No action
*/
void InitDefaultCommand(); void InitDefaultCommand();
void Run(double); /**
* @brief Runs the elevator
*
* @param power The power to run the bin elevator (-1.0 to 1.0)
*/
void Run(double power);
/**
* @brief Sets the encoder value to 0 (unused)
*/
void ResetEncoder(); void ResetEncoder();
/**
* @brief Gets the height of the elevator
*
* @return The hight of the elevator
*/
double GetHeight(); double GetHeight();
/**
* @brief Gets the status of the top sensor
*
* @return True if the sensor is activated
*/
bool GetElevatorTop(); bool GetElevatorTop();
/**
* @brief Gets the status of the middle sensor
*
* @return True if the sensor is activated
*/
bool GetElevatorMiddle(); bool GetElevatorMiddle();
/**
* @brief Gets the status of the bottom sensor
*
* @return True if the sensor is activated
*/
bool GetElevatorBottom(); bool GetElevatorBottom();
void SetUseEncoder(bool); /**
* @brief Use the elevator encoder (unused)
*
* @param use State to use encoder
*/
void SetUseEncoder(bool use);
/**
* @brief Gets the state of useEncoder (unused)
*
* @return State of useEncoder
*/
bool GetUseEncoder(); bool GetUseEncoder();
}; };
#endif #endif

View File

@ -1,7 +1,7 @@
#include "Pneumatics.h" #include "Pneumatics.h"
#include "../RobotMap.h" #include "../RobotMap.h"
Pneumatics::Pneumatics() : Subsystem("Pneumatics"){ Pneumatics::Pneumatics(): Subsystem("Pneumatics"){
solenoid1 = new Solenoid(BINELEVATOR_SOLDENOID_ONE); solenoid1 = new Solenoid(BINELEVATOR_SOLDENOID_ONE);
solenoid2 = new Solenoid(BINELEVATOR_SOLDENOID_TWO); solenoid2 = new Solenoid(BINELEVATOR_SOLDENOID_TWO);
} }

View File

@ -2,14 +2,30 @@
#define PNEUMATICS_H #define PNEUMATICS_H
#include "WPILib.h" #include "WPILib.h"
class Pneumatics: public Subsystem /**
{ * @brief Pneumatics on the robot (unused)
*
* For opening or closing the bin arms
*/
class Pneumatics: public Subsystem{
private: private:
Solenoid *solenoid1, *solenoid2; Solenoid *solenoid1, //<! Solenoid 1
*solenoid2; //<! Solenoid 3
public: public:
/**
* @brief Constructs Pneumatics
*/
Pneumatics(); Pneumatics();
/**
* @brief No action
*/
void InitDefaultCommand(); void InitDefaultCommand();
void SetOpen(bool); /**
* @brief Sets the state of the arms
*
* @param state State of the arms
*/
void SetOpen(bool state);
}; };
#endif #endif
// vim: ts=2:sw=2:et // vim: ts=2:sw=2:et

31
mainpage.dox Normal file
View File

@ -0,0 +1,31 @@
/**
* @mainpage Dent
*
* The Hitchhikers Team 2015 robot, Dent. Features an elevator, bin elevator, and mecanum drive
* @section Subsystems
* -# @ref Drivetrain
* -# @ref BinElevator
* -# @ref Elevator
* -# @ref Collector
* -# @ref Pneumatics (unused)
* @section Commands
* -# @ref AutoDrive
* -# @ref Turn
* -# @ref BinCloseArms
* -# @ref BinLower
* -# @ref BinOpenArms
* -# @ref BinRaise
* -# @ref RollIn
* -# @ref RollOut
* -# @ref Drive
* -# @ref Lower
* -# @ref Raise
* @section Command Groups
* -# @ref Autonomous
* -# @ref CollectTote
* -# @ref ReleaseTote
* -# @ref CheckDrive
* -# @ref CheckRobot
*
* Note: Recycling containers are referred to bins throughout the project
*/