mirror of
https://github.com/team2059/Dent
synced 2025-01-07 22:14:14 -05:00
Merge branch 'develop'
This commit is contained in:
commit
42fbba836a
3
.gitignore
vendored
3
.gitignore
vendored
@ -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
|
||||||
|
@ -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
|
|
@ -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
|
|
@ -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();
|
||||||
|
@ -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
|
||||||
|
@ -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;
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -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();
|
||||||
|
@ -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
|
||||||
|
@ -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;
|
||||||
|
@ -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();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -1,11 +1,10 @@
|
|||||||
#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);
|
||||||
|
@ -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
|
||||||
|
@ -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);
|
||||||
|
@ -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
|
||||||
|
@ -1,11 +1,10 @@
|
|||||||
#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);
|
||||||
|
@ -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
|
||||||
|
@ -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();
|
||||||
|
@ -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
|
||||||
|
@ -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();
|
||||||
|
@ -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
|
||||||
|
@ -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();
|
||||||
|
@ -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
|
||||||
|
@ -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;
|
||||||
|
@ -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
|
||||||
|
@ -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);
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -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();
|
||||||
|
53
DentRobot.h
53
DentRobot.h
@ -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"
|
||||||
|
/**
|
||||||
|
* @brief The Hitchhikers 2015 robot, Dent
|
||||||
|
*
|
||||||
|
* Features a 4-motor collector, 4-motor mecanum drivetrain, two one-motor elevators
|
||||||
|
*/
|
||||||
class DentRobot: public IterativeRobot{
|
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
|
||||||
|
10
Makefile
10
Makefile
@ -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
|
|
||||||
|
9
OI.h
9
OI.h
@ -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);
|
||||||
|
88
README.md
88
README.md
@ -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 Dent’s 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)
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -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();
|
||||||
|
@ -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
|
||||||
|
@ -7,15 +7,23 @@ Drivetrain::Drivetrain() : Subsystem("Drivetrain"){
|
|||||||
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
|
||||||
|
@ -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
|
||||||
|
@ -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;
|
||||||
|
@ -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
|
||||||
|
@ -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
31
mainpage.dox
Normal 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
|
||||||
|
*/
|
Loading…
x
Reference in New Issue
Block a user