public void ConstructorTest2()
{
double a = 0, b = 0;
var f = new QuadraticObjectiveFunction(() => a + b);
Assert.AreEqual(2, f.NumberOfVariables);
Assert.AreEqual(0, f.Variables["a"]);
Assert.AreEqual(1, f.Variables["b"]);
Assert.AreEqual(1, f.LinearTerms[0]);
Assert.AreEqual(1, f.LinearTerms[1]);
var constraints1 = new[]
{
new LinearConstraint(f, () => 0.0732 * a + 0.0799 * b == 0.098),
new LinearConstraint(f, () => a + b == 1),
new LinearConstraint(f, () => a >= 0),
new LinearConstraint(f, () => b >= 0),
new LinearConstraint(f, () => a >= 0.5),
new LinearConstraint(f, () => 1 + a >= -5),
new LinearConstraint(f, () => -1 + a <= -5)
};
var constraints2 = new[]
{
new LinearConstraint(f, () => 0.0732 * a + 0.0799 * b - 0.098 == 0),
new LinearConstraint(f, () => a + b -2 == -1),
new LinearConstraint(f, () => -a + 1 <= +1),
new LinearConstraint(f, () => -b <= 0),
new LinearConstraint(f, () => -a + 0.5 <= 0),
new LinearConstraint(f, () => a + 1 >= -5),
new LinearConstraint(f, () => a - 1 <= -5)
};
Assert.AreEqual(0.098, constraints1[0].Value);
Assert.AreEqual(0.098, constraints2[0].Value);
Assert.AreEqual(0, constraints1[2].Value);
Assert.AreEqual(0, constraints2[2].Value);
Assert.AreEqual(1, constraints1[1].Value);
Assert.AreEqual(1, constraints2[1].Value);
for (int i = 0; i < constraints1.Length; i++)
{
var c1 = constraints1[i];
var c2 = constraints2[i];
for (a = -10; a < 10; a += 0.1)
{
for (b = -10; b < 10; b += 0.1)
{
double[] x = { a, b };
double actual = c1.GetViolation(x);
double expected = c2.GetViolation(x);
Assert.AreEqual(expected, actual);
}
}
}
}