1516X Push Back 1.0
1516X's robot code for the 2025-2026 VEX Robotics Competition
Loading...
Searching...
No Matches
distanceReset.cpp File Reference
#include "globals.h"
#include "lemlib/util.hpp"
#include <numeric>

Go to the source code of this file.

Classes

struct  SensorConfig
 
struct  SensorReadings
 
struct  distancePose
 

Functions

distancePose calculateGlobalPosition (const SensorReadings &front_data, const SensorReadings &left_data, const SensorReadings &right_data, const SensorReadings &back_data, double heading_deg)
 
distancePose distanceReset (bool setPose=false)
 
distancePose distanceReset (bool left_use, bool right_use, bool front_use, bool back_use, bool setPose)
 

Variables

const double MM_TO_IN = 0.0393701
 
const double FIELD_WIDTH = 3657.6 * MM_TO_IN
 
const double FIELD_HEIGHT = 3657.6 * MM_TO_IN
 
const double HALF_WIDTH = FIELD_WIDTH / 2.0
 
const double HALF_HEIGHT = FIELD_HEIGHT / 2.0
 
const double MAX_SENSOR_RANGE = 1500 * MM_TO_IN
 
const double MIN_SENSOR_RANGE = 10 * MM_TO_IN
 
bool controller_screen_avilable
 
const SensorConfig front_sensor_cfg = {-0.75, -3, 0}
 
const SensorConfig left_sensor_cfg = {-0.5, -6.4, 90}
 
const SensorConfig right_sensor_cfg = {-0.5, 6.3, -90}
 
const SensorConfig back_sensor_cfg = {-10.5, -3, 180}
 

Function Documentation

◆ calculateGlobalPosition()

distancePose calculateGlobalPosition ( const SensorReadings & front_data,
const SensorReadings & left_data,
const SensorReadings & right_data,
const SensorReadings & back_data,
double heading_deg )

Definition at line 39 of file distanceReset.cpp.

45{
46 lemlib::Pose current_pose = chassis.getPose();
47 double est_x = current_pose.x;
48 double est_y = current_pose.y;
49
50 // 1. Determine Quadrant based on current Odom
51 // If x >= 0, we are in the Right half (closer to +X wall)
52 // If y >= 0, we are in the Top half (closer to +Y wall)
53 bool use_pos_x_wall = (est_x >= 0);
54 bool use_pos_y_wall = (est_y >= 0);
55
56 bool using_odom_x = true;
57 bool using_odom_y = true;
58
59 struct SensorData { SensorConfig cfg; double dist_in; int confidence;};
60 const SensorData sensors[] = {
61 {front_sensor_cfg, front_data.dist_mm * MM_TO_IN, frontDistance.get_confidence()},
62 {left_sensor_cfg, left_data.dist_mm * MM_TO_IN, leftDistance.get_confidence()},
63 {right_sensor_cfg, right_data.dist_mm * MM_TO_IN, rightDistance.get_confidence()},
64 {back_sensor_cfg, back_data.dist_mm * MM_TO_IN, backDistance.get_confidence()}
65 };
66
67 // Helper to check validity (range and now Quadrant relevance)
68 auto is_valid = [&](int i) {
69 return (sensors[i].dist_in < MAX_SENSOR_RANGE &&
70 sensors[i].dist_in >= MIN_SENSOR_RANGE);
71 };
72
73 double norm_heading = std::fmod(heading_deg, 360.0);
74 if (norm_heading < 0) norm_heading += 360.0;
75 const double TOLERANCE = 40.0;
76
77 std::vector<double> x_cands;
78 std::vector<double> y_cands;
79
80 auto get_global_offsets = [&](const SensorConfig& cfg, double heading_rad) {
81 double cos_h = std::cos(heading_rad);
82 double sin_h = std::sin(heading_rad);
83 double global_offset_x = (cfg.forward_offset * sin_h) + (cfg.strafe_offset * cos_h);
84 double global_offset_y = (cfg.forward_offset * cos_h) - (cfg.strafe_offset * sin_h);
85 return std::make_pair(global_offset_x, global_offset_y);
86 };
87
88
89 if (norm_heading <= TOLERANCE || norm_heading >= 360.0 - TOLERANCE) {
90 double angle_off_rad = (norm_heading <= TOLERANCE) ?
91 lemlib::degToRad(norm_heading) : lemlib::degToRad(norm_heading - 360.0);
92 double heading_rad = angle_off_rad;
93 double perp_dist_0 = sensors[0].dist_in * std::cos(angle_off_rad);
94 double perp_dist_3 = sensors[3].dist_in * std::cos(angle_off_rad);
95 double perp_dist_1 = sensors[1].dist_in * std::cos(angle_off_rad);
96 double perp_dist_2 = sensors[2].dist_in * std::cos(angle_off_rad);
97
98 auto offset_0 = get_global_offsets(sensors[0].cfg, heading_rad);
99 auto offset_1 = get_global_offsets(sensors[1].cfg, heading_rad);
100 auto offset_2 = get_global_offsets(sensors[2].cfg, heading_rad);
101 auto offset_3 = get_global_offsets(sensors[3].cfg, heading_rad);
102
103 if (is_valid(0) && use_pos_y_wall) { y_cands.push_back(HALF_HEIGHT - perp_dist_0 - offset_0.second); }
104 if (is_valid(3) && !use_pos_y_wall) { y_cands.push_back(-HALF_HEIGHT + perp_dist_3 - offset_3.second); }
105 if (is_valid(1) && !use_pos_x_wall) { x_cands.push_back(-HALF_WIDTH + perp_dist_1 - offset_1.first); }
106 if (is_valid(2) && use_pos_x_wall) { x_cands.push_back(HALF_WIDTH - perp_dist_2 - offset_2.first); }
107 }
108 else if (std::fabs(norm_heading - 180.0) <= TOLERANCE) {
109 double angle_off_rad = lemlib::degToRad(norm_heading - 180.0);
110 double heading_rad = lemlib::degToRad(norm_heading);
111
112 double perp_dist_0 = sensors[0].dist_in * std::cos(angle_off_rad);
113 double perp_dist_3 = sensors[3].dist_in * std::cos(angle_off_rad);
114 double perp_dist_1 = sensors[1].dist_in * std::cos(angle_off_rad);
115 double perp_dist_2 = sensors[2].dist_in * std::cos(angle_off_rad);
116
117 auto offset_0 = get_global_offsets(sensors[0].cfg, heading_rad);
118 auto offset_1 = get_global_offsets(sensors[1].cfg, heading_rad);
119 auto offset_2 = get_global_offsets(sensors[2].cfg, heading_rad);
120 auto offset_3 = get_global_offsets(sensors[3].cfg, heading_rad);
121
122
123 if (is_valid(0) && !use_pos_y_wall) { y_cands.push_back(-HALF_HEIGHT + perp_dist_0 - offset_0.second); }
124 if (is_valid(3) && use_pos_y_wall) { y_cands.push_back(HALF_HEIGHT - perp_dist_3 - offset_3.second); }
125 if (is_valid(1) && use_pos_x_wall) { x_cands.push_back(HALF_WIDTH - perp_dist_1 - offset_1.first); }
126 if (is_valid(2) && !use_pos_x_wall) { x_cands.push_back(-HALF_WIDTH + perp_dist_2 - offset_2.first); }
127 }
128
129 else if (std::fabs(norm_heading - 90.0) <= TOLERANCE) {
130 double angle_off_rad = lemlib::degToRad(norm_heading - 90.0);
131 double heading_rad = lemlib::degToRad(norm_heading);
132
133 double perp_dist_0 = sensors[0].dist_in * std::cos(angle_off_rad);
134 double perp_dist_3 = sensors[3].dist_in * std::cos(angle_off_rad);
135 double perp_dist_1 = sensors[1].dist_in * std::cos(angle_off_rad);
136 double perp_dist_2 = sensors[2].dist_in * std::cos(angle_off_rad);
137
138 auto offset_0 = get_global_offsets(sensors[0].cfg, heading_rad);
139 auto offset_1 = get_global_offsets(sensors[1].cfg, heading_rad);
140 auto offset_2 = get_global_offsets(sensors[2].cfg, heading_rad);
141 auto offset_3 = get_global_offsets(sensors[3].cfg, heading_rad);
142
143
144 if (is_valid(0) && use_pos_x_wall) { x_cands.push_back(HALF_WIDTH - perp_dist_0 - offset_0.first); }
145 if (is_valid(3) && !use_pos_x_wall) { x_cands.push_back(-HALF_WIDTH + perp_dist_3 - offset_3.first); }
146 if (is_valid(1) && use_pos_y_wall) { y_cands.push_back(HALF_HEIGHT - perp_dist_1 - offset_1.second); }
147 if (is_valid(2) && !use_pos_y_wall) { y_cands.push_back(-HALF_HEIGHT + perp_dist_2 - offset_2.second); }
148 }
149
150 else if (std::fabs(norm_heading - 270.0) <= TOLERANCE) {
151 double angle_off_rad = lemlib::degToRad(norm_heading - 270.0);
152 double heading_rad = lemlib::degToRad(norm_heading);
153
154 double perp_dist_0 = sensors[0].dist_in * std::cos(angle_off_rad);
155 double perp_dist_3 = sensors[3].dist_in * std::cos(angle_off_rad);
156 double perp_dist_1 = sensors[1].dist_in * std::cos(angle_off_rad);
157 double perp_dist_2 = sensors[2].dist_in * std::cos(angle_off_rad);
158
159 auto offset_0 = get_global_offsets(sensors[0].cfg, heading_rad);
160 auto offset_1 = get_global_offsets(sensors[1].cfg, heading_rad);
161 auto offset_2 = get_global_offsets(sensors[2].cfg, heading_rad);
162 auto offset_3 = get_global_offsets(sensors[3].cfg, heading_rad);
163
164 if (is_valid(0) && !use_pos_x_wall) { x_cands.push_back(-HALF_WIDTH + perp_dist_0 - offset_0.first); }
165 if (is_valid(3) && use_pos_x_wall) { x_cands.push_back(HALF_WIDTH - perp_dist_3 - offset_3.first); }
166 if (is_valid(1) && !use_pos_y_wall) { y_cands.push_back(-HALF_HEIGHT + perp_dist_1 - offset_1.second); }
167 if (is_valid(2) && use_pos_y_wall) { y_cands.push_back(HALF_HEIGHT - perp_dist_2 - offset_2.second); }
168 }
169
170 if (!x_cands.empty()) {
171 est_x = std::accumulate(x_cands.begin(), x_cands.end(), 0.0) / x_cands.size();
172 using_odom_x = false;
173 }
174
175 if (!y_cands.empty()) {
176 est_y = std::accumulate(y_cands.begin(), y_cands.end(), 0.0) / y_cands.size();
177 using_odom_y = false;
178 }
179
180
181 distancePose pose;
182 pose.x = est_x;
183 pose.y = est_y;
184 pose.using_odom_x = using_odom_x;
185 pose.using_odom_y = using_odom_y;
186 return pose;
187}
const double MAX_SENSOR_RANGE
const double MM_TO_IN
const SensorConfig left_sensor_cfg
const SensorConfig back_sensor_cfg
const SensorConfig right_sensor_cfg
const double HALF_WIDTH
const SensorConfig front_sensor_cfg
const double HALF_HEIGHT
const double MIN_SENSOR_RANGE
pros::Distance backDistance(11)
pros::Distance frontDistance(13)
pros::Distance leftDistance(12)
pros::Distance rightDistance(6)
lemlib::OdomSensors sensors
lemlib::Chassis chassis
double forward_offset

References back_sensor_cfg, backDistance(), chassis, SensorReadings::dist_mm, SensorConfig::forward_offset, front_sensor_cfg, frontDistance(), HALF_HEIGHT, HALF_WIDTH, left_sensor_cfg, leftDistance(), MAX_SENSOR_RANGE, MIN_SENSOR_RANGE, MM_TO_IN, right_sensor_cfg, rightDistance(), sensors, SensorConfig::strafe_offset, distancePose::using_odom_x, distancePose::using_odom_y, distancePose::x, and distancePose::y.

Referenced by distanceReset(), and distanceReset().

◆ distanceReset() [1/2]

distancePose distanceReset ( bool left_use,
bool right_use,
bool front_use,
bool back_use,
bool setPose )

Definition at line 203 of file distanceReset.cpp.

203 {
204 double heading_deg = chassis.getPose().theta;
205
206 const int invalid_dist_mm = 10000;
207 const int invalid_confidence = 0;
208
209 SensorReadings front_data = front_use
210 ? SensorReadings{(double)frontDistance.get_distance(), frontDistance.get_object_size(), frontDistance.get_confidence()}
211 : SensorReadings{invalid_dist_mm, 0, invalid_confidence};
212
213 SensorReadings left_data = left_use
214 ? SensorReadings{(double)leftDistance.get_distance(), leftDistance.get_object_size(), leftDistance.get_confidence()}
215 : SensorReadings{invalid_dist_mm, 0, invalid_confidence};
216
217 SensorReadings right_data = right_use
218 ? SensorReadings{(double)rightDistance.get_distance(), rightDistance.get_object_size(), rightDistance.get_confidence()}
219 : SensorReadings{invalid_dist_mm, 0, invalid_confidence};
220
221 SensorReadings back_data = back_use
222 ? SensorReadings{(double)backDistance.get_distance() ,backDistance.get_object_size(), backDistance.get_confidence()}
223 : SensorReadings{invalid_dist_mm, 0, invalid_confidence};
224
225 distancePose pose = calculateGlobalPosition(front_data, left_data, right_data, back_data, heading_deg);
226 if(setPose)
227 chassis.setPose(pose.x, pose.y, chassis.getPose().theta);
228
229 return pose;
230}
distancePose calculateGlobalPosition(const SensorReadings &front_data, const SensorReadings &left_data, const SensorReadings &right_data, const SensorReadings &back_data, double heading_deg)

References backDistance(), calculateGlobalPosition(), chassis, frontDistance(), leftDistance(), rightDistance(), distancePose::x, and distancePose::y.

◆ distanceReset() [2/2]

distancePose distanceReset ( bool setPose = false)

Definition at line 189 of file distanceReset.cpp.

189 {
190 double heading_deg = chassis.getPose().theta;
191
192 const SensorReadings front_data = {(double)frontDistance.get_distance(), frontDistance.get_object_size(), frontDistance.get_confidence()};
193 const SensorReadings left_data = {(double)leftDistance.get_distance(), leftDistance.get_object_size(), leftDistance.get_confidence()};
194 const SensorReadings right_data = {(double)rightDistance.get_distance(), rightDistance.get_object_size(), rightDistance.get_confidence()};
195 const SensorReadings back_data = {(double)backDistance.get_distance(), backDistance.get_object_size(), backDistance.get_confidence()};
196
197 distancePose pose = calculateGlobalPosition(front_data, left_data, right_data, back_data, heading_deg);
198 if(setPose)
199 chassis.setPose(pose.x, pose.y, chassis.getPose().theta);
200 return pose;
201}

References backDistance(), calculateGlobalPosition(), chassis, frontDistance(), leftDistance(), rightDistance(), distancePose::x, and distancePose::y.

Referenced by awp_auton(), carry_auton(), left_auton(), right_auton(), and skills_auton().

Variable Documentation

◆ back_sensor_cfg

const SensorConfig back_sensor_cfg = {-10.5, -3, 180}

Definition at line 24 of file distanceReset.cpp.

24{-10.5, -3, 180};

Referenced by calculateGlobalPosition().

◆ controller_screen_avilable

bool controller_screen_avilable

Definition at line 13 of file distanceReset.cpp.

◆ FIELD_HEIGHT

const double FIELD_HEIGHT = 3657.6 * MM_TO_IN

Definition at line 7 of file distanceReset.cpp.

◆ FIELD_WIDTH

const double FIELD_WIDTH = 3657.6 * MM_TO_IN

Definition at line 6 of file distanceReset.cpp.

◆ front_sensor_cfg

const SensorConfig front_sensor_cfg = {-0.75, -3, 0}

Definition at line 21 of file distanceReset.cpp.

21{-0.75, -3, 0};

Referenced by calculateGlobalPosition().

◆ HALF_HEIGHT

const double HALF_HEIGHT = FIELD_HEIGHT / 2.0

Definition at line 9 of file distanceReset.cpp.

Referenced by calculateGlobalPosition().

◆ HALF_WIDTH

const double HALF_WIDTH = FIELD_WIDTH / 2.0

Definition at line 8 of file distanceReset.cpp.

Referenced by calculateGlobalPosition().

◆ left_sensor_cfg

const SensorConfig left_sensor_cfg = {-0.5, -6.4, 90}

Definition at line 22 of file distanceReset.cpp.

22{-0.5, -6.4, 90};

Referenced by calculateGlobalPosition().

◆ MAX_SENSOR_RANGE

const double MAX_SENSOR_RANGE = 1500 * MM_TO_IN

Definition at line 10 of file distanceReset.cpp.

Referenced by calculateGlobalPosition().

◆ MIN_SENSOR_RANGE

const double MIN_SENSOR_RANGE = 10 * MM_TO_IN

Definition at line 11 of file distanceReset.cpp.

Referenced by calculateGlobalPosition().

◆ MM_TO_IN

const double MM_TO_IN = 0.0393701

Definition at line 5 of file distanceReset.cpp.

Referenced by calculateGlobalPosition().

◆ right_sensor_cfg

const SensorConfig right_sensor_cfg = {-0.5, 6.3, -90}

Definition at line 23 of file distanceReset.cpp.

23{-0.5, 6.3, -90};

Referenced by calculateGlobalPosition().