blob: aed081817646b224a2c78c239a074e6a19574cd2 [file] [log] [blame]
brians343bc112013-02-10 01:53:46 +00001#define __STDC_LIMIT_MACROS
2
3#include <arpa/inet.h>
4
brians343bc112013-02-10 01:53:46 +00005#include "aos/common/inttypes.h"
6#include "aos/common/input/SensorInput.h"
7
8#include "frc971/control_loops/DriveTrain.q.h"
9#include "frc971/queues/sensor_values.h"
10
11#define M_PI 3.14159265358979323846
12
13using ::frc971::control_loops::drivetrain;
14
15namespace frc971 {
16
17namespace {
18inline double drivetrain_translate(int32_t in) {
19 // TODO(2013) fix the math
20 return static_cast<double>(in) / (256.0 * 4.0 * 44.0 / 32.0) *
21 (3.5 * 2.54 / 100.0 * M_PI);
22}
23} // namespace
24
25class SensorReader : public aos::SensorInput<sensor_values> {
26 virtual void RunIteration(sensor_values &sensors) {
27 for (size_t i = 0; i < sizeof(sensors.encoders) / sizeof(sensors.encoders[0]); ++i) {
28 sensors.encoders[i] = ntohl(sensors.encoders[i]);
29 }
30
31 // TODO(aschuh): Convert to meters.
32 const double left_encoder = drivetrain_translate(sensors.lencoder);
33 const double right_encoder = drivetrain_translate(sensors.rencoder);
34 drivetrain.position.MakeWithBuilder()
35 .left_encoder(left_encoder)
36 .right_encoder(right_encoder)
37 .Send();
38 }
39};
40
41} // namespace frc971
42
43AOS_RUN(frc971::SensorReader)