Я хочу перевести некоторый код Matlab в код C ++ с помощью OpenCV.Какие функции мне нужно использовать?
Для поэлементного умножения я не знаю, какую функцию использовать.Например,
cv::Mat A; cv::Mat B; cv::Mat C;
C = A + B;
//or
cv::add(A, B, C);
Это код MATLAB:
% G and b are constant
% Rb, CRb and Rb_final are the images
Rb = G(CRb+b);
min3 = min(min(Rb)); % minimum in the Rb image
max3 = max(max(Rb)); % maximum in the Rb image
Rb_final = uint8(255*(Rb-min3)/(max3-min3)); % This function is to scale the image into 0 ~ 255 using maximum and minimum value in the image. And then convert the image into 8-bit unsigned image.
Это код OpenCV, который я пробовал:
Rb_final = uint8(255*(Rb-min3)/(max3-min3));
Я нашел максимуми min следующим кодом:
double max3, min3;
minMaxLoc(Rb, &min3, &max3);
Rb = Rb - min3;
Rb = 255 * Rb;
Rb = Rb / (max3 - min3);
Я нахожу это для всех каналов B, G, R.Но результат не так хорош, как с cv::convertScaleAbs(Rb, R, 255, 0);