Files
Jungfraujoch/receiver/LossyFilter.cpp
2024-07-06 09:34:44 +02:00

32 lines
682 B
C++

// Copyright (2019-2024) Paul Scherrer Institute
#include "LossyFilter.h"
LossyFilter::LossyFilter(float in_p)
: p(in_p) {}
bool LossyFilter::RollDice() {
std::unique_lock<std::mutex> ul(random_m);
if (distr(mt) < p)
return true;
else
return false;
}
bool LossyFilter::ApplyFilter(DataMessage &message) {
if (p == 1.0)
return true;
else {
if (message.indexing_result || ((p > 0.0) && RollDice())) {
message.number = image_number++;
return true;
} else
return false;
}
}
LossyFilter::LossyFilter(const DiffractionExperiment &x)
: p (x.GetLossyCompressionSerialMX()){}