- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是图像处理新手,正在尝试编写一种用于腐 eclipse 和膨胀的自定义方法。然后我尝试将我的结果与 OpenCV 腐 eclipse 和膨胀函数结果进行比较。我对输入图像进行一处零填充,然后将内核与填充图像重叠。这是我的功能:
import numpy as np
import matplotlib.pyplot as plt
def operation(image, kernel, padding=0, operation=None):
if operation:
img_operated = image.copy() #this will be the image
"""
The add_padding function below will simply add padding to the image, so the new array with one padding will
look like ->
[[0,0,0,0,0,0,0,0],
[0,0,0,1,1,1,1,0],
[0,0,0,1,1,1,1,0],
[0,1,1,1,1,1,1,0],
[0,1,1,1,1,1,1,0],
[0,1,1,1,1,0,0,0],
[0,1,1,1,1,0,0,0],
[0,0,0,0,0,0,0,0]]
)
"""
image = add_padding(image, padding)
print("Image is \n", image)
print("kernel is \n",kernel)
print("="*40)
vertical_window = padded.shape[0] - kernel.shape[0] #final vertical window position
horizontal_window = padded.shape[1] - kernel.shape[1] #final horizontal window position
print("Vertical Window limit: {}".format(vertical_window))
print("Horizontal Window limit: {}".format(horizontal_window))
print("="*40)
#start with vertical window at 0 position
vertical_pos = 0
values = kernel.flatten() #to compare with values with overlapping element for erosion
#sliding the window vertically
while vertical_pos <= (vertical_window):
horizontal_pos = 0
#sliding the window horizontally
while horizontal_pos <= (horizontal_window):
dilation_flag = False
erosion_flag = False
index_position = 0
#gives the index position of the box
for i in range(vertical_pos, vertical_pos+kernel.shape[0]):
for j in range(horizontal_pos, horizontal_pos+kernel.shape[0]):
#First Case
if operation == "erosion":
if padded[i,j] == values[index_position]:
erosion_flag = True
index_position += 1
else:
erosion_flag = False
break
#Second Case
elif operation == "dilation":
#if we find 1, then break the second loop
if padded[i][j] == 1:
dilation_flag = True
break
else:
return "Operation not understood!"
#if opertion is erosion and there is no match found, break the first 'for' loop
if opr == "erosion" and erosion_flag is False:
break
#if operation is dilation and we find a match, then break the first 'for' loop
if opr == "dilation" and dilation_flag is True:
img_operated[vertical_pos, horizontal_pos] = 1
break
#Check whether erosion flag is true after iterating over one complete overlap
if operation == "erosion" and erosion_flag is True:
img_operated[vertical_pos, horizontal_pos] = 1
elif operation == "erosion" and erosion_flag is False:
img_operated[vertical_pos, horizontal_pos] = 0
#increase the horizontal window position
horizontal_pos += 1
#increase the vertical window position
vertical_pos += 1
return img_operated
return "Operation Required!"
array = np.array([[0,0,1,1,1,1],
[0,0,1,1,1,1],
[1,1,1,1,1,1],
[1,1,1,1,1,1],
[1,1,1,1,0,0],
[1,1,1,1,0,0]], dtype=np.uint8)
kernel = np.array ([[0, 1, 0],
[1, 1, 1],
[0, 1, 0]], dtype = np.uint8)
#image will be padded with one zeros around
result_erosion = operation(array, kernel, 1, "erosion")
result_dilation = operation(array, kernel, 1, "dilation")
#CV2 Erosion and Dilation
cv2_erosion = cv2.erode(array, kernel, iterations=1)
cv2_dilation = cv2.dilate(array, kernel, iterations=1)
膨胀结果匹配,但腐 eclipse 结果不匹配。我不知道为什么会这样。是因为某些填充问题吗? OpenCV 是否填充图像?或者我错误地实现了侵 eclipse 方法?这是结果的图像:
最佳答案
您的代码存在两个问题:
您没有检查内核的值。对于膨胀来说,这并不重要,但您会看到不同输入图像的差异。
侵 eclipse 很困惑。正如我在评论中提到的,侵 eclipse 是扩张的完全逻辑逆。您可以将腐 eclipse 视为背景的膨胀:erosion(image) == ~dilation(~image)
(~
是图像的逻辑否定)。因此,您应该能够使用与膨胀完全相同的代码和逻辑来进行侵 eclipse ,但检查是否在内核中看到背景像素 (0),在这种情况下,您将输出中的该像素设置为背景 (0)。要复制 OpenCV 侵 eclipse 的结果,填充必须与前景 (1) 一起使用。
这是更正后的代码。我使用 OpenCV 编写了一个 add_padding 函数,因为它在 OP 中丢失了。代码可以显着简化,例如通过对两个操作使用单个标志;通过在函数顶部仅检查一次操作字符串,并设置一个变量,该变量的值是 0 或 1,以便在比较输入和修改输出时使用;并使用 for 循环而不是 while 循环来迭代图像。我会将这些更改留给感兴趣的读者。
import numpy as np
import matplotlib.pyplot as plt
import cv2
def add_padding(image, padding, value):
return cv2.copyMakeBorder(image, padding, padding, padding, padding, cv2.BORDER_CONSTANT, value=value)
def operation(image, kernel, padding=0, operation=None):
if operation:
img_operated = image.copy() #this will be the image
padding_value = 0 # <<< ADDED
if operation == "erosion": # <<< ADDED
padding_value = 1 # <<< ADDED
padded = add_padding(image, padding, padding_value) # <<< MODIFIED
vertical_window = padded.shape[0] - kernel.shape[0] #final vertical window position
horizontal_window = padded.shape[1] - kernel.shape[1] #final horizontal window position
#start with vertical window at 0 position
vertical_pos = 0
#sliding the window vertically
while vertical_pos <= vertical_window:
horizontal_pos = 0
#sliding the window horizontally
while horizontal_pos <= horizontal_window:
dilation_flag = False
erosion_flag = False
#gives the index position of the box
for i in range(kernel.shape[0]): # <<< MODIFIED
for j in range(kernel.shape[1]): # <<< MODIFIED
if kernel[i][j] == 1: # <<< ADDED
#First Case
if operation == "erosion":
#if we find 0, then break the second loop
if padded[vertical_pos+i][horizontal_pos+j] == 0: # <<< MODIFIED
erosion_flag = True # <<< MODIFIED
break
#Second Case
elif operation == "dilation":
#if we find 1, then break the second loop
if padded[vertical_pos+i][horizontal_pos+j] == 1: # <<< MODIFIED
dilation_flag = True
break
else:
return "Operation not understood!"
#if opertion is erosion and there is no match found, break the first 'for' loop
if operation == "erosion" and erosion_flag: # <<< MODIFIED
img_operated[vertical_pos, horizontal_pos] = 0 # <<< ADDED
break
#if operation is dilation and we find a match, then break the first 'for' loop
if operation == "dilation" and dilation_flag: # <<< FIXED
img_operated[vertical_pos, horizontal_pos] = 1
break
# !!! Removed unnecessary checks here
#increase the horizontal window position
horizontal_pos += 1
#increase the vertical window position
vertical_pos += 1
return img_operated
return "Operation Required!"
array = np.array([[0,0,1,1,1,1],
[0,0,1,1,1,1],
[1,1,1,1,1,1],
[1,1,1,1,1,1],
[1,1,1,1,0,0],
[1,1,1,1,0,0]], dtype=np.uint8)
kernel = np.array ([[0, 1, 0],
[1, 1, 1],
[0, 1, 0]], dtype = np.uint8)
#image will be padded with one zeros around
result_erosion = operation(array, kernel, 1, "erosion")
result_dilation = operation(array, kernel, 1, "dilation")
#CV2 Erosion and Dilation
cv2_erosion = cv2.erode(array, kernel, iterations=1)
cv2_dilation = cv2.dilate(array, kernel, iterations=1)
关于python - 自定义腐 eclipse 结果与 OpenCV 腐 eclipse 不匹配,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59012906/
好的,所以我编辑了以下... 只需将以下内容放入我的 custom.css #rt-utility .rt-block {CODE HERE} 但是当我尝试改变... 与 #rt-sideslid
在表格 View 中,我有一个自定义单元格(在界面生成器中高度为 500)。在该单元格中,我有一个 Collection View ,我按 (10,10,10,10) 固定到边缘。但是在 tablev
对于我的无能,我很抱歉,但总的来说,我对 Cocoa、Swift 和面向对象编程还很陌生。我的主要来源是《Cocoa Programming for OS X》(第 5 版),以及 Apple 的充满
我正在使用 meta-tegra 为我的 NVIDIA Jetson Nano 构建自定义图像。我需要 PyTorch,但没有它的配方。我在设备上构建了 PyTorch,并将其打包到设备上的轮子中。现
在 jquery 中使用 $.POST 和 $.GET 时,有没有办法将自定义变量添加到 URL 并发送它们?我尝试了以下方法: $.ajax({type:"POST", url:"file.php?
Traefik 已经默认实现了很多中间件,可以满足大部分我们日常的需求,但是在实际工作中,用户仍然还是有自定义中间件的需求,为解决这个问题,官方推出了一个 Traefik Pilot[1] 的功
我想让我的 CustomTextInputLayout 将 Widget.MaterialComponents.TextInputLayout.OutlinedBox 作为默认样式,无需在 XML 中
我在 ~/.emacs 中有以下自定义函数: (defun xi-rgrep (term) (grep-compute-defaults) (interactive "sSearch Te
我有下表: 考虑到每个月的权重,我的目标是在 5 个月内分散 10,000 个单位。与 10,000 相邻的行是我最好的尝试(我在这上面花了几个小时)。黄色是我所追求的。 我试图用来计算的逻辑如下:计
我的表单中有一个字段,它是文件类型。当用户点击保存图标时,我想自然地将文件上传到服务器并将文件名保存在数据库中。我尝试通过回显文件名来测试它,但它似乎不起作用。另外,如何将文件名添加到数据库中?是在模
我有一个 python 脚本来发送电子邮件,它工作得很好,但问题是当我检查我的电子邮件收件箱时。 我希望该用户名是自定义用户名,而不是整个电子邮件地址。 最佳答案 发件人地址应该使用的格式是: You
我想减小 ggcorrplot 中标记的大小,并减少文本和绘图之间的空间。 library(ggcorrplot) data(mtcars) corr <- round(cor(mtcars), 1)
GTK+ noob 问题在这里: 是否可以自定义 GtkFileChooserButton 或 GtkFileChooserDialog 以删除“位置”部分(左侧)和顶部的“位置”输入框? 我实际上要
我正在尝试在主页上使用 ajax 在 magento 中使用 ajax 显示流行的产品列表,我可以为 5 或“N”个产品执行此操作,但我想要的是将分页工具栏与结果集一起添加. 这是我添加的以显示流行产
我正在尝试使用 PasswordResetForm 内置函数。 由于我想要自定义表单字段,因此我编写了自己的表单: class FpasswordForm(PasswordResetForm):
据我了解,新的 Angular 7 提供了拖放功能。我搜索了有关 DnD 的 Tree 组件,但没有找到与树相关的内容。 我在 Stackblitz 上找到的一个工作示例.对比drag'ndrop功能
我必须开发一个自定义选项卡控件并决定使用 WPF/XAML 创建它,因为我无论如何都打算学习它。完成后应该是这样的: 到目前为止,我取得了很好的进展,但还有两个问题: 只有第一个/最后一个标签项应该有
我要定制xtable用于导出到 LaTeX。我知道有些问题是关于 xtable在这里,但我找不到我要找的具体东西。 以下是我的表的外观示例: my.table <- data.frame(Specif
用ejs在这里显示日期 它给我结果 Tue Feb 02 2016 16:02:24 GMT+0530 (IST) 但是我需要表现为 19th January, 2016 如何在ejs中执行此操作?
我想问在 JavaFX 中使用自定义对象制作 ListView 的最佳方法,我想要一个每个项目如下所示的列表: 我搜了一下,发现大部分人都是用细胞工厂的方法来做的。有没有其他办法?例如使用客户 fxm
我是一名优秀的程序员,十分优秀!