blob: be0c7d2a9876b725ede707dd0a41257433fb1eca [file] [log] [blame]
Brian Silverman8fce7482020-01-05 13:18:21 -08001/*----------------------------------------------------------------------------*/
2/* Copyright (c) 2008-2019 FIRST. All Rights Reserved. */
3/* Open Source Software - may be modified and shared by FRC teams. The code */
4/* must be accompanied by the FIRST BSD license file in the root directory of */
5/* the project. */
6/*----------------------------------------------------------------------------*/
7
8#include "frc/AnalogAccelerometer.h"
9
10#include <hal/FRCUsageReporting.h>
11
12#include "frc/WPIErrors.h"
13#include "frc/smartdashboard/SendableBuilder.h"
14#include "frc/smartdashboard/SendableRegistry.h"
15
16using namespace frc;
17
18AnalogAccelerometer::AnalogAccelerometer(int channel)
19 : AnalogAccelerometer(std::make_shared<AnalogInput>(channel)) {
20 SendableRegistry::GetInstance().AddChild(this, m_analogInput.get());
21}
22
23AnalogAccelerometer::AnalogAccelerometer(AnalogInput* channel)
24 : m_analogInput(channel, NullDeleter<AnalogInput>()) {
25 if (channel == nullptr) {
26 wpi_setWPIError(NullParameter);
27 } else {
28 InitAccelerometer();
29 }
30}
31
32AnalogAccelerometer::AnalogAccelerometer(std::shared_ptr<AnalogInput> channel)
33 : m_analogInput(channel) {
34 if (channel == nullptr) {
35 wpi_setWPIError(NullParameter);
36 } else {
37 InitAccelerometer();
38 }
39}
40
41double AnalogAccelerometer::GetAcceleration() const {
42 return (m_analogInput->GetAverageVoltage() - m_zeroGVoltage) / m_voltsPerG;
43}
44
45void AnalogAccelerometer::SetSensitivity(double sensitivity) {
46 m_voltsPerG = sensitivity;
47}
48
49void AnalogAccelerometer::SetZero(double zero) { m_zeroGVoltage = zero; }
50
51double AnalogAccelerometer::PIDGet() { return GetAcceleration(); }
52
53void AnalogAccelerometer::InitSendable(SendableBuilder& builder) {
54 builder.SetSmartDashboardType("Accelerometer");
55 builder.AddDoubleProperty("Value", [=]() { return GetAcceleration(); },
56 nullptr);
57}
58
59void AnalogAccelerometer::InitAccelerometer() {
60 HAL_Report(HALUsageReporting::kResourceType_Accelerometer,
61 m_analogInput->GetChannel() + 1);
62
63 SendableRegistry::GetInstance().AddLW(this, "Accelerometer",
64 m_analogInput->GetChannel());
65}