首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Swift MPSCNNConvolution --权重都设置为1,输出不应该像输入一样吗?

Swift MPSCNNConvolution --权重都设置为1,输出不应该像输入一样吗?
EN

Stack Overflow用户
提问于 2021-02-05 04:52:22
回答 1查看 35关注 0票数 0

试图找出如何使用MPSCNNConvolution。我有一个4x3图像和一个4x3内核。我把所有的权重设为1,把所有的输入设为1,这样我就可以得到所有的1。我得到的反而是

代码语言:javascript
运行
复制
12  9  6  3
 8  6  4  2
 4  3  2  1

问题是我不知道它是否应该这样做。我已经翻遍了所有我能找到的苹果文档,每一篇在线文章,每一个github回购,我找不到任何东西可以说明当这个层被正确设置时会期望什么样的输出。

这种模式适用于不同大小的图像。3x2给了我

代码语言:javascript
运行
复制
6 4 2
3 2 1

一个2x2给了我

代码语言:javascript
运行
复制
4 2
2 1

我已经将我的“最小”示例推到了github上。不是很小。Xcode 12.4不再支持Float16,因此有在Float16和Float32之间浮动的实用代码,再加上所有卷积的复杂设置,还有更多的代码用于尝试不安全指针。

我的具体问题是:这是MPSCNNConvolution的“正常行为”吗?这个函数/算法有名字吗?我能查到什么吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-03-16 20:05:55

MPSCNNConvolution的文档有点混乱。对于不熟悉的人来说,MPSCNNConvolution似乎是一种容纳卷积核的容器。事实并非如此。MPSCNNConvolution 本身就是一个内核。具体来说,它对内核窗口下的所有输入值进行加权和求和。只是一个直接的和,没有平均或最大。您所看到的结果是内核从(0,0)开始,然后从右边缘滑出,最后从底部边缘滑出。

在输入图像上设置内核偏移量和剪辑矩形,MPSCNNConvolution将与MPSCNNPooling*内核和所有其他内核一样工作。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/66057742

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档