blob: 579aeff54aa736c8c5e36291c6b64805b5ac52ab [file] [log] [blame]
Austin Schuh76f227c2022-02-23 16:34:08 -08001// Provides a plot for debugging robot state-related issues.
Philipp Schrader548aedf2023-02-17 20:09:13 -08002import {AosPlotter} from '../../../aos/network/www/aos_plotter';
3import * as proxy from '../../../aos/network/www/proxy';
4import {BLUE, BROWN, CYAN, GREEN, PINK, RED, WHITE, ORANGE} from '../../../aos/network/www/colors';
Austin Schuh76f227c2022-02-23 16:34:08 -08005
6import Connection = proxy.Connection;
7
8const TIME = AosPlotter.TIME;
9const DEFAULT_WIDTH = AosPlotter.DEFAULT_WIDTH * 5 / 2;
10const DEFAULT_HEIGHT = AosPlotter.DEFAULT_HEIGHT * 3;
11
12export function plotCatapult(conn: Connection, element: Element) : void {
13 const aosPlotter = new AosPlotter(conn);
14 const goal = aosPlotter.addMessageSource('/superstructure', 'y2022.control_loops.superstructure.Goal');
15 const output = aosPlotter.addMessageSource('/superstructure', 'y2022.control_loops.superstructure.Output');
16 const status = aosPlotter.addMessageSource('/superstructure', 'y2022.control_loops.superstructure.Status');
Austin Schuh42d7e5f2022-03-16 23:35:09 -070017 const position = aosPlotter.addMessageSource('/superstructure', 'y2022.control_loops.superstructure.Position');
Austin Schuh76f227c2022-02-23 16:34:08 -080018 const robotState = aosPlotter.addMessageSource('/aos', 'aos.RobotState');
19
20 // Robot Enabled/Disabled and Mode
21 const positionPlot =
22 aosPlotter.addPlot(element, [DEFAULT_WIDTH, DEFAULT_HEIGHT / 2]);
23 positionPlot.plot.getAxisLabels().setTitle('Position');
24 positionPlot.plot.getAxisLabels().setXLabel(TIME);
25 positionPlot.plot.getAxisLabels().setYLabel('rad');
26 positionPlot.plot.setDefaultYRange([-1.0, 2.0]);
27
28 positionPlot.addMessageLine(goal, ['catapult', 'return_position', 'unsafe_goal']).setColor(BLUE).setPointSize(1.0);
29 positionPlot.addMessageLine(goal, ['catapult', 'fire']).setColor(WHITE).setPointSize(1.0);
Austin Schuh41472552022-03-13 18:09:41 -070030 positionPlot.addMessageLine(status, ['mpc_horizon'])
31 .setColor(WHITE)
32 .setPointSize(3.0);
Austin Schuh76f227c2022-02-23 16:34:08 -080033 positionPlot.addMessageLine(status, ['catapult', 'goal_position']).setColor(RED).setPointSize(4.0);
34 positionPlot.addMessageLine(status, ['catapult', 'goal_velocity']).setColor(ORANGE).setPointSize(4.0);
35 positionPlot.addMessageLine(status, ['catapult', 'position']).setColor(GREEN).setPointSize(4.0);
36 positionPlot.addMessageLine(status, ['catapult', 'velocity']).setColor(PINK).setPointSize(1.0);
37 positionPlot.addMessageLine(status, ['catapult', 'calculated_velocity']).setColor(BROWN).setPointSize(1.0);
Austin Schuhda7e3e12022-03-26 15:14:31 -070038 positionPlot.addMessageLine(position, ['catapult', 'pot']).setColor(WHITE).setPointSize(4.0);
Austin Schuh76f227c2022-02-23 16:34:08 -080039 positionPlot.addMessageLine(status, ['catapult', 'estimator_state', 'position']).setColor(CYAN).setPointSize(1.0);
40
41 const voltagePlot =
42 aosPlotter.addPlot(element, [DEFAULT_WIDTH, DEFAULT_HEIGHT / 2]);
43 voltagePlot.plot.getAxisLabels().setTitle('Voltage');
44 voltagePlot.plot.getAxisLabels().setXLabel(TIME);
45 voltagePlot.plot.getAxisLabels().setYLabel('Volts');
46 voltagePlot.plot.setDefaultYRange([-4.0, 14.0]);
47
48 voltagePlot.addMessageLine(output, ['catapult_voltage']).setColor(BLUE).setPointSize(4.0);
49 voltagePlot.addMessageLine(status, ['catapult', 'voltage_error']).setColor(RED).setPointSize(1.0);
50 voltagePlot.addMessageLine(status, ['catapult', 'position_power']).setColor(BROWN).setPointSize(1.0);
51 voltagePlot.addMessageLine(status, ['catapult', 'velocity_power']).setColor(CYAN).setPointSize(1.0);
52 voltagePlot.addMessageLine(robotState, ['voltage_battery']).setColor(GREEN).setPointSize(1.0);
53
54 const solvePlot =
55 aosPlotter.addPlot(element, [DEFAULT_WIDTH, DEFAULT_HEIGHT / 2]);
56 solvePlot.plot.getAxisLabels().setTitle('Solve Time');
57 solvePlot.plot.getAxisLabels().setXLabel(TIME);
58 solvePlot.plot.getAxisLabels().setYLabel('Seconds');
59 solvePlot.plot.setDefaultYRange([-0.0005, 0.001]);
60 solvePlot.addMessageLine(status, ['solve_time']).setColor(WHITE).setPointSize(4.0);
61}