/*----------------------------------------------------------------------------*/ /* 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 "GyroBase.h" #include "simulation/SimGyro.h" #include 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 uint32_t kOversampleBits; static const uint32_t kAverageBits; static const float kSamplesPerSecond; static const float kCalibrationSampleTime; static const float kDefaultVoltsPerDegreePerSecond; explicit AnalogGyro(uint32_t 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; };