这是 C++ 的答案,您可以轻松地将其转换为 python/numpy。这个想法是在执行 CLAHE 之前使用边界区域,然后裁剪图像。
这些是原始图像中的子图像区域:
data:image/s3,"s3://crabby-images/97808/97808a6546c125b864d6c18ac19be64b169e74d0" alt="在此处输入图像描述"
它们将被复制到图像的左/右,如下所示:
data:image/s3,"s3://crabby-images/bd742/bd7421bd04e69734f59d52ce9e2a888f57c99ea6" alt="在此处输入图像描述"
也许您可以强烈减小边框的大小:
int main()
{
cv::Mat img = cv::imread("C:/data/SO_360.jpg");
int borderSize = img.cols / 4;
// make image that can have some border region
cv::Mat borderImage = cv::Mat(cv::Size(img.cols + 2 * borderSize, img.rows), img.type());
// posX, posY, width, height of the subimages
cv::Rect leftBorderRegion = cv::Rect(0, 0, borderSize, borderImage.rows);
cv::Rect rightBorderRegion = cv::Rect(borderImage.cols - borderSize, 0, borderSize, borderImage.rows);
cv::Rect imgRegion = cv::Rect(borderSize, 0, img.cols, borderImage.rows);
// original image regions to copy:
cv::Rect left = cv::Rect(0, 0, borderSize, borderImage.rows);
cv::Rect right = cv::Rect(img.cols - borderSize, 0, borderSize, img.rows);
cv::Rect full = cv::Rect(0, 0, img.cols, img.rows);
// perform copying to subimage (left part of the img goes to right part of the border image):
img(left).copyTo(borderImage(rightBorderRegion));
img(right).copyTo(borderImage(leftBorderRegion));
img.copyTo(borderImage(imgRegion));
cv::imwrite("SO_360_border.jpg", borderImage);
//# CLAHE(Contrast Limited Adaptive Histogram Equalization)
//clahe = cv2.createCLAHE(clipLimit = 1., tileGridSize = (6, 6))
// apply the CLAHE algorithm to the L channel
cv::Ptr<cv::CLAHE> clahe = cv::createCLAHE();
clahe->setClipLimit(1);
clahe->setTilesGridSize(cv::Size(6, 6));
cv::Mat lab;
cv::cvtColor(borderImage, lab, cv::COLOR_BGR2Lab); // # convert from BGR to LAB color space
std::vector<cv::Mat> labChannels; //l, a, b = cv2.split(lab) # split on 3 different channels
cv::split(lab, labChannels);
//l2 = clahe.apply(l) # apply CLAHE to the L - channel
cv::Mat dst;
clahe->apply(labChannels[0], dst);
labChannels[0] = dst;
//lab = cv2.merge((l2, a, b)) # merge channels
cv::merge(labChannels, lab);
//img2 = cv2.cvtColor(lab, cv2.COLOR_LAB2BGR) # convert from LAB to BGR
cv::cvtColor(lab, dst, cv::COLOR_Lab2BGR);
cv::imwrite("SO_360_border_clahe.jpg", dst);
// to crop the image after performing clahe:
cv::Mat cropped = dst(imgRegion).clone();
cv::imwrite("SO_360_clahe.jpg", cropped);
}
图片:输入您的原始帖子。
创建边框后:
data:image/s3,"s3://crabby-images/cf014/cf0148d62d6bdfe2a7b0bd109447dcff19722857" alt="在此处输入图像描述"
执行 CLAHE(带边框)后:
data:image/s3,"s3://crabby-images/3216e/3216ee3c41539e11ef279c8af549805968b000d6" alt="在此处输入图像描述"
裁剪 CLAHE-border-image 后:
data:image/s3,"s3://crabby-images/f2126/f2126e813123e02086014e01ea97cf05afab7169" alt="在此处输入图像描述"