Пример #1
0
        public void TestRELU()
        {
            var activation = new ActivationReLU();

            Assert.IsTrue(activation.HasDerivative);

            var clone = activation.Clone();

            Assert.IsInstanceOfType(clone, typeof(ActivationReLU));

            double[] input = { -2, -1, 0, 1, 2 };

            activation.ActivationFunction(input, 0, 5);

            CollectionAssert.AreEqual(new double[] { 0, 0, 0, 1, 2 }, input);

            input[2] = activation.DerivativeFunction(0, input[2]);
            Assert.AreEqual(0.0, input[2], EncogFramework.DefaultDoubleEqual);
        }
Пример #2
0
        public void TestRELU()
        {
            var activation = new ActivationReLU();

            Assert.IsTrue(activation.HasDerivative);

            var clone = (ActivationReLU)activation.Clone();

            Assert.IsNotNull(clone);

            double[] input = { 0.0 };

            activation.ActivationFunction(input, 0, 1);

            Assert.AreEqual(0.0, input[0], EncogFramework.DefaultDoubleEqual);

            // test derivative, wiki says this is logistic function (test may be wrong - jeroldhaas)
            input[0] = activation.DerivativeFunction(input[0], input[0]);
            Assert.AreEqual(0.5, input[0], EncogFramework.DefaultDoubleEqual);
        }