本文整理汇总了C++中NeuralNetwork::applyGradient方法的典型用法代码示例。如果您正苦于以下问题:C++ NeuralNetwork::applyGradient方法的具体用法?C++ NeuralNetwork::applyGradient怎么用?C++ NeuralNetwork::applyGradient使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类NeuralNetwork
的用法示例。
在下文中一共展示了NeuralNetwork::applyGradient方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: testConvergence
static void testConvergence(NeuralNetwork &nn, void (NeuralNetwork::*algorithm)(const std::vector<float> &, std::vector<float> &), bool (*sampleGenerator)(int, std::vector<float>&, std::vector<float>&))
{
vector<float> input;
vector<float> expected;
vector<float> gradient;
const float alpha = 0.2f;
float cost = 0.0f;
float prevCost = 0.0f;
input.resize(2);
expected.resize(2);
int sampleId = 0;
for (int i = 0; i < 128; ++i) {
bool lastInBatch = sampleGenerator(sampleId++, input, expected);
nn.setInput(input);
nn.calc();
(nn.*algorithm)(expected, gradient);
ASSERT_EQ(nn.getWeights().size(), gradient.size());
cost += nn.calcCost(expected);
if (lastInBatch) {
nn.applyGradient(gradient, alpha);
for (int w = 0; w < gradient.size(); ++w)
gradient[w] = 0.0f;
if (prevCost != 0.0f)
ASSERT_LT(cost - prevCost, 0.0f);
prevCost = cost;
cost = 0.0f;
}
}
}