数组的卷积
Convolution of array
这些卷积算法有什么不同?
为什么是y=0
和y<1, x = 0; x < 1
而不是其他的y=1
和y <-1, x < - 1
。
for(int y = 0; y < grey.rows; y++)
for(int x = 0; x < grey.cols; x++)
dst.at<uchar>(y,x) = 0;
这是第二个卷积:
for(int y = 1; y < grey.rows - 1; y++){
for(int x = 1; x < grey.cols - 1; x++)
第一个循环不是真正的"卷积",因为赋值操作有一个大小为1的"内核"。第二个示例似乎使用大小为3的内核,因此它需要3个像素才能工作:prev/curr/next(这就是为什么for
循环"更短")
在前两个for循环中,代码只是初始化可能的结果数组。
在第二个循环中,卷积涉及一个卷积核为3x3,因此循环中的代码将引用从dst.at<uchar>(y-1 , x-1)
到dst.at<uchar>(y+1 , x+1)
开始的元素。
所以内核不能在边界上求值,而只是从1开始而不是0,结束于n-2而不是n-1。
相关文章:
- Mongodb c++驱动程序:如何查询元素的数组
- 将数组的地址分配给变量并删除
- 从C++本机插件更新Vector3数组
- lambda参数转换为constexpr技巧,然后获取带链接的数组
- 将数组作为参数传递给函数安全吗?作为第三方职能部门,可以探索他们想要的之外的其他元素
- 数组索引的值没有增加
- 将对象数组的引用传递给函数
- 为char数组调整zlib-zpipe
- 2D数组来自文本输入,中间有空格
- std::向量与传递值的动态数组
- 在c++中用vector填充一个简单的动态数组
- 使用strcpy将char数组的元素复制到另一个数组
- 使用指针从C++中的数组中获取最大值
- C++使用整数的压缩数组初始化对象
- 告诉一个 const char 数组,除了编译时 C 样式的字符串外,它不以 '