blob: 02fc3d0a661b675ecc8d5d55da3bf0eebaba1a76 [file] [log] [blame]
Austin Schuh6bcc2302019-03-23 22:28:06 -07001#include "y2019/actors/auto_splines.h"
2
Alex Perrycb7da4b2019-08-28 19:35:56 -07003#include "frc971/control_loops/control_loops_generated.h"
Austin Schuh6bcc2302019-03-23 22:28:06 -07004
Stephan Pleinesf63bde82024-01-13 15:59:33 -08005namespace y2019::actors {
Austin Schuh6bcc2302019-03-23 22:28:06 -07006
Alex Perrycb7da4b2019-08-28 19:35:56 -07007void MaybeFlipSpline(
James Kuszmaul75a18c52021-03-10 22:02:07 -08008 aos::Sender<frc971::control_loops::drivetrain::SplineGoal>::Builder
9 *builder,
Alex Perrycb7da4b2019-08-28 19:35:56 -070010 flatbuffers::Offset<flatbuffers::Vector<float>> spline_y_offset,
11 bool is_left) {
Alex Perrycb7da4b2019-08-28 19:35:56 -070012 flatbuffers::Vector<float> *spline_y =
13 GetMutableTemporaryPointer(*builder->fbb(), spline_y_offset);
14
Austin Schuhb5b79a52019-05-08 20:32:07 -070015 if (!is_left) {
Alex Perrycb7da4b2019-08-28 19:35:56 -070016 for (size_t i = 0; i < spline_y->size(); i++) {
17 spline_y->Mutate(i, -spline_y->Get(i));
Austin Schuhb5b79a52019-05-08 20:32:07 -070018 }
19 }
20}
21
22// Path off of level 2 to the far side of the rocket with a panel
Alex Perrycb7da4b2019-08-28 19:35:56 -070023flatbuffers::Offset<frc971::MultiSpline> AutonomousSplines::HABToFarRocket(
James Kuszmaul75a18c52021-03-10 22:02:07 -080024 aos::Sender<frc971::control_loops::drivetrain::SplineGoal>::Builder
25 *builder,
Alex Perrycb7da4b2019-08-28 19:35:56 -070026 bool is_left) {
27 flatbuffers::Offset<frc971::Constraint> longitudinal_constraint_offset;
28 flatbuffers::Offset<frc971::Constraint> lateral_constraint_offset;
29 flatbuffers::Offset<frc971::Constraint> voltage_constraint_offset;
30 flatbuffers::Offset<frc971::Constraint> velocity_constraint_offset;
James Kuszmaulbc837872019-04-07 12:01:47 -070031
Alex Perrycb7da4b2019-08-28 19:35:56 -070032 {
33 frc971::Constraint::Builder longitudinal_constraint_builder =
34 builder->MakeBuilder<frc971::Constraint>();
35 longitudinal_constraint_builder.add_constraint_type(
Austin Schuh872723c2019-12-25 14:38:09 -080036 frc971::ConstraintType::LONGITUDINAL_ACCELERATION);
Alex Perrycb7da4b2019-08-28 19:35:56 -070037 longitudinal_constraint_builder.add_value(2.0);
38 longitudinal_constraint_offset = longitudinal_constraint_builder.Finish();
39 }
James Kuszmaulbc837872019-04-07 12:01:47 -070040
Alex Perrycb7da4b2019-08-28 19:35:56 -070041 {
42 frc971::Constraint::Builder lateral_constraint_builder =
43 builder->MakeBuilder<frc971::Constraint>();
44 lateral_constraint_builder.add_constraint_type(
Austin Schuh872723c2019-12-25 14:38:09 -080045 frc971::ConstraintType::LATERAL_ACCELERATION);
Alex Perrycb7da4b2019-08-28 19:35:56 -070046 lateral_constraint_builder.add_value(2.0);
47 lateral_constraint_offset = lateral_constraint_builder.Finish();
48 }
James Kuszmaulbc837872019-04-07 12:01:47 -070049
Alex Perrycb7da4b2019-08-28 19:35:56 -070050 {
51 frc971::Constraint::Builder voltage_constraint_builder =
52 builder->MakeBuilder<frc971::Constraint>();
53 voltage_constraint_builder.add_constraint_type(
Austin Schuh872723c2019-12-25 14:38:09 -080054 frc971::ConstraintType::VOLTAGE);
Alex Perrycb7da4b2019-08-28 19:35:56 -070055 voltage_constraint_builder.add_value(11.0);
56 voltage_constraint_offset = voltage_constraint_builder.Finish();
57 }
James Kuszmaulbc837872019-04-07 12:01:47 -070058
Alex Perrycb7da4b2019-08-28 19:35:56 -070059 {
60 frc971::Constraint::Builder velocity_constraint_builder =
61 builder->MakeBuilder<frc971::Constraint>();
62 velocity_constraint_builder.add_constraint_type(
Austin Schuh872723c2019-12-25 14:38:09 -080063 frc971::ConstraintType::VELOCITY);
Alex Perrycb7da4b2019-08-28 19:35:56 -070064 velocity_constraint_builder.add_value(4.0);
65 velocity_constraint_builder.add_start_distance(0.0);
66 velocity_constraint_builder.add_end_distance(10.0);
67 velocity_constraint_offset = velocity_constraint_builder.Finish();
68 }
James Kuszmaulbc837872019-04-07 12:01:47 -070069
Alex Perrycb7da4b2019-08-28 19:35:56 -070070 flatbuffers::Offset<
71 flatbuffers::Vector<flatbuffers::Offset<frc971::Constraint>>>
72 constraints_offset =
73 builder->fbb()->CreateVector<flatbuffers::Offset<frc971::Constraint>>(
74 {longitudinal_constraint_offset, lateral_constraint_offset,
75 voltage_constraint_offset, velocity_constraint_offset});
Austin Schuhb5b79a52019-05-08 20:32:07 -070076
Alex Perrycb7da4b2019-08-28 19:35:56 -070077 flatbuffers::Offset<flatbuffers::Vector<float>> spline_x_offset =
78 builder->fbb()->CreateVector<float>({1.14763818102, 1.66, 3.10, 4.05,
79 4.45, 5.11, 5.77, 6.71, 7.27, 7.19,
80 6.57});
81 flatbuffers::Offset<flatbuffers::Vector<float>> spline_y_offset =
82 builder->fbb()->CreateVector<float>({1.30261224364, 1.30217320136, 1.39,
83 1.47, 1.56346705393, 1.69, 1.81,
84 1.97, 2.18, 2.84, 3.33});
85 MaybeFlipSpline(builder, spline_y_offset, is_left);
Austin Schuhb5b79a52019-05-08 20:32:07 -070086
Alex Perrycb7da4b2019-08-28 19:35:56 -070087 frc971::MultiSpline::Builder multispline_builder =
88 builder->MakeBuilder<frc971::MultiSpline>();
89
90 multispline_builder.add_spline_count(2);
91 multispline_builder.add_constraints(constraints_offset);
92 multispline_builder.add_spline_x(spline_x_offset);
93 multispline_builder.add_spline_y(spline_y_offset);
94
95 return multispline_builder.Finish();
James Kuszmaulbc837872019-04-07 12:01:47 -070096}
97
Austin Schuhb5b79a52019-05-08 20:32:07 -070098// Path from the far side of the rocket to the loading station to pickup
Alex Perrycb7da4b2019-08-28 19:35:56 -070099flatbuffers::Offset<frc971::MultiSpline> AutonomousSplines::FarRocketToHP(
James Kuszmaul75a18c52021-03-10 22:02:07 -0800100 aos::Sender<frc971::control_loops::drivetrain::SplineGoal>::Builder
101 *builder,
Alex Perrycb7da4b2019-08-28 19:35:56 -0700102 bool is_left) {
103 flatbuffers::Offset<frc971::Constraint> longitudinal_constraint_offset;
104 flatbuffers::Offset<frc971::Constraint> lateral_constraint_offset;
105 flatbuffers::Offset<frc971::Constraint> voltage_constraint_offset;
106 flatbuffers::Offset<frc971::Constraint> velocity_constraint_offset;
Austin Schuhb5b79a52019-05-08 20:32:07 -0700107
Alex Perrycb7da4b2019-08-28 19:35:56 -0700108 {
109 frc971::Constraint::Builder longitudinal_constraint_builder =
110 builder->MakeBuilder<frc971::Constraint>();
111 longitudinal_constraint_builder.add_constraint_type(
Austin Schuh872723c2019-12-25 14:38:09 -0800112 frc971::ConstraintType::LONGITUDINAL_ACCELERATION);
Alex Perrycb7da4b2019-08-28 19:35:56 -0700113 longitudinal_constraint_builder.add_value(3.0);
114 longitudinal_constraint_offset = longitudinal_constraint_builder.Finish();
115 }
Austin Schuhb5b79a52019-05-08 20:32:07 -0700116
Alex Perrycb7da4b2019-08-28 19:35:56 -0700117 {
118 frc971::Constraint::Builder lateral_constraint_builder =
119 builder->MakeBuilder<frc971::Constraint>();
120 lateral_constraint_builder.add_constraint_type(
Austin Schuh872723c2019-12-25 14:38:09 -0800121 frc971::ConstraintType::LATERAL_ACCELERATION);
Alex Perrycb7da4b2019-08-28 19:35:56 -0700122 lateral_constraint_builder.add_value(2.0);
123 lateral_constraint_offset = lateral_constraint_builder.Finish();
124 }
Austin Schuhb5b79a52019-05-08 20:32:07 -0700125
Alex Perrycb7da4b2019-08-28 19:35:56 -0700126 {
127 frc971::Constraint::Builder voltage_constraint_builder =
128 builder->MakeBuilder<frc971::Constraint>();
129 voltage_constraint_builder.add_constraint_type(
Austin Schuh872723c2019-12-25 14:38:09 -0800130 frc971::ConstraintType::VOLTAGE);
Alex Perrycb7da4b2019-08-28 19:35:56 -0700131 voltage_constraint_builder.add_value(11.0);
132 voltage_constraint_offset = voltage_constraint_builder.Finish();
133 }
Austin Schuhb5b79a52019-05-08 20:32:07 -0700134
Alex Perrycb7da4b2019-08-28 19:35:56 -0700135 {
136 frc971::Constraint::Builder velocity_constraint_builder =
137 builder->MakeBuilder<frc971::Constraint>();
138 velocity_constraint_builder.add_constraint_type(
Austin Schuh872723c2019-12-25 14:38:09 -0800139 frc971::ConstraintType::VELOCITY);
Alex Perrycb7da4b2019-08-28 19:35:56 -0700140 velocity_constraint_builder.add_value(4.5);
141 velocity_constraint_builder.add_start_distance(0.0);
142 velocity_constraint_builder.add_end_distance(10.0);
143 velocity_constraint_offset = velocity_constraint_builder.Finish();
144 }
Austin Schuhb5b79a52019-05-08 20:32:07 -0700145
Alex Perrycb7da4b2019-08-28 19:35:56 -0700146 flatbuffers::Offset<
147 flatbuffers::Vector<flatbuffers::Offset<frc971::Constraint>>>
148 constraints_offset =
149 builder->fbb()->CreateVector<flatbuffers::Offset<frc971::Constraint>>(
150 {longitudinal_constraint_offset, lateral_constraint_offset,
151 voltage_constraint_offset, velocity_constraint_offset});
Austin Schuhb5b79a52019-05-08 20:32:07 -0700152
Alex Perrycb7da4b2019-08-28 19:35:56 -0700153 flatbuffers::Offset<flatbuffers::Vector<float>> spline_x_offset =
154 builder->fbb()->CreateVector<float>(
155 {6.6, 7.511, 6.332, 4.590, 1.561, 0.179});
156 flatbuffers::Offset<flatbuffers::Vector<float>> spline_y_offset =
157 builder->fbb()->CreateVector<float>(
158 {3.391, 2.826, 1.384, 3.395 - 0.20, 3.429 - 0.20, 3.434 - 0.20});
159 MaybeFlipSpline(builder, spline_y_offset, is_left);
Austin Schuhb5b79a52019-05-08 20:32:07 -0700160
Alex Perrycb7da4b2019-08-28 19:35:56 -0700161 frc971::MultiSpline::Builder multispline_builder =
162 builder->MakeBuilder<frc971::MultiSpline>();
163
164 multispline_builder.add_spline_count(1);
165 multispline_builder.add_constraints(constraints_offset);
166 multispline_builder.add_spline_x(spline_x_offset);
167 multispline_builder.add_spline_y(spline_y_offset);
168
169 return multispline_builder.Finish();
Austin Schuhb5b79a52019-05-08 20:32:07 -0700170}
171
172// Path from the human player station to the far side of the rocket with a panel
Alex Perrycb7da4b2019-08-28 19:35:56 -0700173flatbuffers::Offset<frc971::MultiSpline> AutonomousSplines::HPToFarRocket(
James Kuszmaul75a18c52021-03-10 22:02:07 -0800174 aos::Sender<frc971::control_loops::drivetrain::SplineGoal>::Builder
175 *builder,
Alex Perrycb7da4b2019-08-28 19:35:56 -0700176 bool is_left) {
177 flatbuffers::Offset<frc971::Constraint> longitudinal_constraint_offset;
178 flatbuffers::Offset<frc971::Constraint> lateral_constraint_offset;
179 flatbuffers::Offset<frc971::Constraint> voltage_constraint_offset;
180 flatbuffers::Offset<frc971::Constraint> velocity_constraint_offset;
Austin Schuhb5b79a52019-05-08 20:32:07 -0700181
Alex Perrycb7da4b2019-08-28 19:35:56 -0700182 {
183 frc971::Constraint::Builder longitudinal_constraint_builder =
184 builder->MakeBuilder<frc971::Constraint>();
185 longitudinal_constraint_builder.add_constraint_type(
Austin Schuh872723c2019-12-25 14:38:09 -0800186 frc971::ConstraintType::LONGITUDINAL_ACCELERATION);
Alex Perrycb7da4b2019-08-28 19:35:56 -0700187 longitudinal_constraint_builder.add_value(3.0);
188 longitudinal_constraint_offset = longitudinal_constraint_builder.Finish();
189 }
Austin Schuhb5b79a52019-05-08 20:32:07 -0700190
Alex Perrycb7da4b2019-08-28 19:35:56 -0700191 {
192 frc971::Constraint::Builder lateral_constraint_builder =
193 builder->MakeBuilder<frc971::Constraint>();
194 lateral_constraint_builder.add_constraint_type(
Austin Schuh872723c2019-12-25 14:38:09 -0800195 frc971::ConstraintType::LATERAL_ACCELERATION);
Alex Perrycb7da4b2019-08-28 19:35:56 -0700196 lateral_constraint_builder.add_value(3.0);
197 lateral_constraint_offset = lateral_constraint_builder.Finish();
198 }
Austin Schuhb5b79a52019-05-08 20:32:07 -0700199
Alex Perrycb7da4b2019-08-28 19:35:56 -0700200 {
201 frc971::Constraint::Builder voltage_constraint_builder =
202 builder->MakeBuilder<frc971::Constraint>();
203 voltage_constraint_builder.add_constraint_type(
Austin Schuh872723c2019-12-25 14:38:09 -0800204 frc971::ConstraintType::VOLTAGE);
Alex Perrycb7da4b2019-08-28 19:35:56 -0700205 voltage_constraint_builder.add_value(11.0);
206 voltage_constraint_offset = voltage_constraint_builder.Finish();
207 }
Austin Schuhb5b79a52019-05-08 20:32:07 -0700208
Alex Perrycb7da4b2019-08-28 19:35:56 -0700209 {
210 frc971::Constraint::Builder velocity_constraint_builder =
211 builder->MakeBuilder<frc971::Constraint>();
212 velocity_constraint_builder.add_constraint_type(
Austin Schuh872723c2019-12-25 14:38:09 -0800213 frc971::ConstraintType::VELOCITY);
Alex Perrycb7da4b2019-08-28 19:35:56 -0700214 velocity_constraint_builder.add_value(4.0);
215 velocity_constraint_builder.add_start_distance(7.0);
216 velocity_constraint_builder.add_end_distance(15.0);
217 velocity_constraint_offset = velocity_constraint_builder.Finish();
218 }
Austin Schuhb5b79a52019-05-08 20:32:07 -0700219
Alex Perrycb7da4b2019-08-28 19:35:56 -0700220 flatbuffers::Offset<
221 flatbuffers::Vector<flatbuffers::Offset<frc971::Constraint>>>
222 constraints_offset =
223 builder->fbb()->CreateVector<flatbuffers::Offset<frc971::Constraint>>(
224 {longitudinal_constraint_offset, lateral_constraint_offset,
225 voltage_constraint_offset, velocity_constraint_offset});
Austin Schuhb5b79a52019-05-08 20:32:07 -0700226
Alex Perrycb7da4b2019-08-28 19:35:56 -0700227 flatbuffers::Offset<flatbuffers::Vector<float>> spline_x_offset =
228 builder->fbb()->CreateVector<float>({0.895115737979, 2.9155615909,
229 5.02361983866, 6.40346237218,
230 7.1260656844, 7.83907559509});
231 flatbuffers::Offset<flatbuffers::Vector<float>> spline_y_offset =
232 builder->fbb()->CreateVector<float>({3.43030859063, 3.44230565037,
233 2.8824369646, 2.81000389973,
234 3.08853311072, 2.6933085577});
235 MaybeFlipSpline(builder, spline_y_offset, is_left);
Austin Schuhb5b79a52019-05-08 20:32:07 -0700236
Alex Perrycb7da4b2019-08-28 19:35:56 -0700237 frc971::MultiSpline::Builder multispline_builder =
238 builder->MakeBuilder<frc971::MultiSpline>();
239
240 multispline_builder.add_spline_count(1);
241 multispline_builder.add_constraints(constraints_offset);
242 multispline_builder.add_spline_x(spline_x_offset);
243 multispline_builder.add_spline_y(spline_y_offset);
244
245 return multispline_builder.Finish();
Austin Schuhb5b79a52019-05-08 20:32:07 -0700246}
247
248// Path from the far side of the rocket to close to the loading station
Alex Perrycb7da4b2019-08-28 19:35:56 -0700249flatbuffers::Offset<frc971::MultiSpline> AutonomousSplines::FarRocketToNearHP(
James Kuszmaul75a18c52021-03-10 22:02:07 -0800250 aos::Sender<frc971::control_loops::drivetrain::SplineGoal>::Builder
251 *builder,
Alex Perrycb7da4b2019-08-28 19:35:56 -0700252 bool is_left) {
Austin Schuhb5b79a52019-05-08 20:32:07 -0700253 // TODO(theo): Add some real constraints.
Alex Perrycb7da4b2019-08-28 19:35:56 -0700254 flatbuffers::Offset<flatbuffers::Vector<float>> spline_x_offset =
255 builder->fbb()->CreateVector<float>({6.51652191988, 6.83156293562,
256 5.74513904409, 2.2337653586,
257 1.94766705864, 0.727526876557});
258 flatbuffers::Offset<flatbuffers::Vector<float>> spline_y_offset =
259 builder->fbb()->CreateVector<float>({3.2465107468, 2.88277456846,
260 1.93458779243, 3.44064777429,
261 3.44377880106, 3.43326367284});
262 MaybeFlipSpline(builder, spline_y_offset, is_left);
Austin Schuhb5b79a52019-05-08 20:32:07 -0700263
Alex Perrycb7da4b2019-08-28 19:35:56 -0700264 frc971::MultiSpline::Builder multispline_builder =
265 builder->MakeBuilder<frc971::MultiSpline>();
Austin Schuhb5b79a52019-05-08 20:32:07 -0700266
Alex Perrycb7da4b2019-08-28 19:35:56 -0700267 multispline_builder.add_spline_count(1);
268 multispline_builder.add_spline_x(spline_x_offset);
269 multispline_builder.add_spline_y(spline_y_offset);
Austin Schuhb5b79a52019-05-08 20:32:07 -0700270
Alex Perrycb7da4b2019-08-28 19:35:56 -0700271 return multispline_builder.Finish();
Austin Schuhb5b79a52019-05-08 20:32:07 -0700272}
273
274// Path from level 2 to 2nd cargo ship bay with a hatch panel
James Kuszmaul75a18c52021-03-10 22:02:07 -0800275flatbuffers::Offset<frc971::MultiSpline>
276AutonomousSplines::HABToSecondCargoShipBay(
277 aos::Sender<frc971::control_loops::drivetrain::SplineGoal>::Builder
278 *builder,
Alex Perrycb7da4b2019-08-28 19:35:56 -0700279 bool is_left) {
280 flatbuffers::Offset<frc971::Constraint> longitudinal_constraint_offset;
281 flatbuffers::Offset<frc971::Constraint> voltage_constraint_offset;
282 flatbuffers::Offset<frc971::Constraint> velocity_constraint_offset;
Austin Schuhb5b79a52019-05-08 20:32:07 -0700283
Alex Perrycb7da4b2019-08-28 19:35:56 -0700284 {
285 frc971::Constraint::Builder longitudinal_constraint_builder =
286 builder->MakeBuilder<frc971::Constraint>();
287 longitudinal_constraint_builder.add_constraint_type(
Austin Schuh872723c2019-12-25 14:38:09 -0800288 frc971::ConstraintType::LONGITUDINAL_ACCELERATION);
Alex Perrycb7da4b2019-08-28 19:35:56 -0700289 longitudinal_constraint_builder.add_value(2.0);
290 longitudinal_constraint_offset = longitudinal_constraint_builder.Finish();
291 }
Austin Schuhb5b79a52019-05-08 20:32:07 -0700292
Alex Perrycb7da4b2019-08-28 19:35:56 -0700293 {
294 frc971::Constraint::Builder voltage_constraint_builder =
295 builder->MakeBuilder<frc971::Constraint>();
296 voltage_constraint_builder.add_constraint_type(
Austin Schuh872723c2019-12-25 14:38:09 -0800297 frc971::ConstraintType::VOLTAGE);
Alex Perrycb7da4b2019-08-28 19:35:56 -0700298 voltage_constraint_builder.add_value(10.0);
299 voltage_constraint_offset = voltage_constraint_builder.Finish();
300 }
Austin Schuhb5b79a52019-05-08 20:32:07 -0700301
Alex Perrycb7da4b2019-08-28 19:35:56 -0700302 {
303 frc971::Constraint::Builder velocity_constraint_builder =
304 builder->MakeBuilder<frc971::Constraint>();
305 velocity_constraint_builder.add_constraint_type(
Austin Schuh872723c2019-12-25 14:38:09 -0800306 frc971::ConstraintType::VELOCITY);
Alex Perrycb7da4b2019-08-28 19:35:56 -0700307 velocity_constraint_builder.add_value(1.6);
308 velocity_constraint_builder.add_start_distance(4.0);
309 velocity_constraint_builder.add_end_distance(10.0);
310 velocity_constraint_offset = velocity_constraint_builder.Finish();
311 }
Austin Schuhb5b79a52019-05-08 20:32:07 -0700312
Alex Perrycb7da4b2019-08-28 19:35:56 -0700313 flatbuffers::Offset<
314 flatbuffers::Vector<flatbuffers::Offset<frc971::Constraint>>>
315 constraints_offset =
316 builder->fbb()->CreateVector<flatbuffers::Offset<frc971::Constraint>>(
317 {longitudinal_constraint_offset, voltage_constraint_offset,
318 velocity_constraint_offset});
319
Austin Schuhb5b79a52019-05-08 20:32:07 -0700320 constexpr double kLess = 0.06;
Alex Perrycb7da4b2019-08-28 19:35:56 -0700321 flatbuffers::Offset<flatbuffers::Vector<float>> spline_x_offset =
322 builder->fbb()->CreateVector<float>(
323 {1.0, 2.53944573074, 5.75526086906, 6.52583747973 - kLess,
324 7.12318661548 - kLess, 7.22595029399 - kLess});
325 flatbuffers::Offset<flatbuffers::Vector<float>> spline_y_offset =
326 builder->fbb()->CreateVector<float>({1.5, 1.48, 2.05178220103,
327 2.56666687655, 1.79340280288,
328 1.16170693058});
329 MaybeFlipSpline(builder, spline_y_offset, is_left);
Austin Schuhb5b79a52019-05-08 20:32:07 -0700330
Alex Perrycb7da4b2019-08-28 19:35:56 -0700331 frc971::MultiSpline::Builder multispline_builder =
332 builder->MakeBuilder<frc971::MultiSpline>();
Austin Schuhb5b79a52019-05-08 20:32:07 -0700333
Alex Perrycb7da4b2019-08-28 19:35:56 -0700334 multispline_builder.add_spline_count(1);
335 multispline_builder.add_constraints(constraints_offset);
336 multispline_builder.add_spline_x(spline_x_offset);
337 multispline_builder.add_spline_y(spline_y_offset);
338
339 return multispline_builder.Finish();
Austin Schuhb5b79a52019-05-08 20:32:07 -0700340}
341
342// Path from 2nd cargo ship bay to loading station
James Kuszmaul75a18c52021-03-10 22:02:07 -0800343flatbuffers::Offset<frc971::MultiSpline>
344AutonomousSplines::SecondCargoShipBayToHP(
345 aos::Sender<frc971::control_loops::drivetrain::SplineGoal>::Builder
346 *builder,
Alex Perrycb7da4b2019-08-28 19:35:56 -0700347 bool is_left) {
348 flatbuffers::Offset<frc971::Constraint> voltage_constraint_offset;
349 flatbuffers::Offset<frc971::Constraint> velocity_constraint_offset;
Austin Schuhb5b79a52019-05-08 20:32:07 -0700350
Alex Perrycb7da4b2019-08-28 19:35:56 -0700351 {
352 frc971::Constraint::Builder voltage_constraint_builder =
353 builder->MakeBuilder<frc971::Constraint>();
354 voltage_constraint_builder.add_constraint_type(
Austin Schuh872723c2019-12-25 14:38:09 -0800355 frc971::ConstraintType::VOLTAGE);
Alex Perrycb7da4b2019-08-28 19:35:56 -0700356 voltage_constraint_builder.add_value(11.0);
357 voltage_constraint_offset = voltage_constraint_builder.Finish();
358 }
Austin Schuhb5b79a52019-05-08 20:32:07 -0700359
Alex Perrycb7da4b2019-08-28 19:35:56 -0700360 {
361 frc971::Constraint::Builder velocity_constraint_builder =
362 builder->MakeBuilder<frc971::Constraint>();
363 velocity_constraint_builder.add_constraint_type(
Austin Schuh872723c2019-12-25 14:38:09 -0800364 frc971::ConstraintType::VELOCITY);
Alex Perrycb7da4b2019-08-28 19:35:56 -0700365 velocity_constraint_builder.add_value(4.0);
366 velocity_constraint_builder.add_start_distance(0.0);
367 velocity_constraint_builder.add_end_distance(10.0);
368 velocity_constraint_offset = velocity_constraint_builder.Finish();
369 }
Austin Schuhb5b79a52019-05-08 20:32:07 -0700370
Alex Perrycb7da4b2019-08-28 19:35:56 -0700371 flatbuffers::Offset<
372 flatbuffers::Vector<flatbuffers::Offset<frc971::Constraint>>>
373 constraints_offset =
374 builder->fbb()->CreateVector<flatbuffers::Offset<frc971::Constraint>>(
375 {voltage_constraint_offset, velocity_constraint_offset});
376
377 flatbuffers::Offset<flatbuffers::Vector<float>> spline_x_offset =
378 builder->fbb()->CreateVector<float>({7.22595029399, 7.1892447864,
379 6.5373977907, 5.55997590982,
380 1.22953437637, 0.32521840905});
Austin Schuhb5b79a52019-05-08 20:32:07 -0700381 constexpr double kYShift = 0.1;
Alex Perrycb7da4b2019-08-28 19:35:56 -0700382 flatbuffers::Offset<flatbuffers::Vector<float>> spline_y_offset =
383 builder->fbb()->CreateVector<float>(
384 {1.2, 1.44543230529, 2.00646674662, 3.43762336271 - kYShift,
385 3.44125430793 - kYShift, 3.4360348159 - kYShift});
386 MaybeFlipSpline(builder, spline_y_offset, is_left);
Austin Schuhb5b79a52019-05-08 20:32:07 -0700387
Alex Perrycb7da4b2019-08-28 19:35:56 -0700388 frc971::MultiSpline::Builder multispline_builder =
389 builder->MakeBuilder<frc971::MultiSpline>();
Austin Schuhb5b79a52019-05-08 20:32:07 -0700390
Alex Perrycb7da4b2019-08-28 19:35:56 -0700391 multispline_builder.add_spline_count(1);
392 multispline_builder.add_constraints(constraints_offset);
393 multispline_builder.add_spline_x(spline_x_offset);
394 multispline_builder.add_spline_y(spline_y_offset);
395
396 return multispline_builder.Finish();
Austin Schuhb5b79a52019-05-08 20:32:07 -0700397}
398
399// Path from loading station to 3rd cargo ship bay with a hatch panel
James Kuszmaul75a18c52021-03-10 22:02:07 -0800400flatbuffers::Offset<frc971::MultiSpline>
401AutonomousSplines::HPToThirdCargoShipBay(
402 aos::Sender<frc971::control_loops::drivetrain::SplineGoal>::Builder
403 *builder,
Alex Perrycb7da4b2019-08-28 19:35:56 -0700404 bool is_left) {
405 flatbuffers::Offset<frc971::Constraint> voltage_constraint_offset;
406 flatbuffers::Offset<frc971::Constraint> velocity_constraint_offset;
407 flatbuffers::Offset<frc971::Constraint> velocity_constraint2_offset;
Austin Schuhb5b79a52019-05-08 20:32:07 -0700408
Alex Perrycb7da4b2019-08-28 19:35:56 -0700409 {
410 frc971::Constraint::Builder voltage_constraint_builder =
411 builder->MakeBuilder<frc971::Constraint>();
412 voltage_constraint_builder.add_constraint_type(
Austin Schuh872723c2019-12-25 14:38:09 -0800413 frc971::ConstraintType::VOLTAGE);
Alex Perrycb7da4b2019-08-28 19:35:56 -0700414 voltage_constraint_builder.add_value(10.0);
415 voltage_constraint_offset = voltage_constraint_builder.Finish();
416 }
Austin Schuhb5b79a52019-05-08 20:32:07 -0700417
Alex Perrycb7da4b2019-08-28 19:35:56 -0700418 {
419 frc971::Constraint::Builder velocity_constraint_builder =
420 builder->MakeBuilder<frc971::Constraint>();
421 velocity_constraint_builder.add_constraint_type(
Austin Schuh872723c2019-12-25 14:38:09 -0800422 frc971::ConstraintType::VELOCITY);
Alex Perrycb7da4b2019-08-28 19:35:56 -0700423 velocity_constraint_builder.add_value(3.5);
424 velocity_constraint_builder.add_start_distance(0.0);
425 velocity_constraint_builder.add_end_distance(10.0);
426 velocity_constraint_offset = velocity_constraint_builder.Finish();
427 }
Austin Schuhb5b79a52019-05-08 20:32:07 -0700428
Alex Perrycb7da4b2019-08-28 19:35:56 -0700429 {
430 frc971::Constraint::Builder velocity_constraint2_builder =
431 builder->MakeBuilder<frc971::Constraint>();
432 velocity_constraint2_builder.add_constraint_type(
Austin Schuh872723c2019-12-25 14:38:09 -0800433 frc971::ConstraintType::VELOCITY);
Alex Perrycb7da4b2019-08-28 19:35:56 -0700434 velocity_constraint2_builder.add_value(2.0);
435 velocity_constraint2_builder.add_start_distance(6.0);
436 velocity_constraint2_builder.add_end_distance(10.0);
437 velocity_constraint2_offset = velocity_constraint2_builder.Finish();
438 }
439
440 flatbuffers::Offset<
441 flatbuffers::Vector<flatbuffers::Offset<frc971::Constraint>>>
442 constraints_offset =
443 builder->fbb()->CreateVector<flatbuffers::Offset<frc971::Constraint>>(
444 {voltage_constraint_offset, velocity_constraint_offset,
445 velocity_constraint2_offset});
446
Austin Schuhb5b79a52019-05-08 20:32:07 -0700447 constexpr double kEndMove = 0.25;
Alex Perrycb7da4b2019-08-28 19:35:56 -0700448 flatbuffers::Offset<flatbuffers::Vector<float>> spline_x_offset =
449 builder->fbb()->CreateVector<float>({0.75, 1.112, 5.576, 7.497 - kEndMove,
450 7.675 - kEndMove, 7.768 - kEndMove});
451 flatbuffers::Offset<flatbuffers::Vector<float>> spline_y_offset =
452 builder->fbb()->CreateVector<float>(
453 {3.431, 3.434, 2.712, 2.874, 1.786, 1.168});
454 MaybeFlipSpline(builder, spline_y_offset, is_left);
Austin Schuhb5b79a52019-05-08 20:32:07 -0700455
Alex Perrycb7da4b2019-08-28 19:35:56 -0700456 frc971::MultiSpline::Builder multispline_builder =
457 builder->MakeBuilder<frc971::MultiSpline>();
Austin Schuhb5b79a52019-05-08 20:32:07 -0700458
Alex Perrycb7da4b2019-08-28 19:35:56 -0700459 multispline_builder.add_spline_count(1);
460 multispline_builder.add_constraints(constraints_offset);
461 multispline_builder.add_spline_x(spline_x_offset);
462 multispline_builder.add_spline_y(spline_y_offset);
463
464 return multispline_builder.Finish();
Austin Schuhb5b79a52019-05-08 20:32:07 -0700465}
466
467// Path from 3rd cargo ship bay to near the loading station
James Kuszmaul75a18c52021-03-10 22:02:07 -0800468flatbuffers::Offset<frc971::MultiSpline>
469AutonomousSplines::ThirdCargoShipBayToNearHP(
470 aos::Sender<frc971::control_loops::drivetrain::SplineGoal>::Builder
471 *builder,
Austin Schuhb5b79a52019-05-08 20:32:07 -0700472 bool is_left) {
Alex Perrycb7da4b2019-08-28 19:35:56 -0700473 flatbuffers::Offset<frc971::Constraint> velocity_constraint_offset;
Austin Schuhb5b79a52019-05-08 20:32:07 -0700474
Alex Perrycb7da4b2019-08-28 19:35:56 -0700475 {
476 frc971::Constraint::Builder velocity_constraint_builder =
477 builder->MakeBuilder<frc971::Constraint>();
478 velocity_constraint_builder.add_constraint_type(
Austin Schuh872723c2019-12-25 14:38:09 -0800479 frc971::ConstraintType::VELOCITY);
Alex Perrycb7da4b2019-08-28 19:35:56 -0700480 velocity_constraint_builder.add_value(0.5);
481 velocity_constraint_builder.add_start_distance(0.0);
482 velocity_constraint_builder.add_end_distance(10.0);
483 velocity_constraint_offset = velocity_constraint_builder.Finish();
484 }
Austin Schuhb5b79a52019-05-08 20:32:07 -0700485
Alex Perrycb7da4b2019-08-28 19:35:56 -0700486 flatbuffers::Offset<
487 flatbuffers::Vector<flatbuffers::Offset<frc971::Constraint>>>
488 constraints_offset =
489 builder->fbb()->CreateVector<flatbuffers::Offset<frc971::Constraint>>(
490 {velocity_constraint_offset});
Austin Schuhb5b79a52019-05-08 20:32:07 -0700491
Alex Perrycb7da4b2019-08-28 19:35:56 -0700492 flatbuffers::Offset<flatbuffers::Vector<float>> spline_x_offset =
493 builder->fbb()->CreateVector<float>({7.75823205276, 7.58356294646,
494 5.95536035287, 2.12377989323,
495 1.29347361128, 0.598613577531});
496 flatbuffers::Offset<flatbuffers::Vector<float>> spline_y_offset =
497 builder->fbb()->CreateVector<float>({1.16791407107, 1.94564064915,
498 2.54565614767, 3.43728005786,
499 3.43775494434, 3.43119598027});
500 MaybeFlipSpline(builder, spline_y_offset, is_left);
Austin Schuhb5b79a52019-05-08 20:32:07 -0700501
Alex Perrycb7da4b2019-08-28 19:35:56 -0700502 frc971::MultiSpline::Builder multispline_builder =
503 builder->MakeBuilder<frc971::MultiSpline>();
504
505 multispline_builder.add_spline_count(1);
506 multispline_builder.add_constraints(constraints_offset);
507 multispline_builder.add_spline_x(spline_x_offset);
508 multispline_builder.add_spline_y(spline_y_offset);
509
510 return multispline_builder.Finish();
Austin Schuhb5b79a52019-05-08 20:32:07 -0700511}
512
Alex Perrycb7da4b2019-08-28 19:35:56 -0700513flatbuffers::Offset<frc971::MultiSpline> AutonomousSplines::HabToFarRocketTest(
James Kuszmaul75a18c52021-03-10 22:02:07 -0800514 aos::Sender<frc971::control_loops::drivetrain::SplineGoal>::Builder
515 *builder,
Alex Perrycb7da4b2019-08-28 19:35:56 -0700516 bool is_left) {
517 flatbuffers::Offset<frc971::Constraint> longitudinal_constraint_offset;
518 flatbuffers::Offset<frc971::Constraint> lateral_constraint_offset;
519 flatbuffers::Offset<frc971::Constraint> voltage_constraint_offset;
520 flatbuffers::Offset<frc971::Constraint> velocity_constraint_offset;
Austin Schuhb5b79a52019-05-08 20:32:07 -0700521
Alex Perrycb7da4b2019-08-28 19:35:56 -0700522 {
523 frc971::Constraint::Builder longitudinal_constraint_builder =
524 builder->MakeBuilder<frc971::Constraint>();
525 longitudinal_constraint_builder.add_constraint_type(
Austin Schuh872723c2019-12-25 14:38:09 -0800526 frc971::ConstraintType::LONGITUDINAL_ACCELERATION);
Alex Perrycb7da4b2019-08-28 19:35:56 -0700527 longitudinal_constraint_builder.add_value(2.0);
528 longitudinal_constraint_offset = longitudinal_constraint_builder.Finish();
529 }
Austin Schuhb5b79a52019-05-08 20:32:07 -0700530
Alex Perrycb7da4b2019-08-28 19:35:56 -0700531 {
532 frc971::Constraint::Builder lateral_constraint_builder =
533 builder->MakeBuilder<frc971::Constraint>();
534 lateral_constraint_builder.add_constraint_type(
Austin Schuh872723c2019-12-25 14:38:09 -0800535 frc971::ConstraintType::LATERAL_ACCELERATION);
Alex Perrycb7da4b2019-08-28 19:35:56 -0700536 lateral_constraint_builder.add_value(2.0);
537 lateral_constraint_offset = lateral_constraint_builder.Finish();
538 }
Austin Schuhb5b79a52019-05-08 20:32:07 -0700539
Alex Perrycb7da4b2019-08-28 19:35:56 -0700540 {
541 frc971::Constraint::Builder voltage_constraint_builder =
542 builder->MakeBuilder<frc971::Constraint>();
543 voltage_constraint_builder.add_constraint_type(
Austin Schuh872723c2019-12-25 14:38:09 -0800544 frc971::ConstraintType::VOLTAGE);
Alex Perrycb7da4b2019-08-28 19:35:56 -0700545 voltage_constraint_builder.add_value(11.0);
546 voltage_constraint_offset = voltage_constraint_builder.Finish();
547 }
Austin Schuhb5b79a52019-05-08 20:32:07 -0700548
Alex Perrycb7da4b2019-08-28 19:35:56 -0700549 {
550 frc971::Constraint::Builder velocity_constraint_builder =
551 builder->MakeBuilder<frc971::Constraint>();
552 velocity_constraint_builder.add_constraint_type(
Austin Schuh872723c2019-12-25 14:38:09 -0800553 frc971::ConstraintType::VELOCITY);
Alex Perrycb7da4b2019-08-28 19:35:56 -0700554 velocity_constraint_builder.add_value(1.7);
555 velocity_constraint_builder.add_start_distance(0.0);
556 velocity_constraint_builder.add_end_distance(0.8);
557 velocity_constraint_offset = velocity_constraint_builder.Finish();
558 }
Austin Schuhb5b79a52019-05-08 20:32:07 -0700559
Alex Perrycb7da4b2019-08-28 19:35:56 -0700560 flatbuffers::Offset<
561 flatbuffers::Vector<flatbuffers::Offset<frc971::Constraint>>>
562 constraints_offset =
563 builder->fbb()->CreateVector<flatbuffers::Offset<frc971::Constraint>>(
564 {longitudinal_constraint_offset, lateral_constraint_offset,
565 voltage_constraint_offset, velocity_constraint_offset});
Austin Schuhb5b79a52019-05-08 20:32:07 -0700566
Alex Perrycb7da4b2019-08-28 19:35:56 -0700567 flatbuffers::Offset<flatbuffers::Vector<float>> spline_x_offset =
568 builder->fbb()->CreateVector<float>({1.14763818102, 2.53944573074,
569 3.74586892131, 5.22352745444,
570 6.70255737219, 7.35784750785});
571 flatbuffers::Offset<flatbuffers::Vector<float>> spline_y_offset =
572 builder->fbb()->CreateVector<float>({1.30261224364, 1.28295363394,
573 1.27450357714, 2.89953366429,
574 3.10734391012, 2.90125929705});
575 MaybeFlipSpline(builder, spline_y_offset, is_left);
Austin Schuhb5b79a52019-05-08 20:32:07 -0700576
Alex Perrycb7da4b2019-08-28 19:35:56 -0700577 frc971::MultiSpline::Builder multispline_builder =
578 builder->MakeBuilder<frc971::MultiSpline>();
579
580 multispline_builder.add_spline_count(1);
581 multispline_builder.add_constraints(constraints_offset);
582 multispline_builder.add_spline_x(spline_x_offset);
583 multispline_builder.add_spline_y(spline_y_offset);
584
585 return multispline_builder.Finish();
Austin Schuhb5b79a52019-05-08 20:32:07 -0700586}
587
Alex Perrycb7da4b2019-08-28 19:35:56 -0700588flatbuffers::Offset<frc971::MultiSpline> AutonomousSplines::FarRocketToHPTest(
James Kuszmaul75a18c52021-03-10 22:02:07 -0800589 aos::Sender<frc971::control_loops::drivetrain::SplineGoal>::Builder
590 *builder) {
Alex Perrycb7da4b2019-08-28 19:35:56 -0700591 flatbuffers::Offset<frc971::Constraint> longitudinal_constraint_offset;
592 flatbuffers::Offset<frc971::Constraint> lateral_constraint_offset;
593 flatbuffers::Offset<frc971::Constraint> voltage_constraint_offset;
594 flatbuffers::Offset<frc971::Constraint> velocity_constraint_offset;
James Kuszmaulbc837872019-04-07 12:01:47 -0700595
Alex Perrycb7da4b2019-08-28 19:35:56 -0700596 {
597 frc971::Constraint::Builder longitudinal_constraint_builder =
598 builder->MakeBuilder<frc971::Constraint>();
599 longitudinal_constraint_builder.add_constraint_type(
Austin Schuh872723c2019-12-25 14:38:09 -0800600 frc971::ConstraintType::LONGITUDINAL_ACCELERATION);
Alex Perrycb7da4b2019-08-28 19:35:56 -0700601 longitudinal_constraint_builder.add_value(1.5);
602 longitudinal_constraint_offset = longitudinal_constraint_builder.Finish();
603 }
James Kuszmaulbc837872019-04-07 12:01:47 -0700604
Alex Perrycb7da4b2019-08-28 19:35:56 -0700605 {
606 frc971::Constraint::Builder lateral_constraint_builder =
607 builder->MakeBuilder<frc971::Constraint>();
608 lateral_constraint_builder.add_constraint_type(
Austin Schuh872723c2019-12-25 14:38:09 -0800609 frc971::ConstraintType::LATERAL_ACCELERATION);
Alex Perrycb7da4b2019-08-28 19:35:56 -0700610 lateral_constraint_builder.add_value(1.0);
611 lateral_constraint_offset = lateral_constraint_builder.Finish();
612 }
James Kuszmaulbc837872019-04-07 12:01:47 -0700613
Alex Perrycb7da4b2019-08-28 19:35:56 -0700614 {
615 frc971::Constraint::Builder voltage_constraint_builder =
616 builder->MakeBuilder<frc971::Constraint>();
617 voltage_constraint_builder.add_constraint_type(
Austin Schuh872723c2019-12-25 14:38:09 -0800618 frc971::ConstraintType::VOLTAGE);
Alex Perrycb7da4b2019-08-28 19:35:56 -0700619 voltage_constraint_builder.add_value(11.0);
620 voltage_constraint_offset = voltage_constraint_builder.Finish();
621 }
James Kuszmaulbc837872019-04-07 12:01:47 -0700622
Alex Perrycb7da4b2019-08-28 19:35:56 -0700623 {
624 frc971::Constraint::Builder velocity_constraint_builder =
625 builder->MakeBuilder<frc971::Constraint>();
626 velocity_constraint_builder.add_constraint_type(
Austin Schuh872723c2019-12-25 14:38:09 -0800627 frc971::ConstraintType::VELOCITY);
Alex Perrycb7da4b2019-08-28 19:35:56 -0700628 velocity_constraint_builder.add_value(0.5);
629 velocity_constraint_builder.add_start_distance(9.5);
630 velocity_constraint_builder.add_end_distance(10.0);
631 velocity_constraint_offset = velocity_constraint_builder.Finish();
632 }
James Kuszmaulbc837872019-04-07 12:01:47 -0700633
Alex Perrycb7da4b2019-08-28 19:35:56 -0700634 flatbuffers::Offset<
635 flatbuffers::Vector<flatbuffers::Offset<frc971::Constraint>>>
636 constraints_offset =
637 builder->fbb()->CreateVector<flatbuffers::Offset<frc971::Constraint>>(
638 {longitudinal_constraint_offset, lateral_constraint_offset,
639 voltage_constraint_offset, velocity_constraint_offset});
Austin Schuhb5b79a52019-05-08 20:32:07 -0700640
Alex Perrycb7da4b2019-08-28 19:35:56 -0700641 flatbuffers::Offset<flatbuffers::Vector<float>> spline_x_offset =
642 builder->fbb()->CreateVector<float>({6.53, 7.8, 7.8, 4.0, 2.0, 0.4});
643 flatbuffers::Offset<flatbuffers::Vector<float>> spline_y_offset =
644 builder->fbb()->CreateVector<float>({3.47, 3.0, 1.5, 3.0, 3.4, 3.4});
645
646 frc971::MultiSpline::Builder multispline_builder =
647 builder->MakeBuilder<frc971::MultiSpline>();
648
649 multispline_builder.add_spline_count(1);
650 multispline_builder.add_constraints(constraints_offset);
651 multispline_builder.add_spline_x(spline_x_offset);
652 multispline_builder.add_spline_y(spline_y_offset);
653
654 return multispline_builder.Finish();
James Kuszmaulbc837872019-04-07 12:01:47 -0700655}
656
Alex Perrycb7da4b2019-08-28 19:35:56 -0700657flatbuffers::Offset<frc971::MultiSpline> AutonomousSplines::HPToNearRocketTest(
James Kuszmaul75a18c52021-03-10 22:02:07 -0800658 aos::Sender<frc971::control_loops::drivetrain::SplineGoal>::Builder
659 *builder) {
Alex Perrycb7da4b2019-08-28 19:35:56 -0700660 flatbuffers::Offset<frc971::Constraint> longitudinal_constraint_offset;
661 flatbuffers::Offset<frc971::Constraint> lateral_constraint_offset;
662 flatbuffers::Offset<frc971::Constraint> voltage_constraint_offset;
663 flatbuffers::Offset<frc971::Constraint> velocity_constraint_offset;
Austin Schuh6bcc2302019-03-23 22:28:06 -0700664
Alex Perrycb7da4b2019-08-28 19:35:56 -0700665 {
666 frc971::Constraint::Builder longitudinal_constraint_builder =
667 builder->MakeBuilder<frc971::Constraint>();
668 longitudinal_constraint_builder.add_constraint_type(
Austin Schuh872723c2019-12-25 14:38:09 -0800669 frc971::ConstraintType::LONGITUDINAL_ACCELERATION);
Alex Perrycb7da4b2019-08-28 19:35:56 -0700670 longitudinal_constraint_builder.add_value(1.0);
671 longitudinal_constraint_offset = longitudinal_constraint_builder.Finish();
672 }
Austin Schuh6bcc2302019-03-23 22:28:06 -0700673
Alex Perrycb7da4b2019-08-28 19:35:56 -0700674 {
675 frc971::Constraint::Builder lateral_constraint_builder =
676 builder->MakeBuilder<frc971::Constraint>();
677 lateral_constraint_builder.add_constraint_type(
Austin Schuh872723c2019-12-25 14:38:09 -0800678 frc971::ConstraintType::LATERAL_ACCELERATION);
Alex Perrycb7da4b2019-08-28 19:35:56 -0700679 lateral_constraint_builder.add_value(1.0);
680 lateral_constraint_offset = lateral_constraint_builder.Finish();
681 }
Austin Schuh6bcc2302019-03-23 22:28:06 -0700682
Alex Perrycb7da4b2019-08-28 19:35:56 -0700683 {
684 frc971::Constraint::Builder voltage_constraint_builder =
685 builder->MakeBuilder<frc971::Constraint>();
686 voltage_constraint_builder.add_constraint_type(
Austin Schuh872723c2019-12-25 14:38:09 -0800687 frc971::ConstraintType::VOLTAGE);
Alex Perrycb7da4b2019-08-28 19:35:56 -0700688 voltage_constraint_builder.add_value(11.0);
689 voltage_constraint_offset = voltage_constraint_builder.Finish();
690 }
James Kuszmaulbc837872019-04-07 12:01:47 -0700691
Alex Perrycb7da4b2019-08-28 19:35:56 -0700692 {
693 frc971::Constraint::Builder velocity_constraint_builder =
694 builder->MakeBuilder<frc971::Constraint>();
695 velocity_constraint_builder.add_constraint_type(
Austin Schuh872723c2019-12-25 14:38:09 -0800696 frc971::ConstraintType::VELOCITY);
Alex Perrycb7da4b2019-08-28 19:35:56 -0700697 velocity_constraint_builder.add_value(0.5);
698 velocity_constraint_builder.add_start_distance(2.7);
699 velocity_constraint_builder.add_end_distance(10.0);
700 velocity_constraint_offset = velocity_constraint_builder.Finish();
701 }
Austin Schuh6bcc2302019-03-23 22:28:06 -0700702
Alex Perrycb7da4b2019-08-28 19:35:56 -0700703 flatbuffers::Offset<
704 flatbuffers::Vector<flatbuffers::Offset<frc971::Constraint>>>
705 constraints_offset =
706 builder->fbb()->CreateVector<flatbuffers::Offset<frc971::Constraint>>(
707 {longitudinal_constraint_offset, lateral_constraint_offset,
708 voltage_constraint_offset, velocity_constraint_offset});
Austin Schuhb5b79a52019-05-08 20:32:07 -0700709
Alex Perrycb7da4b2019-08-28 19:35:56 -0700710 flatbuffers::Offset<flatbuffers::Vector<float>> spline_x_offset =
711 builder->fbb()->CreateVector<float>({1.5, 2.0, 3.0, 4.0, 4.5, 5.12});
712 flatbuffers::Offset<flatbuffers::Vector<float>> spline_y_offset =
713 builder->fbb()->CreateVector<float>({3.4, 3.4, 3.4, 3.0, 3.0, 3.43});
714
715 frc971::MultiSpline::Builder multispline_builder =
716 builder->MakeBuilder<frc971::MultiSpline>();
717
718 multispline_builder.add_spline_count(1);
719 multispline_builder.add_constraints(constraints_offset);
720 multispline_builder.add_spline_x(spline_x_offset);
721 multispline_builder.add_spline_y(spline_y_offset);
722
723 return multispline_builder.Finish();
Austin Schuh6bcc2302019-03-23 22:28:06 -0700724}
725
Alex Perrycb7da4b2019-08-28 19:35:56 -0700726flatbuffers::Offset<frc971::MultiSpline> AutonomousSplines::BasicSSpline(
James Kuszmaul75a18c52021-03-10 22:02:07 -0800727 aos::Sender<frc971::control_loops::drivetrain::SplineGoal>::Builder
728 *builder) {
Alex Perrycb7da4b2019-08-28 19:35:56 -0700729 flatbuffers::Offset<frc971::Constraint> longitudinal_constraint_offset;
730 flatbuffers::Offset<frc971::Constraint> lateral_constraint_offset;
731 flatbuffers::Offset<frc971::Constraint> voltage_constraint_offset;
Austin Schuh6bcc2302019-03-23 22:28:06 -0700732
Alex Perrycb7da4b2019-08-28 19:35:56 -0700733 {
734 frc971::Constraint::Builder longitudinal_constraint_builder =
735 builder->MakeBuilder<frc971::Constraint>();
736 longitudinal_constraint_builder.add_constraint_type(
Austin Schuh872723c2019-12-25 14:38:09 -0800737 frc971::ConstraintType::LONGITUDINAL_ACCELERATION);
Alex Perrycb7da4b2019-08-28 19:35:56 -0700738 longitudinal_constraint_builder.add_value(1.0);
739 longitudinal_constraint_offset = longitudinal_constraint_builder.Finish();
740 }
Austin Schuh6bcc2302019-03-23 22:28:06 -0700741
Alex Perrycb7da4b2019-08-28 19:35:56 -0700742 {
743 frc971::Constraint::Builder lateral_constraint_builder =
744 builder->MakeBuilder<frc971::Constraint>();
745 lateral_constraint_builder.add_constraint_type(
Austin Schuh872723c2019-12-25 14:38:09 -0800746 frc971::ConstraintType::LATERAL_ACCELERATION);
Alex Perrycb7da4b2019-08-28 19:35:56 -0700747 lateral_constraint_builder.add_value(1.0);
748 lateral_constraint_offset = lateral_constraint_builder.Finish();
749 }
Austin Schuh6bcc2302019-03-23 22:28:06 -0700750
Alex Perrycb7da4b2019-08-28 19:35:56 -0700751 {
752 frc971::Constraint::Builder voltage_constraint_builder =
753 builder->MakeBuilder<frc971::Constraint>();
754 voltage_constraint_builder.add_constraint_type(
Austin Schuh872723c2019-12-25 14:38:09 -0800755 frc971::ConstraintType::VOLTAGE);
Alex Perrycb7da4b2019-08-28 19:35:56 -0700756 voltage_constraint_builder.add_value(6.0);
757 voltage_constraint_offset = voltage_constraint_builder.Finish();
758 }
Austin Schuh6bcc2302019-03-23 22:28:06 -0700759
Alex Perrycb7da4b2019-08-28 19:35:56 -0700760 flatbuffers::Offset<
761 flatbuffers::Vector<flatbuffers::Offset<frc971::Constraint>>>
762 constraints_offset =
763 builder->fbb()->CreateVector<flatbuffers::Offset<frc971::Constraint>>(
764 {longitudinal_constraint_offset, lateral_constraint_offset,
765 voltage_constraint_offset});
766
Austin Schuh6bcc2302019-03-23 22:28:06 -0700767 const float startx = 0.4;
768 const float starty = 3.4;
Alex Perrycb7da4b2019-08-28 19:35:56 -0700769 flatbuffers::Offset<flatbuffers::Vector<float>> spline_x_offset =
770 builder->fbb()->CreateVector<float>({0.0f + startx, 0.6f + startx,
771 0.6f + startx, 0.4f + startx,
772 0.4f + startx, 1.0f + startx});
773 flatbuffers::Offset<flatbuffers::Vector<float>> spline_y_offset =
774 builder->fbb()->CreateVector<float>({starty - 0.0f, starty - 0.0f,
775 starty - 0.3f, starty - 0.7f,
776 starty - 1.0f, starty - 1.0f});
Austin Schuhb5b79a52019-05-08 20:32:07 -0700777
Alex Perrycb7da4b2019-08-28 19:35:56 -0700778 frc971::MultiSpline::Builder multispline_builder =
779 builder->MakeBuilder<frc971::MultiSpline>();
Austin Schuhb5b79a52019-05-08 20:32:07 -0700780
Alex Perrycb7da4b2019-08-28 19:35:56 -0700781 multispline_builder.add_spline_count(1);
782 multispline_builder.add_constraints(constraints_offset);
783 multispline_builder.add_spline_x(spline_x_offset);
784 multispline_builder.add_spline_y(spline_y_offset);
785
786 return multispline_builder.Finish();
Austin Schuh6bcc2302019-03-23 22:28:06 -0700787}
788
Alex Perrycb7da4b2019-08-28 19:35:56 -0700789flatbuffers::Offset<frc971::MultiSpline> AutonomousSplines::StraightLine(
James Kuszmaul75a18c52021-03-10 22:02:07 -0800790 aos::Sender<frc971::control_loops::drivetrain::SplineGoal>::Builder
791 *builder) {
Alex Perrycb7da4b2019-08-28 19:35:56 -0700792 flatbuffers::Offset<flatbuffers::Vector<float>> spline_x_offset =
793 builder->fbb()->CreateVector<float>(
794 {-12.3, -11.9, -11.5, -11.1, -10.6, -10.0});
795 flatbuffers::Offset<flatbuffers::Vector<float>> spline_y_offset =
796 builder->fbb()->CreateVector<float>({1.25, 1.25, 1.25, 1.25, 1.25, 1.25});
Austin Schuh6bcc2302019-03-23 22:28:06 -0700797
Alex Perrycb7da4b2019-08-28 19:35:56 -0700798 frc971::MultiSpline::Builder multispline_builder =
799 builder->MakeBuilder<frc971::MultiSpline>();
Austin Schuh6bcc2302019-03-23 22:28:06 -0700800
Alex Perrycb7da4b2019-08-28 19:35:56 -0700801 multispline_builder.add_spline_count(1);
802 multispline_builder.add_spline_x(spline_x_offset);
803 multispline_builder.add_spline_y(spline_y_offset);
Austin Schuhb5b79a52019-05-08 20:32:07 -0700804
Alex Perrycb7da4b2019-08-28 19:35:56 -0700805 return multispline_builder.Finish();
Austin Schuh6bcc2302019-03-23 22:28:06 -0700806}
807
Stephan Pleinesf63bde82024-01-13 15:59:33 -0800808} // namespace y2019::actors