- 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/
我想在文件系统上手动创建文件夹/文件,以便在 eclipse 的工作区中创建新项目,并在启动 eclipse 并选择工作区时显示在项目资源管理器中。 执行此操作需要创建哪些文件,它们需要位于何处? 请
我正在关注these instructions ,但在运行 mvn eclipse:eclipse 等命令时遇到问题。 我应该如何以及在哪里运行该命令? 我的设置: Windows 7 32 位 面向
是否有任何命令可以在不实际启动 eclipse 的情况下创建 eclipse 工作区?我希望该命令成为脚本的一部分。创建工作区后,将对其进行配置(例如文本编码),然后用于将项目导入到 RTC。我知道下
我想为 Eclipse 插件创建一个自动安装程序(即不通过“更新管理器”)。我的场景很简单:用户关闭 Eclipse,将下载的 JAR 放入 dropins 文件夹,启动 Eclipse,其余的过程是
每当我们想要使用现有源位置创建 Eclipse 项目时,我们将选择现有源位置(根)作为项目位置。 Eclipse 将在该源的根目录中创建所有项目特定文件。 现在,出于某种原因,如果我们想用不同的设置重
可能被问过多次; 有没有办法从控制台(Linux 或 Windows)刷新 Eclipse 工作区文件夹。 我知道有 Ant 任务可以做到这一点。但很想知道是否有命令行技巧。 最佳答案 不,您能做的最
我说的是工具栏上的小图标。 网络上似乎没有任何这样的问题,它们都指的是 android 或自定义应用程序,而不是与 eclipse 捆绑在一起的图标。 我想知道是否有人尝试过这个,或者可以告诉我它不值
如何使用 Eclipse 比较两个文件? (目前我正在使用 WinMerge 。) 最佳答案 要在 Eclipse 中比较两个文件,请首先在 Project Explorer/Package Expl
我正在尝试将我在一个带有数据库的 Eclipse JEE6 项目中所做的所有工作转移到另一个 Eclipse 程序。我知道我将不得不重新配置很多并重建很多库文件,但是尽可能多地传输的最简单方法是什么?
在 Eclipse 中加载我的工作台并启用 TFS 插件时,它挂起。与此类似: http://social.msdn.microsoft.com/Forums/vstudio/en-US/85c1d3
Eclipse 可以通过插件包含许多不同的功能集。您是否在一个 Eclipse 中安装所有插件?或者您是否从 spring 安装 STS,从 adobe 安装 Flex eclipse,甚至从 ecl
我错误地单击了“在 Eclipse 首选项中将目标运行标记为忽略在 Eclipse 构建中(实验)”: 在哪里/如何撤消此操作? 最佳答案 m2e 使用文件 YOUR_WORKSPACE/.metad
我是 Maven 新手。我尝试执行 >mvn eclipse:eclipse -Dwtpversion=2.0。但我收到以下错误: D:\test\CounterWebApp>mvn eclips
当我运行多个 Eclipse 实例时,操作系统不断请求上述权限。 我已经授予了该权限,并且我尝试了多次禁用和启用该权限。 我正在使用, macOS Catalina(版本:10.15.3 (19D76
我有一个 Maven 项目,其中我在项目构建期间使用 wsimport 作为目标来使用 Web 服务。 org.codehaus.mojo
当尝试使用 eclipse 新软件功能安装 eclipse 时,出现此错误: Cannot complete the install because one or more required item
我已经下载了整个 Eclipse Helios/Indigo 版本的源代码。现在我想对它进行一些修改等等。所以我导入了整个源代码,但现在我在编译时遇到了 n 个错误。此外,我正在尝试 RunAs> 插
我已经安装了 eclipse Oxygen 并且正在尝试连接到 Eclipse 市场,以安装插件,它给出了以下异常 - org.eclipse.equinox.p2.core.ProvisionExc
我的 IDE 中安装了来自 Sonatype 的 m2Eclipse 插件。它允许我通过右键单击 pom.xml 文件并导航到“运行方式”菜单来运行各种 Maven 命令(打包、安装等)。 但是,我还
我在 Windows7 64 位上运行 Maven 3 时遇到问题。当我执行maven eclipse:eclipse(我使用maven-eclipse-plugin 2.8)时,maven不会创建任
我是一名优秀的程序员,十分优秀!