|
static LinearSystem< 2, 1, 1 > | ElevatorSystem (DCMotor motor, units::kilogram_t mass, units::meter_t radius, double G) |
| Create a state-space model of the elevator system. More...
|
|
static LinearSystem< 2, 1, 1 > | SingleJointedArmSystem (DCMotor motor, units::kilogram_square_meter_t J, double G) |
| Create a state-space model of a single-jointed arm system.The states of the system are [angle, angular velocity], inputs are [voltage], and outputs are [angle]. More...
|
|
template<typename Distance , typename = std::enable_if_t< std::is_same_v<units::meter, Distance> || std::is_same_v<units::radian, Distance>>> |
static LinearSystem< 1, 1, 1 > | IdentifyVelocitySystem (decltype(1_V/Velocity_t< Distance >(1)) kV, decltype(1_V/Acceleration_t< Distance >(1)) kA) |
| Create a state-space model for a 1 DOF velocity system from its kV (volts/(unit/sec)) and kA (volts/(unit/sec²)). More...
|
|
template<typename Distance , typename = std::enable_if_t< std::is_same_v<units::meter, Distance> || std::is_same_v<units::radian, Distance>>> |
static LinearSystem< 2, 1, 1 > | IdentifyPositionSystem (decltype(1_V/Velocity_t< Distance >(1)) kV, decltype(1_V/Acceleration_t< Distance >(1)) kA) |
| Create a state-space model for a 1 DOF position system from its kV (volts/(unit/sec)) and kA (volts/(unit/sec²)). More...
|
|
static LinearSystem< 2, 2, 2 > | IdentifyDrivetrainSystem (decltype(1_V/1_mps) kVLinear, decltype(1_V/1_mps_sq) kALinear, decltype(1_V/1_mps) kVAngular, decltype(1_V/1_mps_sq) kAAngular) |
| Identify a differential drive drivetrain given the drivetrain's kV and kA in both linear {(volts/(meter/sec), (volts/(meter/sec²))} and angular {(volts/(radian/sec), (volts/(radian/sec²))} cases. More...
|
|
static LinearSystem< 2, 2, 2 > | IdentifyDrivetrainSystem (decltype(1_V/1_mps) kVLinear, decltype(1_V/1_mps_sq) kALinear, decltype(1_V/1_rad_per_s) kVAngular, decltype(1_V/1_rad_per_s_sq) kAAngular, units::meter_t trackwidth) |
| Identify a differential drive drivetrain given the drivetrain's kV and kA in both linear {(volts/(meter/sec)), (volts/(meter/sec²))} and angular {(volts/(radian/sec)), (volts/(radian/sec²))} cases. More...
|
|
static LinearSystem< 1, 1, 1 > | FlywheelSystem (DCMotor motor, units::kilogram_square_meter_t J, double G) |
| Create a state-space model of a flywheel system, the states of the system are [angular velocity], inputs are [voltage], and outputs are [angular velocity]. More...
|
|
static LinearSystem< 2, 1, 2 > | DCMotorSystem (DCMotor motor, units::kilogram_square_meter_t J, double G) |
| Create a state-space model of a DC motor system. More...
|
|
static LinearSystem< 2, 2, 2 > | DrivetrainVelocitySystem (const DCMotor &motor, units::kilogram_t mass, units::meter_t r, units::meter_t rb, units::kilogram_square_meter_t J, double G) |
| Create a state-space model of differential drive drivetrain. More...
|
|
static LinearSystem< 2, 2, 2 > frc::LinearSystemId::IdentifyDrivetrainSystem |
( |
decltype(1_V/1_mps) |
kVLinear, |
|
|
decltype(1_V/1_mps_sq) |
kALinear, |
|
|
decltype(1_V/1_mps) |
kVAngular, |
|
|
decltype(1_V/1_mps_sq) |
kAAngular |
|
) |
| |
|
static |
Identify a differential drive drivetrain given the drivetrain's kV and kA in both linear {(volts/(meter/sec), (volts/(meter/sec²))} and angular {(volts/(radian/sec), (volts/(radian/sec²))} cases.
These constants can be found using SysId.
States: [[left velocity], [right velocity]]
Inputs: [[left voltage], [right voltage]]
Outputs: [[left velocity], [right velocity]]
- Parameters
-
kVLinear | The linear velocity gain in volts per (meters per second). |
kALinear | The linear acceleration gain in volts per (meters per second squared). |
kVAngular | The angular velocity gain in volts per (meters per second). |
kAAngular | The angular acceleration gain in volts per (meters per second squared). |
- Exceptions
-
domain_error | if kVLinear <= 0, kALinear <= 0, kVAngular <= 0, or kAAngular <= 0. |
static LinearSystem< 2, 2, 2 > frc::LinearSystemId::IdentifyDrivetrainSystem |
( |
decltype(1_V/1_mps) |
kVLinear, |
|
|
decltype(1_V/1_mps_sq) |
kALinear, |
|
|
decltype(1_V/1_rad_per_s) |
kVAngular, |
|
|
decltype(1_V/1_rad_per_s_sq) |
kAAngular, |
|
|
units::meter_t |
trackwidth |
|
) |
| |
|
static |
Identify a differential drive drivetrain given the drivetrain's kV and kA in both linear {(volts/(meter/sec)), (volts/(meter/sec²))} and angular {(volts/(radian/sec)), (volts/(radian/sec²))} cases.
This can be found using SysId.
States: [[left velocity], [right velocity]]
Inputs: [[left voltage], [right voltage]]
Outputs: [[left velocity], [right velocity]]
- Parameters
-
kVLinear | The linear velocity gain in volts per (meters per second). |
kALinear | The linear acceleration gain in volts per (meters per second squared). |
kVAngular | The angular velocity gain in volts per (radians per second). |
kAAngular | The angular acceleration gain in volts per (radians per second squared). |
trackwidth | The distance between the differential drive's left and right wheels, in meters. |
- Exceptions
-
domain_error | if kVLinear <= 0, kALinear <= 0, kVAngular <= 0, kAAngular <= 0, or trackwidth <= 0. |
template<typename Distance , typename = std::enable_if_t< std::is_same_v<units::meter, Distance> || std::is_same_v<units::radian, Distance>>>
Create a state-space model for a 1 DOF position system from its kV (volts/(unit/sec)) and kA (volts/(unit/sec²)).
These constants can be found using SysId. the states of the system are [position, velocity], inputs are [voltage], and outputs are [position].
You MUST use an SI unit (i.e. meters or radians) for the Distance template argument. You may still use non-SI units (such as feet or inches) for the actual method arguments; they will automatically be converted to SI internally.
The parameters provided by the user are from this feedforward model:
u = K_v v + K_a a
- Parameters
-
kV | The velocity gain, in volts/(unit/sec). |
kA | The acceleration gain, in volts/(unit/sec²). |
- Exceptions
-
std::domain_error | if kV <= 0 or kA <= 0. |
template<typename Distance , typename = std::enable_if_t< std::is_same_v<units::meter, Distance> || std::is_same_v<units::radian, Distance>>>
Create a state-space model for a 1 DOF velocity system from its kV (volts/(unit/sec)) and kA (volts/(unit/sec²)).
These constants can be found using SysId. The states of the system are [velocity], inputs are [voltage], and outputs are [velocity].
You MUST use an SI unit (i.e. meters or radians) for the Distance template argument. You may still use non-SI units (such as feet or inches) for the actual method arguments; they will automatically be converted to SI internally.
The parameters provided by the user are from this feedforward model:
u = K_v v + K_a a
- Parameters
-
kV | The velocity gain, in volts/(unit/sec). |
kA | The acceleration gain, in volts/(unit/sec²). |
- Exceptions
-
std::domain_error | if kV <= 0 or kA <= 0. |