WPILib  2014.0
WPIRoboticsLibraryforFRC
 All Classes Functions Variables Pages
Public Member Functions | Static Public Attributes | Protected Member Functions | List of all members
IterativeRobot Class Reference

#include <IterativeRobot.h>

Inheritance diagram for IterativeRobot:
RobotBase

Public Member Functions

virtual void StartCompetition ()
 
virtual void RobotInit ()
 
virtual void DisabledInit ()
 
virtual void AutonomousInit ()
 
virtual void TeleopInit ()
 
virtual void TestInit ()
 
virtual void DisabledPeriodic ()
 
virtual void AutonomousPeriodic ()
 
virtual void TeleopPeriodic ()
 
virtual void TestPeriodic ()
 
void SetPeriod (double period)
 
double GetPeriod ()
 
double GetLoopsPerSec ()
 
- Public Member Functions inherited from RobotBase
bool IsEnabled ()
 
bool IsDisabled ()
 
bool IsAutonomous ()
 
bool IsOperatorControl ()
 
bool IsTest ()
 
bool IsSystemActive ()
 
bool IsNewDataAvailable ()
 
WatchdogGetWatchdog ()
 

Static Public Attributes

static constexpr double kDefaultPeriod = 0.0
 

Protected Member Functions

virtual ~IterativeRobot ()
 
 IterativeRobot ()
 
- Protected Member Functions inherited from RobotBase
virtual ~RobotBase ()
 
 RobotBase ()
 

Additional Inherited Members

- Static Public Member Functions inherited from RobotBase
static RobotBasegetInstance ()
 
static void setInstance (RobotBase *robot)
 
static void startRobotTask (FUNCPTR factory)
 
static void robotTask (FUNCPTR factory, Task *task)
 
- Static Protected Member Functions inherited from RobotBase
static void WriteVersionString ()
 
- Protected Attributes inherited from RobotBase
Taskm_task
 
Watchdog m_watchdog
 
DriverStationm_ds
 

Detailed Description

IterativeRobot implements a specific type of Robot Program framework, extending the RobotBase class.

The IterativeRobot class is intended to be subclassed by a user creating a robot program.

This class is intended to implement the "old style" default code, by providing the following functions which are called by the main loop, StartCompetition(), at the appropriate times:

RobotInit() – provide for initialization at robot power-on

Init() functions – each of the following functions is called once when the appropriate mode is entered:

Periodic() functions – each of these functions is called iteratively at the appropriate periodic rate (aka the "slow loop"). The default period of the iterative robot is synced to the driver station control packets, giving a periodic frequency of about 50Hz (50 times per second).

Constructor & Destructor Documentation

IterativeRobot::~IterativeRobot ( )
protectedvirtual

Free the resources for a RobotIterativeBase class.

IterativeRobot::IterativeRobot ( )
protected

Constructor for RobotIterativeBase

The constructor initializes the instance variables for the robot to indicate the status of initialization for disabled, autonomous, teleop, and test code.

Member Function Documentation

void IterativeRobot::AutonomousInit ( )
virtual

Initialization code for autonomous mode should go here.

Users should override this method for initialization code which will be called each time the robot enters autonomous mode.

void IterativeRobot::AutonomousPeriodic ( )
virtual

Periodic code for autonomous mode should go here.

Users should override this method for code which will be called periodically at a regular rate while the robot is in autonomous mode.

void IterativeRobot::DisabledInit ( )
virtual

Initialization code for disabled mode should go here.

Users should override this method for initialization code which will be called each time the robot enters disabled mode.

void IterativeRobot::DisabledPeriodic ( )
virtual

Periodic code for disabled mode should go here.

Users should override this method for code which will be called periodically at a regular rate while the robot is in disabled mode.

double IterativeRobot::GetLoopsPerSec ( )

Get the number of loops per second for the IterativeRobot

Returns
Frequency of the periodic function calls
double IterativeRobot::GetPeriod ( )

Get the period for the periodic functions. Returns 0.0 if configured to syncronize with DS control data packets.

Returns
Period of the periodic function calls
void IterativeRobot::RobotInit ( )
virtual

Robot-wide initialization code should go here.

Users should override this method for default Robot-wide initialization which will be called when the robot is first powered on. It will be called exactly 1 time.

void IterativeRobot::SetPeriod ( double  period)

Set the period for the periodic functions.

Parameters
periodThe period of the periodic function calls. 0.0 means sync to driver station control data.
void IterativeRobot::StartCompetition ( )
virtual

Provide an alternate "main loop" via StartCompetition().

This specific StartCompetition() implements "main loop" behavior like that of the FRC control system in 2008 and earlier, with a primary (slow) loop that is called periodically, and a "fast loop" (a.k.a. "spin loop") that is called as fast as possible with no delay between calls.

Implements RobotBase.

void IterativeRobot::TeleopInit ( )
virtual

Initialization code for teleop mode should go here.

Users should override this method for initialization code which will be called each time the robot enters teleop mode.

void IterativeRobot::TeleopPeriodic ( )
virtual

Periodic code for teleop mode should go here.

Users should override this method for code which will be called periodically at a regular rate while the robot is in teleop mode.

void IterativeRobot::TestInit ( )
virtual

Initialization code for test mode should go here.

Users should override this method for initialization code which will be called each time the robot enters test mode.

void IterativeRobot::TestPeriodic ( )
virtual

Periodic code for test mode should go here.

Users should override this method for code which will be called periodically at a regular rate while the robot is in test mode.


The documentation for this class was generated from the following files: