- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在 MXNet 中编写 C++ 自定义运算符,但无法找到有关何时在运算符调用中设置 kAddTo
的文档。作为一个最小的例子,假设我的新运算符称为 foo()
,我想执行以下计算:
A = mx.sym.Variable('A')
B = mx.sym.Variable('B')
T = mx.sym.foo(A)
T += mx.sym.foo(B)
一般来说,我如何确保上面的第四行累积到 T 中,而不是为 mx.sym.foo(B)
的结果创建一个新的临时存储然后执行 T = T + temp
计算?
(使用 Kernighan-Ritchie 调试器,又名打印语句,我发现 kWriteTo
在第三行和第四行都设置了。枚举 kAddTo
永远不会设置。)
关于我的具体问题的更多细节:在我当前的实现中,foo()
清零 输出内存,然后执行计算并用适当的值填充它。我绝对只想在创建新输出位置时执行此清零,而不是在累积到现有位置时。
更新
离线,同事建议使用
mx.sym.elemwise_add(lhs=T, rhs=mx.sym.foo(B), out=T)
代替上面的第 4 行。但是,我仍然看到 kWriteTo
在两行计算中都被设置了。然后我收到了以下回复:
“Memory planning and inplace operations are automatic. It will be done automatically. Users don’t need to worry about it.”, which probably means that
req[0]
is not an accurate indicator in this case. If you want to verify whether it’s an inplace addTo, you can print out the value ofoutputs[0].dptr_
andlhs.dptr_
to see whether they are equal.
我还没有检查过这个。
最佳答案
Operator 无法控制它将以何种模式执行。问题是,只有图优化器知道使用运算符的上下文,并且可以决定运算符是否需要在 kWriteTo
或 kAddTo
中执行。更准确地说,这发生了 here in the method DetectInplaceAddTo .即使在某些情况下它已在 kAddTo
中执行,但由于优化计算图的逻辑发生变化,此行为将来可能会发生变化。
“Memory planning and inplace operations are automatic. It will be done automatically. Users don’t need to worry about it.”
这意味着运算符无法控制它在哪种模式下执行,但是运算符必须严格遵守已请求的模式(kWriteTo
或kAddTo
)。例如,如果模式是 kWriteTo
并且运算符(operator)试图将差异添加到输出,而不是覆盖其中的内容,这将导致不可预测的结果,因为输出可能填充有垃圾。另一方面,如果模式是 kAddTo
但是运算符不支持它,情况可能会更糟,因为它不会将结果添加到输出中,而是会覆盖输出(通常是这样的情况很难调试)。这有时会导致像 this one 这样的错误。 .
所以,简而言之:
In general, how do I ensure that the fourth line above accumulates into T as opposed to creating a new temporary storage for the result of mx.sym.foo(B) and then performing the T = T + temp calculation?
你不能,这不是运营商决定在哪种模式下执行。即使配置在 MXNet 的 future 版本中使用模式 kAddTo
。同样在未来,可能会创建新的 API 来向图形优化器(或建议)发送提示以使用特定模式。但我不知道有这样的发展。
现在的问题是:“在哪种特定情况下 MXNet 0.10/0.11 将使用 kAddTo
”?
这很棘手,通过查看 following code :
for (uint32_t nid = 0; nid < idx.num_nodes(); ++nid) {
const auto& inode = idx[nid];
if (inode.source->op() != ewise_plus_op) continue; // <= HERE
int sid = storage_id[idx.entry_id(inode.inputs[0])];
看起来 kAddTo
只在 _grad_add
期间使用,这很可悲。这也可能是一个错误,因为也许不是:
static const Op* ewise_plus_op = Op::Get("_grad_add");
实际意图是:
static const Op* ewise_plus_op = Op::Get("elemwise_add");
关于mxnet - 自定义 MXNet 运算符和 kAddTo,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44959694/
Or 运算符 对两个表达式进行逻辑“或”运算。 result = expression1 Or expression2 参数 result 任意数值变量。 expression1 任意
Not 运算符 对表达式执行逻辑非运算。 result = Not expression 参数 result 任意数值变量。 expression 任意表达式。 说明 下表显示如何
Is 运算符 比较两个对象引用变量。 result = object1 Is object2 参数 result 任意数值变量。 object1 任意对象名。 object2 任意
\ 运算符 两个数相除并返回以整数形式表示的结果。 result = number1\number2 参数 result 任意数值变量。 number1 任意数值表达式。 numbe
And 运算符 对两个表达式进行逻辑“与”运算。 result = expression1 And expression2 参数 result 任意数值变量。 expression1
运算符(+) 计算两个数之和。 result = expression1 + expression2 参数 result 任意数值变量。 expression1 任意表达式。 exp
我对此感到困惑snippet : var n1 = 5-"4"; var n2 = 5+"4"; alert(n1); alert(n2); 我知道 n1 是 1。那是因为减号运算符会将字符串“4”转
我想我会得到 12,而不是 7。 w++,那么w就是4,也就是100,而w++, w 将是 8,1000;所以 w++|z++ 将是 100|1000 = 1100 将是 12。 我怎么了? int
Xor 运算符 对两个表达式进行逻辑“异或”运算。 result = expression1 Xor expression2 参数 result 任意数值变量。 expression1
Mod 运算符 两个数值相除并返回其余数。 result = number1 Mod number2 参数 result 任意数值变量。 number1 任意数值表达式。 numbe
Imp 运算符 对两个表达式进行逻辑蕴涵运算。 result = expression1 Imp expression2 参数 result 任意数值变量。 expression1 任
Eqv 运算符 执行两个表达式的逻辑等价运算。 result = expression1 Eqv expression2 参数 result 任意数值变量。 expression1 任
我有一个运算符重载的简单数学 vector 类。我想为我的运算符(operator)获取一些计时结果。我可以通过计时以下代码轻松计时我的 +=、-=、*= 和/=: Vector sum; for(s
我是用户定义比较运算符的新手。我正在读一本书,其中提到了以下示例: struct P { int x, y; bool operator、运算符<等),我们
在 SQL 的维基百科页面上,有一些关于 SQL 中 bool 逻辑的真值表。 [1] 维基百科页面似乎来源于 SQL:2003 标准。 等号运算符 (=) 的真值表与 SQL:2003 草案中的 I
我遇到了一个奇怪的 C++ 运算符。 http://www.terralib.org/html/v410/classoracle_1_1occi_1_1_number.html#a0f2780081f
我正在阅读关于 SO 和 answers 中的一个问题,它被提到为: If no unambiguous matching deallocation function can be found, pr
我偶然发现了这个解决方案,但我无法理解其中到底发生了什么。谁能解释一下! 据我了解,它试图通过计算一半的单元格然后将其加倍来计算 a*b 网格中的单元格数量。但是我无法理解递归调用。 请不要建议其他解
Go的基本类型 布尔类型bool 长度:1字节 取值:布尔类型的取值只能是true或者false,不能用数字来表示 整型 通用整型 int / uint(有符号 / 无符号,下面也类似) 长度:根据运
在本教程中,您将学习JavaScript中可用的不同运算符,以及在示例的帮助下如何使用它们。 什么是运算符? 在JavaScript中,运算符是一种特殊符号,用于对运算数(值和变量)执行操作。例如,
我是一名优秀的程序员,十分优秀!