Brian Silverman | 431500a | 2013-10-28 19:50:15 -0700 | [diff] [blame] | 1 | #ifndef FRC971_CONSTANTS_H_ |
| 2 | #define FRC971_CONSTANTS_H_ |
Brian Silverman | 2c590c3 | 2013-11-04 18:08:54 -0800 | [diff] [blame] | 3 | |
Austin Schuh | 5f01f15 | 2017-02-11 21:34:08 -0800 | [diff] [blame] | 4 | #include <cstddef> |
| 5 | |
brians | 343bc11 | 2013-02-10 01:53:46 +0000 | [diff] [blame] | 6 | namespace frc971 { |
| 7 | namespace constants { |
| 8 | |
Austin Schuh | 5593403 | 2017-03-11 12:45:27 -0800 | [diff] [blame] | 9 | struct HallEffectZeroingConstants { |
| 10 | // The absolute position of the lower edge of the hall effect sensor. |
| 11 | double lower_hall_position; |
| 12 | // The absolute position of the upper edge of the hall effect sensor. |
| 13 | double upper_hall_position; |
| 14 | // The difference in scaled units between two hall effect edges. This is the |
| 15 | // number of units/cycle. |
| 16 | double index_difference; |
| 17 | // Number of cycles we need to see the hall effect high. |
| 18 | size_t hall_trigger_zeroing_length; |
| 19 | // Direction the system must be moving in order to zero. True is positive, |
| 20 | // False is negative direction. |
| 21 | bool zeroing_move_direction; |
| 22 | }; |
| 23 | |
Tyler Chatow | f8f0311 | 2017-02-05 14:31:34 -0800 | [diff] [blame] | 24 | struct PotAndIndexPulseZeroingConstants { |
Brian Silverman | b691f5e | 2015-08-02 11:37:55 -0700 | [diff] [blame] | 25 | // The number of samples in the moving average filter. |
Austin Schuh | 5f01f15 | 2017-02-11 21:34:08 -0800 | [diff] [blame] | 26 | size_t average_filter_size; |
Brian Silverman | b691f5e | 2015-08-02 11:37:55 -0700 | [diff] [blame] | 27 | // The difference in scaled units between two index pulses. |
| 28 | double index_difference; |
| 29 | // The absolute position in scaled units of one of the index pulses. |
| 30 | double measured_index_position; |
Philipp Schrader | 3f5b618 | 2017-03-25 22:36:37 +0000 | [diff] [blame] | 31 | // Value between 0 and .5 which determines a fraction of the index_diff |
Brian Silverman | b691f5e | 2015-08-02 11:37:55 -0700 | [diff] [blame] | 32 | // you want to use. |
| 33 | double allowable_encoder_error; |
Brian Silverman | 431500a | 2013-10-28 19:50:15 -0700 | [diff] [blame] | 34 | }; |
| 35 | |
Tyler Chatow | 61f7797 | 2017-02-04 17:41:14 -0800 | [diff] [blame] | 36 | struct EncoderPlusIndexZeroingConstants { |
Isaac Wilcove | 0851ffd | 2017-02-16 04:13:14 +0000 | [diff] [blame] | 37 | // The amount of index pulses in the joint's range of motion. |
| 38 | int index_pulse_count; |
| 39 | // The difference in scaled units between two index pulses. |
| 40 | double index_difference; |
| 41 | // The absolute position in scaled units of one of the index pulses. |
| 42 | double measured_index_position; |
| 43 | // The index pulse that is known, going from lowest in the range of motion to |
| 44 | // highest (Starting at 0). |
| 45 | int known_index_pulse; |
Philipp Schrader | 3f5b618 | 2017-03-25 22:36:37 +0000 | [diff] [blame] | 46 | // Value between 0 and 0.5 which determines a fraction of the index_diff |
| 47 | // you want to use. If an index pulse deviates by more than this amount from |
| 48 | // where we expect to see one then we flag an error. |
| 49 | double allowable_encoder_error; |
Tyler Chatow | 61f7797 | 2017-02-04 17:41:14 -0800 | [diff] [blame] | 50 | }; |
| 51 | |
| 52 | struct PotAndAbsoluteEncoderZeroingConstants { |
Austin Schuh | 5f01f15 | 2017-02-11 21:34:08 -0800 | [diff] [blame] | 53 | // The number of samples in the moving average filter. |
| 54 | size_t average_filter_size; |
Tyler Chatow | 61f7797 | 2017-02-04 17:41:14 -0800 | [diff] [blame] | 55 | // The distance that the absolute encoder needs to complete a full rotation. |
Austin Schuh | 5f01f15 | 2017-02-11 21:34:08 -0800 | [diff] [blame] | 56 | double one_revolution_distance; |
| 57 | // Measured absolute position of the encoder when at zero. |
| 58 | double measured_absolute_position; |
| 59 | |
Brian Silverman | a10d20a | 2017-02-19 14:28:53 -0800 | [diff] [blame] | 60 | // Treshold for deciding if we are moving. moving_buffer_size samples need to |
| 61 | // be within this distance of each other before we use the middle one to zero. |
Austin Schuh | 5f01f15 | 2017-02-11 21:34:08 -0800 | [diff] [blame] | 62 | double zeroing_threshold; |
Diana Vandenberg | 8fea6ea | 2017-02-18 17:24:45 -0800 | [diff] [blame] | 63 | // Buffer size for deciding if we are moving. |
| 64 | size_t moving_buffer_size; |
Brian Silverman | a10d20a | 2017-02-19 14:28:53 -0800 | [diff] [blame] | 65 | |
| 66 | // Value between 0 and 1 indicating what fraction of one_revolution_distance |
| 67 | // it is acceptable for the offset to move. |
| 68 | double allowable_encoder_error; |
Tyler Chatow | 61f7797 | 2017-02-04 17:41:14 -0800 | [diff] [blame] | 69 | }; |
| 70 | |
Austin Schuh | d82068e | 2019-01-26 20:05:42 -0800 | [diff] [blame] | 71 | struct AbsoluteEncoderZeroingConstants { |
| 72 | // The number of samples in the moving average filter. |
| 73 | size_t average_filter_size; |
| 74 | // The distance that the absolute encoder needs to complete a full rotation. |
| 75 | double one_revolution_distance; |
| 76 | // Measured absolute position of the encoder when at zero. |
| 77 | double measured_absolute_position; |
| 78 | // Position of the middle of the range of motion in output coordinates. |
| 79 | double middle_position; |
| 80 | |
| 81 | // Threshold for deciding if we are moving. moving_buffer_size samples need to |
| 82 | // be within this distance of each other before we use the middle one to zero. |
| 83 | double zeroing_threshold; |
| 84 | // Buffer size for deciding if we are moving. |
| 85 | size_t moving_buffer_size; |
| 86 | |
| 87 | // Value between 0 and 1 indicating what fraction of one_revolution_distance |
| 88 | // it is acceptable for the offset to move. |
| 89 | double allowable_encoder_error; |
| 90 | }; |
| 91 | |
Brian Silverman | ebca77a | 2016-02-14 22:14:00 -0500 | [diff] [blame] | 92 | // Defines a range of motion for a subsystem. |
| 93 | // These are all absolute positions in scaled units. |
| 94 | struct Range { |
| 95 | double lower_hard; |
| 96 | double upper_hard; |
| 97 | double lower; |
| 98 | double upper; |
Austin Schuh | 2d64acd | 2019-02-15 22:55:07 -0800 | [diff] [blame] | 99 | |
James Kuszmaul | b83d6e1 | 2020-02-22 20:44:48 -0800 | [diff] [blame] | 100 | constexpr double middle() const { return (lower_hard + upper_hard) / 2.0; } |
Austin Schuh | 9dcd520 | 2020-02-20 20:06:04 -0800 | [diff] [blame] | 101 | |
James Kuszmaul | b83d6e1 | 2020-02-22 20:44:48 -0800 | [diff] [blame] | 102 | constexpr double range() const { return upper_hard - lower_hard; } |
Brian Silverman | ebca77a | 2016-02-14 22:14:00 -0500 | [diff] [blame] | 103 | }; |
| 104 | |
brians | 343bc11 | 2013-02-10 01:53:46 +0000 | [diff] [blame] | 105 | } // namespace constants |
| 106 | } // namespace frc971 |
Brian Silverman | 431500a | 2013-10-28 19:50:15 -0700 | [diff] [blame] | 107 | |
| 108 | #endif // FRC971_CONSTANTS_H_ |