blob: 86f701977017bd4d712d48f3e0c80a966810b3df [file] [log] [blame]
Brian Silverman26e4e522015-12-17 01:56:40 -05001/*----------------------------------------------------------------------------*/
Brian Silverman1a675112016-02-20 20:42:49 -05002/* Copyright (c) FIRST 2008-2016. All Rights Reserved. */
Brian Silverman26e4e522015-12-17 01:56:40 -05003/* Open Source Software - may be modified and shared by FRC teams. The code */
Brian Silverman1a675112016-02-20 20:42:49 -05004/* must be accompanied by the FIRST BSD license file in the root directory of */
5/* the project. */
Brian Silverman26e4e522015-12-17 01:56:40 -05006/*----------------------------------------------------------------------------*/
Brian Silverman1a675112016-02-20 20:42:49 -05007
Brian Silverman26e4e522015-12-17 01:56:40 -05008#pragma once
9
10#include "AnalogInput.h"
11#include "SensorBase.h"
12#include "PIDSource.h"
13#include "LiveWindow/LiveWindowSendable.h"
14
15#include <memory>
16
17/**
18 * Handle operation of an analog accelerometer.
19 * The accelerometer reads acceleration directly through the sensor. Many
20 * sensors have
21 * multiple axis and can be treated as multiple devices. Each is calibrated by
22 * finding
23 * the center value over a period of time.
24 */
25class AnalogAccelerometer : public SensorBase,
26 public PIDSource,
27 public LiveWindowSendable {
28 public:
29 explicit AnalogAccelerometer(int32_t channel);
30 explicit AnalogAccelerometer(AnalogInput *channel);
31 explicit AnalogAccelerometer(std::shared_ptr<AnalogInput> channel);
32 virtual ~AnalogAccelerometer() = default;
33
34 float GetAcceleration() const;
35 void SetSensitivity(float sensitivity);
36 void SetZero(float zero);
37 double PIDGet() override;
38
39 void UpdateTable() override;
40 void StartLiveWindowMode() override;
41 void StopLiveWindowMode() override;
42 std::string GetSmartDashboardType() const override;
43 void InitTable(std::shared_ptr<ITable> subTable) override;
44 std::shared_ptr<ITable> GetTable() const override;
45
46 private:
47 void InitAccelerometer();
48
49 std::shared_ptr<AnalogInput> m_analogInput;
50 float m_voltsPerG = 1.0;
51 float m_zeroGVoltage = 2.5;
52
53 std::shared_ptr<ITable> m_table;
54};