为什么必须使用Sobel算子?

最近我阅读了一些关于神经网络的期刊和PDF文件,并且我特别关注了一篇关于“使用神经网络进行手写识别”的文章。此外,我还在学习反向传播。我的问题是“为什么作者建议读者在将手写输入神经网络之前使用Sobel算子作为预处理技术,而不是直接处理手写输入?”


回答:

手写是由笔画组成的,通常笔画内部填充的是纯色:基于这些假设,笔画可以通过其边缘很好地描述,而其颜色或背景颜色在描述笔画时并不那么有用。边缘基本上是由布尔值来描述的:当一个像素是边缘的一部分时,它是白色的,否则是黑色的。

Sobel滤波器的输出图像的灰度级与边缘的强度成正比,因此可以用来描述边缘,从而描述笔画,或者说,“捕捉”手写字母和数字的本质。

如果直接将手写字母或数字的原始图像输入网络,网络可能会学习到一些不太有用的特征,比如完整的灰度级,这些特征并不能很好地描述字母或数字。

一些作者声称Sobel滤波器以亮度不变的方式给出边缘,尽管我认为这并不完全正确。

出于好奇,作者建议读者使用Sobel滤波器的那篇论文是哪一篇?

Related Posts

Keras Dense层输入未被展平

这是我的测试代码: from keras import…

无法将分类变量输入随机森林

我有10个分类变量和3个数值变量。我在分割后直接将它们…

如何在Keras中对每个输出应用Sigmoid函数?

这是我代码的一部分。 model = Sequenti…

如何选择类概率的最佳阈值?

我的神经网络输出是一个用于多标签分类的预测类概率表: …

在Keras中使用深度学习得到不同的结果

我按照一个教程使用Keras中的深度神经网络进行文本分…

‘MatMul’操作的输入’b’类型为float32,与参数’a’的类型float64不匹配

我写了一个简单的TensorFlow代码,但不断遇到T…

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注