cavis/libnd4j/include/graph/execution/impl/LogicNextIteration.cpp

52 lines
1.8 KiB
C++
Raw Normal View History

2021-02-01 13:31:45 +01:00
/* ******************************************************************************
*
2019-06-06 14:21:15 +02:00
*
* This program and the accompanying materials are made available under the
* terms of the Apache License, Version 2.0 which is available at
* https://www.apache.org/licenses/LICENSE-2.0.
*
2021-02-01 13:31:45 +01:00
* See the NOTICE file distributed with this work for additional
* information regarding copyright ownership.
2019-06-06 14:21:15 +02:00
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
*
* SPDX-License-Identifier: Apache-2.0
******************************************************************************/
//
// @author raver119@gmail.com
//
#include <graph/execution/LogicNextIteration.h>
namespace sd {
2019-06-06 14:21:15 +02:00
namespace graph {
Nd4jStatus LogicNextIeration::processNode(Graph *graph, Node *node) {
auto __variableSpace = graph->getVariableSpace();
auto __flowPath = __variableSpace->flowPath();
auto inputAddr = node->input()->at(0);
auto var = __variableSpace->getVariable(inputAddr);
Variable *lvar = nullptr;
if (__variableSpace->hasVariable(node->id(), 0))
lvar = __variableSpace->getVariable(node->id(), 0);
else
lvar = new Variable(nullptr, node->getName()->c_str(), node->id(), 0);
// if (lvar->hasNDArray())
// delete lvar->getNDArray();
auto array = var->getNDArray();
lvar->setNDArray(array);
lvar->markReadOnly(true);
return ND4J_STATUS_OK;
}
}
}