Opencv 最大池化

我们将这种把图片使用均等大小网格分割,并求网格内代表值的操作称为池化(Pooling).网格内的值不取平均值,而是取网格内的最大值进行池化操作,叫做最大池化

python实现:

import cv2
import numpy as np

# Read image
img = cv2.imread("imori.jpg")

# Max Pooling
out = img.copy()

H, W, C = img.shape
G = 8
Nh = int(H / G)
Nw = int(W / G)

for y in range(Nh):
    for x in range(Nw):
        for c in range(C):
            out[G*y:G*(y+1), G*x:G*(x+1), c] = np.max(out[G*y:G*(y+1), G*x:G*(x+1), c])

# Save result
cv2.imwrite("out.jpg", out)
cv2.imshow("result", out)
cv2.waitKey(0)
cv2.destroyAllWindows()

C++实现:

#include <opencv2/core.hpp>
#include <opencv2/highgui.hpp>
#include <iostream>
#include <math.h>

int main(int argc, const char* argv[]){
  cv::Mat img = cv::imread("imori.jpg", cv::IMREAD_COLOR);

  int width = img.rows;
  int height = img.cols;

  cv::Mat out = cv::Mat::zeros(height, width, CV_8UC3);

  int r = 8;
  uchar v = 0;

  for (int j = 0; j < height; j+=r){
    for (int i = 0; i < width; i+=r){
      for (int c = 0; c < 3; c++){
    v = 0;
    for (int _j = 0; _j < r; _j++){
      for (int _i = 0; _i < r; _i++){
        v = fmax(img.at<cv::Vec3b>(j+_j, i+_i)[c], v);
      }
    }
    for (int _j = 0; _j < r; _j++){
      for (int _i = 0; _i < r; _i++){
        out.at<cv::Vec3b>(j+_j, i+_i)[c] = v;
      }
    }
      }
    }
  }

  //cv::imwrite("out.jpg", out);
  cv::imshow("answer", out);
  cv::waitKey(0);
  cv::destroyAllWindows();

  return 0;
}

输入:

最大池化

输出:

最大池化

Python教程

Java教程

Web教程

数据库教程

图形图像教程

大数据教程

开发工具教程

计算机教程