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

Merged documentation from feature/doxygen

This commit is contained in:
Adam Long 2015-03-08 19:32:45 +00:00
commit b5460f9b1e
25 changed files with 2366 additions and 24 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

@ -6,15 +6,45 @@
#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
public: public:
/**
* @brief Constructs AutoDrive
*
* @param double Timeout in seconds
* @param double Joystick x value (default: 0.0)
* @param double Joystick y value (default: 0.75)
*/
AutoDrive(double duration, double xtmp = 0.0, double ytmp = -0.75); AutoDrive(double duration, double xtmp = 0.0, double ytmp = -0.75);
/**
* @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

@ -49,16 +49,16 @@ Autonomous::Autonomous(int seq){
printf("Done"); printf("Done");
AddSequential(new CollectTote()); AddSequential(new CollectTote());
if(SmartDashboard::GetBoolean("Two totes")){ if(SmartDashboard::GetBoolean("Two totes")){
AddSequential(new Raise()); AddSequential(new Raise(3.5));
AddSequential(new AutoDrive(SmartDashboard::GetNumber("Auto Tote Distance"), 0, 0.75)); AddSequential(new AutoDrive(SmartDashboard::GetNumber("Auto Tote Distance"), 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));
if(SmartDashboard::GetBoolean("Three totes")){ if(SmartDashboard::GetBoolean("Three totes")){
AddSequential(new AutoDrive(SmartDashboard::GetNumber("Auto Tote Distance"), 0, 0.75)); AddSequential(new AutoDrive(SmartDashboard::GetNumber("Auto Tote Distance"), 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")));

View File

@ -6,8 +6,27 @@
#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:
/**
* @brief Constructs Autonomous
*
* @param int The sequence to run
*/
Autonomous(int); Autonomous(int);
}; };
#endif #endif

View File

@ -6,8 +6,16 @@
#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:
/**
* @brief Constructs CollectTote
*/
CollectTote(); CollectTote();
}; };
#endif #endif

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.75));
} }
// vim: ts=2:sw=2:et // vim: ts=2:sw=2:et

View File

@ -6,8 +6,16 @@
#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

@ -6,15 +6,41 @@
#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:
/**
* @brief Constructs Turn
*
* @param double Timeout in seconds
*/
Turn(double); Turn(double);
/**
* @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

@ -4,13 +4,39 @@
#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(double timeout = 0.5); BinCloseArms(double timeout = 0.5);
/**
* @brief Constructs BinCloseArms
*/
BinCloseArms();
/**
* @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,7 +1,7 @@
#include "BinLower.h" #include "BinLower.h"
#include "../../DentRobot.h" #include "../../DentRobot.h"
#include "../../OI.h" #include "../../OI.h"
BinLower::BinLower(double timeout) : Command("BinLower"){ BinLower::BinLower(float timeout) : Command("BinLower"){
SetTimeout(timeout); SetTimeout(timeout);
} }
void BinLower::Initialize(){ void BinLower::Initialize(){

View File

@ -4,14 +4,40 @@
#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; //<! The timeout
public: public:
BinLower(double); /**
* @brief Constructs BinLower
*
* @param float Timeout in seconds
*/
BinLower(float);
/**
* @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

@ -7,12 +7,32 @@
class BinOpenArms: public Command{ class BinOpenArms: public Command{
public: public:
BinOpenArms(double); BinOpenArms(double);
/**
* @brief Constructs 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

@ -4,16 +4,42 @@
#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; //<! The timeout
public: public:
BinRaise(double); BinRaise(double);
/**
* @brief Constructs BinRaise
*
* @param float Timeout in seconds
*/
BinRaise(float);
/**
* @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

@ -6,18 +6,42 @@
#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(); RollIn();
/**
* @brief Constructs RollIn
*
* @param double Timeout in seconds
*/
RollIn(double); RollIn(double);
/**
* @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

@ -6,15 +6,38 @@
#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(double timeout = 2.0); RollOut(double timeout = 2.0);
/**
* @brief Constructs RollOut
*/
RollOut();
/**
* @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

@ -6,13 +6,38 @@
#include "../../DentRobot.h" #include "../../DentRobot.h"
#include "WPILib.h" #include "WPILib.h"
/**
* @brief Drives the robot with a joystick
*
* Uses mechanum 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

@ -4,13 +4,37 @@
#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(double timeout=3.0); Lower(double timeout=3.0);
/**
* @brief Constructs Lower
*/
Lower();
/**
* @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

@ -4,15 +4,38 @@
#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(double timeout=3.5); Raise(double timeout=3.5);
/**
* @brief Constructs Raise
*/
Raise();
/**
* @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

@ -6,15 +6,40 @@
#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 int
*/
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

@ -6,8 +6,14 @@
#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

@ -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 Collctor
*/
static Collector* collector; static Collector* collector;
/**
* @brief The 4-motor mechanum 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

6
OI.cpp
View File

@ -18,10 +18,10 @@ OI::OI() {
JoystickButton *left1=new JoystickButton(leftStick, 1); JoystickButton *left1=new JoystickButton(leftStick, 1);
JoystickButton *left2=new JoystickButton(leftStick, 2); JoystickButton *left2=new JoystickButton(leftStick, 2);
left1->WhileHeld(new RollIn(GetLeftThrottle())); left1->WhileHeld(new RollIn(GetLeftThrottle()));
left2->WhileHeld(new RollOut()); left2->WhileHeld(new RollOut(2.0));
// Elevator // Elevator
raise=new Raise(); raise=new Raise(3.5);
lower=new Lower(); lower=new Lower(3.0);
JoystickButton *right4=new JoystickButton(rightStick, 4); JoystickButton *right4=new JoystickButton(rightStick, 4);
JoystickButton *right6=new JoystickButton(rightStick, 6); JoystickButton *right6=new JoystickButton(rightStick, 6);
right4->WhenPressed(lower); right4->WhenPressed(lower);

31
OI.h
View File

@ -4,16 +4,45 @@
#include "WPILib.h" #include "WPILib.h"
#include "Commands/Command.h" #include "Commands/Command.h"
/**
* @brief Controls the robot with joysticks
*/
class OI class OI
{ {
private: private:
Joystick *leftStick, *rightStick; Joystick *leftStick, *rightStick;
public: public:
/**
* @brief Constructs OI
*/
OI(); OI();
Command *raise, *lower, *binLower, *binRaise; Command *raise, //!< Raise command
*lower, //!< Lower command
*binLower, //!< BinLower command
*binRaise; //!< BinRaise command
/**
* @brief Returns the right joystick
*
* @return The right joystick
*/
Joystick* GetRightStick(); Joystick* GetRightStick();
/**
* @brief Returns the left joystick
*
* @return The left joystick
*/
Joystick* GetLeftStick(); Joystick* GetLeftStick();
/**
* @brief Returns the left joystick throttle
*
* @return The left joystick throttle
*/
double GetLeftThrottle(); double GetLeftThrottle();
/**
* @brief Returns the right joystick throttle
*
* @return The right joystick throttle
*/
double GetRightThrottle(); double GetRightThrottle();
}; };
#endif #endif

View File

@ -2,16 +2,46 @@
#define COLLECTOR_H #define COLLECTOR_H
#include "WPILib.h" #include "WPILib.h"
/**
* @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 class Collector: public Subsystem
{ {
private: private:
CANTalon *collectorMotorLeft, *collectorMotorBottom, *collectorMotorRamp, *collectorMotorRight; CANTalon *collectorMotorLeft, //<! Left collector motor
*collectorMotorBottom, //<! Bottom collctor motor
*collectorMotorRamp, //<! Ramp collctor 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();
/**
* @brief Moves the collectors
*
* @param double The speed to run the collectors
*/
void MoveRollers(double); void MoveRollers(double);
/**
* @brief Gets the distance of the sonar (UNUSED)
*
* @return The sonar distance
*/
double GetSonarDistance(); double GetSonarDistance();
}; };
#endif #endif