修改开火延迟一直为0的错误

This commit is contained in:
2026-03-23 23:45:27 +08:00
parent 032e964b95
commit a8995393cd
2 changed files with 28 additions and 7 deletions

View File

@@ -10,11 +10,12 @@
template<int length> template<int length>
static double mean(RoundQueue<double, length> &vec) { static double mean(RoundQueue<double, length> &vec) {
if (vec.size() == 0) return 0;
double sum = 0; double sum = 0;
for (int i = 0; i < vec.size(); i++) { for (int i = 0; i < vec.size(); i++) {
sum += vec[i]; sum += vec[i];
} }
return sum / length; return sum / vec.size();
} }
static systime getFrontTime(const vector<systime> time_seq, const vector<float> angle_seq) { static systime getFrontTime(const vector<systime> time_seq, const vector<float> angle_seq) {
@@ -47,6 +48,15 @@ void ArmorFinder::antiTop(double dist_m, double pitch_imu_deg) {
// return; // return;
// } // }
LOGM(STR_CTR(WORD_GREEN, "Top period: %.1lf"), once_periodms); LOGM(STR_CTR(WORD_GREEN, "Top period: %.1lf"), once_periodms);
bool is_period_stable = true;
if (!top_periodms.empty()) {
double last_period = top_periodms[-1];
if (abs(once_periodms - last_period) > 50) {
is_period_stable = false;
}
}
top_periodms.push(once_periodms); top_periodms.push(once_periodms);
auto periodms = mean(top_periodms); auto periodms = mean(top_periodms);
systime curr_time; systime curr_time;
@@ -67,7 +77,7 @@ void ArmorFinder::antiTop(double dist_m, double pitch_imu_deg) {
: static_cast<uint16_t>(delay_raw + static_cast<int32_t>(periodms)); : static_cast<uint16_t>(delay_raw + static_cast<int32_t>(periodms));
if (anti_top_cnt < 4) { if (anti_top_cnt < 4) {
sendBoxPosition(0); sendBoxPosition(0);
} else if (abs(once_periodms - top_periodms[-1]) > 50) { } else if (!is_period_stable) {
sendBoxPosition(0); sendBoxPosition(0);
} else { } else {
sendBoxPosition(shoot_delay); sendBoxPosition(shoot_delay);

View File

@@ -42,21 +42,28 @@ private:
type data[length]; type data[length];
int head; int head;
int tail; int tail;
int count;
public: public:
RoundQueue<type, length>() : head(0), tail(0) {}; RoundQueue<type, length>() : head(0), tail(0), count(0) {};
constexpr int size() const { constexpr int capacity() const {
return length; return length;
}; };
int size() const {
return count;
};
bool empty() const { bool empty() const {
return head == tail; return count == 0;
}; };
void push(const type &obj) { void push(const type &obj) {
data[head] = obj; data[head] = obj;
head = (head + 1) % length; head = (head + 1) % length;
if (head == tail) { if (count < length) {
count++;
} else {
tail = (tail + 1) % length; tail = (tail + 1) % length;
} }
}; };
@@ -65,11 +72,15 @@ public:
if (empty()) return false; if (empty()) return false;
obj = data[tail]; obj = data[tail];
tail = (tail + 1) % length; tail = (tail + 1) % length;
count--;
return true; return true;
}; };
type &operator[](int idx) { type &operator[](int idx) {
while (tail + idx < 0) idx += length; if (count == 0) return data[0];
if (idx < 0) idx += count;
if (idx < 0) idx = 0;
if (idx >= count) idx = count - 1;
return data[(tail + idx) % length]; return data[(tail + idx) % length];
}; };
}; };