Brian Silverman | 6ae77dd | 2013-03-29 22:28:08 -0700 | [diff] [blame] | 1 | #include "math.h" |
| 2 | |
Brian Silverman | 5b3e51e | 2013-03-29 22:53:44 -0700 | [diff] [blame] | 3 | #include "aos/common/time.h" |
| 4 | #include "aos/atom_code/init.h" |
| 5 | |
Brian Silverman | 6ae77dd | 2013-03-29 22:28:08 -0700 | [diff] [blame] | 6 | #include "frc971/queues/GyroAngle.q.h" |
| 7 | #include "frc971/queues/CameraTarget.q.h" |
Brian Silverman | 5b3e51e | 2013-03-29 22:53:44 -0700 | [diff] [blame] | 8 | |
Brian Silverman | 6ae77dd | 2013-03-29 22:28:08 -0700 | [diff] [blame] | 9 | #include "vision/RingBuffer.h" |
Brian Silverman | 68a5a01 | 2013-03-29 23:37:04 -0700 | [diff] [blame^] | 10 | #include "vision/SensorProcessor.h" |
Brian Silverman | 6ae77dd | 2013-03-29 22:28:08 -0700 | [diff] [blame] | 11 | |
Brian Silverman | 68a5a01 | 2013-03-29 23:37:04 -0700 | [diff] [blame^] | 12 | using ::frc971::vision::RingBuffer; |
| 13 | using ::frc971::sensors::gyro; |
| 14 | using ::frc971::vision::targets; |
| 15 | using ::frc971::vision::target_angle; |
| 16 | using ::frc971::kPixelsToMeters; |
| 17 | using ::frc971::kMetersToShooterSpeeds; |
| 18 | using ::frc971::kMetersToShooterAngles; |
| 19 | using ::frc971::interpolate; |
Brian Silverman | 6ae77dd | 2013-03-29 22:28:08 -0700 | [diff] [blame] | 20 | |
Brian Silverman | e8ee1e5 | 2013-03-29 23:09:37 -0700 | [diff] [blame] | 21 | int main() { |
Brian Silverman | 68a5a01 | 2013-03-29 23:37:04 -0700 | [diff] [blame^] | 22 | //RingBuffer< ::aos::time::Time, double> buff; |
Brian Silverman | e8ee1e5 | 2013-03-29 23:09:37 -0700 | [diff] [blame] | 23 | ::aos::InitNRT(); |
| 24 | while (true) { |
Brian Silverman | 68a5a01 | 2013-03-29 23:37:04 -0700 | [diff] [blame^] | 25 | //gyro.FetchNextBlocking(); |
| 26 | //buff.Sample(gyro->sent_time, gyro->angle); |
Brian Silverman | e8ee1e5 | 2013-03-29 23:09:37 -0700 | [diff] [blame] | 27 | if (targets.FetchNext()) { |
Brian Silverman | 68a5a01 | 2013-03-29 23:37:04 -0700 | [diff] [blame^] | 28 | /*::aos::time::Time stamp = ::aos::time::Time::InNS(targets->timestamp); |
Brian Silverman | e8ee1e5 | 2013-03-29 23:09:37 -0700 | [diff] [blame] | 29 | double angle_goal = |
| 30 | buff.ValueAt(stamp) - |
| 31 | M_PI / 2.0 * targets->percent_azimuth_off_center / 2.0; |
| 32 | printf("%g ",angle_goal); |
Brian Silverman | 68a5a01 | 2013-03-29 23:37:04 -0700 | [diff] [blame^] | 33 | printf("%g\n",gyro->angle);*/ |
| 34 | |
| 35 | double meters = interpolate( |
| 36 | sizeof(kPixelsToMeters) / sizeof(kPixelsToMeters[0]), |
| 37 | kPixelsToMeters, |
| 38 | targets->percent_elevation_off_center); |
Brian Silverman | e8ee1e5 | 2013-03-29 23:09:37 -0700 | [diff] [blame] | 39 | |
| 40 | target_angle.MakeWithBuilder() |
Brian Silverman | 68a5a01 | 2013-03-29 23:37:04 -0700 | [diff] [blame^] | 41 | .target_angle(/*angle_goal*/0) |
| 42 | .shooter_speed(interpolate( |
| 43 | sizeof(kMetersToShooterSpeeds) / sizeof(kMetersToShooterSpeeds[0]), |
| 44 | kMetersToShooterSpeeds, |
| 45 | meters)) |
| 46 | .shooter_angle(interpolate( |
| 47 | sizeof(kMetersToShooterAngles) / sizeof(kMetersToShooterAngles[0]), |
| 48 | kMetersToShooterAngles, |
| 49 | meters)) |
| 50 | .Send(); |
Brian Silverman | 6ae77dd | 2013-03-29 22:28:08 -0700 | [diff] [blame] | 51 | } |
| 52 | } |
Brian Silverman | e8ee1e5 | 2013-03-29 23:09:37 -0700 | [diff] [blame] | 53 | ::aos::Cleanup(); |
Brian Silverman | 6ae77dd | 2013-03-29 22:28:08 -0700 | [diff] [blame] | 54 | } |