blob: 95b9fcffd3ccc90ef27ccf14b73ed1258f653f8c [file] [log] [blame]
Stephan Massaltd021f972020-01-05 20:41:23 -08001#!/usr/bin/python
2
3from frc971.control_loops.python import drivetrain
Austin Schuhc1c957a2020-02-20 17:47:58 -08004from frc971.control_loops.python import control_loop
Stephan Massaltd021f972020-01-05 20:41:23 -08005import sys
6
7import gflags
8import glog
9
10FLAGS = gflags.FLAGS
11
12gflags.DEFINE_bool('plot', False, 'If true, plot the loop response.')
13
14kDrivetrain = drivetrain.DrivetrainParams(
Austin Schuhc1c957a2020-02-20 17:47:58 -080015 J=6.0,
Austin Schuh989a3132020-02-20 18:20:06 -080016 mass=68.0,
Austin Schuhc1c957a2020-02-20 17:47:58 -080017 # TODO(austin): Measure radius a bit better.
18 robot_radius=0.7 / 2.0,
19 wheel_radius=6.0 * 0.0254 / 2.0,
20 motor_type=control_loop.Falcon(),
21 G=(8.0 / 70.0) * (17.0 / 24.0),
Stephan Massaltd021f972020-01-05 20:41:23 -080022 q_pos=0.14,
23 q_vel=1.30,
24 efficiency=0.80,
25 has_imu=True,
26 force=True,
27 kf_q_voltage=13.0,
Austin Schuh989a3132020-02-20 18:20:06 -080028 controller_poles=[0.82, 0.82])
Stephan Massaltd021f972020-01-05 20:41:23 -080029
30
31def main(argv):
32 argv = FLAGS(argv)
33 glog.init()
34
35 if FLAGS.plot:
36 drivetrain.PlotDrivetrainMotions(kDrivetrain)
37 elif len(argv) != 5:
38 print "Expected .h file name and .cc file name"
39 else:
40 # Write the generated constants out to a file.
41 drivetrain.WriteDrivetrain(argv[1:3], argv[3:5], 'y2020', kDrivetrain)
42
Austin Schuh989a3132020-02-20 18:20:06 -080043
Stephan Massaltd021f972020-01-05 20:41:23 -080044if __name__ == '__main__':
45 sys.exit(main(sys.argv))