- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想知道如何比较轮廓的两条路径是否重叠,是否相似。
更具体地说,我有一组 n 实现,每个实现都有其轮廓级别。我需要在 l 级别验证每个轮廓的稳定性。为此,我必须计算它在整体中发生了多少次。
到目前为止,我正在处理这段代码:
def iso_contours(scalar_fields):
#TODO : access the paths by level (0, 1, 2 ...)
default = 0
contours = {}
contours_number = 0
for scalar_field in scalar_fields:
cs = plt.contour(scalar_field)
for collection in cs.collections:
paths = collection.get_paths()
for path in paths:
num = contours.get(path, default)
contours[path] = num + 1
contours_number += 1
contours.update((x, y/float(contours_number)) for x, y in contours.items())
return contours
然而,即使有两条相同的路径,它们也被视为不同。
所以,我想知道如何在给定两条路径的情况下确定它们在视觉上是否相似。正如@unutbu 提醒我的那样,我不能只比较顶点,因为顶点可能以不同的顺序出现,或者一条路径中可能有 1000 个顶点,而另一条路径中可能有 100 个顶点......
最佳答案
首先,我在这里假设您知道您的等高线是按相同的比例绘制的并且没有平移,所以这与其说是图像匹配的问题,不如说是试图找出两个笨拙形状之间的差异。
有几种方法可以做到这一点,这两种方法应该会产生大致相同的结果。最准确的方法是取两条曲线之间的内积,但这需要曲线对齐并描述为相同的分辨率。例如,这可以使用插值来完成,但这是一个很大的麻烦。
我在这里尝试的方法是一个捷径,但它应该给出一个合理的估计,即绘制两条曲线之间的面积并从图中求和这个面积。面积越小,曲线越相似。 (也就是说,总而言之,对于曲线,您将使用内积,对于图像,您将使用差异区域)。
例如,从这些轮廓开始:
我们以这个情节结束,不同之处在于标题中的总和:
这是代码(它有点复杂,因为我不认为有一种方法可以简单地在两个任意参数化曲线之间进行填充,所以我取而代之的是从每个填充的单个轮廓制作图像,然后将它们相减):
import matplotlib.pyplot as plt
import matplotlib.mlab as mlab
import matplotlib.cm as cm
import numpy as np
import io
import Image
xmin, xmax, ymin, ymax = -3, 6, -2, 3
delta = 0.025
x = np.arange(xmin, xmax, delta)
y = np.arange(ymin, ymax, delta)
X, Y = np.meshgrid(x, y)
Z1 = mlab.bivariate_normal(X, Y, 1.0, 1.0, 0.0, 0.0)
Z2 = mlab.bivariate_normal(X, Y, 1.5, 0.5, 1, 1)
def f(a, b):
return 10.*(a*Z2 - b*Z1)
def fill_contour(cs):
v = cs.collections[0].get_paths()[0].vertices
fig = plt.figure()
ax = fig.add_subplot(111)
ax.fill(v[:,0], v[:,1], 'k')
ax.set_xlim(xmin, xmax)
ax.set_ylim(ymin, ymax)
buf = io.BytesIO()
fig.savefig(buf, format = 'png')
buf.seek(0)
im = Image.open(buf).convert('L')
r = np.asarray(im).astype(np.int)
r/=max(r.flat)
return r
figc = plt.figure()
axc = figc.add_subplot(111)
c0 = .07
cs1 = axc.contour(X, Y, f(.6 ,.7), [c0], colors='r')
cs2 = axc.contour(X, Y, f(.8, 1.2), [c0], colors='g')
figd = plt.figure()
axd = figd.add_subplot(111)
d1 = fill_contour(cs1)
d2 = fill_contour(cs2)
d = abs(d1-d2)
im = axd.imshow(d, cmap=cm.gray)
figd.colorbar(im)
axd.set_title( "sum = %i" % np.sum(d.flat))
figc.show()
figd.show()
关于python - 如何比较两条轮廓路径在视觉上是否相似 - Python/Matplotlib,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25994856/
当我尝试以非整数的步长(例如,每帧 0.5 像素)在屏幕上移动图形对象时,这会导致移动不稳定和“滞后”;因为对象只会每两帧移动 1 个像素。 我理解为什么会发生这种情况,因为对象的 x/y 值必须是整
市面上有大量的家谱应用程序,但出于某种原因,我找不到一个示例来说明如何为 Android 应用程序创建一个。我是否使用 Canvas ,是否有图表库? 我的基本要求是画一个三层的树(节点)图/图表,其
[ {name: 'John'}, {name: 'Plasmody'}, {name: 'Kugelschreiber'}, {name: 'Sarrah'}, ] 如果我在 J并做
我试图定位所有没有 www 的链接。在数据库中。 https://launchhousing.org.au 并替换为 https://www.launchhousing.org.au 我使用了“搜索和
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 想改进这个问题?将问题更新为 on-topic对于堆栈溢出。 6年前关闭。 Improve this qu
我需要排除具有以下模式的文件: ProjectFoo.Data[0-9]{14}.lgp 如何将 RegEx 用于 (Visual)SVN 忽略列表? 最佳答案 subversion 忽略列表不支持正
我正在寻找在处理中创建该项目的方法,但是,我发现该术语有点困难。我不确定如何调用在整个歌曲中线条永久保持的效果来“绘制”音乐数据。 对于我可以查看哪些教程或某人的回答,我将不胜感激。 我的目标是创建尽
我正在尝试为 android 制作游戏。我目前已将所有美术资源加载到 drawables 文件夹中,但我的问题是如何实际引用特定资源来渲染它? 我知道每个文件都有一个唯一的@id,我可能必须在onDr
Closed. This question is off-topic。它当前不接受答案。
只是一个简单的问题。 有一个简单的可视化工具可以生成iOS/QuartzCore的源代码吗? 例如,我会制作一个带有路径和a的CAKeyframeAnimation(例如CGPathMoveToPoi
编辑 3:我想这已经解决了。我刚刚启用了古腾堡编辑器并发现了它的“经典编辑器”部分,即代码编辑器。我唯一需要习惯的是我无法轻易修改的编辑器行高,这还不错。这对我有用,它超过了修改 functions.
我想在具有背景 slider 的可视 Composer 行内创建一个下拉菜单,最重要的是我要切换的链接。我在编辑自定义 css 时面临的问题是链接没有设置为 bottom:0;已设置position:
我正在学习 C++,并且了解一点 Visual Basic 和 Delphi。 但我想知道,有没有像 Delphi 这样的程序,但适用于 C++。您可以将按钮拖到窗体上,双击它,就像在 Delphi
我正在努力使用 pygame 初始化 OpenGL 显示。和pyopengl . import pygame pygame.init() pygame.display.set_mode((1920,
不确定我做错了什么。我创建了一个主题,除了我在可视化编辑器中创建帖子外,一切都很好。对我来说,这很好,但大多数用户不了解 HTML,因此无法真正进入并编辑代码。 在元素检查器(Chrome)中,文章是
我正在编写一个 C# 程序,它接受一堆参数并对数据点进行一些转换,然后将它们绘制到屏幕上。 在我的一个表单上,我有一堆文本框,我都想执行相同的 KeyPress 事件。在我只做一个 switch 语句
我正在创建 UML 事件图,我需要使用发送和接受信号,但我似乎找不到它。我试图用谷歌搜索它,但我似乎找不到任何东西。有谁知道我在哪里可以找到它们,或者它们在 Visio 中不存在? 最佳答案 想知道为
是 Haskell for Visual Studio 2005兼容VS2008 SP1 ? 最佳答案 您最初问题的答案是否定的。visual haskell 的代码是用 Haskell 编写的,并通
我正在使用 Visual Composer 开发我的 WordPress 网站。 我需要包含一个可分页的容器,但如果它可以像幻灯片一样就更好了。 This is my pageable contain
有哪些 Web 应用程序可以让我直观地(通过单击)使用任何 REST API 并生成一些代码(以任何语言)来捕捉我所描述的视觉内容? 与 Swagger 或 Google API Playground
我是一名优秀的程序员,十分优秀!