电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

python 圖像增強算法實現詳解

瀏覽:15日期:2022-06-29 11:34:04

使用python編寫了共六種圖像增強算法:

1)基于直方圖均衡化2)基于拉普拉斯算子3)基于對數變換4)基于伽馬變換5)限制對比度自適應直方圖均衡化:CLAHE6)retinex-SSR7)retinex-MSR其中,6和7屬于同一種下的變化。將每種方法編寫成一個函數,封裝,可以直接在主函數中調用。采用同一幅圖進行效果對比。

圖像增強的效果為:

直方圖均衡化:對比度較低的圖像適合使用直方圖均衡化方法來增強圖像細節拉普拉斯算子可以增強局部的圖像對比度log對數變換對于整體對比度偏低并且灰度值偏低的圖像增強效果較好伽馬變換對于圖像對比度偏低,并且整體亮度值偏高(對于相機過曝)情況下的圖像增強效果明顯CLAHE和retinex的效果均較好

python代碼為:

# 圖像增強算法,圖像銳化算法# 1)基于直方圖均衡化 2)基于拉普拉斯算子 3)基于對數變換 4)基于伽馬變換 5)CLAHE 6)retinex-SSR 7)retinex-MSR# 其中,基于拉普拉斯算子的圖像增強為利用空域卷積運算實現濾波# 基于同一圖像對比增強效果# 直方圖均衡化:對比度較低的圖像適合使用直方圖均衡化方法來增強圖像細節# 拉普拉斯算子可以增強局部的圖像對比度# log對數變換對于整體對比度偏低并且灰度值偏低的圖像增強效果較好# 伽馬變換對于圖像對比度偏低,并且整體亮度值偏高(對于相機過曝)情況下的圖像增強效果明顯import cv2import numpy as npimport matplotlib.pyplot as plt# 直方圖均衡增強def hist(image): r, g, b = cv2.split(image) r1 = cv2.equalizeHist(r) g1 = cv2.equalizeHist(g) b1 = cv2.equalizeHist(b) image_equal_clo = cv2.merge([r1, g1, b1]) return image_equal_clo# 拉普拉斯算子def laplacian(image): kernel = np.array([[0, -1, 0], [-1, 5, -1], [0, -1, 0]]) image_lap = cv2.filter2D(image, cv2.CV_8UC3, kernel) return image_lap# 對數變換def log(image): image_log = np.uint8(np.log(np.array(image) + 1)) cv2.normalize(image_log, image_log, 0, 255, cv2.NORM_MINMAX) # 轉換成8bit圖像顯示 cv2.convertScaleAbs(image_log, image_log) return image_log# 伽馬變換def gamma(image): fgamma = 2 image_gamma = np.uint8(np.power((np.array(image) / 255.0), fgamma) * 255.0) cv2.normalize(image_gamma, image_gamma, 0, 255, cv2.NORM_MINMAX) cv2.convertScaleAbs(image_gamma, image_gamma) return image_gamma# 限制對比度自適應直方圖均衡化CLAHEdef clahe(image): b, g, r = cv2.split(image) clahe = cv2.createCLAHE(clipLimit=2.0, tileGridSize=(8, 8)) b = clahe.apply(b) g = clahe.apply(g) r = clahe.apply(r) image_clahe = cv2.merge([b, g, r]) return image_clahedef replaceZeroes(data): min_nonzero = min(data[np.nonzero(data)]) data[data == 0] = min_nonzero return data# retinex SSRdef SSR(src_img, size): L_blur = cv2.GaussianBlur(src_img, (size, size), 0) img = replaceZeroes(src_img) L_blur = replaceZeroes(L_blur) dst_Img = cv2.log(img/255.0) dst_Lblur = cv2.log(L_blur/255.0) dst_IxL = cv2.multiply(dst_Img, dst_Lblur) log_R = cv2.subtract(dst_Img, dst_IxL) dst_R = cv2.normalize(log_R,None, 0, 255, cv2.NORM_MINMAX) log_uint8 = cv2.convertScaleAbs(dst_R) return log_uint8def SSR_image(image): size = 3 b_gray, g_gray, r_gray = cv2.split(image) b_gray = SSR(b_gray, size) g_gray = SSR(g_gray, size) r_gray = SSR(r_gray, size) result = cv2.merge([b_gray, g_gray, r_gray]) return result# retinex MMRdef MSR(img, scales): weight = 1 / 3.0 scales_size = len(scales) h, w = img.shape[:2] log_R = np.zeros((h, w), dtype=np.float32) for i in range(scales_size): img = replaceZeroes(img) L_blur = cv2.GaussianBlur(img, (scales[i], scales[i]), 0) L_blur = replaceZeroes(L_blur) dst_Img = cv2.log(img/255.0) dst_Lblur = cv2.log(L_blur/255.0) dst_Ixl = cv2.multiply(dst_Img, dst_Lblur) log_R += weight * cv2.subtract(dst_Img, dst_Ixl) dst_R = cv2.normalize(log_R,None, 0, 255, cv2.NORM_MINMAX) log_uint8 = cv2.convertScaleAbs(dst_R) return log_uint8def MSR_image(image): scales = [15, 101, 301] # [3,5,9] b_gray, g_gray, r_gray = cv2.split(image) b_gray = MSR(b_gray, scales) g_gray = MSR(g_gray, scales) r_gray = MSR(r_gray, scales) result = cv2.merge([b_gray, g_gray, r_gray]) return resultif __name__ == '__main__': image = cv2.imread('example.jpg') image_gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY) plt.subplot(4, 2, 1) plt.imshow(image) plt.axis(’off’) plt.title(’Offical’) # 直方圖均衡增強 image_equal_clo = hist(image) plt.subplot(4, 2, 2) plt.imshow(image_equal_clo) plt.axis(’off’) plt.title(’equal_enhance’) # 拉普拉斯算法增強 image_lap = laplacian(image) plt.subplot(4, 2, 3) plt.imshow(image_lap) plt.axis(’off’) plt.title(’laplacian_enhance’) # LoG對象算法增強 image_log = log(image) plt.subplot(4, 2, 4) plt.imshow(image_log) plt.axis(’off’) plt.title(’log_enhance’) # 伽馬變換 image_gamma = gamma(image) plt.subplot(4, 2, 5) plt.imshow(image_gamma) plt.axis(’off’) plt.title(’gamma_enhance’) # CLAHE image_clahe = clahe(image) plt.subplot(4, 2, 6) plt.imshow(image_clahe) plt.axis(’off’) plt.title(’CLAHE’) # retinex_ssr image_ssr = SSR_image(image) plt.subplot(4, 2, 7) plt.imshow(image_ssr) plt.axis(’off’) plt.title(’SSR’) # retinex_msr image_msr = MSR_image(image) plt.subplot(4, 2, 8) plt.imshow(image_msr) plt.axis(’off’) plt.title(’MSR’) plt.show()

增強效果如下圖所示:

python 圖像增強算法實現詳解

到此這篇關于python 圖像增強算法實現詳解的文章就介紹到這了,更多相關python 圖像增強算法內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 同步带轮_同步带_同步轮_iHF合发齿轮厂家-深圳市合发齿轮机械有限公司 | 蒸汽热收缩机_蒸汽发生器_塑封机_包膜机_封切收缩机_热收缩包装机_真空机_全自动打包机_捆扎机_封箱机-东莞市中堡智能科技有限公司 | 玻纤土工格栅_钢塑格栅_PP焊接_单双向塑料土工格栅_复合防裂布厂家_山东大庚工程材料科技有限公司 | 橡胶接头_橡胶软接头_可曲挠橡胶接头-巩义市创伟机械制造有限公司 | 讲师宝经纪-专业培训机构师资供应商_培训机构找讲师、培训师、讲师经纪就上讲师宝经纪 | 知名电动蝶阀,电动球阀,气动蝶阀,气动球阀生产厂家|价格透明-【固菲阀门官网】 | 基业箱_环网柜_配电柜厂家_开关柜厂家_开关断路器-东莞基业电气设备有限公司 | 防水套管|柔性防水套管|伸缩器|伸缩接头|传力接头-河南伟创管道 防水套管_柔性防水套管_刚性防水套管-巩义市润达管道设备制造有限公司 | 广州网站建设_小程序开发_番禺网站建设_佛山网站建设_粤联网络 | 聚合甘油__盐城市飞龙油脂有限公司| 美名宝起名网-在线宝宝、公司、起名平台 | 不锈钢复合板厂家_钛钢复合板批发_铜铝复合板供应-威海泓方金属复合材料股份有限公司 | 深圳法律咨询【24小时在线】深圳律师咨询免费 | 信阳市建筑勘察设计研究院有限公司| 【德信自动化】点胶机_全自动点胶机_自动点胶机厂家_塑料热压机_自动螺丝机-深圳市德信自动化设备有限公司 | 杭州ROHS检测仪-XRF测试仪价格-百科 | HDPE土工膜,复合土工膜,防渗膜价格,土工膜厂家-山东新路通工程材料有限公司 | 美的商用净水器_美的直饮机_一级代理经销商_Midea租赁价格-厂家反渗透滤芯-直饮水批发品牌售后 | 东莞市踏板石餐饮管理有限公司_正宗桂林米粉_正宗桂林米粉加盟_桂林米粉加盟费-东莞市棒子桂林米粉 | 河南档案架,档案密集架,手动密集架,河南密集架批发/报价 | 泰来华顿液氮罐,美国MVE液氮罐,自增压液氮罐,定制液氮生物容器,进口杜瓦瓶-上海京灿精密机械有限公司 | 体视显微镜_荧光生物显微镜_显微镜报价-微仪光电生命科学显微镜有限公司 | 广州云仓代发-昊哥云仓专业电商仓储托管外包代发货服务 | 世纪豪门官网 世纪豪门集成吊顶加盟电话 世纪豪门售后电话 | 网络推广公司_网络营销方案策划_企业网络推广外包平台-上海澜推网络 | 书法培训-高考书法艺考培训班-山东艺霖书法培训凭实力挺进央美 | 金属雕花板_厂家直销_价格低-山东慧诚建筑材料有限公司 | 重庆私家花园设计-别墅花园-庭院-景观设计-重庆彩木园林建设有限公司 | 浙江华锤电器有限公司_地磅称重设备_防作弊地磅_浙江地磅售后维修_无人值守扫码过磅系统_浙江源头地磅厂家_浙江工厂直营地磅 | 方源木业官网-四川木门-全国木门专业品牌 | 郑州墨香品牌设计公司|品牌全案VI设计公司 | 深圳VI设计-画册设计-LOGO设计-包装设计-品牌策划公司-[智睿画册设计公司] | 深圳市东信高科自动化设备有限公司 | 上海logo设计| 污水提升器,污水提升泵,地下室排水,增压泵,雨水泵,智能供排水控制器-上海智流泵业有限公司 | 碎石机设备-欧版反击破-欧版颚式破碎机(站)厂家_山东奥凯诺机械 高低温试验箱-模拟高低温试验箱订制-北京普桑达仪器科技有限公司【官网】 | 透平油真空滤油机-变压器油板框滤油机-滤油车-华之源过滤设备 | 郑州律师咨询-郑州律师事务所_河南锦盾律师事务所 | 冷轧机|两肋冷轧机|扁钢冷轧机|倒立式拉丝机|钢筋拔丝机|收线机-巩义市华瑞重工机械制造有限公司 | 全国国际化学校_国际高中招生_一站式升学择校服务-国际学校网 | 合肥白癜风医院_[治疗白癜风]哪家好_合肥北大白癜风医院 |