- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我试图自己实现直方图均衡功能,但没有得到所需的输出图像。
import numpy as np
import cv2
import matplotlib.pyplot as plt
import math
%matplotlib inline
def freq(lst):
d = {}
for i in lst:
for j in i:
if d.get(j):
d[j] += 1
else:
d[j] = 1
return d
def probability(d,total_pixels):
l = {}
for i in range(256):
value = d.get(i)
if value != None:
l[i] = value/total_pixels
return l
def equalizer(d, l):
f_dic = {}
last_sum = 0
for i in range(l):
if d.get(i):
prob = d.get(i)
last_sum = last_sum+((l-1)*prob)
f_dic[i] = math.floor(last_sum)
return f_dic
def replace_values(f_dic, img):
print(f_dic)
for i in range(len(img)):
for j in range(len(img)):
vv = f_dic.get(img[i][j])
if vv != None:
img[i][j] = vv
return img
def histogramEqualization(img):
img = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
freqq = freq(img)
area = img.shape
total_pixels = area[0]*area[1]
prob = probability(freqq, total_pixels)
f_dic = equalizer(prob,len(img))
new_img = replace_values(f_dic,img)
return new_img
pollen_dark = cv2.imread("/home/ahmed/Downloads/dip/DIP_A1_Fall2019/pollen_dark.tif")
new = histogramEqualization(pollen_dark)
plt.imshow(new, cmap='gray')
最佳答案
使用NumPy进行此操作的一种方法是使用np.unique()
查找要修改的值及其概率分布函数(pdf),该函数基本上是直方图。根据从pdf上np.cumsum()
获得的累积分布函数(cdf),可使用以下公式生成相应的归一化值:round((cdf - min_cdf) / (num_voxels - min_cdf) * (depth - 1))
整个概念(以及公式)在Wikipedia中得到了很好的图示说明。
与循环遍历数组相比,这通常是一种更干净的方法:
DEPTH = 2 ** 8
def hist_equalization(arr, depth=DEPTH):
vals, pdf = np.unique(arr, return_counts=True)
cdf = np.cumsum(pdf)
min_cdf = min(cdf)
new_vals = (
np.round((cdf - min_cdf) / (arr.size - min_cdf) * (depth - 1))
.astype(int))
result = np.empty_like(arr)
for i, val in enumerate(vals):
result[np.nonzero(arr == val)] = new_vals[i]
return result
plt.imshow(arr, cmap='gray', vmin=0, vmax=DEPTH - 1)
plt.imshow(hist_equalization(arr), cmap='gray', vmin=0, vmax=DEPTH - 1)
PIL
而不是
cv
进行I / O,但这与问题无关。)
equalizer()
本质上是错误的。
equalizer()
版本替换为:
def equalizer(pdf, l, depth=2 ** 8):
min_cdf = pdf[min(pdf)]
result = {}
accumulator = 0
for k, v in sorted(pdf.items()):
accumulator += v
result[k] = int(round((accumulator - min_cdf) / (l - min_cdf) * (depth - 1)))
return result
f_dic = equalizer(freqq, total_pixels)
probability()
完全没有必要,您确实需要
total_pixels
(或
img.size
),因为应用于N维数组的
len(img)
将沿第0维给出长度
,而不是像素总数。关于python - 直方图均衡:未获得所需的输出图像,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58433683/
我有一个依赖于包 B 的包 A。当包 A 中的代码运行并访问包 B 中的类时,包 B 的状态将被解析 (4),而不是 Activity (32) 和包 B 的激活器也没跑好。我认为 bundle B
这个问题在这里已经有了答案: How to remove the space between inline/inline-block elements? (41 个回答) 关闭 7 年前。
我正在尝试使用 Java OpenAL 库。我在导入名为 libsoft_oal.so 的 native 库时遇到问题。 Java OpenAL 依赖于 OpenAL 软实现。我尝试根据他们在 git
我正在尝试启动我的应用程序。是一个 unicorn +工头+sinatra的应用。 这是我的 config.ru 文件: require "rubygems" require "sinatra" Bu
我有一个下拉列表,其中包含一些从数据库表中检索的值,我想要的是当单击按钮时它应该只获得选项标签的中间值,但只有那些类名为“get_this”的选项标签并离开那些选项,如果他们没有这个类 预期输出:值
我有一个index.php文件,需要一个通用的head.php文件,head.php文件中有几个Javascript文件,当这样尝试时,代码在源代码中看起来很好,但文件却不是实际上对文档做任何事情。
有人能帮帮我吗? 我已经像这样运行了 imsmod: $ insmod /data/mm/mmdev.ko epoll_rate=100 但是我得到一个错误: insmod: init_module
是否有键盘快捷键或插件可以在 Notepad++ 中打开 PHP 所需或包含的文件?我知道,在 Dreamweaver 中,执行此操作的命令是 Ctrl+D,但我似乎无法在 Notepad++ 中找到
我已经用 js 设置了一个显示/隐藏 div,但我很难弄清楚如何一次显示一个 div。目前发生的情况是,除非我再次单击原始链接来关闭该 div,否则每个 div 都会显示。 http://www.li
当我尝试将未分配的辅助分片分配给节点时出现错误。 { "error": { "root_cause": [ { "type": "remote_transpor
我正在构建一个 C++ 应用程序,使用 Netbeans 6.9 作为我的 IDE。我有一个 C++ 库,它是一个纯 C 库的包装器。 我已将文件正确添加到项目中(使用添加库文件选项)。这是 g++
我是一名优秀的程序员,十分优秀!