mirror of
https://github.com/wpilibsuite/allwpilib
synced 2026-06-26 01:51:41 +00:00
Also update copyright to include "and other WPILib contributors" and clarify license referral language to not be restricted to FIRST teams.
52 lines
1.0 KiB
C++
52 lines
1.0 KiB
C++
// Copyright (c) FIRST and other WPILib contributors.
|
|
// Open Source Software; you can modify and/or share it under the terms of
|
|
// the WPILib BSD license file in the root directory of this project.
|
|
|
|
#pragma once
|
|
|
|
#include <hal/SimDevice.h>
|
|
#include <units/angle.h>
|
|
#include <units/angular_velocity.h>
|
|
|
|
#include "frc/geometry/Rotation2d.h"
|
|
|
|
namespace frc {
|
|
|
|
class ADXRS450_Gyro;
|
|
|
|
namespace sim {
|
|
|
|
/**
|
|
* Class to control a simulated ADXRS450 gyroscope.
|
|
*/
|
|
class ADXRS450_GyroSim {
|
|
public:
|
|
/**
|
|
* Constructs from a ADXRS450_Gyro object.
|
|
*
|
|
* @param gyro ADXRS450_Gyro to simulate
|
|
*/
|
|
explicit ADXRS450_GyroSim(const ADXRS450_Gyro& gyro);
|
|
|
|
/**
|
|
* Sets the angle.
|
|
*
|
|
* @param angle The angle (clockwise positive).
|
|
*/
|
|
void SetAngle(units::degree_t angle);
|
|
|
|
/**
|
|
* Sets the angular rate (clockwise positive).
|
|
*
|
|
* @param rate The angular rate.
|
|
*/
|
|
void SetRate(units::degrees_per_second_t rate);
|
|
|
|
private:
|
|
hal::SimDouble m_simAngle;
|
|
hal::SimDouble m_simRate;
|
|
};
|
|
|
|
} // namespace sim
|
|
} // namespace frc
|