【影像處理知識複習】03對比度線性拉伸matlab,C++實現
演算法:(1), 通過畫灰度直方圖點選開啟連結,估計目標物灰度範圍。(2), 求斜率,即斜率大於1,則拉伸;(3), 根據線性公式,求拉伸後灰度值,如下圖
1. matlab程式碼:
%題目: 對比度拉伸
%意義:所期望觀察的物件因對比度不足而不夠清晰,需進行對比度拉伸。
%灰度值的分段線性對映
%已知條件:原影像的目標景物灰度範圍[fa,fb],拉伸後範圍在[ga,gb]。
%實現方法:目標景物灰度範圍拉伸k2=(gb-ga)/(fb-fa),其他進行抑制k1=ga/fa,k3=(255-gb)/(255-fb)
%難點:分段線性函式求解。
clc;
clear;
image = rgb2gray(imread('D:/Code/Image/classic.jpg'));
figure,imshow(image);
%1, 通過畫灰度直方圖,估計目標物灰度範圍。
fa = 75; % 橫座標,即目標灰度區間[75,150]
fb = 150;
ga = 30; % 縱座標, 即拉伸後目標灰度區間[30,200],動態範圍擴大
gb = 200;
%2, 求斜率,即斜率大於1,則拉伸
k1 = ga/fa;
k2 = (gb-ga)/(fb-fa);
k3 = (255-gb)/(255-fb);
%3, 求拉伸後灰度值
[row,col] = size(image);
g = zeros(row,col);%預設g 為double。g = f; g為uint8
for i=1:row
for j=1:col
if 0<=image(i,j) && image(i,j)<=fa
g(i,j) = k1*image(i,j);
else if fa<=image(i,j) && image(i,j)<=fb
g(i,j) = k2*(image(i,j)-fa)+ga;
else if fb<=image(i,j) && image(i,j)<=255
g(i,j) = k3*(image(i,j)-fb)+gb;
end
end
end
end
end
figure,imshow(uint8(g));%因為宣告g為double,必須轉為uint8,因為影像灰度範圍[0,255]
% imshow顯示時對double型是認為在0~1範圍內,所以大於1時都是顯示為白色,從uint8轉換的數除了0都是大於等於1的。
% imshow顯示uint8型時是0~255範圍。
% 程式設計時用uint8型時會出現減的結果沒有負數,乘除時有精度問題,但uint8型佔用記憶體小。
效果圖:
2. C++實現
#include <opencv2/opencv.hpp>
using namespace cv;
int main()
{
Mat img = imread("D:/Code/Image/classic.jpg",0);
imshow("原圖",img);
//假設已知目標灰度範圍[75,150],需要拉伸到[30,200]
int x1 = 75, y1 = 30, x2 = 150, y2 = 200;
int x; //當前灰度值
//Mat y = img.clone(); //拉伸後的灰度值
Mat y = Mat::zeros(img.size(), img.type()); //拉伸後的灰度值
double k1 = y1 / x1, k2 = (y2 - y1) / (x2 - x1), k3 = (255 - y2) / (255 - x2);
for (int i = 0; i < img.rows; i++)
{
for (int j = 0; j < img.cols; j++)
{
x = img.at<uchar>(i, j);
if (0 <= x && x < x1)
y.at<uchar>(i, j) = k1 * x;
else if (x1 <= x && x < x2)
y.at<uchar>(i, j) = k2 * (x - x1) + y1;
else if (x2 <= x && x < 255)
y.at<uchar>(i, j) = k3 * (x - x2) + y2;
}
}
imshow("效果圖", y);
waitKey();
return 0;
}
效果圖:
灰級窗:演算法和對比度線性拉伸一樣,只是分段線性函式不同。分段啊線性對映,將目標物進行對比度增強,其他灰度設定為0(即背景全黑);
灰級窗切片:演算法和灰級窗一樣,分段線性函式不同,目標簡單置為0,背景依然置為255。也就是二值化。
相關文章
- matlab實現 線性拉伸某灰度影像的對比度 程式碼 對比度拉伸Matlab
- 數字影像處理實驗之對比度拉伸
- Matlab——對比度拉伸Matlab
- matlab影像點運算 對比度增強 對比度拉伸 灰度變換Matlab
- matlab影像對比度增強,拉伸和灰度變換Matlab
- 影像的灰度變換——影像旋轉、影像的反色處理、對比度拉伸
- MATLAB影像處理imadjust()函式調節影像的對比度示例Matlab函式
- 影像處理案例03
- OpenCV與影像處理學習二——影像基礎知識(下)OpenCV
- intrans函式(對比度拉伸)函式
- matlab實現調整圖片的對比度Matlab
- 數字影像處理,經典對比度增強演算法演算法
- 使用matlab對影像進行二值化處理Matlab
- 影像處理的基礎知識(5)——繪製影像(1)
- matlab練習程式(灰度拉伸)Matlab
- 海量資料處理問題知識點複習手冊
- [00]數字影像處理-matlab速成Matlab
- Matlab影像處理常用基本函式Matlab函式
- 前端知識學習03前端
- 灰度變換函式:對數及對比度拉伸變換函式
- 影像處理的基礎知識(11)——圖層(1)
- Infrastructure 知識: dnf對module的處理ASTStruct
- 影像處理的基礎知識(9)——編輯與修飾影像(1)
- 數字影像處理-取樣量化(Matlab)Matlab
- 線性表的理論知識總結
- 影像處理的基礎知識(14)——通道與蒙版
- 比預想嚴重:FireFox現影像處理漏洞Firefox
- C++實現對Json資料的友好處理C++JSON
- C/C++期末考試複習---知識點+習題C++
- 數字影像處理--認識影像各種概念
- MatLab 基本影像處理(3)——函式變換Matlab函式
- Linux複習知識Linux
- 【影像處理】基於OpenCV實現影像直方圖的原理OpenCV直方圖
- 用 matlab 對圖片進行對比度和均衡度調整Matlab
- Python 影像處理 OpenCV (3):影像屬性、影像感興趣 ROI 區域及通道處理PythonOpenCV
- 影像處理的實現與應用(Ruby 版)
- 影像處理的實現與應用(Swift 版)Swift
- 影像處理的實現與應用(TypeScript 版)TypeScript