Class DifferentialSensorsConfigs
Configs related to sensors used for differential control of a mechanism.
Includes the differential sensor sources and IDs.public class DifferentialSensorsConfigs : IParentConfiguration, ISerializable, ICloneable
- Inheritance
-
DifferentialSensorsConfigs
- Implements
- Inherited Members
Fields
DifferentialRemoteSensorID
Device ID of which remote sensor to use on the differential axis. This is used when the Differential Sensor Source is not Disabled or RemoteTalonFX_HalfDiff.
- Minimum Value0
- Maximum Value62
- Default Value0
- Units
public int DifferentialRemoteSensorID
Field Value
DifferentialSensorSource
Choose what sensor source is used for differential control of a mechanism. The default is Disabled. All other options require setting the DifferentialTalonFXSensorID, as the average of this Talon FX's sensor and the remote TalonFX's sensor is used for the differential controller's primary targets.
Choose RemoteTalonFX_HalfDiff to use another TalonFX on the same CAN bus. Talon FX will update its differential position and velocity whenever the remote TalonFX publishes its information on CAN bus. The differential controller will use half of the difference between this TalonFX's sensor and the remote Talon FX's sensor for the differential component of the output. Choose RemotePigeon2Yaw, RemotePigeon2Pitch, and RemotePigeon2Roll to use another Pigeon2 on the same CAN bus (this also requires setting DifferentialRemoteSensorID). Talon FX will update its differential position to match the selected value whenever Pigeon2 publishes its information on CAN bus. Note that the Talon FX differential position will be in rotations and not degrees. Choose RemoteCANcoder to use another CANcoder on the same CAN bus (this also requires setting DifferentialRemoteSensorID). Talon FX will update its differential position and velocity to match the CANcoder whenever CANcoder publishes its information on CAN bus.public DifferentialSensorSourceValue DifferentialSensorSource
Field Value
DifferentialTalonFXSensorID
Device ID of which remote Talon FX to use. This is used whenever the Differential Sensor Source is not disabled.
The differential Talon FX must enable its Position and Velocity status signals. The update rate of the status signals determines the update rate of differential control.- Minimum Value0
- Maximum Value62
- Default Value0
- Units
public int DifferentialTalonFXSensorID
Field Value
SensorToDifferentialRatio
The ratio of sensor rotations to the differential mechanism's difference output, where a ratio greater than 1 is a reduction.
When using RemoteTalonFX_HalfDiff, the sensor is considered half of the difference between the two devices' mechanism positions/velocities. As a result, this should be set to the gear ratio on the difference axis when using RemoteTalonFX_HalfDiff, or any gear ratio between the sensor and the mechanism differential when using another sensor source. We recommend against using this config to perform onboard unit conversions. Instead, unit conversions should be performed in robot code using the units library. If this is set to zero, the device will reset back to one.- Minimum Value-1000
- Maximum Value1000
- Default Value1.0
- Unitsscalar
public double SensorToDifferentialRatio
Field Value
Methods
Clone()
Creates a copy of this config group.
public DifferentialSensorsConfigs Clone()
Returns
Deserialize(string)
Deserialize string and put values into this object
public StatusCode Deserialize(string to_deserialize)
Parameters
to_deserializestringString to deserialize
Returns
- StatusCode
OK if deserialization is OK
Serialize()
Serialize this object into a string
public string Serialize()
Returns
- string
This object's data serialized into a string
ToString()
Provides the string representation of this object
public override string ToString()
Returns
WithDifferentialRemoteSensorID(int)
Modifies this configuration's DifferentialRemoteSensorID parameter and returns itself for method-chaining and easier to use config API.
Device ID of which remote sensor to use on the differential axis. This is used when the Differential Sensor Source is not Disabled or RemoteTalonFX_HalfDiff.- Minimum Value0
- Maximum Value62
- Default Value0
- Units
public DifferentialSensorsConfigs WithDifferentialRemoteSensorID(int newDifferentialRemoteSensorID)
Parameters
newDifferentialRemoteSensorIDintParameter to modify
Returns
- DifferentialSensorsConfigs
Itself
WithDifferentialSensorSource(DifferentialSensorSourceValue)
Modifies this configuration's DifferentialSensorSource parameter and returns itself for method-chaining and easier to use config API.
Choose what sensor source is used for differential control of a mechanism. The default is Disabled. All other options require setting the DifferentialTalonFXSensorID, as the average of this Talon FX's sensor and the remote TalonFX's sensor is used for the differential controller's primary targets. Choose RemoteTalonFX_HalfDiff to use another TalonFX on the same CAN bus. Talon FX will update its differential position and velocity whenever the remote TalonFX publishes its information on CAN bus. The differential controller will use half of the difference between this TalonFX's sensor and the remote Talon FX's sensor for the differential component of the output. Choose RemotePigeon2Yaw, RemotePigeon2Pitch, and RemotePigeon2Roll to use another Pigeon2 on the same CAN bus (this also requires setting DifferentialRemoteSensorID). Talon FX will update its differential position to match the selected value whenever Pigeon2 publishes its information on CAN bus. Note that the Talon FX differential position will be in rotations and not degrees. Choose RemoteCANcoder to use another CANcoder on the same CAN bus (this also requires setting DifferentialRemoteSensorID). Talon FX will update its differential position and velocity to match the CANcoder whenever CANcoder publishes its information on CAN bus.public DifferentialSensorsConfigs WithDifferentialSensorSource(DifferentialSensorSourceValue newDifferentialSensorSource)
Parameters
newDifferentialSensorSourceDifferentialSensorSourceValueParameter to modify
Returns
- DifferentialSensorsConfigs
Itself
WithDifferentialTalonFXSensorID(int)
Modifies this configuration's DifferentialTalonFXSensorID parameter and returns itself for method-chaining and easier to use config API.
Device ID of which remote Talon FX to use. This is used whenever the Differential Sensor Source is not disabled. The differential Talon FX must enable its Position and Velocity status signals. The update rate of the status signals determines the update rate of differential control.- Minimum Value0
- Maximum Value62
- Default Value0
- Units
public DifferentialSensorsConfigs WithDifferentialTalonFXSensorID(int newDifferentialTalonFXSensorID)
Parameters
newDifferentialTalonFXSensorIDintParameter to modify
Returns
- DifferentialSensorsConfigs
Itself
WithSensorToDifferentialRatio(double)
Modifies this configuration's SensorToDifferentialRatio parameter and returns itself for method-chaining and easier to use config API.
The ratio of sensor rotations to the differential mechanism's difference output, where a ratio greater than 1 is a reduction. When using RemoteTalonFX_HalfDiff, the sensor is considered half of the difference between the two devices' mechanism positions/velocities. As a result, this should be set to the gear ratio on the difference axis when using RemoteTalonFX_HalfDiff, or any gear ratio between the sensor and the mechanism differential when using another sensor source. We recommend against using this config to perform onboard unit conversions. Instead, unit conversions should be performed in robot code using the units library. If this is set to zero, the device will reset back to one.- Minimum Value-1000
- Maximum Value1000
- Default Value1.0
- Unitsscalar
public DifferentialSensorsConfigs WithSensorToDifferentialRatio(double newSensorToDifferentialRatio)
Parameters
newSensorToDifferentialRatiodoubleParameter to modify
Returns
- DifferentialSensorsConfigs
Itself