REVLib - C++
DetachedEncoderSim.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2025 REV Robotics
3 *
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions are met:
6 *
7 * 1. Redistributions of source code must retain the above copyright notice,
8 * this list of conditions and the following disclaimer.
9 * 2. Redistributions in binary form must reproduce the above copyright
10 * notice, this list of conditions and the following disclaimer in the
11 * documentation and/or other materials provided with the distribution.
12 * 3. Neither the name of REV Robotics nor the names of its
13 * contributors may be used to endorse or promote products derived from
14 * this software without specific prior written permission.
15 *
16 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
17 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
20 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
21 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
22 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
23 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
24 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
25 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
26 * POSSIBILITY OF SUCH DAMAGE.
27 */
28
29#pragma once
30
31#include <string>
32
33#include <hal/SimDevice.h>
34
35#include "rev/DetachedEncoder.h"
36
37namespace rev::detached {
38
40public:
41 explicit DetachedEncoderSim(DetachedEncoder* encoder);
42
43 void SetPosition(double position);
44 double GetPosition() const;
45
46 void SetVelocity(double velocity);
47 double GetVelocity() const;
48
49 void SetAngle(double angle);
50 double GetAngle() const;
51
52 void SetRawAngle(double rawAngle);
53 double GetRawAngle() const;
54
55 void SetInverted(bool inverted);
56 bool GetInverted() const;
57
58 void SetZeroOffset(double zeroOffset);
59 double GetZeroOffset() const;
60
61 double GetPositionConversionFactor() const;
62 double GetVelocityConversionFactor() const;
63
64 void iterate(double velocity, double dt);
65
66private:
67 hal::SimDouble m_position;
68 hal::SimDouble m_velocity;
69 hal::SimDouble m_angle;
70 hal::SimDouble m_rawAngle;
71 hal::SimBoolean m_isInverted;
72 hal::SimDouble m_zeroOffset;
73 hal::SimDouble m_positionConversionFactor;
74 hal::SimDouble m_velocityConversionFactor;
75
76 DetachedEncoder* m_encoder;
77 std::string simDeviceName;
78};
79
80} // namespace rev::detached
Definition: DetachedEncoder.h:43
Definition: DetachedEncoderSim.h:39
DetachedEncoderSim(DetachedEncoder *encoder)
Definition: DetachedEncoderSim.cpp:40
void SetPosition(double position)
Definition: DetachedEncoderSim.cpp:58
void SetVelocity(double velocity)
Definition: DetachedEncoderSim.cpp:66
void SetAngle(double angle)
Definition: DetachedEncoderSim.cpp:78
double GetPositionConversionFactor() const
Definition: DetachedEncoderSim.cpp:102
double GetPosition() const
Definition: DetachedEncoderSim.cpp:62
double GetRawAngle() const
Definition: DetachedEncoderSim.cpp:90
void SetInverted(bool inverted)
Definition: DetachedEncoderSim.cpp:74
double GetVelocity() const
Definition: DetachedEncoderSim.cpp:70
double GetZeroOffset() const
Definition: DetachedEncoderSim.cpp:100
double GetVelocityConversionFactor() const
Definition: DetachedEncoderSim.cpp:106
void SetRawAngle(double rawAngle)
Definition: DetachedEncoderSim.cpp:86
bool GetInverted() const
Definition: DetachedEncoderSim.cpp:94
void iterate(double velocity, double dt)
Definition: DetachedEncoderSim.cpp:110
void SetZeroOffset(double zeroOffset)
Definition: DetachedEncoderSim.cpp:96
double GetAngle() const
Definition: DetachedEncoderSim.cpp:82
Definition: ClosedLoopConfig.h:38