/*----------------------------------------------------------------------------*/ /* Copyright (c) FIRST 2008-2016. All Rights Reserved. */ /* Open Source Software - may be modified and shared by FRC teams. The code */ /* must be accompanied by the FIRST BSD license file in the root directory of */ /* the project. */ /*----------------------------------------------------------------------------*/ #pragma once #include #include "GyroBase.h" #include "simulation/SimGyro.h" class AnalogInput; class AnalogModule; /** * Use a rate gyro to return the robots heading relative to a starting position. * * The AnalogGyro class tracks the robots heading based on the starting * position. As the robot rotates the new heading is computed by integrating * the rate of rotation returned by the sensor. When the class is instantiated, * it does a short calibration routine where it samples the gyro while at rest * to determine the default offset. This is subtracted from each sample to * determine the heading. This gyro class must be used with a channel that is * assigned one of the Analog accumulators from the FPGA. See AnalogInput for * the current accumulator assignments. */ class AnalogGyro : public GyroBase { public: static const int kOversampleBits; static const int kAverageBits; static const float kSamplesPerSecond; static const float kCalibrationSampleTime; static const float kDefaultVoltsPerDegreePerSecond; explicit AnalogGyro(int channel); virtual ~AnalogGyro() = default; float GetAngle() const; void Calibrate() override; double GetRate() const; void Reset(); private: void InitAnalogGyro(int channel); SimGyro* impl; std::shared_ptr m_table; };