bool runTransform(Node* n, Graph& graph, NodeDestroyType& destroy_current) override { ostringstream os; string strBoundingBoxSizeName; Node *node = n->inputs()[0]->node()->inputs()[0]->node(); Node *mul1 = node; Node *pow = node->outputs()[0]->uses()[0].user; Node *mul2 = node->outputs()[0]->uses()[0].user->outputs()[0]->uses()[0].user; Value *tmp = mul1->inputs()[0]->node()->outputs()[0]; ArrayRef<Value *> target_confidence(tmp); Node *newNode = graph.create(Symbol(kBoundingBoxSize), target_confidence); // creat anchor grid Value *anchorGrid; createAnchorGridCoeff(graph, mul1, mul2, &anchorGrid); newNode->addInput(anchorGrid); mNumber++; os << "bounding_box_size_"<<mNumber; strBoundingBoxSizeName = os.str(); newNode->outputs()[0]->setSizes(mul2->outputs()[0]->sizes()); newNode->outputs()[0]->setUniqueName(strBoundingBoxSizeName); newNode->insertBefore(mul1); mul2->replaceAllUsesWith(newNode); pow->replaceAllUsesWith(newNode); pow->destroy(); mul1->replaceAllUsesWith(newNode); mul1->destroy(); destroy_current = NodeDestroyType::DestroyOne; return true; }这段代码什么意思
时间: 2024-04-27 12:19:56 浏览: 78
这段代码是一个函数,函数名为 runTransform。该函数的作用是在给定的Graph中对输入的Node n 进行一些转换操作,并返回一个布尔值。
具体来说,该函数首先获取输入Node n 的第一个输入的第一个输入的Node,将其赋值给node。然后,获取node的输出的第一个使用者,将其赋值给pow。再获取pow的输出的第一个使用者的输出的第一个使用者,将其赋值给mul2。接下来,获取mul1的输入的第一个Node的输出的第一个Value,将其存储在名为target_confidence的ArrayRef中。然后,使用这个Value创建一个新的Node,名为newNode,类型为kBoundingBoxSize。接着,创建一个名为anchorGrid的Value,调用createAnchorGridCoeff函数,将其与newNode连接起来。然后,更新newNode的输出大小和名称,并将其插入mul1之前。最后,将mul2和pow替换为newNode,并将mul1销毁。函数最后返回true。
这段代码的具体作用需要结合整个程序的上下文才能准确理解。
阅读全文