Skip to content

Commit

Permalink
Add start_item to image inference.
Browse files Browse the repository at this point in the history
  • Loading branch information
anarkiwi committed Feb 13, 2024
1 parent 8a6cf48 commit e8fa05a
Show file tree
Hide file tree
Showing 2 changed files with 15 additions and 5 deletions.
16 changes: 12 additions & 4 deletions lib/image_inference_impl.cc
Original file line number Diff line number Diff line change
Expand Up @@ -254,7 +254,8 @@ image_inference_impl::image_inference_impl(
min_peak_points_(min_peak_points), confidence_(confidence),
max_rows_(max_rows), rotate_secs_(rotate_secs), n_image_(n_image),
n_inference_(n_inference), samp_rate_(samp_rate), running_(true),
inference_connected_(false), image_count_(0), inference_count_(0) {
inference_connected_(false), image_count_(0), inference_count_(0),
last_image_start_item_(0) {
points_buffer_ = NULL;
normalized_buffer_.reset(
new cv::Mat(cv::Size(vlen_, 0), CV_32F, cv::Scalar::all(0)));
Expand Down Expand Up @@ -343,7 +344,8 @@ bool image_inference_impl::stop() {
return true;
}

void image_inference_impl::process_items_(size_t c, const input_type *&in) {
void image_inference_impl::process_items_(size_t c, size_t &consumed,
const input_type *&in) {
while (c) {
size_t existing_rows = 0;
if (points_buffer_) {
Expand All @@ -355,11 +357,13 @@ void image_inference_impl::process_items_(size_t c, const input_type *&in) {
cv::Size new_size(vlen_, new_rows);
if (!points_buffer_) {
points_buffer_ = new cv::Mat(new_size, CV_32F, (void *)in);
last_image_start_item_ = nitems_read(0) + consumed;
} else {
cv::Mat new_rows(new_size, CV_32F, (void *)in);
points_buffer_->push_back(new_rows);
}
c -= new_rows;
consumed += new_rows;
in += (vlen_ * new_rows);
}
if (points_buffer_ && points_buffer_->rows == max_rows_) {
Expand All @@ -377,6 +381,7 @@ void image_inference_impl::create_image_(bool discard) {
output_item_type output_item;
output_item.rx_freq = last_rx_freq_;
output_item.ts = last_rx_time_;
output_item.start_item = last_image_start_item_;
output_item.points_min = points_min;
output_item.points_max = points_max;
output_item.points_buffer = points_buffer_;
Expand All @@ -403,6 +408,7 @@ std::string image_inference_impl::write_image_(
cv::imencode(IMAGE_EXT, *output_item.image_buffer, *encoded_buffer);
std::string image_file_base =
prefix + "_" + std::to_string(image_count_) + "_" +
std::to_string(output_item.start_item) + "_" +
host_now_str_(output_item.ts) + "_" + std::to_string(uint64_t(x_)) + "x" +
std::to_string(uint64_t(y_)) + "_" +
std::to_string(uint64_t(output_item.rx_freq)) + "Hz";
Expand Down Expand Up @@ -534,6 +540,7 @@ void image_inference_impl::run_inference_() {
metadata_json["rssi_min"] = std::to_string(output_item.points_min);
metadata_json["ts"] = host_now_str_(output_item.ts);
metadata_json["rx_freq"] = std::to_string(output_item.rx_freq);
metadata_json["start_item"] = std::to_string(output_item.start_item);
metadata_json["orig_rows"] = output_item.points_buffer->rows;

const std::string secs_image_dir = secs_dir(image_dir_, rotate_secs_);
Expand Down Expand Up @@ -656,6 +663,7 @@ int image_inference_impl::general_work(int noutput_items,
size_t in_count = ninput_items[0];
size_t in_first = nitems_read(0);
size_t leftover = 0;
size_t consumed = 0;

while (!json_q_.empty()) {
std::string json;
Expand All @@ -678,7 +686,7 @@ int image_inference_impl::general_work(int noutput_items,
get_tags(tag_, all_tags, rx_freq_tags, rx_times, in_count);

if (rx_freq_tags.empty()) {
process_items_(in_count, in);
process_items_(in_count, consumed, in);
} else {
for (size_t t = 0; t < rx_freq_tags.size(); ++t) {
const auto &tag = rx_freq_tags[t];
Expand All @@ -688,7 +696,7 @@ int image_inference_impl::general_work(int noutput_items,

// TODO: process leftover untagged items.
if (rel > 0) {
process_items_(rel, in);
process_items_(rel, consumed, in);
}

FREQ_T rx_freq = GET_FREQ(tag);
Expand Down
4 changes: 3 additions & 1 deletion lib/image_inference_impl.h
Original file line number Diff line number Diff line change
Expand Up @@ -236,6 +236,7 @@ typedef struct output_item {
double points_min;
double points_mean;
double points_max;
uint64_t start_item;
} output_item_type;

class image_inference_impl : public image_inference, base_impl {
Expand All @@ -244,6 +245,7 @@ class image_inference_impl : public image_inference, base_impl {
rotate_secs_, n_image_, n_inference_, image_count_, inference_count_,
samp_rate_;
FREQ_T last_rx_freq_;
uint64 last_image_start_item_;
double convert_alpha_, norm_alpha_, norm_beta_, last_rx_time_,
min_peak_points_, confidence_;
boost::lockfree::spsc_queue<output_item_type> inference_q_{MAX_INFERENCE};
Expand All @@ -263,7 +265,7 @@ class image_inference_impl : public image_inference, base_impl {
boost::scoped_ptr<boost::beast::tcp_stream> stream_;
cv::Scalar text_color_;

void process_items_(size_t c, const input_type *&in);
void process_items_(size_t c, size_t &consumed, const input_type *&in);
void create_image_(bool discard);
void run_inference_();
void background_run_inference_();
Expand Down

0 comments on commit e8fa05a

Please sign in to comment.