- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在图像处理中,特别是在指纹识别中,我必须应用具有单位积分的二维低通滤波器。
这个单位积分是什么意思?另外,如果我选择高斯滤波器,要使用什么西格玛?
最佳答案
单位积分意味着掩码或内核的总面积应为 1。例如,3 x 3 平均滤波器意味着掩码中的每个系数都应为 1/9。当您将掩码中的所有元素相加时,它会加 1。
高斯滤波器固有的单位积分/单位面积为 1。如果您使用 MATLAB,带有 gaussian
标志的 fspecial
命令对其掩码进行归一化。
但是,如果您想自己创建高斯掩模,可以使用以下等式:
请记住,(x,y)
是掩码内相对于中心 的位置。因此,如果您有一个 5 x 5 的掩码,则在 row = 2, col = 2
、x = 0
和 y = 0
.然而,上面的等式并没有生成单位面积1。如果在整个 2D 平面上积分,理论上它等于 1。因为我们正在截断高斯函数,所以面积不是 1。因此,一旦生成了所有系数,您需要通过对掩码中的每个元素求和来确保总面积为 1。然后,您使用这个数字并将掩码中的每个元素 除以这个数字。事实上,当您生成高斯掩码时,将指数项乘以等式中的比例因子并不重要。通过确保掩码的总和等于 1,可以有效地去除水垢。您可以只使用指数项来减少一些计算。
sigma
完全取决于您。通常人们会采用 3*sigma
规则的一半宽度,因此 1D 中从左到右的总宽度为 6*sigma + 1
(包括中心)。为了弄清楚您具体想要什么 sigma,人们会弄清楚图像中最小特征 的宽度,将其设置为宽度,然后从那里算出 sigma
.例如,如果最大宽度为 13,则重新排列等式中的 sigma
会得到 2。换句话说:
13 = 6*sigma + 1
12 = 6*sigma
sigma = 2
因此,您可以将 sigma
设置为 2,并将掩码设置为 13 x 13。有关 3*sigma
规则的更多信息,请查看我的帖子关于这里的主题:By which measures should I set the size of my Gaussian filter in MATLAB?
创建该掩码后,使用您希望的任何卷积方法对图像进行高斯滤波。
如果您会使用 MATLAB,这里有另一篇文章可能会对您有所帮助。
How to make a Gaussian filter in Matlab
如果您需要使用其他语言,如 C 或 Java,则可以通过以下方式创建高斯掩模:
#define WIDTH 13
float sigma = ((float)WIDTH - 1.0f) / 6.0f;
int half_width = (int)(WIDTH / 2.0);
float mask[WIDTH][WIDTH];
float scale = 0.0f;
for (int i = -half_width; i <= half_width; i++) {
for(int j = -half_width; j <= half_width; j++) {
mask[i+half_width][j+half_width] = expf( -((float)(i*i + j*j) / (2.0*sigma*sigma)) );
scale += mask[i+half_width][j+half_width];
}
}
for (int i = 0; i < WIDTH; i++)
for (int j = 0; j < WIDTH; j++)
mask[i][j] /= scale;
int WIDTH = 13;
float sigma = ((float)WIDTH - 1.0f) / 6.0f);
int half_width = Math.floor((float)WIDTH / 2.0f);
float[][] mask = new float[WIDTH][WIDTH];
float scale = 0.0f;
for (int i = -half_width; i <= half_width; i++) {
for (int j = -half_width; j <= half_width; j++) {
mask[i+half_width][j+half_width] = (float) Math.exp( -((double)(i*i + j*j) / (2.0*sigma*sigma)) );
scale += mask[i+half_width][j+half_width];
}
}
for (int i = 0; i < WIDTH; i++)
for (int j = 0; j < WIDTH; j++)
mask[i][j] /= scale;
如前所述,请注意,在代码中我不必除以 2*pi*sigma^2
。同样,原因是当您对内核进行归一化时,这个常数因子无论如何都会被抵消,因此在计算掩码系数时不需要添加任何额外的开销。
关于image - 具有单位积分的低通滤波器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22885476/
我有 2 张 table ; item_in(item_id,unit) item_out(item_id,unit) 现在假设我想知道为每个项目插入了多少个单元,我只是查询 select sum(u
API 浏览器中有 3 个速率限制类别: 如果我使用 Youtube 数据 API(其中跟随 implicit OAuth grant flow)创建客户端 Web 应用程序,我是否仍被限制为总共 1
我正在使用一个 postgresql 表,该表包含许多带有 GEOMETRY(Point, 4326) 的行。使用 ST_SnapToGrid 函数和 DISTINCT 选择,我只根据显示的 map
我对 C++ 和 Cppunit 都很陌生。我正在尝试编译一个小的 cppunit 测试。但是,我没有成功。 qwerty@qwerty:~/chessgame/src$ g++ -Wall Coor
我注意到 REM 单位可用于元素的大小,而不仅仅是字体大小。并且对 HTML 字体大小属性非常有用。 html { font-size:1vw } @media all and (max-width:
我试图在 Shapely 中找到线串的长度(以米为单位),但似乎无法达到预期的结果。几乎可以肯定我在坐标系方面犯了一些错误,但我无法弄清楚。 这是单行的一些简化代码: from shapely.geo
对于大量的物种数据集,我试图计算给定月份集的圆形平均值,例如对于从 3 月到 7 月开花的物种,我想知道开花的平均月份(即 5 月),以及围绕平均值的方差。 给定月份是循环的,因此 12 月到 2 月
我还应该在单元测试中释放对象吗? 我注意到在Apple的“iPhoneUnitTests”示例项目中,设置方法中的对象是[[object alloc] init],但从未在单元测试中的任何地方发布?
我目前正在使用 OpenGL 进行开发,并使用米作为我自己的单位,即 20 厘米宽的三角形为 0.2。然而 OpenGL 似乎对这些数字进行了舍入,最终的形状并不完全符合我的意愿。这在 OpenGL
我的问题与对信号进行频谱分析或将信号放入 FFT 并使用合适的数值包解释结果的物理意义有关, 具体: 获取一个信号,例如时变电压 v(t) 将其放入 FFT 中(您将得到复数序列) 现在取模 (abs
在深入研究代码后,我意识到 Fabricjs Text 对象的 fontSize 是在 PIXELS 中测量的。在我的项目中,有时我需要使用点而不是像素。 当指定单位时,我只在代码中找到一个位置,此片
在我的应用程序中,我尝试使用,RentModel.find({prop_location : { $near : [msg.lat, msg.lng],$maxDistance : 500}},函数(
我正在开发我的第一个 LibGdx (Scene2d + Box2d) 游戏,这对我来说是一个全新的领域,但仍然对一些事情感到有点困惑,尤其是关于单位。已经看到了几种不同的处理方法,但仍然不确定哪种方
我正在寻找一个 MySQL 查询(子查询很好),它将以下列格式获取过去一年中每个订单的单位分布: units_per_order | number_of_orders |
我正在使用 Highcharts生成折线图。 我遇到了 numberFormat 的问题: var test = 15975000; numberFormat(test, 0,',','.'); 结果
我正在尝试创建一些用户定义的类型来表示单位,以便我可以强类型化函数参数。例如,长度为毫米,速度为毫米每秒,加速度为毫米每秒等。 到目前为止我已经这样做了: template struct Value
谁能解释一下最低精度的 ULP 单位?我有如下定义,但还是不清楚 “表示分数时的误差大小与存储的数字大小成正比。ULP 或最小精度单位定义了存储数字时可以获得的最大误差。存储的数字越大,ULP 越大”
我有一张卡片图像,我需要重复它 30 次,每次我想申请一张特定卡片的左侧位置时,它会与卡片重叠,然后再停留在一副牌的位置上。 问题是,当我将左侧位置应用于图像卡片时,它会将相同的左侧位置应用于所有卡片
有没有办法用php代码更改每个滚动条的大小。 说明:当我向下滚动时,它会下降x(50~)像素,我想将x改为20。 编辑:这是我的代码。。。 Excel "; $i=1; wh
我不知道下面的想法是否可行或不能概括它,但我想将每个计算值四舍五入到 100 单位四舍五入。 例子: double x; int x_final; ... if (x<400) x_final=400
我是一名优秀的程序员,十分优秀!