婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > python 圖像增強算法實現詳解

python 圖像增強算法實現詳解

熱門標簽:上海企業外呼系統 熱門電銷機器人 智能機器人電銷神器 電話機器人哪里有賣 外呼電信系統 萬利達百貨商場地圖標注 惠州龍門400電話要怎么申請 河南虛擬外呼系統公司 okcc外呼系統怎么調速度

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

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

圖像增強的效果為:

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

python代碼為:

# 圖像增強算法,圖像銳化算法
# 1)基于直方圖均衡化 2)基于拉普拉斯算子 3)基于對數變換 4)基于伽馬變換 5)CLAHE 6)retinex-SSR 7)retinex-MSR
# 其中,基于拉普拉斯算子的圖像增強為利用空域卷積運算實現濾波
# 基于同一圖像對比增強效果
# 直方圖均衡化:對比度較低的圖像適合使用直方圖均衡化方法來增強圖像細節
# 拉普拉斯算子可以增強局部的圖像對比度
# log對數變換對于整體對比度偏低并且灰度值偏低的圖像增強效果較好
# 伽馬變換對于圖像對比度偏低,并且整體亮度值偏高(對于相機過曝)情況下的圖像增強效果明顯

import cv2
import numpy as np
import 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


# 限制對比度自適應直方圖均衡化CLAHE
def 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_clahe


def replaceZeroes(data):
  min_nonzero = min(data[np.nonzero(data)])
  data[data == 0] = min_nonzero
  return data


# retinex SSR
def 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_uint8


def 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 MMR
def 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_uint8


def 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 result


if __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 實現非極大值抑制算法(Non-maximum suppression, NMS)
  • python 實現Harris角點檢測算法
  • python動態規劃算法實例詳解
  • 詳解非極大值抑制算法之Python實現

標簽:淮安 綏化 周口 綿陽 合肥 秦皇島 周口 百色

巨人網絡通訊聲明:本文標題《python 圖像增強算法實現詳解》,本文關鍵詞  python,圖像,增強,算法,實現,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《python 圖像增強算法實現詳解》相關的同類信息!
  • 本頁收集關于python 圖像增強算法實現詳解的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    欧美大片一区二区| 欧美日本视频在线| 亚洲人成精品久久久久久| 欧美乱妇23p| 成人99免费视频| 日本午夜精品视频在线观看| 欧美日韩亚洲综合在线| 欧美aⅴ一区二区三区视频| 亚洲私人影院在线观看| 久久蜜桃一区二区| 99久久综合精品| 亚洲大片精品永久免费| 欧美日本一区二区| 国产精品资源在线观看| 亚洲线精品一区二区三区八戒| 欧美精品一级二级三级| a4yy欧美一区二区三区| 日韩不卡一区二区三区 | 毛片av一区二区| 婷婷六月综合亚洲| 一本色道久久综合狠狠躁的推荐| 亚洲男人天堂一区| 国产欧美一区二区三区在线看蜜臀 | 亚洲精品va在线观看| 久久精品日韩一区二区三区| 91色在线porny| 国产98色在线|日韩| 亚洲日本丝袜连裤袜办公室| 精品国产乱码久久久久久久久| 国产女主播一区| 国产剧情av麻豆香蕉精品| 亚洲成人免费在线观看| 在线观看91精品国产入口| 亚洲成va人在线观看| 日韩视频在线你懂得| 国产乱淫av一区二区三区| 2014亚洲片线观看视频免费| 日韩av高清在线观看| 精品国产精品一区二区夜夜嗨| 国产日韩一级二级三级| proumb性欧美在线观看| 国产精品嫩草影院com| 国产精品成人免费| 成人一级视频在线观看| 久久欧美一区二区| 天使萌一区二区三区免费观看| 亚洲国产中文字幕| 一区二区三区四区精品在线视频| 欧美三区免费完整视频在线观看| 日本中文字幕一区二区视频| 青青国产91久久久久久| 亚洲一区二区av在线| 日韩精品亚洲专区| 蜜桃在线一区二区三区| 国产一区二区主播在线| 国产一区免费电影| 欧美精品亚洲一区二区在线播放| 另类调教123区| 欧美xxxxx裸体时装秀| 日韩精品资源二区在线| 石原莉奈在线亚洲二区| 麻豆成人久久精品二区三区红| 亚洲国产毛片aaaaa无费看| 樱花草国产18久久久久| 午夜天堂影视香蕉久久| 日本亚洲欧美天堂免费| 另类小说一区二区三区| 国产精品99久久久久久宅男| 婷婷开心久久网| 一区二区三区四区五区视频在线观看| 国产精品少妇自拍| 中文字幕第一页久久| 日本一区二区成人| 一区二区高清在线| 樱花草国产18久久久久| 免费的国产精品| 狠狠色2019综合网| eeuss鲁一区二区三区| 欧美最猛性xxxxx直播| 在线影视一区二区三区| 在线成人免费视频| 久久精品一区二区三区不卡牛牛 | 福利一区在线观看| 奇米影视在线99精品| 亚洲一区在线电影| 久久久久久日产精品| 久久久久久久久久看片| 欧美日韩一区不卡| 99麻豆久久久国产精品免费| 国产精品综合网| jiyouzz国产精品久久| 欧美韩日一区二区三区四区| 国产农村妇女精品| 一区av在线播放| 亚洲午夜电影在线观看| 亚洲综合自拍偷拍| 亚洲欧洲另类国产综合| 久久免费电影网| 国产精品网曝门| 亚洲综合丝袜美腿| 91国内精品野花午夜精品| 久久老女人爱爱| 日本一区二区三区国色天香 | 91福利精品第一导航| 91精品欧美一区二区三区综合在| 色综合天天天天做夜夜夜夜做| 国产mv日韩mv欧美| 色一情一乱一乱一91av| 久久99国产精品尤物| 成人黄色在线网站| 欧美精品久久99久久在免费线| 日韩欧美在线一区二区三区| 国产精品每日更新| 亚洲综合区在线| 精品一区二区久久| 国产一区二区按摩在线观看| 99亚偷拍自图区亚洲| 欧美成人午夜电影| 亚洲国产成人tv| 91在线观看视频| 91 com成人网| 精品国产一区二区三区不卡| 国产精品麻豆99久久久久久| 美女视频免费一区| 色爱区综合激月婷婷| 欧美日韩国产成人在线91| 中文字幕日韩精品一区| 日韩精品五月天| 91免费国产视频网站| 久久久美女毛片| 日韩综合在线视频| 国产成人精品影视| 欧美一区二区成人| 亚洲精品水蜜桃| k8久久久一区二区三区| 久久久99久久精品欧美| 美女高潮久久久| 国产伦精品一区二区三区免费迷 | 日韩一区二区三区免费看| 欧美顶级少妇做爰| 波多野结衣中文字幕一区 | 性久久久久久久| 欧美久久一二区| 国产一区二区不卡| 欧美成人a∨高清免费观看| 亚洲免费av网站| 亚洲尤物视频在线| 青青国产91久久久久久| 欧美高清视频不卡网| 日本一二三不卡| 国产电影一区二区三区| 久久夜色精品国产噜噜av | 国产精品麻豆视频| 国产精品原创巨作av| 午夜国产不卡在线观看视频| aa级大片欧美| 久久欧美中文字幕| 国产成人免费在线视频| 欧美日韩精品电影| 日韩欧美你懂的| 激情图片小说一区| 国产清纯白嫩初高生在线观看91| 午夜精品123| 中文字幕一区二区三区精华液 | 日韩毛片精品高清免费| 一本一本大道香蕉久在线精品| 67194成人在线观看| 国产福利91精品一区二区三区| 亚洲成人免费看| 亚洲mv大片欧洲mv大片精品| 亚洲va韩国va欧美va| 国产精品资源在线| 欧美日韩中文一区| 国产免费成人在线视频| 亚洲免费成人av| 精品亚洲国产成人av制服丝袜| 奇米888四色在线精品| 国产成人免费在线| 欧美日韩日日摸| 亚洲精品视频观看| 日本三级亚洲精品| 91麻豆高清视频| 国产精品网站导航| 欧美性大战久久久久久久蜜臀| 色婷婷综合久久久久中文| 亚洲精品一区二区三区99| 亚洲免费色视频| 大胆亚洲人体视频| 久久人人97超碰com| 亚洲成人免费观看| 国产在线麻豆精品观看| 久久福利资源站| 成人黄色777网| 国产成人精品一区二区三区四区 | 欧美又粗又大又爽| 国产精品污污网站在线观看| 久草热8精品视频在线观看| 91一区二区三区在线观看| 久久伊人蜜桃av一区二区| 久久久久久久av麻豆果冻|