blob: 035586a654093761405f6840331a4a966c0477e0 [file] [log] [blame]
#!/usr/bin/python3
from frc971.control_loops.python import control_loop
from y2020.control_loops.python import flywheel
import numpy
import sys
import gflags
import glog
FLAGS = gflags.FLAGS
gflags.DEFINE_bool('plot', False, 'If true, plot the loop response.')
# Gear ratio to the final wheel.
# 40 tooth on the flywheel
# 48 for the falcon.
# 60 tooth on the outer wheel.
G = 48.0 / 40.0
# Overall flywheel inertia.
J = 0.00507464
# The position and velocity are measured for the final wheel.
kFinisher = flywheel.FlywheelParams(
name='Finisher',
motor=control_loop.NMotor(control_loop.Falcon(), 2),
G=G,
J=J,
q_pos=0.01,
q_vel=100.0,
q_voltage=6.0,
r_pos=0.05,
controller_poles=[.90])
def main(argv):
if FLAGS.plot:
R = numpy.matrix([[0.0], [500.0], [0.0]])
flywheel.PlotSpinup(params=kFinisher, goal=R, iterations=400)
return 0
if len(argv) != 5:
glog.fatal('Expected .h file name and .cc file name')
else:
namespaces = ['y2020', 'control_loops', 'superstructure', 'finisher']
flywheel.WriteFlywheel(kFinisher, argv[1:3], argv[3:5], namespaces)
if __name__ == '__main__':
argv = FLAGS(sys.argv)
sys.exit(main(argv))