advantagekit
Original:🇺🇸 English
Translated
AdvantageKit logging framework best practices for FRC Java robots (2026 / AKit 4.x). Use when implementing or reviewing AdvantageKit IO layers, Logger usage, replay-compatible subsystem design, signal logging, output logging, or deterministic simulation. Triggers on: AdvantageKit, Logger.recordOutput, Logger.processInputs, LoggedRobot, IO interfaces, IOInputs, AutoLog annotation, replay, log-replay, non-deterministic, or any AdvantageKit-related robot code task.
2installs
Added on
NPX Install
npx skill4agent add yeti-robotics/robot-skills advantagekitTags
Translated version includes tags in frontmatterSKILL.md Content
View Translation Comparison →AdvantageKit (2026)
Documentation sourced from docs.advantagekit.org. AdvantageKit is developed by Littleton Robotics (FRC 6328).
Core IO Layer Pattern
Every hardware-interacting subsystem uses three pieces:
- IO interface — declares and output methods
updateInputs() - IOInputs inner class — annotated , holds all sensor values
@AutoLog - Subsystem — depends on IO, calls in
processInputsperiodic()
The annotation generates a class — always instantiate the generated class, not the original.
@AutoLog<ClassName>AutoLoggedjava
// DriveIO.java
public interface DriveIO {
@AutoLog
class DriveIOInputs {
public double leftPositionRad = 0.0;
public double rightPositionRad = 0.0;
public double leftVelocityRadPerSec = 0.0;
public double rightVelocityRadPerSec = 0.0;
public double[] appliedVolts = new double[] {};
}
default void updateInputs(DriveIOInputs inputs) {}
default void setVoltage(double leftVolts, double rightVolts) {}
}
// Drive.java
public class Drive extends SubsystemBase {
private final DriveIO io;
private final DriveIOInputsAutoLogged inputs = new DriveIOInputsAutoLogged();
public Drive(DriveIO io) {
this.io = io;
}
@Override
public void periodic() {
io.updateInputs(inputs);
Logger.processInputs("Drive", inputs);
// All logic uses inputs.leftPositionRad, etc. — never calls hardware directly
}
public void setVoltage(double left, double right) {
io.setVoltage(left, right);
}
}IO Implementations
- — real hardware, talks to CAN devices
DriveIOSparkMax - — physics simulation
DriveIOSim - (interface default) — no-op for replay / unit tests
DriveIO
Inject the correct implementation in based on / .
RobotContainerRobot.isReal()isSimulation()Logger Initialization Order
Rule: call before instantiating any subsystem or .
Logger.start()RobotContainerjava
public class Robot extends LoggedRobot {
private RobotContainer robotContainer;
@Override
public void robotInit() {
// Configure data receivers BEFORE start()
Logger.addDataReceiver(new WPILOGWriter());
Logger.addDataReceiver(new NT4Publisher());
Logger.start(); // ← must be first
robotContainer = new RobotContainer(); // ← safe to create subsystems now
}
}Key Rules
| Rule | Reason |
|---|---|
| Hardware access only inside IO implementations | Ensures all inputs are logged and replayable |
Use | FPGA timestamps are non-deterministic |
| Call logging APIs from main thread only | |
| Don't read subsystem inputs in constructors | Inputs are stale until first |
| Test replay regularly during development | Catches non-determinism early |
Output Logging
Log computed values for post-match analysis:
java
Logger.recordOutput("Drive/LeftVelocityError", setpoint - inputs.leftVelocityRadPerSec);
Logger.recordOutput("Odometry/Robot", poseEstimator.getEstimatedPosition());
Logger.recordOutput("Mechanism", mechanism2d);See references/output-logging.md for replay-based output generation and version control integration.
Common Issues
See references/common-issues.md for detailed guidance on:
- Non-deterministic data sources (NetworkTables, YAGSL, random, maps)
- Multithreading constraints
- Uninitialized inputs in constructors
Recording Inputs (Detail)
See references/recording-inputs.md for:
- annotation and
@AutoLogclass namingAutoLogged - Units in input fields (naming convention vs. types)
Measure - IO implementation structure (real / sim / replay no-op)
- Dashboard inputs — ,
LoggedDashboardChooser, etc.LoggedNetworkNumber - Coprocessor / vision data via IO layer