3#include "../navtypes.h"
12#include <frozen/string.h>
13#include <frozen/unordered_map.h>
14#include <frozen/unordered_set.h>
99constexpr auto all_jointid_t = frozen::make_unordered_set<jointid_t>(
100 {jointid_t::armBase, jointid_t::shoulder, jointid_t::elbow, jointid_t::forearm,
101 jointid_t::wristRoll, jointid_t::wristPitch, jointid_t::hand, jointid_t::handActuator, jointid_t::ikForward,
102 jointid_t::ikUp, jointid_t::fourBarLinkage, jointid_t::drillActuator, jointid_t::drillMotor});
104constexpr auto name_to_jointid = frozen::make_unordered_map<frozen::string, jointid_t>(
105 {{
"armBase", jointid_t::armBase},
106 {
"shoulder", jointid_t::shoulder},
107 {
"elbow", jointid_t::elbow},
108 {
"forearm", jointid_t::forearm},
109 {
"wristPitch", jointid_t::wristPitch},
110 {
"wristRoll", jointid_t::wristRoll},
111 {
"hand", jointid_t::hand},
112 {
"handActuator", jointid_t::handActuator},
113 {
"ikForward", jointid_t::ikForward},
114 {
"ikUp", jointid_t::ikUp},
115 {
"fourBarLinkage", jointid_t::fourBarLinkage},
116 {
"drillActuator", jointid_t::drillActuator},
117 {
"drillMotor", jointid_t::drillMotor}});
119enum class servoid_t {
127constexpr auto all_servoid_t = frozen::make_unordered_set<servoid_t>(
128 {servoid_t::microscope, servoid_t::syringe, servoid_t::soilBox,
129 servoid_t::cuvette, servoid_t::filter});
131constexpr auto name_to_servoid = frozen::make_unordered_map<frozen::string, servoid_t>(
132 {{
"microscope", servoid_t::microscope},
133 {
"syringe", servoid_t::syringe},
134 {
"cuvette", servoid_t::cuvette},
135 {
"filter", servoid_t::filter},
136 {
"soilBox", servoid_t::soilBox}});
138constexpr auto servoid_to_servo_num = frozen::make_unordered_map<servoid_t, int>(
139 {{servoid_t::microscope, 7},
140 {servoid_t::syringe, 9},
141 {servoid_t::cuvette, 5},
142 {servoid_t::filter, 8},
143 {servoid_t::soilBox, 6}});
145enum class stepperid_t {
153constexpr auto all_stepperid_t = frozen::make_unordered_set<stepperid_t>(
154 {stepperid_t::plunger, stepperid_t::judges, stepperid_t::mast,
155 stepperid_t::lock, stepperid_t::lazySusan});
157constexpr auto name_to_stepperid = frozen::make_unordered_map<frozen::string, stepperid_t>(
158 {{
"plunger", stepperid_t::plunger},
159 {
"judges", stepperid_t::judges},
160 {
"mast", stepperid_t::mast},
161 {
"lock", stepperid_t::lock},
162 {
"lazySusan", stepperid_t::lazySusan}});
164constexpr auto stepperid_to_stepper_num = frozen::make_unordered_map<stepperid_t, uint8_t>(
165 {{stepperid_t::plunger, 4},
166 {stepperid_t::judges, 5},
167 {stepperid_t::mast, 2},
168 {stepperid_t::lock, 1},
169 {stepperid_t::lazySusan, 6}});
209 operator bool()
const {
230 return datapoint.has_value();
240 return datapoint.value().first;
251 return datapoint.value().second;
277 template <
typename F>
290 std::optional<std::pair<datatime_t, T>> datapoint;
298constexpr int LIMIT_SWITCH_LIM_MIN_IDX = 0;
299constexpr int LIMIT_SWITCH_LIM_MAX_IDX = 1;
368std::string to_string(robot::types::jointid_t joint);
371std::string to_string(robot::types::servoid_t servo);
_GLIBCXX_END_NAMESPACE_CXX11 typedef basic_string< char > string
duration< int64_t, milli > milliseconds
DataPoint()
Construct an invalid DataPoint, holding no data.
Definition data.h:187
LimitSwitchData(unsigned long long data)
Construct a new LimitSwitchData object, from the given bits.
Definition data.cpp:5
Represents data measured using a sensor at a given time.
Definition data.h:182
bool isFresh(std::chrono::milliseconds duration) const
Check if this measurement was taken recently.
Definition data.h:220
DataPoint(T data)
Construct a new DataPoint object, measured now.
Definition data.h:194
T getData() const
Get the value of this data point.
Definition data.h:249
DataPoint(datatime_t time, T data)
Construct a new DataPoint object, measured at the given time.
Definition data.h:202
datatime_t getTime() const
Get the time at which the measurement was taken.
Definition data.h:239
bool isValid() const
Check if this measurement is valid.
Definition data.h:229
DataPoint()
Construct an invalid DataPoint, holding no data.
Definition data.h:187
DataPoint< std::invoke_result_t< F, T > > transform(const F &f)
Transforms the data in this datapoint by the given function.
Definition data.h:278
T getDataOrElse(T defaultData)
Get the value of this data point, defaulting to a given value if this data point is invalid.
Definition data.h:264
std::bitset< N_LIMIT_SWITCH > diff(const LimitSwitchData &other)
Check which indices differ between this data and other.
Definition data.cpp:23
LimitSwitchData(unsigned long long data)
Construct a new LimitSwitchData object, from the given bits.
Definition data.cpp:5
bool isAnyClosed()
Check if any index is closed.
Definition data.cpp:15
bool isAnyOpen()
Check if any index is open.
Definition data.cpp:19
bool isClosed(size_t idx)
Check if the given index is closed.
Definition data.cpp:11
bool isOpen(size_t idx)
Check if the given index is open.
Definition data.cpp:7
Types for use in the world interface.
Definition data.cpp:3
indication_t
An indication enum, used to command the LED to flash different signals.
Definition data.h:49
std::chrono::time_point< dataclock > datatime_t
A point in time as measured by dataclock.
Definition data.h:31
motorid_t
The motors on the robot.
Definition data.h:57
std::vector< DataPoint< navtypes::point_t > > landmarks_t
A data structure that represents when each landmark was seen.
Definition data.h:41
mountedperipheral_t
the mounted peripheral on the robot.
Definition data.h:77
std::pair< cv::Mat, uint32_t > CameraFrame
A pair of a camera frame and its corresponding frame number.
Definition data.h:44
uint32_t CameraID
The type of a camera id.
Definition data.h:46
std::chrono::steady_clock dataclock
The clock used for time measurements for data.
Definition data.h:29
constexpr size_t N_LIMIT_SWITCH
The maximum number of limit switches associated with any motor.
Definition data.h:296
A collection of utility functions and classes with common use-cases.
Definition SwerveController.cpp:145