mirror of
https://github.com/2martens/uni.git
synced 2026-05-06 19:36:26 +02:00
[CCV] Fixed mean fusion function
Signed-off-by: Jim Martens <github@2martens.de>
This commit is contained in:
@ -49,15 +49,22 @@ cv::Mat mean_fusion_generic(const std::vector<cv::Mat> feature_maps) {
|
|||||||
unsigned long number_of_features = feature_maps.size();
|
unsigned long number_of_features = feature_maps.size();
|
||||||
cv::Mat sum_of_features;
|
cv::Mat sum_of_features;
|
||||||
double max = -1;
|
double max = -1;
|
||||||
|
bool first_run = true;
|
||||||
for (auto& f : feature_maps) {
|
for (auto& f : feature_maps) {
|
||||||
sum_of_features += f;
|
if (first_run) {
|
||||||
|
sum_of_features = f.clone();
|
||||||
|
first_run = false;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
sum_of_features = sum_of_features + f;
|
||||||
|
}
|
||||||
double max_value;
|
double max_value;
|
||||||
cv::minMaxLoc(f, nullptr, &max_value);
|
cv::minMaxLoc(f, nullptr, &max_value);
|
||||||
if (max_value >= max) {
|
if (max_value >= max) {
|
||||||
max = max_value;
|
max = max_value;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
cv::Mat C = 1/number_of_features * sum_of_features;
|
cv::Mat C = 1./number_of_features * sum_of_features;
|
||||||
cv::normalize(C, C, 0, max, cv::NORM_MINMAX, -1);
|
cv::normalize(C, C, 0, max, cv::NORM_MINMAX, -1);
|
||||||
|
|
||||||
return C.clone();
|
return C.clone();
|
||||||
|
|||||||
Reference in New Issue
Block a user