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