Austin Schuh | 085eab9 | 2020-11-26 13:54:51 -0800 | [diff] [blame] | 1 | #!/usr/bin/python3 |
Comran Morshed | 9a9948c | 2016-01-16 15:58:04 +0000 | [diff] [blame] | 2 | |
Austin Schuh | ce7e03d | 2020-11-20 22:32:44 -0800 | [diff] [blame] | 3 | from __future__ import print_function |
Campbell Crowley | d86a216 | 2017-12-28 16:04:43 -0800 | [diff] [blame] | 4 | from frc971.control_loops.python import drivetrain |
Comran Morshed | 9a9948c | 2016-01-16 15:58:04 +0000 | [diff] [blame] | 5 | import sys |
Comran Morshed | 9a9948c | 2016-01-16 15:58:04 +0000 | [diff] [blame] | 6 | |
| 7 | import gflags |
| 8 | import glog |
| 9 | |
| 10 | FLAGS = gflags.FLAGS |
| 11 | |
| 12 | gflags.DEFINE_bool('plot', False, 'If true, plot the loop response.') |
| 13 | |
Ravago Jones | 5127ccc | 2022-07-31 16:32:45 -0700 | [diff] [blame] | 14 | kDrivetrain = drivetrain.DrivetrainParams( |
| 15 | J=2.0, |
| 16 | mass=68, |
| 17 | robot_radius=0.601 / 2.0, |
| 18 | wheel_radius=0.097155 * 0.9811158901447808 / 118.0 * 115.75, |
| 19 | G_high=14.0 / 48.0 * 28.0 / 50.0 * 18.0 / 36.0, |
| 20 | G_low=14.0 / 48.0 * 18.0 / 60.0 * 18.0 / 36.0, |
| 21 | q_pos_low=0.12, |
| 22 | q_pos_high=0.14, |
| 23 | q_vel_low=1.0, |
| 24 | q_vel_high=0.95, |
| 25 | has_imu=False, |
| 26 | dt=0.005, |
| 27 | controller_poles=[0.67, 0.67]) |
| 28 | |
Comran Morshed | 9a9948c | 2016-01-16 15:58:04 +0000 | [diff] [blame] | 29 | |
| 30 | def main(argv): |
Ravago Jones | 5127ccc | 2022-07-31 16:32:45 -0700 | [diff] [blame] | 31 | argv = FLAGS(argv) |
| 32 | glog.init() |
Comran Morshed | 9a9948c | 2016-01-16 15:58:04 +0000 | [diff] [blame] | 33 | |
Ravago Jones | 5127ccc | 2022-07-31 16:32:45 -0700 | [diff] [blame] | 34 | if FLAGS.plot: |
| 35 | drivetrain.PlotDrivetrainMotions(kDrivetrain) |
James Kuszmaul | eeb98e9 | 2024-01-14 22:15:32 -0800 | [diff] [blame] | 36 | elif len(argv) != 7: |
| 37 | print("Expected .h, .cc, and .json filenames") |
Ravago Jones | 5127ccc | 2022-07-31 16:32:45 -0700 | [diff] [blame] | 38 | else: |
| 39 | # Write the generated constants out to a file. |
James Kuszmaul | eeb98e9 | 2024-01-14 22:15:32 -0800 | [diff] [blame] | 40 | drivetrain.WriteDrivetrain(argv[1:4], argv[4:7], 'y2016', kDrivetrain) |
Ravago Jones | 5127ccc | 2022-07-31 16:32:45 -0700 | [diff] [blame] | 41 | |
Comran Morshed | 9a9948c | 2016-01-16 15:58:04 +0000 | [diff] [blame] | 42 | |
| 43 | if __name__ == '__main__': |
Ravago Jones | 5127ccc | 2022-07-31 16:32:45 -0700 | [diff] [blame] | 44 | sys.exit(main(sys.argv)) |