public void DerivativeTest2()
{
double beta = 2;
double constant = 0.5;
LogLogLinkFunction target = new LogLogLinkFunction(beta, constant);
double[] expected =
{
-0.634084, -0.537619, -0.420439, -0.297894, -0.187093, -0.101414,
-0.0459225, -0.0166933, -0.00464008, -0.000929341, -0.000124732
};
for (int i = 0; i < 11; i++)
{
double x = i / 10.0;
double y = target.Inverse(x);
double d1 = target.Derivative(x);
double d2 = target.Derivative2(y);
Assert.AreEqual(expected[i], d1, 1e-5);
Assert.AreEqual(expected[i], d2, 1e-5);
Assert.IsFalse(Double.IsNaN(d1));
Assert.IsFalse(Double.IsNaN(d2));
}
}